UNPKG

5.02 MBSource Map (JSON)View Raw
1{"version":3,"sources":["webpack://G6/webpack/universalModuleDefinition","webpack://G6/webpack/bootstrap","webpack://G6/./node_modules/_tslib@2.3.1@tslib/tslib.es6.js","webpack://G6/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/mat3.js","webpack://G6/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/mat4.js","webpack://G6/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/vec4.js","webpack://G6/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/quat.js","webpack://G6/../src/index.ts","webpack://G6/../src/is-array-like.ts","webpack://G6/../src/contains.ts","webpack://G6/../src/filter.ts","webpack://G6/../src/difference.ts","webpack://G6/../src/is-type.ts","webpack://G6/../src/is-function.ts","webpack://G6/../src/is-nil.ts","webpack://G6/../src/is-array.ts","webpack://G6/../src/is-object.ts","webpack://G6/../src/each.ts","webpack://G6/../src/keys.ts","webpack://G6/../src/is-match.ts","webpack://G6/../src/is-object-like.ts","webpack://G6/../src/is-plain-object.ts","webpack://G6/../src/find.ts","webpack://G6/../src/find-index.ts","webpack://G6/../src/first-value.ts","webpack://G6/../src/flatten.ts","webpack://G6/../src/flatten-deep.ts","webpack://G6/../src/max.ts","webpack://G6/../src/min.ts","webpack://G6/../src/get-range.ts","webpack://G6/../src/pull.ts","webpack://G6/../src/pull-at.ts","webpack://G6/../src/reduce.ts","webpack://G6/../src/remove.ts","webpack://G6/../src/is-string.ts","webpack://G6/../src/sort-by.ts","webpack://G6/../src/uniq.ts","webpack://G6/../src/union.ts","webpack://G6/../src/values-of-key.ts","webpack://G6/../src/head.ts","webpack://G6/../src/last.ts","webpack://G6/../src/starts-with.ts","webpack://G6/../src/ends-with.ts","webpack://G6/../src/every.ts","webpack://G6/../src/some.ts","webpack://G6/../src/group-by.ts","webpack://G6/../src/group-to-map.ts","webpack://G6/../src/group.ts","webpack://G6/../src/get-wrap-behavior.ts","webpack://G6/../src/wrap-behavior.ts","webpack://G6/../src/number2color.ts","webpack://G6/../src/parse-radius.ts","webpack://G6/../src/clamp.ts","webpack://G6/../src/fixed-base.ts","webpack://G6/../src/is-number.ts","webpack://G6/../src/is-decimal.ts","webpack://G6/../src/is-even.ts","webpack://G6/../src/is-integer.ts","webpack://G6/../src/is-negative.ts","webpack://G6/../src/is-number-equal.ts","webpack://G6/../src/is-odd.ts","webpack://G6/../src/is-positive.ts","webpack://G6/../src/max-by.ts","webpack://G6/../src/min-by.ts","webpack://G6/../src/mod.ts","webpack://G6/../src/to-degree.ts","webpack://G6/../src/to-integer.ts","webpack://G6/../src/to-radian.ts","webpack://G6/../src/for-in.ts","webpack://G6/../src/has.ts","webpack://G6/../src/has-key.ts","webpack://G6/../src/values.ts","webpack://G6/../src/has-value.ts","webpack://G6/../src/to-string.ts","webpack://G6/../src/lower-case.ts","webpack://G6/../src/lower-first.ts","webpack://G6/../src/substitute.ts","webpack://G6/../src/upper-case.ts","webpack://G6/../src/upper-first.ts","webpack://G6/../src/get-type.ts","webpack://G6/../src/is-arguments.ts","webpack://G6/../src/is-boolean.ts","webpack://G6/../src/is-date.ts","webpack://G6/../src/is-error.ts","webpack://G6/../src/is-finite.ts","webpack://G6/../src/is-null.ts","webpack://G6/../src/is-prototype.ts","webpack://G6/../src/is-reg-exp.ts","webpack://G6/../src/is-undefined.ts","webpack://G6/../src/is-element.ts","webpack://G6/../src/request-animation-frame.ts","webpack://G6/../src/clear-animation-frame.ts","webpack://G6/../src/mix.ts","webpack://G6/../src/augment.ts","webpack://G6/../src/clone.ts","webpack://G6/../src/debounce.ts","webpack://G6/../src/memoize.ts","webpack://G6/../src/deep-mix.ts","webpack://G6/../src/extend.ts","webpack://G6/../src/index-of.ts","webpack://G6/../src/is-empty.ts","webpack://G6/../src/is-equal.ts","webpack://G6/../src/is-equal-with.ts","webpack://G6/../src/map.ts","webpack://G6/../src/map-values.ts","webpack://G6/../src/get.ts","webpack://G6/../src/set.ts","webpack://G6/../src/pick.ts","webpack://G6/../src/omit.ts","webpack://G6/../src/throttle.ts","webpack://G6/../src/to-array.ts","webpack://G6/../src/unique-id.ts","webpack://G6/../src/noop.ts","webpack://G6/../src/identity.ts","webpack://G6/../src/size.ts","webpack://G6/../src/cache.ts","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/defineProperty.js","webpack://G6/../src/inversify.ts","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/classCallCheck.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/createClass.js","webpack://G6/./node_modules/_@webgpu_types@0.0.31@@webgpu/types/dist/constants.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/regenerator/index.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/initializerDefineProperty.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/applyDecoratedDescriptor.js","webpack://G6/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/common.js","webpack://G6/../src/identifier.ts","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/asyncToGenerator.js","webpack://G6/../../src/util/util.ts","webpack://G6/../src/constant.ts","webpack://G6/../src/ext.ts","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/getPrototypeOf.js","webpack://G6/../src/util.ts","webpack://G6/../src/line.ts","webpack://G6/../src/bezier.ts","webpack://G6/../src/quadratic.ts","webpack://G6/../src/cubic.ts","webpack://G6/../src/ellipse.ts","webpack://G6/../src/arc.ts","webpack://G6/../src/segments.ts","webpack://G6/../src/polyline.ts","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/assertThisInitialized.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/inherits.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/possibleConstructorReturn.js","webpack://G6/../src/ComponentManager.ts","webpack://G6/../../src/util/dom.ts","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/toConsumableArray.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/lodash.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/initializerWarningHelper.js","webpack://G6/../../src/util/draw.ts","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isArray.js","webpack://G6/../../src/constants/metadata_keys.ts","webpack://G6/../../src/util/arrow.ts","webpack://G6/../../src/util/svg.ts","webpack://G6/../../../src/components/renderer/gl.ts","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/util.js","webpack://G6/../../src/util/matrix.ts","webpack://G6/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/vec3.js","webpack://G6/../../src/constants/error_msgs.ts","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/typeof.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/lodash.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isObject.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/util.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/graphlib.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_root.js","webpack://G6/../../src/planning/metadata.ts","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isObjectLike.js","webpack://G6/../../../../src/components/renderer/passes/RenderPass.ts","webpack://G6/../../src/util/path.ts","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isArrayLike.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIteratee.js","webpack://G6/../../src/constants/literal_types.ts","webpack://G6/../../src/shape/base.ts","webpack://G6/../../src/shape/circle.ts","webpack://G6/../../src/shape/ellipse.ts","webpack://G6/../../src/shape/image.ts","webpack://G6/../../../src/util/in-stroke/line.ts","webpack://G6/../../src/shape/line.ts","webpack://G6/../../src/shape/marker.ts","webpack://G6/../../../src/util/in-path/point-in-path.ts","webpack://G6/../../../src/util/in-path/polygon.ts","webpack://G6/../../../src/util/in-stroke/arc.ts","webpack://G6/../../src/shape/path.ts","webpack://G6/../../../src/util/in-stroke/polyline.ts","webpack://G6/../../src/shape/polygon.ts","webpack://G6/../../src/shape/polyline.ts","webpack://G6/../../src/shape/rect.ts","webpack://G6/../../../src/util/in-stroke/rect-radius.ts","webpack://G6/../../../src/util/in-stroke/rect.ts","webpack://G6/../../src/shape/text.ts","webpack://G6/../src/parse-path.ts","webpack://G6/../src/catmull-rom-2-bezier.ts","webpack://G6/../src/parse-path-string.ts","webpack://G6/../src/path-2-absolute.ts","webpack://G6/../src/get-arc-params.ts","webpack://G6/../src/path-2-segments.ts","webpack://G6/../../src/shape/Frustum.ts","webpack://G6/./node_modules/_lodash@4.17.21@lodash/keys.js","webpack://G6/../../src/annotation/decorator_utils.ts","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/slicedToArray.js","webpack://G6/./node_modules/_polyline-miter-util@1.0.1@polyline-miter-util/index.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getNative.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseGetTag.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/keysIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/identity.js","webpack://G6/../../src/utils/id.ts","webpack://G6/../../src/util/text.ts","webpack://G6/../../../../src/components/renderer/passes/PixelPickingPass.ts","webpack://G6/./node_modules/_lodash@4.17.21@lodash/eq.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_Symbol.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isBuffer.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getTag.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isSymbol.js","webpack://G6/../../src/shape/AABB.ts","webpack://G6/../../src/shape/dom.ts","webpack://G6/../../../src/shape/marker/symbols.ts","webpack://G6/../../../src/shape/marker/index.ts","webpack://G6/../../src/util/format.ts","webpack://G6/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/vec2.js","webpack://G6/./node_modules/_insert-css@2.0.0@insert-css/index.js","webpack://G6/../../../../src/components/renderer/passes/CopyPass.ts","webpack://G6//webpack/universalModuleDefinition","webpack://G6/webpack:/webpack/bootstrap 4fd512329b599d5b36c3","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-array.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-array-like.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/each.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-function.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-type.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-number.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-nil.js","webpack://G6//src/util.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-string.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-plain-object.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/to-string.js","webpack://G6//src/layout/base.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/contains.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-object.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/filter.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-object-like.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/mix.js","webpack://G6//src/layout/do-layout.js","webpack://G6//src/layout/hierarchy.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-match.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/keys.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/pull-at.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/uniq.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/group-to-map.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/group-by.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/has.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/values.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/get-type.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-prototype.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-equal.js","webpack://G6//src/layout/separate-root.js","webpack://G6//src/index.js","webpack://G6//src/compact-box.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/index.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/difference.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/find.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/find-index.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/first-value.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/flatten.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/flatten-deep.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/get-range.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/pull.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/reduce.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/remove.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/sort-by.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/union.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/values-of-key.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/head.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/last.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/starts-with.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/ends-with.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/every.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/some.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/group.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/get-wrap-behavior.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/wrap-behavior.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/number2color.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/parse-radius.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/clamp.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/fixed-base.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-decimal.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-even.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-integer.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-negative.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-number-equal.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-odd.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-positive.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/max-by.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/min-by.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/mod.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/to-degree.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/to-integer.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/to-radian.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/for-in.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/has-key.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/has-value.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/lower-case.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/lower-first.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/substitute.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/upper-case.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/upper-first.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-arguments.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-boolean.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-date.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-error.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-finite.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-null.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-reg-exp.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-undefined.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-element.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/request-animation-frame.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/clear-animation-frame.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/augment.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/clone.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/debounce.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/memoize.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/deep-mix.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/extend.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/index-of.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-empty.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/is-equal-with.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/map.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/map-values.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/get.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/set.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/pick.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/throttle.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/to-array.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/unique-id.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/noop.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/identity.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/size.js","webpack://G6//node_modules/_@antv_util@2.0.7@@antv/util/esm/cache.js","webpack://G6//src/layout/non-layered-tidy.js","webpack://G6//src/dendrogram.js","webpack://G6//src/layout/dendrogram.js","webpack://G6//src/indented.js","webpack://G6//src/layout/indented.js","webpack://G6//src/mindmap.js","webpack://G6//src/layout/mindmap.js","webpack://G6/./node_modules/_color@3.2.1@color/index.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isFunction.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_copyObject.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isArguments.js","webpack://G6/(webpack)/buildin/module.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isTypedArray.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_toKey.js","webpack://G6/../../src/utils/serialization.ts","webpack://G6/../../../src/components/framegraph/ResourcePool.ts","webpack://G6/../../../src/components/scenegraph/NameComponent.ts","webpack://G6/../src/inversify.config.ts","webpack://G6/../../src/util/arc-params.ts","webpack://G6/./node_modules/_tinycolor2@1.4.2@tinycolor2/tinycolor.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/index.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/adjacent-matrix.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_Stack.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_ListCache.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_assocIndexOf.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_nativeCreate.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getMapData.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_assignValue.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseAssignValue.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_isIndex.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseUnary.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_isPrototype.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getPrototype.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseEach.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseGet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_castPath.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_arrayMap.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseRest.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_isIterateeCall.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/rank/util.js","webpack://G6/../../../src/components/renderer/index.ts","webpack://G6/../../src/event/graph-event.ts","webpack://G6/../../src/abstract/base.ts","webpack://G6/../../src/util/offscreen.ts","webpack://G6/../src/Entity.ts","webpack://G6/../../../src/components/geometry/System.ts","webpack://G6/../../../src/components/material/MaterialComponent.ts","webpack://G6/../../../src/components/material/System.ts","webpack://G6/../../../src/components/mesh/CullableComponent.ts","webpack://G6/../../../src/components/mesh/MeshComponent.ts","webpack://G6/../../../src/components/mesh/System.ts","webpack://G6/../../src/shape/Plane.ts","webpack://G6/../../../src/components/renderer/System.ts","webpack://G6/../../../src/components/scenegraph/HierarchyComponent.ts","webpack://G6/../../../src/components/scenegraph/System.ts","webpack://G6/../../../src/components/scenegraph/TransformComponent.ts","webpack://G6/../../../src/services/config/ConfigService.ts","webpack://G6/../../../src/services/interactor/IteractorService.ts","webpack://G6/../../../src/components/framegraph/FrameGraphHandle.ts","webpack://G6/../../../src/components/framegraph/FrameGraphPass.ts","webpack://G6/../../../src/components/framegraph/PassNode.ts","webpack://G6/../../../src/components/framegraph/ResourceEntry.ts","webpack://G6/../../../src/components/framegraph/VirtualResource.ts","webpack://G6/../../../src/components/framegraph/ResourceNode.ts","webpack://G6/../../../src/components/framegraph/System.ts","webpack://G6/../../src/utils/shader-module.ts","webpack://G6/../../../src/services/shader-module/ShaderModuleService.ts","webpack://G6/../../src/utils/uniq.ts","webpack://G6/../../src/utils/is-typedarray.ts","webpack://G6/../../../src/components/geometry/GeometryComponent.ts","webpack://G6/../../src/abstract/container.ts","webpack://G6/../../src/abstract/element.ts","webpack://G6/./node_modules/_detect-browser@5.2.0@detect-browser/es/index.js","webpack://G6/../../src/util/parse.ts","webpack://G6/../../src/utils/math.ts","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/workers/constant.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/dijkstra.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/graph.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_Map.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_MapCache.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_arrayEach.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isLength.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_nodeUtil.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseKeys.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getSymbols.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_arrayPush.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_cloneArrayBuffer.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/constant.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseForOwn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseFor.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_setToArray.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_isKey.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseFlatten.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseExtremum.js","webpack://G6/../../src/syntax/binding_on_syntax.ts","webpack://G6/../../src/syntax/binding_when_syntax.ts","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/subtract.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/index.js","webpack://G6/./node_modules/_process@0.11.10@process/browser.js","webpack://G6/../../src/abstract/group.ts","webpack://G6/../../src/abstract/shape.ts","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/connected-component.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/degree.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/dfs.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/floydWarshall.js","webpack://G6/./node_modules/_color-convert@1.9.3@color-convert/conversions.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseClone.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_freeGlobal.js","webpack://G6/(webpack)/buildin/global.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_toSource.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_defineProperty.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_arrayLikeKeys.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_overArg.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_cloneBuffer.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_copyArray.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_arrayFilter.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/stubArray.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getSymbolsIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getAllKeys.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseGetAllKeys.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_Set.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_Uint8Array.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_cloneTypedArray.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_initCloneObject.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseCreate.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/each.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/forEach.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_castFunction.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/filter.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIsEqual.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_equalArrays.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_SetCache.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_cacheHas.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_isStrictComparable.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_matchesStrictComparable.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/toString.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/hasIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_hasPath.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseProperty.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/has.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isUndefined.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/map.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseMap.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/reduce.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_overRest.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_setToString.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseFindIndex.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isArrayLikeObject.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/values.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/dijkstra.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/data/priority-queue.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/tarjan.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/topsort.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/dfs.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/toFinite.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/flatten.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_assignMergeValue.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_safeGet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseLt.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/rank/feasible-tree.js","webpack://G6/./node_modules/_reflect-metadata@0.1.13@reflect-metadata/Reflect.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/unsupportedIterableToArray.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/arrayLikeToArray.js","webpack://G6/../../src/planning/metadata_reader.ts","webpack://G6/../../src/utils/exceptions.ts","webpack://G6/../../src/annotation/inject.ts","webpack://G6/../../src/planning/target.ts","webpack://G6/../../src/syntax/binding_when_on_syntax.ts","webpack://G6/../../src/syntax/constraint_helpers.ts","webpack://G6/../../src/utils/aabb.ts","webpack://G6/../../src/utils/isSafari.ts","webpack://G6/../../../src/components/renderer/IMultiPassRenderer.ts","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/epsilon.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/create.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/set.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/add.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/multiply.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/divide.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/distance.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/squaredDistance.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/length.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/squaredLength.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/normalize.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/dot.js","webpack://G6/./node_modules/_d3-timer@1.0.10@d3-timer/src/timer.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/linear.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/quad.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/cubic.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/poly.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/sin.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/math.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/exp.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/circle.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/bounce.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/back.js","webpack://G6/./node_modules/_d3-ease@1.0.7@d3-ease/src/elastic.js","webpack://G6/./node_modules/_d3-color@1.4.1@d3-color/src/define.js","webpack://G6/./node_modules/_d3-color@1.4.1@d3-color/src/color.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/basis.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/constant.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/color.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/rgb.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/basisClosed.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/numberArray.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/array.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/date.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/number.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/object.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/string.js","webpack://G6/./node_modules/_d3-interpolate@1.4.0@d3-interpolate/src/value.js","webpack://G6/../../src/animate/timeline.ts","webpack://G6/../../src/util/color.ts","webpack://G6/../../src/event/event-contoller.ts","webpack://G6/../../src/abstract/canvas.ts","webpack://G6/../../src/bbox/register.ts","webpack://G6/../../src/bbox/rect.ts","webpack://G6/../../src/bbox/circle.ts","webpack://G6/../../src/bbox/util.ts","webpack://G6/../../src/bbox/polyline.ts","webpack://G6/../../src/bbox/path.ts","webpack://G6/../../src/bbox/index.ts","webpack://G6/../../src/bbox/polygon.ts","webpack://G6/../../src/bbox/text.ts","webpack://G6/../../src/bbox/line.ts","webpack://G6/../../src/bbox/ellipse.ts","webpack://G6/../../src/defs/gradient.ts","webpack://G6/../../src/defs/shadow.ts","webpack://G6/../../src/defs/arrow.ts","webpack://G6/../../src/defs/clip.ts","webpack://G6/../../src/defs/pattern.ts","webpack://G6/../../src/defs/index.ts","webpack://G6/../src/canvas.ts","webpack://G6/../../src/shape/BoundingSphere.ts","webpack://G6/../../src/shape/Ray.ts","webpack://G6/../../src/util/hit.ts","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/asyncIndex.js","webpack://G6/./node_modules/_inversify-inject-decorators@3.1.0@inversify-inject-decorators/lib/index.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/workers/index.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/workers/createWorker.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/workers/index.worker.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/workers/algorithm.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/bfs.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/structs/queue.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/structs/linked-list.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/detect-cycle.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/find-path.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/label-propagation.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/louvain.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/mts.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/structs/union-find.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/structs/binary-heap.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/pageRank.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/gaddi.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/gSpan/gSpan.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/lib/gSpan/struct.js","webpack://G6/./node_modules/_color-string@1.6.0@color-string/index.js","webpack://G6/./node_modules/_color-name@1.1.4@color-name/index.js","webpack://G6/./node_modules/_simple-swizzle@0.2.2@simple-swizzle/index.js","webpack://G6/./node_modules/_is-arrayish@0.3.2@is-arrayish/index.js","webpack://G6/./node_modules/_color-convert@1.9.3@color-convert/index.js","webpack://G6/./node_modules/_color-name@1.1.3@color-name/index.js","webpack://G6/./node_modules/_color-convert@1.9.3@color-convert/route.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/index.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/index.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/clone.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_listCacheClear.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_listCacheDelete.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_listCacheGet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_listCacheHas.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_listCacheSet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_stackClear.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_stackDelete.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_stackGet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_stackHas.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_stackSet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIsNative.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getRawTag.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_objectToString.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_isMasked.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_coreJsData.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getValue.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_mapCacheClear.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_Hash.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_hashClear.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_hashDelete.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_hashGet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_hashHas.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_hashSet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_mapCacheDelete.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_isKeyable.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_mapCacheGet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_mapCacheHas.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_mapCacheSet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseAssign.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseTimes.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIsArguments.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/stubFalse.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIsTypedArray.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_nativeKeys.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseAssignIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseKeysIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_nativeKeysIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_copySymbols.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_copySymbolsIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getAllKeysIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_DataView.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_Promise.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_WeakMap.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_initCloneArray.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_initCloneByTag.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_cloneDataView.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_cloneRegExp.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_cloneSymbol.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isMap.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIsMap.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isSet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIsSet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_createBaseFor.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_createBaseEach.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseFilter.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseMatches.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIsMatch.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIsEqualDeep.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_setCacheAdd.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_setCacheHas.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_arraySome.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_equalByTag.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_mapToArray.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_equalObjects.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_getMatchData.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseMatchesProperty.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/get.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_stringToPath.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_memoizeCapped.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/memoize.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseToString.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseHasIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/property.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_basePropertyDeep.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseHas.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isEmpty.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_arrayReduce.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseReduce.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/size.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isString.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_stringSize.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_asciiSize.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_hasUnicode.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_unicodeSize.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/transform.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/union.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_isFlattenable.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_apply.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseSetToString.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_shortOut.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseUniq.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_arrayIncludes.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIndexOf.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseIsNaN.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_strictIndexOf.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_arrayIncludesWith.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_createSet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/noop.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseValues.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/version.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/json.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/index.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/components.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/dijkstra-all.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/find-cycles.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/floyd-warshall.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/is-acyclic.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/postorder.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/preorder.js","webpack://G6/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/prim.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/layout.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/cloneDeep.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/defaults.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/find.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_createFind.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/findIndex.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/toInteger.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/toNumber.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseTrim.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_trimmedEndIndex.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/forIn.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/last.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/mapValues.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/max.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseGt.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/merge.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseMerge.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseMergeDeep.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/isPlainObject.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/toPlainObject.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_createAssigner.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/min.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/minBy.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/now.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/pick.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_basePick.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_basePickBy.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseSet.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_flatRest.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/range.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_createRange.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseRange.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/sortBy.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseOrderBy.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseSortBy.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_compareMultiple.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_compareAscending.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/uniqueId.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/zipObject.js","webpack://G6/./node_modules/_lodash@4.17.21@lodash/_baseZipObject.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/acyclic.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/greedy-fas.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/data/list.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/normalize.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/rank/index.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/rank/network-simplex.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/parent-dummy-chains.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/nesting-graph.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/add-border-segments.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/coordinate-system.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/order/index.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/order/init-order.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/order/cross-count.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/order/sort-subgraph.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/order/barycenter.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/order/resolve-conflicts.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/order/sort.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/order/build-layer-graph.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/order/add-subgraph-constraints.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/position/index.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/position/bk.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/debug.js","webpack://G6/./node_modules/_dagre@0.8.5@dagre/lib/version.js","webpack://G6/./node_modules/_regenerator-runtime@0.13.9@regenerator-runtime/runtime.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/arrayWithHoles.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/iterableToArrayLimit.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/nonIterableRest.js","webpack://G6/../../src/container/container.ts","webpack://G6/../../src/bindings/binding.ts","webpack://G6/../../src/planning/planner.ts","webpack://G6/../../src/bindings/binding_count.ts","webpack://G6/../../src/planning/context.ts","webpack://G6/../../src/planning/plan.ts","webpack://G6/../../src/planning/reflection_utils.ts","webpack://G6/../../src/planning/queryable_string.ts","webpack://G6/../../src/planning/request.ts","webpack://G6/../../src/resolution/resolver.ts","webpack://G6/../../src/resolution/instantiation.ts","webpack://G6/../../src/syntax/binding_to_syntax.ts","webpack://G6/../../src/syntax/binding_in_when_on_syntax.ts","webpack://G6/../../src/syntax/binding_in_syntax.ts","webpack://G6/../../src/container/container_snapshot.ts","webpack://G6/../../src/container/lookup.ts","webpack://G6/../../src/container/container_module.ts","webpack://G6/../../src/annotation/injectable.ts","webpack://G6/../../src/annotation/tagged.ts","webpack://G6/../../src/annotation/named.ts","webpack://G6/../../src/annotation/optional.ts","webpack://G6/../../src/annotation/unmanaged.ts","webpack://G6/../../src/annotation/multi_inject.ts","webpack://G6/../../src/annotation/target_name.ts","webpack://G6/../../src/annotation/post_construct.ts","webpack://G6/../../src/utils/binding_utils.ts","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/setPrototypeOf.js","webpack://G6/./node_modules/_inversify-inject-decorators@3.1.0@inversify-inject-decorators/lib/decorators.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/arrayWithoutHoles.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/iterableToArray.js","webpack://G6/./node_modules/_@babel_runtime@7.15.3@@babel/runtime/helpers/nonIterableSpread.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/clone.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/fromValues.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/copy.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/equals.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/exactEquals.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/sub.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/mul.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/div.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/inverse.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/min.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/max.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/rotate.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/floor.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/ceil.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/round.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/scale.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/scaleAndAdd.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/dist.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/sqrDist.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/len.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/sqrLen.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/negate.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/cross.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/lerp.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/random.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/transformMat2.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/transformMat2d.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/transformMat3.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/transformMat4.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/forEach.js","webpack://G6/./node_modules/_gl-vec2@1.3.0@gl-vec2/limit.js","webpack://G6/../src/measure-text-width.ts","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/behavior/behaviorOption.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/behavior/behavior.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/behavior/index.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/adjacent-matrix.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/structs/linked-list.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/structs/queue.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/util.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/bfs.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/connected-component.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/degree.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/dfs.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/detect-cycle.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/dijkstra.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/find-path.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/floydWarshall.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/label-propagation.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/louvain.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/structs/union-find.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/structs/binary-heap.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/mts.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/pageRank.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/gSpan/struct.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/gSpan/gSpan.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/gaddi.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/structs/stack.js","webpack://G6/./node_modules/_@antv_algorithm@0.1.10@@antv/algorithm/es/index.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/util/math.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/global.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/util/letterAspectRatio.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/util/graphic.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/util/validation.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/graph/controller/mode.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/interface/behavior.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/util/base.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/graph/controller/view.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/xml.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/shape.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/item/item.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/item/edge.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/item/node.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/item/combo.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/graph/controller/item.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/graph/controller/state.js","webpack://G6/../../src/process/arc-2-cubic.ts","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/util/path.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/hull/convexHull.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/hull/bubbleset.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/item/hull.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/graph/graph.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/shapeBase.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/node.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/edge.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/combo.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/combos/circle.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/combos/rect.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/nodes/simple-circle.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/nodes/simple-rect.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/nodes/image.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/arrow.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/types/index.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/marker.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/element/index.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/util/color.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/util/index.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/graph/controller/layout.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/graph/controller/event.js","webpack://G6/./node_modules/_@antv_g6-core@0.3.11@@antv/g6-core/es/index.js","webpack://G6/./node_modules/_@ant-design_colors@4.0.5@@ant-design/colors/dist/index.esm.js","webpack://G6/../src/create-dom.ts","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/util/color.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/global.js","webpack://G6/../src/add-event-listener.ts","webpack://G6/../src/modify-css.ts","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/graph/controller/event.js","webpack://G6/../../src/layout/base.ts","webpack://G6/../../src/util/string.ts","webpack://G6/../../src/util/array.ts","webpack://G6/../../src/util/number.ts","webpack://G6/../../src/util/object.ts","webpack://G6/../../src/util/math.ts","webpack://G6/../../src/util/function.ts","webpack://G6/../../src/registy/index.ts","webpack://G6/../../src/layout/grid.ts","webpack://G6/../../src/layout/random.ts","webpack://G6/../../src/layout/gForce.ts","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/add.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/cover.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/quad.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/x.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/y.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/quadtree.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/data.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/extent.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/find.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/remove.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/root.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/size.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/visit.js","webpack://G6/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/visitAfter.js","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/constant.js","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/jiggle.js","webpack://G6/./node_modules/_d3-dispatch@2.0.0@d3-dispatch/src/dispatch.js","webpack://G6/./node_modules/_d3-timer@2.0.0@d3-timer/src/timer.js","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/simulation.js","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/lcg.js","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/manyBody.js","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/link.js","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/collide.js","webpack://G6/../../../src/layout/force/force-in-a-box.ts","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/x.js","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/y.js","webpack://G6/../../src/layout/constants.ts","webpack://G6/../../../src/layout/force/force.ts","webpack://G6/./node_modules/_d3-force@2.1.1@d3-force/src/center.js","webpack://G6/../../src/layout/circular.ts","webpack://G6/../../src/layout/dagre.ts","webpack://G6/./node_modules/_is-any-array@1.0.0@is-any-array/src/index.js","webpack://G6/./node_modules/_ml-array-max@1.2.3@ml-array-max/lib-es6/index.js","webpack://G6/./node_modules/_ml-array-min@1.2.2@ml-array-min/lib-es6/index.js","webpack://G6/./node_modules/_ml-array-rescale@1.3.5@ml-array-rescale/lib-es6/index.js","webpack://G6/./node_modules/_ml-matrix@6.8.0@ml-matrix/src/inspect.js","webpack://G6/./node_modules/_ml-matrix@6.8.0@ml-matrix/src/util.js","webpack://G6/./node_modules/_ml-matrix@6.8.0@ml-matrix/src/stat.js","webpack://G6/./node_modules/_ml-matrix@6.8.0@ml-matrix/src/matrix.js","webpack://G6/./node_modules/_ml-matrix@6.8.0@ml-matrix/src/mathOperations.js","webpack://G6/./node_modules/_ml-matrix@6.8.0@ml-matrix/src/wrap/WrapperMatrix2D.js","webpack://G6/./node_modules/_ml-matrix@6.8.0@ml-matrix/src/dc/util.js","webpack://G6/./node_modules/_ml-matrix@6.8.0@ml-matrix/src/dc/svd.js","webpack://G6/../../../src/layout/radial/mds.ts","webpack://G6/../../../src/layout/radial/radialNonoverlapForce.ts","webpack://G6/../../../src/layout/radial/radial.ts","webpack://G6/../../src/layout/concentric.ts","webpack://G6/../../src/layout/mds.ts","webpack://G6/../../src/layout/fruchterman.ts","webpack://G6/../../src/utils/is-number.ts","webpack://G6/../../src/camera/Camera.ts","webpack://G6/../../src/camera/Landmark.ts","webpack://G6/../../src/geometry/index.ts","webpack://G6/../../src/utils/canvas.ts","webpack://G6/../../src/utils/is-type.ts","webpack://G6/../src/Kernel.ts","webpack://G6/../../src/utils/is-array.ts","webpack://G6/../../src/material/index.ts","webpack://G6/../../src/renderable/Renderable.ts","webpack://G6/../../src/webgl/ReglAttribute.ts","webpack://G6/../../src/webgl/constants.ts","webpack://G6/../../src/webgl/ReglBuffer.ts","webpack://G6/../../src/webgl/ReglComputeModel.ts","webpack://G6/../../src/webgl/ReglElements.ts","webpack://G6/../../src/webgl/ReglFramebuffer.ts","webpack://G6/../../src/utils/uniform.ts","webpack://G6/../../src/utils/is-object.ts","webpack://G6/../../src/webgpu/glslang.ts","webpack://G6/../../src/webgl/ReglModel.ts","webpack://G6/../../src/webgl/ReglTexture2D.ts","webpack://G6/../../src/webgl/index.ts","webpack://G6/../../src/utils/dom.ts","webpack://G6/../../src/webgpu/WebGPUAttribute.ts","webpack://G6/../../src/webgpu/WebGPUBuffer.ts","webpack://G6/../../src/webgpu/WebGPUComputeModel.ts","webpack://G6/../../src/webgpu/WebGPUElements.ts","webpack://G6/../../src/webgpu/WebGPUFramebuffer.ts","webpack://G6/../../src/webgpu/constants.ts","webpack://G6/../../src/webgpu/WebGPUModel.ts","webpack://G6/../../src/webgpu/WebGPUTexture2D.ts","webpack://G6/../../src/webgpu/index.ts","webpack://G6/../../src/geometry/Box.ts","webpack://G6/../../src/geometry/Merged.ts","webpack://G6/../../src/utils/typedarray.ts","webpack://G6/../../src/geometry/Plane.ts","webpack://G6/../../src/geometry/Sphere.ts","webpack://G6/../../../src/material/basic/index.ts","webpack://G6/../../../src/renderable/grid/index.ts","webpack://G6/../../src/utils/polyline-normals.ts","webpack://G6/../../../src/renderable/line/index.ts","webpack://G6/../../../src/renderable/point/index.ts","webpack://G6/../../src/utils/picking.ts","webpack://G6/../src/Renderer.ts","webpack://G6/../src/Scene.ts","webpack://G6/../../src/texture/Cache.ts","webpack://G6/../../src/texture/Texture2D.ts","webpack://G6/../src/View.ts","webpack://G6/../src/World.ts","webpack://G6/../../src/util/gpu.ts","webpack://G6/../../../src/layout/gpu/fruchterman.ts","webpack://G6/../../../src/layout/gpu/fruchtermanShader.ts","webpack://G6/../../../src/layout/gpu/gForce.ts","webpack://G6/../../../src/layout/gpu/gForceShader.ts","webpack://G6/../../src/layout/comboForce.ts","webpack://G6/../../../src/layout/forceAtlas2/body.ts","webpack://G6/../../../src/layout/forceAtlas2/quad.ts","webpack://G6/../../../src/layout/forceAtlas2/quadTree.ts","webpack://G6/../../../src/layout/forceAtlas2/index.ts","webpack://G6/../../src/layout/layout.ts","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/util/layout.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/util/gpu.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/util/index.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/layout/tree-layout.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/layout/index.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/layout/worker/work.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/layout/worker/layout.worker.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/layout/worker/layoutConst.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/graph/controller/layout.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/graph/graph.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/grid/index.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/graph/tree-graph.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/base.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/menu/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/minimap/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/bundling/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/fisheye/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/toolBar/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/tooltip/index.js","webpack://G6/../../src/tick-method/register.ts","webpack://G6/../src/base.ts","webpack://G6/../../src/category/base.ts","webpack://G6/../src/fecha.ts","webpack://G6/../../src/util/time.ts","webpack://G6/../../src/util/bisector.ts","webpack://G6/../../src/category/time.ts","webpack://G6/../../src/continuous/base.ts","webpack://G6/../../src/continuous/linear.ts","webpack://G6/../../src/continuous/log.ts","webpack://G6/../../src/continuous/pow.ts","webpack://G6/../../src/continuous/time.ts","webpack://G6/../../src/continuous/quantize.ts","webpack://G6/../../src/continuous/quantile.ts","webpack://G6/../src/factory.ts","webpack://G6/../../src/identity/index.ts","webpack://G6/../../src/util/extended.ts","webpack://G6/../../src/tick-method/cat.ts","webpack://G6/../../src/util/d3-linear.ts","webpack://G6/../../src/util/interval.ts","webpack://G6/../../src/util/strict-limit.ts","webpack://G6/../../src/util/pretty.ts","webpack://G6/../../src/tick-method/quantile.ts","webpack://G6/../../src/tick-method/time-pretty.ts","webpack://G6/../../src/tick-method/index.ts","webpack://G6/../../src/tick-method/time-cat.ts","webpack://G6/../../src/tick-method/linear.ts","webpack://G6/../../src/tick-method/r-prettry.ts","webpack://G6/../../src/tick-method/time.ts","webpack://G6/../../src/tick-method/log.ts","webpack://G6/../../src/tick-method/pow.ts","webpack://G6/../../src/tick-method/d3-linear.ts","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/path.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/trend.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/handler.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/timeButton.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/constant.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/controllerBtn.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/trendTimeBar.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/timeBarTooltip.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/timeBarSlice.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/timeBar/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/imageMinimap/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/edgeFilterLens/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/snapline/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/legend/index.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/plugin/index.js","webpack://G6/./node_modules/_@antv_g6-plugin@0.3.11@@antv/g6-plugin/es/index.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/nodes/circle.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/nodes/rect.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/nodes/ellipse.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/nodes/diamond.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/nodes/triangle.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/nodes/modelRect.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/nodes/star.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/nodes/donut.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/edges/polyline-util.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/edges/router.js","webpack://G6/./node_modules/_@antv_g6-element@0.3.11@@antv/g6-element/es/edges/polyline.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/drag-canvas.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/drag-node.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/activate-relations.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/brush-select.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/click-select.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/zoom-canvas.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/tooltip-base.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/tooltip.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/edge-tooltip.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/collapse-expand.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/drag-combo.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/collapse-expand-combo.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/lasso-select.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/create-edge.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/shortcuts-call.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/scroll-canvas.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/behavior/index.js","webpack://G6/./node_modules/_@antv_g6-pc@0.3.11@@antv/g6-pc/es/index.js","webpack://G6/./src/index.ts"],"names":["root","factory","exports","module","define","amd","this","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","extendStatics","b","setPrototypeOf","__proto__","Array","__extends","TypeError","String","__","constructor","__assign","assign","arguments","length","apply","__rest","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__decorate","decorators","target","desc","getOwnPropertyDescriptor","Reflect","decorate","__param","paramIndex","decorator","__metadata","metadataKey","metadataValue","metadata","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","step","next","rejected","result","done","then","__generator","body","f","y","g","_","label","sent","trys","ops","verb","iterator","v","op","pop","push","__createBinding","k","k2","undefined","__exportStar","__values","__read","ar","error","__spread","concat","__spreadArrays","il","a","j","jl","__spreadArray","to","from","pack","slice","__await","__asyncGenerator","asyncIterator","q","resume","fulfill","settle","shift","__asyncDelegator","__asyncValues","__makeTemplateObject","cooked","raw","__setModuleDefault","__importStar","mod","__importDefault","default","__classPrivateFieldGet","receiver","state","kind","has","__classPrivateFieldSet","set","out","glMatrix","Float32Array","fromMat4","clone","copy","fromValues","m00","m01","m02","m10","m11","m12","m20","m21","m22","identity","transpose","a01","a02","a12","invert","a00","a10","a11","a20","a21","a22","b01","b11","b21","det","adjoint","determinant","multiply","b00","b02","b10","b12","b20","b22","translate","x","rotate","rad","Math","sin","cos","scale","fromTranslation","fromRotation","fromScaling","fromMat2d","fromQuat","z","w","x2","y2","z2","xx","yx","yy","zx","zy","zz","wx","wy","wz","normalFromMat4","a03","a13","a23","a30","a31","a32","a33","b03","b04","b05","b06","b07","b08","b09","projection","width","height","str","frob","hypot","add","subtract","multiplyScalar","multiplyScalarAndAdd","exactEquals","equals","a0","a1","a2","a3","a4","a5","a6","a7","a8","b0","b1","b2","b3","b4","b5","b6","b7","b8","abs","max","mul","sub","m03","m13","m23","m30","m31","m32","m33","axis","len","rotateX","rotateY","rotateZ","fromXRotation","fromYRotation","fromZRotation","fromRotationTranslation","xy","xz","yz","fromQuat2","translation","bx","by","bz","bw","ax","ay","az","aw","magnitude","getTranslation","mat","getScaling","getRotation","scaling","is1","is2","is3","sm11","sm12","sm13","sm21","sm22","sm23","sm31","sm32","sm33","trace","S","sqrt","fromRotationTranslationScale","sx","sy","sz","fromRotationTranslationScaleOrigin","ox","oy","oz","out0","out1","out2","out4","out5","out6","out8","out9","out10","frustum","left","right","bottom","top","near","far","rl","tb","nf","perspective","fovy","aspect","tan","Infinity","perspectiveFromFieldOfView","fov","upTan","upDegrees","PI","downTan","downDegrees","leftTan","leftDegrees","rightTan","rightDegrees","xScale","yScale","ortho","lr","bt","lookAt","eye","center","up","x0","x1","y0","y1","z0","z1","eyex","eyey","eyez","upx","upy","upz","centerx","centery","centerz","targetTo","a9","a14","a15","b9","b13","b14","b15","divide","ceil","floor","min","round","scaleAndAdd","distance","squaredDistance","squaredLength","negate","inverse","normalize","dot","cross","u","A","B","C","D","E","F","G","H","I","J","lerp","random","v1","v2","v3","v4","s1","s2","transformMat4","transformQuat","qx","qy","qz","qw","ix","iy","iz","iw","zero","vec","div","dist","sqrDist","sqrLen","forEach","stride","offset","count","fn","arg","setAxisAngle","getAxisAngle","out_axis","acos","getAngle","dotproduct","calculateW","exp","et","ln","atan2","log","pow","slerp","omega","cosom","sinom","scale0","scale1","u1","u2","u3","sqrt1MinusU1","sqrtU1","invDot","conjugate","fromMat3","fRoot","fTrace","fromEuler","halfToRad","cx","cy","cz","tmpvec3","xUnitVec3","yUnitVec3","temp1","temp2","matr","vec4","rotationTo","vec3","sqlerp","setAxes","mat3","view","AST_TOKEN_TYPES","AST_NODE_TYPES","STORAGE_CLASS","Target","DefineValuePlaceholder","type","elements","uniq","arr","cache","base","toString","index","num","requestAnimationFrame","window","cancelAnimationFrame","handler","_mix","obj","rst","memoized","superObj","func","default_1","configurable","writable","instance","Constructor","_defineProperties","props","descriptor","protoProps","staticProps","ExtensionName","AddressMode","BindingType","BlendFactor","BlendOperation","CompareFunction","CullMode","FilterMode","FrontFace","IndexFormat","InputStepMode","LoadOp","PrimitiveTopology","StencilOperation","StoreOp","TextureDimension","TextureFormat","TextureComponentType","TextureViewDimension","VertexFormat","TextureAspect","CompilationMessageType","QueryType","BufferUsage","ColorWrite","ShaderStage","TextureUsage","MapMode","require","context","initializer","keys","reverse","reduce","EPSILON","ARRAY_TYPE","RANDOM","IDENTIFIER","HierarchyComponentManager","TransformComponentManager","NameComponentManager","SceneGraphSystem","FrameGraphSystem","ResourcePool","ResourceHandleComponentManager","PassNodeComponentManager","RendererSystem","RenderPass","RenderPassFactory","Renderable","MeshSystem","MeshComponentManager","CullableComponentManager","Geometry","GeometrySystem","GeometryComponentManager","Material","MaterialSystem","MaterialComponentManager","ForwardRenderPath","ComputeSystem","ComputeComponentManager","ComputeStrategy","Systems","World","RenderEngine","WebGPUEngine","WebGLEngine","ShaderModuleService","ConfigService","InteractorService","IEventEmitter","Light","asyncGeneratorStep","gen","_next","_throw","info","self","args","err","rect","circle","line","path","marker","text","polyline","polygon","image","ellipse","dom","fill","lineDash","font","_getPrototypeOf","getPrototypeOf","quadratic","extremas","rx","startAngle","segments","ReferenceError","subClass","superClass","_typeof","assertThisInitialized","Component","ComponentManager","clazz","components","entities","lookup","entity","component","data","componentIndex","entity2","srcIndex","srcComponent","srcEntity","direction","entityInNum","Number","getComponent","callback","parentNode","arrayWithoutHoles","iterableToArray","unsupportedIterableToArray","nonIterableSpread","lodash","cloneDeep","constant","defaults","each","filter","find","flatten","forIn","isUndefined","last","map","mapValues","merge","minBy","now","pick","range","sortBy","uniqueId","values","zipObject","Error","isArray","arrowShape","id","el","console","clip","hasAttribute","gl","Graph","addDummyNode","attrs","hasNode","dummy","setNode","maxRank","nodes","rank","node","simplify","simplified","setGraph","graph","edges","simpleLabel","edge","weight","minlen","setEdge","asNonCompoundGraph","multigraph","isMultigraph","children","successorWeights","weightMap","sucs","outEdges","predecessorWeights","preds","inEdges","intersectRect","point","dx","dy","h","buildLayerMatrix","layering","order","normalizeRanks","removeEmptyRanks","layers","delta","nodeRankFactor","vs","addBorderNode","prefix","partition","collection","lhs","rhs","time","start","notime","hermite","factorTimes2","factor1","factor2","factor3","factor4","bezier","inverseFactor","inverseFactorTimesTwo","zScale","transformMat3","uvx","uvy","uvz","uuvx","uuvy","uuvz","w2","angle","mag","cosine","isEmpty","isFunction","size","transform","union","getEdgesByNodeId","getOutEdgesNodeId","getNeighbors","nodeId","currentEdges","source","split","substr","graphlib","freeGlobal","freeSelf","Function","injectable","inject","named","output","fg","usage","COPY_SRC","pass","passNode","resourceNode","framebuffer","canvas","enable","color","views","depth","scene","camera","viewMatrix","viewProjectionMatrix","mat4","meshEntity","mesh","getComponentByEntity","material","geometry","modelViewMatrix","projectionMatrix","modelMatrix","cameraPosition","u_viewport","uniforms","cur","prev","modelCacheKey","modelCache","createModel","createAttribute","modelInitializationOptions","fs","defines","attributes","buffer","arrayStride","stepMode","divisor","scissor","box","initMesh","isLength","baseMatches","baseMatchesProperty","ShapeBase","Marker","onAttrChange","_super","arc","endAngle","lineWidth","r2","r4","Text","item","catmullRom2Bezier","crp","segment","cp1","Mask","Frustum","planes","m0","m1","m2","m3","m4","m5","m6","m7","m8","m9","m14","m15","plane","arrayLikeKeys","baseKeys","isArrayLike","arrayWithHoles","iterableToArrayLimit","nonIterableRest","tmp","computeMiter","tangent","miter","lineA","lineB","halfThick","normal","dir","baseIsNative","getValue","getRawTag","objectToString","symToStringTag","baseKeysIn","fontSize","PickingStage","PixelPickingPass","stencil","renderPass","meshes","readPixels","useFramebuffer","xInDevicePixel","yInDevicePixel","pickedColors","Uint8Array","pickingFBO","pickedFeatureIdx","decodePickingColor","other","stubFalse","freeExports","nodeType","freeModule","Buffer","isBuffer","DataView","Map","Set","WeakMap","baseGetTag","toSource","dataViewCtorString","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","getTag","ArrayBuffer","Ctor","ctorString","isObjectLike","AABB","halfExtents","tc","tcx","tcy","tcz","th","thx","thy","thz","tminx","tmaxx","tminy","tmaxy","tminz","tmaxz","oc","aabb","ocx","ocy","ocz","oh","ohx","ohy","ohz","ominx","omaxx","ominy","omaxy","ominz","omaxz","aMax","aMin","bMax","bMin","getDefaultAttrs","square","diamond","triangle","triangleDown","createPath","Polyline","r1","r3","transformMat2","transformMat2d","p0","p1","sinC","cosC","containers","styleElements","insertCss","css","options","styleElement","position","prepend","container","document","querySelector","containerId","createElement","setAttribute","createStyleElement","insertBefore","childNodes","appendChild","charCodeAt","styleSheet","cssText","textContent","CopyPass","input","createBuffer","a_Position","FLOAT","shaderLocation","format","u_Texture","blend","model","util","WrappedTree","colorString","convert","_slice","skippedModels","hashedModelKeys","labels","sort","join","limiters","Color","channels","valpha","newArr","zeroArray","splice","alpha","hashedKeys","JSON","stringify","limit","freeze","getset","channel","modifier","val","maxfn","assertArray","string","toJSON","places","rgb","percentString","percent","array","unitArray","unitObject","toFixed","roundTo","roundToPlace","red","green","blue","hue","saturationl","lightness","saturationv","chroma","gray","white","wblack","cyan","magenta","yellow","black","keyword","hex","rgbNumber","luminosity","lum","chan","contrast","color2","lum1","lum2","level","contrastRatio","isDark","isLight","lighten","ratio","hsl","darken","saturate","desaturate","whiten","hwb","blacken","grayscale","fade","opaquer","degrees","mix","mixinColor","color1","w1","newAlpha","isObject","tag","assignValue","baseAssignValue","customizer","isNew","newValue","baseIsArguments","objectProto","isArguments","webpackPolyfill","deprecate","paths","baseIsTypedArray","baseUnary","nodeUtil","nodeIsTypedArray","isTypedArray","isSymbol","resourcePool","resource","engine","createFramebuffer","createTexture2D","wrapS","wrapT","NameComponent","getDecorators","createWorldContainer","worldContainer","trimLeft","trimRight","tinyCounter","mathRound","mathMin","mathMax","mathRandom","tinycolor","opts","ok","replace","toLowerCase","match","names","matchers","exec","rgba","hsla","hsv","hsva","hex8","parseIntFromHex","convertHexToDecimal","hex6","hex4","hex3","stringInputToObject","isValidCSSUnit","bound01","convertToPercentage","hsvToRgb","hue2rgb","hslToRgb","boundAlpha","inputToRGB","_originalInput","_r","_g","_b","_a","_roundA","_format","_gradientType","gradientType","_ok","_tc_id","rgbToHsl","rgbToHsv","rgbToHex","allow3Char","pad2","charAt","rgbaToArgbHex","convertDecimalToHex","amount","toHsl","clamp01","greyscale","brighten","toRgb","spin","complement","triad","tetrad","splitcomplement","analogous","results","slices","part","ret","monochromatic","toHsv","modification","getBrightness","isValid","getOriginalInput","getFormat","getAlpha","getLuminance","RsRGB","GsRGB","BsRGB","setAlpha","toHsvString","toHslString","toHex","toHexString","toHex8","allow4Char","rgbaToHex","toHex8String","toRgbString","toPercentageRgb","toPercentageRgbString","toName","hexNames","toFilter","secondColor","hex8String","secondHex8String","formatSet","formattedString","hasAlpha","_applyModification","_applyCombination","fromRatio","newColor","rgb1","rgb2","readability","c1","c2","isReadable","wcag2","wcag2Parms","parms","toUpperCase","validateWCAG2Parms","mostReadable","baseColor","colorList","includeFallbackColors","bestColor","bestScore","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","blanchedalmond","blueviolet","brown","burlywood","burntsienna","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","teal","thistle","tomato","turquoise","violet","wheat","whitesmoke","yellowgreen","flipped","flip","parseFloat","isNaN","isOnePointZero","processPercent","isPercentage","parseInt","CSS_UNIT","PERMISSIVE_MATCH3","PERMISSIVE_MATCH4","RegExp","_default","graphData","directed","matrix","nodeMap","sIndex","tIndex","ListCache","stackClear","stackDelete","stackGet","stackHas","stackSet","Stack","entries","__data__","clear","listCacheClear","listCacheDelete","listCacheGet","listCacheHas","listCacheSet","entry","eq","nativeCreate","getNative","isKeyable","objValue","reIsUint","test","getPrototype","overArg","baseForOwn","baseEach","createBaseEach","castPath","toKey","isKey","stringToPath","iteratee","overRest","setToString","isIndex","longestPath","visited","sources","dfs","POSITIVE_INFINITY","slack","Base","offScreenCtx","getOffScreenContext","EMPTY","entitySequence","createEntity","attribute","STATIC_DRAW","vertexCount","maxInstancedCount","MaterialComponent","vertexShaderGLSL","fragmentShaderGLSL","dirty","cull","face","BACK","existedUniform","params","moduleName","fragmentShader","materialModule","shaderModule","getModule","Strategy","CullableComponent","strategy","Standard","visibilityPlaneMask","visible","MeshComponent","aabbDirty","hierarchyComponent","hierarchy","cullableComponent","cullable","geometryComponent","meshTransform","worldTransform","transformedCenter","rotationScale","getRotationScale","transformedHalfExtents","parentCullableComponent","computeVisibilityWithPlaneMask","parentPlaneMask","mask","flag","Plane","pnVertexFlag","invLen","d0","distanceToPoint","intersects","renderPassFactory","setupRenderPass","executeRenderPass","frameGraphSystem","addPass","setupCopyPass","executeCopyPass","tearDownCopyPass","copyPass","pickingPass","HierarchyComponent","parentID","transformChild","transformParent","parentComponent","contains","parent","getCount","parentCandidateEntity","getEntity","childCandidateEntity","isChildAlreadyInLocalSpace","TransformComponent","transformed","quatX","quatY","quatZ","aS","aR","aT","bS","bR","bT","tr","parentInvertMatrix","parentInvertRotation","invParentRot","dirtyFlag","localDirtyFlag","localPosition","localRotation","quat","localScale","localTransform","rotation","matrixTransform","rotateRollPitchYaw","translateLocal","setPosition","rot","parentRot","rotateLocal","setRotation","DIRTY","IInteractorEvent","FrameGraphHandle","FrameGraphPass","PassNode","reads","handle","writes","newNode","ResourceEntry","ResourceNode","executePassNodes","frameGraphPass","setup","frameGraphPasses","stack","pNode","writer","resourceNodes","pResource","priority","pFirst","pLast","passNodes","execute","resourceEntry","fgh","createResourceNode","uniformRegExp","extractUniforms","content","defaultValues","uniformName","defaultValue","arrayLength","getUniformLengthByType","precisionRegExp","includeRegExp","moduleCache","rawContentCache","moduleParams","declaredUniforms","extractedVS","vsUniforms","extractedFS","fsUniforms","rawVS","rawFS","processModule","vsIncludeList","fsIncludeList","compiledFs","rawContent","includeList","includeName","strMatch","includeOpt","txt","typedArrayTags","GeometryComponent","indices","indicesBuffer","existed","bufferGetter","Uint32Array","positionAttribute","normalAttribute","normalMatrix","minX","maxX","minY","maxY","group","shape","Container","Element","BrowserInfo","version","os","NodeInfo","process","platform","SearchBotDeviceInfo","bot","BotInfo","ReactNativeInfo","SEARCHBOT_OS_REGEX","userAgentRules","operatingSystemRules","detect","userAgent","parseUserAgent","navigator","product","matchUserAgent","ua","matched","browser","regex","uaMatch","matchedRule","versionParts","ii","createVersionParts","detectOS","searchBotMatch","i1","MESSAGE","ALGORITHM","pageRank","breadthFirstSearch","connectedComponent","depthFirstSearch","detectCycle","detectDirectedCycle","detectAllCycles","detectAllDirectedCycle","detectAllUndirectedCycle","dijkstra","findAllPath","findShortestPath","floydWarshall","getAdjMatrix","getDegree","getInDegree","getOutDegree","labelPropagation","louvain","GADDI","minimumSpanningTree","SUCCESS","FAILURE","_tslib","_util","_util2","weightPropertyName","nodeIds","marks","prevs","nodeNum","_loop_1","minNode","minDis","minVertex","minNodeId","edgeTarget","edgeSource","findAllPaths","allPath","foundPaths","_i","prevPaths","prevPaths_1","prePath","_isDirected","_isMultigraph","_isCompound","compound","_label","_defaultNodeLabelFn","_defaultEdgeLabelFn","_nodes","_parent","_children","_in","_preds","_out","_sucs","_edgeObjs","_edgeLabels","incrementOrInitEntry","decrementOrRemoveEntry","edgeArgsToId","isDirected","v_","w_","edgeArgsToObj","edgeObj","edgeObjToId","_nodeCount","_edgeCount","isCompound","setDefaultNodeLabel","newDefault","nodeCount","sinks","setNodes","removeNode","removeEdge","_removeFromParentsChildList","child","setParent","ancestor","predecessors","predsV","successors","sucsV","neighbors","isLeaf","filterNodes","parents","findParent","setDefaultEdgeLabel","edgeCount","setPath","valueSpecified","arg0","hasEdge","inV","outV","nodeEdges","mapCacheClear","mapCacheDelete","mapCacheGet","mapCacheHas","mapCacheSet","MapCache","freeProcess","types","binding","isPrototype","nativeKeys","arrayFilter","stubArray","nativeGetSymbols","getSymbols","symbol","arrayBuffer","byteLength","baseFor","createBaseFor","reIsDeepProp","reIsPlainProp","arrayPush","isFlattenable","baseFlatten","predicate","isStrict","comparator","current","computed","_binding","constraint","binding_on_syntax_1","BindingOnSyntax","layout","debug","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","setTimeout","clearTimeout","currentQueue","queue","draining","queueIndex","cleanUpNextTick","drainQueue","timeout","run","runClearTimeout","Item","noop","nextTick","title","env","argv","versions","on","addListener","once","off","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","cwd","chdir","umask","AbstractShape","detectStrongConnectComponents","detectConnectedComponents","allComponents","nodeStack","neighbor","targetNode","inStack","lowLink","_loop_2","targetNodeID","tmpNode","nodes_1","degree","inDegree","outDegree","startNodeId","callbacks","depthFirstSearchRecursive","currentNode","previousNode","enter","previous","nextNode","allowTraversal","leave","initiatedCallback","stubCallback","allowTraversalCallback","seen","initCallbacks","_adjacentMatrix","adjacentMatrix","cssKeywords","reverseKeywords","cmyk","xyz","lab","lch","ansi16","ansi256","hcg","apple","rdif","gdif","bdif","diff","diffc","reversed","currentClosestKeyword","currentClosestDistance","t1","t2","t3","smin","lmin","hi","sl","vmin","wh","bl","hr","ansi","mult","rem","substring","char","integer","mg","pure","arrayEach","baseAssign","baseAssignIn","cloneBuffer","copyArray","copySymbols","copySymbolsIn","getAllKeys","getAllKeysIn","initCloneArray","initCloneByTag","initCloneObject","isMap","isSet","keysIn","cloneableTags","baseClone","bitmask","isDeep","isFlat","isFull","isArr","isFunc","stacked","subValue","global","funcToString","baseTimes","inherited","isArg","isBuff","isType","skipIndexes","allocUnsafe","resIndex","getSymbolsIn","baseGetAllKeys","keysFunc","symbolsFunc","cloneArrayBuffer","typedArray","byteOffset","baseCreate","objectCreate","proto","castFunction","baseFilter","baseIteratee","baseIsEqualDeep","baseIsEqual","SetCache","arraySome","cacheHas","equalFunc","isPartial","arrLength","othLength","arrStacked","othStacked","arrValue","othValue","compared","othIndex","setCacheAdd","setCacheHas","srcValue","baseToString","baseHasIn","hasPath","hasFunc","baseHas","arrayMap","baseMap","arrayReduce","baseReduce","accumulator","initAccum","nativeMax","otherArgs","baseSetToString","shortOut","fromIndex","fromRight","baseValues","PriorityQueue","weightFn","edgeFn","vEntry","pq","updateNeighbors","wEntry","predecessor","decrease","removeMin","runDijkstra","DEFAULT_WEIGHT_FUNC","_arr","_keyIndices","keyIndices","_decrease","_swap","_heapify","largest","origArrI","origArrJ","onStack","lowlink","cmpt","topsort","visit","CycleException","navigation","acc","doDfs","postorder","toNumber","tightTree","edgeV","findMinSlackEdge","shiftRanks","exporter","makeExporter","hasOwn","supportsSymbol","toPrimitiveSymbol","toPrimitive","iteratorSymbol","supportsCreate","supportsProto","downLevel","HashMap","MakeDictionary","functionPrototype","usePolyfill","_Map","cacheSentinel","arraySentinel","MapIterator","selector","_index","_keys","_values","_selector","throw","return","_cacheKey","_cacheIndex","_find","delete","getKey","getEntry","insert","CreateMapPolyfill","_Set","_map","Metadata","rootKey","CreateUniqueKey","_key","table","GetOrCreateWeakMapTable","CreateUUID","FillRandomBytes","crypto","getRandomValues","msCrypto","byte","CreateWeakMapPolyfill","GetOrCreateMetadataMap","O","Create","targetMetadata","IsUndefined","metadataMap","OrdinaryHasOwnMetadata","MetadataKey","OrdinaryGetOwnMetadata","OrdinaryDefineOwnMetadata","MetadataValue","OrdinaryOwnMetadataKeys","method","GetMethod","IsCallable","IsObject","GetIterator","IteratorStep","nextValue","IteratorClose","Type","IsNull","ToPrimitive","PreferredType","hint","exoticToPrim","toString_1","valueOf","toString_2","OrdinaryToPrimitive","ToPropertyKey","argument","ToString","IsArray","IsConstructor","V","OrdinaryGetPrototypeOf","prototypeProto","propertyKey","decorated","DecorateConstructor","DecorateProperty","IsPropertyKey","OrdinaryHasMetadata","OrdinaryGetMetadata","OrdinaryMetadataKeys","ownKeys","parentKeys","ownKeys_1","parentKeys_1","arrayLikeToArray","minLen","arr2","isStackOverflowExeption","LazyServiceIdentifer","_bindingWhenSyntax","generateAABBFromVertices","positions","isSafari","PassType","taskHead","taskTail","frame","interval","clockLast","clockNow","clockSkew","clock","performance","Date","setFrame","clearNow","Timer","_call","_time","timer","delay","restart","wake","timerFlush","t0","sleep","nap","poke","clearInterval","setInterval","linear","quadIn","quadOut","quadInOut","cubicIn","cubicOut","cubicInOut","stop","polyIn","custom","exponent","polyOut","polyInOut","pi","halfPi","sinIn","sinOut","sinInOut","tpmt","expIn","expOut","expInOut","circleIn","circleOut","circleInOut","bounceIn","bounceOut","bounceInOut","backIn","overshoot","backOut","backInOut","tau","elasticIn","asin","amplitude","period","elasticOut","elasticInOut","extend","definition","reI","reN","reP","reHex","reRgbInteger","reRgbPercent","reRgbaInteger","reRgbaPercent","reHslPercent","reHslaPercent","color_formatHex","formatHex","color_formatRgb","formatRgb","trim","rgbn","Rgb","NaN","rgbConvert","opacity","rgb_formatHex","rgb_formatRgb","Hsl","hslConvert","hsl2rgb","basis","v0","displayable","formatHsl","brighter","darker","gamma","nogamma","exponential","rgbGamma","end","colorRgb","rgbSpline","spline","colors","isNumberArray","isView","genericArray","nb","na","setTime","reA","reB","am","bm","bs","bi","lastIndex","number","one","date","numberArray","update","duration","animation","easing","elapsed","cPathPoint","cProps","Timeline","relativeShape","_emitEvent","EventController","event","_this","register","Canvas","cfg","getShapeBase","region","getAdjMatrixAsync","connectedComponentAsync","getDegreeAsync","getInDegreeAsync","getOutDegreeAsync","detectCycleAsync","detectAllCyclesAsync","detectAllDirectedCycleAsync","detectAllUndirectedCycleAsync","dijkstraAsync","findAllPathAsync","findShortestPathAsync","floydWarshallAsync","labelPropagationAsync","louvainAsync","minimumSpanningTreeAsync","pageRankAsync","getNeighborsAsync","GADDIAsync","detectDirectedCycleAsync","decorators_1","doCache","lazyInject","makePropertyInjectDecorator","lazyInjectNamed","makePropertyInjectNamedDecorator","lazyInjectTagged","makePropertyInjectTaggedDecorator","lazyMultiInject","makePropertyMultiInjectDecorator","_createWorker","_constant","maxIteration","threshold","algo","epsilon","linkProb","pattern","nodeLabelProp","edgeLabelProp","worker","postMessage","_algorithmType","onmessage","terminate","algorithm","nodeInterop","_getRequireWildcardCache","newObj","hasPropertyDescriptor","_interopRequireWildcard","cacheBabelInterop","cacheNodeInterop","ctx","_bfs","_connectedComponent","_degree","_detectCycle","_dfs","_dijkstra","_findPath","_floydWarshall","_labelPropagation","_louvain","_mts","_pageRank","_gaddi","_interopRequireDefault","_queue","originalCallbacks","nodeQueue","enqueue","dequeue","_linkedList","Queue","linkedList","head","peek","append","removeHead","deleteHead","LinkedListNode","defaultComparator","LinkedList","tail","compare","deleteNode","_c","deleteTail","deletedTail","deletedHead","fromArray","toArray","prevNode","include","allCycles","components_1","rootId","parent_1","used","curNode","curNodeId","neighborId","cycleValid","cyclePath","findIndex","cycle","blocked","idx2Node","node2Idx","circuit","adjList","closed","thisNode","unblock","getMinComponentAdj","minCompIdx","minIdx","comp","nodeIdx_1","nodeIdx","subgraphNodes","sccs","scc","startNode","dfsParentMap","unvisitedSet","visitingSet","visitedSet","currentCycleNode","previousCycleNode","firsetUnVisitedKey","isVisited","clusters","cid","clusterId","idx","adjMatrix","ks","row","iid","jid","iter","changed","neighborClusters","neighborWeight","neighborClusterId","maxWeight","bestClusterIds","selfClusterIdx","selfCluster","nodeInSelfClusterIdx","randomIdx","bestCluster","cluster","clusterEdges","clusterEdgeMap","sourceClusterId","targetClusterId","newEdgeId","newEdge","clustersArray","getModularity","param","modularity","clusteri","totalModularity","previousModularity","sumTot","bestIncrease","commonParam","kiin","scNode","scNodeIdx","removeModurarity","nodeNeighborIds","neighborNodeId","neighborCluster","clusterNodes","neighborClusterKiin","cNode","cNodeIdx","increase","previousClusterId_1","neighborClusterSumTot_1","selfClusterSumTot_1","newClusterIdMap","clusterIdx","newId","_unionFind","_binaryHeap","primMST","selectedEdges","currNode","edgeQueue","currEdge","delMin","kruskalMST","weightEdges","disjointSet","curEdge","connected","prim","kruskal","UnionFind","items","items_1","rootA","rootB","defaultCompare","MinBinaryHeap","compareFn","list","getLeft","getRight","getParent","moveDown","moveUp","element","currentRank","leakedRank","maxIterations","nodesCount","curRanks","prevRanks","nodeDegree","_gSpan","findKNeighborUnits","spm","units","findKNeighborUnit","unitNodeIdxs","labelCountMap","dists","nodeIdxs","neighborNum","nodeLabelCountMap","getIntersectNeighborInducedGraph","nodePairMap","neighborUnits","cachedInducedGraphMap","pair","startUnitNodeIds","endUnitNodeIds","endSet","intersect","intersectIdMap","intersectLength","getMatchedCount","structure","sourceLabel","targetLabel","strNodeLabel1","strNodeLabel2","strEdgeLabel","getNodeMaps","nodeLabelMap","getEdgeMaps","edgeMap","edgeLabelMap","sourceNode","getSpmMap","iId","jId","getNDSDist","node1","node2","spDist","kNeighborUnits","cachedNDSMap","cachedInterInducedGraph","interInducedGraph","pairMap","stashPatternNodeLabelDegreeMap","minPatternNodeLabelDegreeMap","neighborLabel","patternNodeMap","patternNodeLabelMap","minPatternNodeLabelDegree","minPatternNodeLabelInDegree","minPatternNodeLabelOutDegree","patternNodeWithLabel","patternNodeDegree","patternNodeInDegree","patternNodeOutDegree","patternSpm","spmMap","patternSpmMap","patternEdgeLabelMap","patternKNeighborUnits","nodePairsMap","maxNodePairNum","nodePairNumEachNode","foundNodePairCount","unit","nodePairForICount","outerLoopCount","oidx","innerLoopCount","findNodePairsRandomly","intGMap","graphs","minSupport","minNodeNum","maxNodeNum","freStructures","structureNum","matchedCountMap","subStructureCount","structures","maxOffset","representClusterType","countMapI","sortedGraphKeys","totalCount","aveCount","aveIntraDist","aveCounts","graphsInCluster","aveIntraPerCluster","graphsNum","graphKey1","graph1Count","graphKey2","aveInterDist","aveCount1","aveCount2","structureCountMap","findRepresentStructure","dsG","ndsDist","beginPNode","candidates","patternIntGraphMap","patternNDSDist","patternNDSDistMap","patternSpDist","patternSpDistBack","label2","maxDist","patternNodesWithLabel2","patternNodePairMap","nodeWithLabel2","distBack","currentPatternNDSDistArray","patternIntGraph","_loop_4","graphNeighborUnit","graphNeighborUnitCountMap","patternLabel2Num","prune2Invalid","cNodePairMap","neighborNode","currentNDSDistArray","intGraph","prune3Invalid","candidateGraphs","candidate","neighborNodes","unmatched","distToCandidate","keyBack","distFromCandidate","ndsToCandidate","patternKey","undirectedLengthsToBeginPNode","undirectedLengthsToBeginPNodeLabelMap","nodeLabel","pLabel","candidateGraph","candidateNodeLabelCountMap","candidateNodeMap","cNodeLabel","candidateEdges","edgeLabelCountMap","pattenrEdgeLabelNum","prunedByEdgeLabel","label_1","candidateEdgeNum","candidateGraphInvalid","_loop_5","edgeLabel","patternEdgesWithLabel","edgeMatched","patternEdge","patternSource","patternTarget","lengthsToCandidate","targetId","targetNodeLabel","nLabel","degreeChanged","loopCount","cgNode","nodeInDegree","nodeOutDegree","_d","cedge","currentLength","_loop_3","cg1","cg1EdgeMap","_loop_6","cg2","cg2EdgeMap","same","_struct","DFSedge","fromNode","toNode","fromNodeLabel","toNodeLabel","nodeEdgeNodeLabel","nodeLabel1","VACANT_NODE_LABEL","VACANT_EDGE_LABEL","nodeLabel2","equalTo","formNode","notEqualTo","DFScode","rmpath","dfsEdgeList","aLength","pushBack","toGraph","graphId","VACANT_GRAPH_ID","dfsEdge","fromNodeId","toNodeId","addNode","addEdge","buildRmpath","oldFrom","fromNodeIdx","toNodeIdx","getNodeNum","History","pdfs","his","nodesUsed","edgesUsed","preNode","GSpan","_e","_f","verbose","dfsCode","support","frequentSize1Subgraphs","frequentSubgraphs","counter","reportDF","findForwardRootEdges","findBackwardEdge","edge1","edge2","history","edge2ToEdges","edgeLength","findForwardPureEdges","rightmostEdge","minNodeLabel","rightmostEdgeToId","findForwardRmpathEdges","newToNodeLabel","getSupport","projected","graphMap","pro","findMinLabel","minLabel","isMin","dfsCodeMin","otherNode","projectIsMin","maxToC","backwardRoot","newTo","backwardEdge","minBackwardEdgeLabel","idx_1","forwardRoot","newFrom","forwardPureEdges","pathLength","forwardRmpathEdges","forwardMinEdgeNodeLabel","report","subGraphMining","generate1EdgeFrequentSubGraphs","nodeLabelCounter","nodeEdgeNodeCounter","nodeLableCounted","nodeEdgeNodeLabelCounted","graphNodeKey","graphKey","graphNodeEdgeNodeKey","nodeEdgeNodeKey","formattedGraphs","fGraph","nodeIdxMap","sourceIdx","targetIdx","formatGraphs","calculator","toGraphDatas","Node","Edge","AUTO_EDGE_ID","VACANT_NODE_ID","VACANT_EDGE_ID","edgeIdAutoIncrease","rEdge","colorNames","swizzle","reverseNames","cs","clamp","hexDouble","hexAlpha","i2","hwba","isArrayish","wrap","conversions","route","fromModel","routes","toModel","wrappedFn","conversion","wrapRounded","wrapRaw","deriveBFS","models","buildGraph","adjacents","adjacent","unshift","link","wrapConversion","lib","json","alg","assocIndexOf","pairs","LARGE_ARRAY_SIZE","isMasked","reIsHostCtor","funcProto","reIsNative","nativeObjectToString","isOwn","unmasked","uid","coreJsData","maskSrcKey","IE_PROTO","Hash","hashClear","hashDelete","hashGet","hashHas","hashSet","getMapData","copyObject","nativeKeysIn","isProto","cloneDataView","cloneRegExp","cloneSymbol","cloneTypedArray","dataView","reFlags","regexp","symbolProto","symbolValueOf","baseIsMap","nodeIsMap","baseIsSet","nodeIsSet","iterable","eachFunc","baseIsMatch","getMatchData","matchesStrictComparable","matchData","noCustomizer","COMPARE_PARTIAL_FLAG","equalArrays","equalByTag","equalObjects","objectTag","objIsArr","othIsArr","objTag","othTag","objIsObj","othIsObj","isSameTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","mapToArray","setToArray","message","objProps","objLength","objStacked","skipCtor","objCtor","othCtor","isStrictComparable","hasIn","baseGet","memoizeCapped","rePropName","reEscapeChar","quote","subString","memoize","resolver","Cache","symbolToString","baseProperty","basePropertyDeep","isString","stringSize","asciiSize","hasUnicode","unicodeSize","reHasUnicode","rsAstral","rsCombo","rsFitz","rsNonAstral","rsRegional","rsSurrPair","reOptMod","rsSeq","rsSymbol","reUnicode","isArrLike","baseRest","baseUniq","isArrayLikeObject","arrays","spreadableSymbol","isConcatSpreadable","nativeNow","lastCalled","stamp","remaining","arrayIncludes","arrayIncludesWith","createSet","includes","isCommon","outer","seenIndex","baseIndexOf","baseFindIndex","baseIsNaN","strictIndexOf","writeNodes","nodeValue","writeEdges","edgeValue","write","read","dijkstraAll","findCycles","isAcyclic","preorder","tarjan","cmpts","weightFunc","edgeFunc","rowK","rowI","ik","kj","ij","altDistance","runFloydWarshall","pri","edgeWeight","init","acyclic","parentDummyChains","nestingGraph","addBorderSegments","coordinateSystem","debugTiming","layoutGraph","inputGraph","canonicalize","graphDefaults","selectNumberAttrs","graphNumAttrs","graphAttrs","nodeNumAttrs","nodeDefaults","edgeDefaults","edgeNumAttrs","edgeAttrs","buildLayoutGraph","ranksep","labelpos","rankdir","labeloffset","makeSpaceForEdgeLabels","selfEdges","removeSelfEdges","injectEdgeLabelProxies","cleanup","borderTop","minRank","borderBottom","assignRankMinMax","labelRank","removeEdgeLabelProxies","layer","orderShift","selfEdge","insertSelfEdges","adjust","selfNode","points","positionSelfEdges","borderLeft","borderRight","removeBorderNodes","undo","fixupEdgeLabelCoords","graphLabel","marginX","marginx","marginY","marginy","getExtremes","translateGraph","p2","nodeV","nodeW","assignNodeIntersects","reversePointsForReversedEdges","runLayout","inputLabel","layoutLabel","updateInputGraph","edgesep","nodesep","newAttrs","CLONE_DEEP_FLAG","isIterateeCall","guard","propsIndex","propsLength","createFind","findIndexFunc","toInteger","toFinite","remainder","baseTrim","reIsBadHex","reIsBinary","reIsOctal","freeParseInt","isBinary","trimmedEndIndex","reTrimStart","reWhitespace","baseExtremum","baseGt","baseMerge","createAssigner","assignMergeValue","baseMergeDeep","safeGet","isPlainObject","toPlainObject","mergeFunc","isTyped","objectCtorString","assigner","baseLt","basePick","flatRest","basePickBy","baseSet","nested","createRange","baseRange","nativeCeil","baseOrderBy","iteratees","baseSortBy","compareMultiple","orders","comparer","compareAscending","objCriteria","criteria","othCriteria","ordersLength","valIsDefined","valIsNull","valIsReflexive","valIsSymbol","othIsDefined","othIsNull","othIsReflexive","othIsSymbol","idCounter","baseZipObject","assignFunc","valsLength","greedyFAS","fas","acyclicer","dfsFAS","forwardName","List","fasGraph","maxIn","maxOut","prevWeight","buckets","zeroIdx","assignBucket","buildState","DEFAULT_WEIGHT_FN","doGreedyFAS","collectPredecessors","uEntry","sentinel","_prev","_sentinel","unlink","filterOutLinks","strs","curr","dummyChains","vRank","wRank","normalizeEdge","origLabel","feasibleTree","networkSimplex","ranker","networkSimplexRanker","tightTreeRanker","longestPathRanker","initRank","initLowLimValues","initCutValues","leaveEdge","exchangeEdges","enterEdge","cutvalue","calcCutValue","assignCutValue","childIsTail","graphEdge","cutValue","isOutEdge","pointsToHead","otherWeight","otherCutValue","tree","dfsAssignLowLim","nextLim","low","lim","vLabel","wLabel","tailLabel","isDescendant","updateRanks","rootLabel","postorderNums","pathData","lca","vPath","wPath","findPath","pathIdx","pathV","ascending","depths","treeDepths","nodeSep","nestingRoot","sumWeights","childNode","childTop","childBottom","thisWeight","nestingEdge","prop","sg","sgNode","borderType","swapWidthHeight","swapWidthHeightOne","reverseYOne","swapXYOne","rankDir","reverseY","swapXY","initOrder","crossCount","sortSubgraph","buildLayerGraph","addSubgraphConstraints","buildLayerGraphs","ranks","relationship","sweepLayerGraphs","layerGraphs","biasRight","cg","lg","sorted","assignOrder","downLayerGraphs","upLayerGraphs","best","bestCC","lastBest","cc","simpleNodes","orderedVs","twoLayerCrossCount","northLayer","southLayer","southPos","southEntries","pos","firstIndex","treeSize","weightSum","barycenter","resolveConflicts","movable","br","subgraphs","barycenters","subgraphResult","expandSubgraphs","blPred","brPred","nodeU","sum","mappedEntries","indegree","entryV","entryW","sourceSet","handleIn","merged","mergeEntries","handleOut","doResolveConflicts","consumeUnsortable","unsortable","parts","sortable","vsIndex","bias","createRootNode","rootPrev","prevChild","positionX","rankSep","prevY","maxHeight","positionY","findType1Conflicts","conflicts","prevLayer","k0","scanPos","prevLayerLength","lastNode","findOtherInnerSegmentNode","k1","scanNode","uLabel","uPos","addConflict","findType2Conflicts","scan","south","southEnd","prevNorthBorder","nextNorthBorder","uNode","north","nextNorthPos","prevNorthPos","southLookahead","conflictsV","hasConflict","verticalAlignment","neighborFn","align","prevIdx","ws","mp","horizontalCompaction","reverseSep","xs","blockG","blockGraph","sepFn","edgeSep","sep","vRoot","uRoot","prevMax","buildBlockGraph","iterate","setXsFunc","nextNodesFunc","elem","findSmallestWidthAlignment","xss","NEGATIVE_INFINITY","halfWidth","alignCoordinates","alignTo","alignToVals","alignToMin","alignToMax","vert","horiz","alignment","xsVals","balance","ul","ignore","adjustedLayering","inner","smallestWidth","debugOrdering","layerMatrix","layerV","style","runtime","Op","$Symbol","asyncIteratorSymbol","toStringTagSymbol","innerFn","outerFn","tryLocsList","protoGenerator","Generator","Context","_invoke","doneResult","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","_sent","dispatchException","abrupt","record","tryCatch","makeInvokeMethod","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","NativeIteratorPrototype","Gp","defineIteratorMethods","AsyncIterator","PromiseImpl","previousPromise","callInvokeWithMethodAndArg","invoke","unwrapped","resultName","nextLoc","pushTryEntry","locs","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","reset","iteratorMethod","displayName","isGeneratorFunction","genFun","ctor","mark","awrap","async","skipTempReset","rootRecord","rval","exception","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","globalThis","_s","_n","defaultScope","autoBindInjectable","_get","binding_1","childRequest","literal_types_1","BindingTypeEnum","_bindingInSyntax","when","scope","BindingScopeEnum","binding_when_on_syntax_1","BindingWhenOnSyntax","snapshot","Lookup","decorator_utils_1","targetKey","tagProperty","_setPrototypeOf","INJECTION","for","_proxyGetter","hasMetadata","defineMetadata","getMetadata","newVal","serviceIdentifier","getNamed","propertyName","getTagged","getAll","mSq","getDefaultCfg","getEvents","updateCfg","shouldBegin","shouldUpdate","shouldEnd","events","addEventListener","keydown","unbind","draggable","Behavior","registerBehavior","behavior","behaviorOption","eventsToBind","wrapBehavior","hasBehavior","getBehavior","getConnectedComponents","gSpan","maxStep","isMaxStack","ext","attributeName","isBetween","getLineIntersect","p3","D0","D1","kross","invertKross","getRectIntersectByPoint","getCircleIntersectByPoint","signX","sign","signY","atan","getEllipseIntersectByPoint","ry","applyMatrix","vector","invertMatrix","inversedMatrix","getCircleCenterByPoints","denominator","vx","vy","scaleMatrix","newRow","move","animate","animateCfg","getMatrix","bbox","getCanvasBBox","dx_1","dy_1","lastX_1","lastY_1","newX_1","newY_1","movedMatrix","setMatrix","scaleXY","onSegment","isPointInPolygon","isHit","dcmp","xValue","intersectBBox","box1","box2","isPolygonsIntersect","points1","points2","getBBox","xArr","yArr","parseToLines","lines","first","bbox1","bbox2","isIn","lines1","lines2","isIntersect","lineIntersectPolygon","Line","getBBoxBoundLine","fractionAlongLineA","la","lb","uaT","ubT","uB","ub","itemIntersectByLine","directions","countIntersections","intersections","fractionToLine","minDistance","testDistance","getPointsCenter","centerX","centerY","points_1","squareDist","pointLineSquareDist","projlenSq","px","py","dotprod","lenSq","isPointsOverlap","pointRectSquareDist","isLeft","isRight","isTop","isBottom","pointLineDistance","vec2","comboFill","colorSet","rootContainerClassName","nodeContainerClassName","edgeContainerClassName","comboContainerClassName","delegateContainerClassName","defaultLoopPosition","textAlign","textBaseline","defaultNode","stroke","linkPoints","nodeStateStyles","active","shadowColor","shadowBlur","selected","fontWeight","highlight","inactive","disable","defaultEdge","lineAppendWidth","edgeStateStyles","comboLabel","refY","refX","defaultCombo","padding","comboStateStyles","delegateStyle","fillOpacity","strokeOpacity","K","L","M","N","Q","R","T","U","W","X","Y","Z","$","SELF_LINK_SIN","SELF_LINK_COS","leftTop","rightBottom","lx","ly","getLoopCfgs","containerMatrix","getKeyShape","loopCfg","Global","startPoint","endPoint","rstart","rend","sinDeltaStart","cosDeltaStart","sinDeltaEnd","cosDeltaEnd","clockwise","swap","startVec","scaleRateStart","scaleRateEnd","startExtendVec","controlPoint1","endVec","endExtendVec","controlPoint2","controlPoints","getLabelPosition","pathShape","getPoint","getStartTangent","getEndTangent","offsetPoint","traverse","traverseTree","traverseTreeUp","traverseUp","getLetterWidth","letter","letterAspectRatio","getTextSize","plainCombosToTrees","addedMap","modelMap","cd","itemType","parentId","warn","mappedObj","mappedParent","parent_2","pa","combo","comboId","cnode","maxDepth","oriNodeModel","reconstructTree","trees","subtreeId","newParentId","subtree","brothers","comboChildsMap","foundSubTree","oldParentId","removed","found_1","newParentDepth_1","currentDepth_1","getComboBBox","comboBBox","childItem","findById","isVisible","childBBox","shouldRefreshEdge","refreshEdge","isNumber","anchorPoints","cloneBesidesImg","clonedObj","key1","obj2","clonedObj2_1","key2","dataValidation","combos","validated_1","nonNode","comboIds","ids","nonEdges","ModeController","destroyed","modes","formatModes","currentBehaves","setMode","setBehaviors","behave","behaviors","behaves","BehaviorInstance","mergeBehaviors","modeBehaviors","filterBehaviors","remove","getMode","manipulateBehaviors","isAdd","currentMode","updateBehavior","newCfg","behaviorSet","length_2","length_1","destroy","G6GraphEvent","canvasX","canvasY","wheelDelta","detail","GraphEvent","formatPadding","isNil","cloneEvent","clientX","clientY","currentTarget","bubbles","isViewportChanged","ORIGIN_MATRIX","calculationItemsBBox","minx","maxx","miny","maxy","processParallelEdges","offsetDiff","multiEdgeType","singleEdgeType","loopEdgeType","cod","loopPosition","tags","reverses","sourceTarget","sedge","src","dst","arcEdges","curveOffset","ViewController","getViewCenter","getFormatPadding","fitCenter","resetMatrix","viewCenter","groupCenter","fitView","zoom","focusPoint","modelCenter","getPointByCanvas","viewportMatrix","getPointByClient","canvasPoint","getClientByPoint","getCanvasByPoint","focus","getType","sourceMatrix","getSource","targetMatrix","getTarget","changeSize","plugin","positionInit","looseJSONParse","safeParse","parse","firstAttempt","objectStack","syntaxStack","isLastPair","syntaxes","some","syntax","temp","nowChar","isInString","isLastTranslate","isInObject","isInArray","isWaitingValue","tempArr","generateTarget","lastOffset","defaultBbox","marginTop","chilrenBBox","shapeHeight","shapeWidth","marginLeft","createNodeFromXML","compileXML","xml","endsWith","xmlDataRenderer","xmlParser","innerHTML","parseXML","getAttributeNames","tagName","innerText","getAttribute","keyshape","draw","resultTarget","renderTarget","rest","addShape","origin","getContainer","newTarget","diffResult","compareTwoTarget","nowTarget","formerTarget","action","formerChilren","nowChilren","formerKeys","nowKeys","delShape","targetShape","removeChild","updateTarget","originAttr","getOriginStyle","attr","getAnchorPoints","ucfirst","upperFirst","ShapeFactoryBase","defaultShapeType","className","getShape","afterDraw","baseUpdate","updateType","afterUpdate","setState","getControlPoints","ShapeFramework","drawShape","defaultAnchorPoints","Shape","registerFactory","factoryType","factoryBase","shapeFactory","getFactory","registerNode","shapeType","nodeDefinition","extendShapeType","shapeObj","autoNodeDefinition","jsx","extendShape","registerEdge","edgeDefinition","registerCombo","comboDefinition","Combo","ItemBase","_cfg","defaultCfg","locked","keyShape","states","stateStyles","styles","deepMix","calculateBBox","calculateCanvasBBox","drawInner","changeVisibility","updatePosition","getShapeCfg","setOriginStyle","restoreStates","keyShapeName","styles_1","currentStatesStyle_1","getCurrentStatesStyle","shapeAttrs","shapeStateStyle_1","getShapeStyleByName","shapeAttrs_1","keyShapeStateStyles_1","styleKey","subStyle","originStyles_1","keyShapeStyle","shapeName","clearCache","beforeDraw","currentShape","styles_2","newModel","getStateStyle","getStates","stateName","filterStateName","newStates","isBoolean","filterStates","clearStates","originStates","getModel","getID","isItem","hasState","refresh","updateShape","getUpdateType","oriVisible","cfgVisible","originPosition","toFront","toBack","show","hide","enableCapture","stopAnimate","END_MAP","linkCenter","setEnd","pointName","itemName","preItem","getLinkPoint","anchorName","prePoint","getPrePoint","anchorIndex","getLinkPointByAnchor","oppositeName","getEndPoint","getControlPointsByCenter","sourcePoint","targetPoint","getEndCenter","setSource","setTarget","sourceItem","targetItem","getNearestPoint","curPoint","nearestPoint","dis","getEdges","getInEdges","getOutEdges","intersectPoint","linkPoint","bbox_1","shapeCfg","pointArr","lock","unlock","hasLocked","existX","existY","cacheSize","cacheBBox","oriX","oriY","getChildren","getNodes","getCombos","addChild","addCombo","removeCombo","ItemController","edgeToBeUpdateMap","throttleRefresh","throttle","eid","trailing","leading","addItem","vType","upperType","defaultModel","mapper","mappedModel_1","isComboEdge","addGroup","comboGroup","setZIndex","comboModel_1","collapsed","collapseCombo","updateItem","mappedModel","edges_1","updateCombo","comboX","comboY","updateComboEdges","combEdges","edgeSF","edgeCfg","edgeGroup","hideItem","expandCombo","showItem","removeItem","itemModel","vitems","vindex","itemId","comboTrees","brothers_1","ctree","bidx","comboInTree_1","found_2","setItemState","enabled","autoPaint","priorityState","currentItem","clearItemStates","refreshItem","addCombos","comboModels","comboModel","changeItemVisibility","id_1","children_1","found_3","StateController","cachedStates","disabled","checkCache","cacheState","updateState","enabledStates","disabledStates","updateGraphStates","updateStates","map_1","substitute","res","getSpline","spliePath","getControlPoint","perpendicular","pointsToPolygon","pathToPoints","seg","getClosedSpline","second","lastSecond","closedPath","cp1x","cp1y","cp2x","cp2y","vecScaleTo","unitNormal","nLength","vecFrom","roundedHull","polyPoints","roundedHull1","offsetVector","invOffsetVector","roundedHull2","segmentIndex","arcData","pathFragment","paddedHull","pointCount","extensionVec","extension0","extension1","tangentHalfLength","controlDelta","invControlDelta","control0","control1","control3","smoothHull2","hullPoints","pNext","priorIndex","genConvexHull","lower","upper","defaultOps","maxRoutingIterations","maxMarchingIterations","pixelGroupSize","edgeR0","edgeR1","nodeR0","nodeR1","morphBuffer","skip","nodeInfluenceFactor","edgeInfluenceFactor","negativeNodeInfluenceFactor","MarchingSquares","contour","potentialArea","marched","getVal","cells","getState","squareVal","doMarch","xPos","yPos","prevX","march","getIntersectItem","closestItem","getRoute","nonMembers","optimalNeighbor","closestNeighbour","minCost","neighbourItem","itemP","neighbourItemP","directLine","numberObstacles","_item","pickBestNeighbor","checkedLines","finalRoute","line1","line2","mergeLine","mergeLines","linesToCheck","hasIntersection","iterations","pointExists","isPointInNonMembers","_nonMembers","_nonMembers_1","itemContour","intersections_1","testReroute","isFirst","tempMorphBuffer","virtualNode","rerouteLine","exist","pointInside","computeRoute","genBubbleSet","members","centroid","virtualEdges","scaleWidth","scaleHeight","activeRegion","bboxes","bboxes_1","getActiveRregion","hull","fillPotentialArea","marchedPath","members_1","isContourValid","memberInfluenceFactor","nonMemberInfluenceFactor","pos2GridIx","gridIx","gridIx2Pos","nodeInfA","edgeInfA","getAffectedRegion","thresholdR","addItemInfluence","influenceFactor","startX","startY","endX","endY","tempX","tempY","distanceSq","dr","minDistanceSq","mdr","addEdgeInfluence","wrapNormal","topIntersect","leftIntersect","bottomIntersect","rightIntersect","cornerPos","topLeft","topRight","bottomLeft","bottomRight","totalArea","calcHalfArea","intersect1","intersect2","Hull","setPadding","setType","calcPath","render","nodeSize","bubbleCfg","parsePathString","addMember","updateData","addNonMember","removeMember","removeNonMember","updateStyle","contain","nodeItem","shapePoints","shapeBBox","AbstractGraph","animating","enabledStack","undoStack","redoStack","initCanvas","viewController","modeController","itemController","stateController","initLayoutController","initEventController","initGroups","initPlugins","nodeGroup","delegateGroup","renderer","plugins","fitViewPadding","minZoom","maxZoom","groupByTypes","vedges","itemMap","onFrame","tooltips","getGroup","getMinZoom","setMinZoom","getMaxZoom","setMaxZoom","getWidth","getHeight","nodeFn","comboFn","findAll","findAllByState","moveTo","addBehaviors","removeBehaviors","zoomTo","toRatio","getZoom","focusItem","isAnimate","curAniamteCfg","paint","getGraphCenterPoint","getViewPortCenterPoint","before","after","pushStack","setAutoPaint","auto","deletedModel","updateComboTree","newComboTrees","sortCombo","currentComboSorted","singleDataValidation","itemMap_1","foundParent_1","newCombo","parentCombo","itemMap_2","foundParent_2","foundNode_1","cloneNode","sortCombos","addedModel","UnupdateModel","afterModel","clearStack","layoutController","diffItems","changeData","save","removeHulls","localRefresh","combosData","comboItems","getLayoutType","positionsAnimate","createCombo","comboConfig","elementId","cItem","uncombo","comboItem","treeToBeUncombo","parentItem","childModel","updateCombos","uItem","itemSubTree_1","valid_1","subTree","beforeData","afterData","vedge","getComboChildren","toNodes","isAnimating","originAttrs","refreshPositions","updatedNodes","sourceModel","targetModel","getCurrentMode","avoidEmit","groups","updateLayout","alignPoint","toPoint_1","forceTypes","layoutType","bboxPoint","oriLayoutCfg","layoutCfg","isLayoutTypeSame","gpuEnabled","updateLayoutCfg","changeLayout","destroyLayout","workerEnabled","layoutMethod","relayout","cnodes","ccombos","found","edgeWeightMap","addedVEdges","isVEdge","edgeModel","sourceId","vedgeModel","vedgeId","collapseExpandCombo","parentModel","depthMap","dataDepthMap","cTree","edgeItem","sourceDepth","targetDepth","getNodeDegree","nodeDegrees","getUndoStack","getRedoStack","getStackData","stackType","stackData","currentAdjMatrix","getAdjacentMatrix","getShortestPathMatrix","currentShourtestPathMatrix","eventName","createHull","hullMap","getHulls","getHullById","hullId","removeHull","hullInstance","hulls","EventEmitter","ARROWS","SHAPE_DEFAULT_ATTRS","shadowOffsetX","shadowOffsetY","SHAPES_DEFAULT_ATTRS","startArrow","endArrow","shapeBase","getCustomConfig","getOptions","labelCfg","fontFamily","getComputedStyle","getPropertyValue","descriptionCfg","drawLabel","labelStyle","getLabelStyle","labelBBox","labelMatrix","rotateCenter","background","drawLabelBg","labelBgClassname","getLabelBgStyleByPosition","getLabelStyleByPosition","calculateStyle","attrName","defaultStyle","getShapeStyle","updateShapeStyle","updateLabel","shapeStyle","subShape","defaultLabelCfg","labelClassName","labelBg","currentLabelCfg","cfgStyle","cfgBgStyle","rotateMatrix","calculateBgStyle","labelBgStyle","bgRotateMatrix","shapeStateStyle","itemStateStyle","keptAttrs","enableStatesStyle","originStyle_1","keyShapeName_1","keyShapeStyles_1","filtetDisableStatesStyle","subShape_1","subShapeStyles_1","value_1","value_2","value_3","enableStyle","originstyles","keyShapeSetted","originKey","value_4","modelStateStyle","singleNode","labelPosition","getSize","backgroundStyle","backgroundWidth","backgroundHeight","updateLinkPoints","currentLinkPoints","defaultLinkPoints","markLeft","markRight","markTop","markBottom","markFill","markStroke","borderWidth","markSize","isAnchorPoint","hasIcon","updateIcon","icon","iconShape","iconConfig","labelShape","singleNodeDef","singleEdge","labelAutoRotate","getPath","getPathPoints","strokeStyle","currentAttr","previousStyle","routeCfg","radius","pointPercent","autoRotate","offsetX","offsetY","offsetStyle","_getTextAlign","bgOffsetX","revertAlign","defaultFontFamily","rotateAtStart","singleEdgeDef","arcPoint","midPoint","edgeAngle","curvePosition","minCurveOffset","yDist","xDist","singleCombo","singleComboDef","fixSize","itemCacheSize","leftDis","topDis","fixCollapseSize","img","clipCfg","drawClip","setClip","rectX","rectY","shapeClassName","G6Event","begin","vee","triangleRect","tWidth","tLength","rWidth","rLength","gap","rectBegin","collapse","expand","upTriangle","l1","l2","downTriangle","defaultSubjectColors","Util","BaseUtil","GraphicUtil","PathUtil","MathUtil","ColorUtil","LayoutController","layoutMethods","initLayout","getLayoutCfgType","pipes","pipe","every","refreshLayout","destoryLayoutMethods","setDataFromGraph","hiddenNodes","hiddenEdges","comboEdges","nodeItems","edgeItems","nodeLength","comboLength","hiddenCombos","reLayoutMethod","reslove","onLayoutEnd","ticking","forceSimulation","isCustomLayout","reloadData","initPositions","currentCfg","onAllLayoutEnd","catch","filterLayoutData","nodesFilter","edegsFilter","fNodes","edgesFilter","nodesMap_1","getLayoutBBox","graphGroupNodes","groupBy","layoutOrder","layoutNodes","groupNodes","layoutAnimate","moveToZero","meanCenter","horiNum","horiGap","vertiGap","isFinite","beginX","beginY","allHavePos","initEvents","BaseGlobal","darkColorMap","getHue","light","getSaturation","saturation","generate","patterns","pColor","_hsv","_colorString","theme","_ref","backgroundColor","presetPrimaryColors","volcano","geekblue","presetPalettes","presetDarkPalettes","primary","TABLE","mixColor","backColor","frontColor","frontAlpha","bc","fc","getColorsWithSubjectColor","subjectColor","disableColor","subjectColor005","subjectColor01","subjectColor02","subjectColor04","disableColor002","disableColor005","disableColor01","disableColor02","disableColor03","paletteFromSubject","subjectHex","subjectIdx","deeperSubject","mainStroke","mainFill","activeStroke","activeFill","inactiveStroke","inactiveFill","selectedStroke","selectedFill","highlightStroke","highlightFill","disableStroke","disableFill","edgeMainStroke","edgeActiveStroke","edgeInactiveStroke","edgeSelectedStroke","edgeHighlightStroke","edgeDisableStroke","comboMainStroke","comboMainFill","comboActiveStroke","comboActiveFill","comboInactiveStroke","comboInactiveFill","comboSelectedStroke","comboSelectedFill","comboHighlightStroke","comboHighlightFill","comboDisableStroke","comboDisableFill","getColorsWithDefaultTheme","subjectColor03","subjectColor06","subjectColor08","disableColor025","disableColor04","disableColor05","getColorsWithDarkTheme","getColorSetsBySubjectColors","subjectColors","sets","sColor","textWaterMarkerConfig","compatible","lineHeight","baseline","imageWaterMarkerConfig","waterMarkerImage","modifyCSS","extendEvents","dragging","canvasHandler","originHandler","wheelHandler","getItemRoot","onCanvasEvents","evt","eventType","handleMouseMove","itemShape","onExtendEvents","onWheelEvent","emitCustomEvent","AbstractEvent","xm","ym","xp","yp","_root","leaf","_x0","_y0","_x1","_y1","_x","_y","defaultX","defaultY","quadtree","Quadtree","addAll","leaf_copy","treeProto","cover","extent","x3","y3","quads","Quad","d2","retainer","removeAll","visitAfter","dispatch","Dispatch","parseTypenames","typenames","typename","that","initialAngle","simulation","alphaMin","alphaDecay","alphaTarget","velocityDecay","forces","stepper","tick","force","fx","fy","initializeNodes","initializeForce","initialize","randomSource","closest","strengths","strength","distanceMin2","distanceMax2","theta2","accumulate","quad","jiggle","_random","distanceMin","distanceMax","theta","nodeById","links","distances","initializeStrength","initializeDistance","radii","xi","yi","ri","ri2","prepare","rj","LAYOUT_MESSAGE","isAnyArray","_options$fromIndex","_options$toIndex","toIndex","isInteger","maxValue","minValue","rescale","currentMin","currentMax","RangeError","_options$min","autoMinMax","_options$max","factor","indent","repeat","indentData","inspectMatrixWithOptions","maxRows","maxColumns","maxNumSize","inspectData","rows","columns","maxI","maxJ","formatNumber","numStr","padEnd","precise","toPrecision","toExponential","eIndex","checkRowIndex","checkColumnIndex","checkRowVector","to1DArray","checkColumnVector","checkRowIndices","rowIndices","checkColumnIndices","columnIndices","checkRange","startRow","endRow","startColumn","endColumn","checkNumber","newArray","checkNonEmpty","varianceByRow","unbiased","mean","cols","variance","sum1","sum2","varianceByColumn","varianceAll","centerByRow","centerByColumn","centerAll","getScaleByRow","scaleByRow","getScaleByColumn","scaleByColumn","getScaleAll","divider","scaleAll","AbstractMatrix","to2DArray","isSquare","previousColumn","isEchelonForm","checked","isReducedEchelonForm","iMax","swapRows","echelonForm","maxRow","pivot","Matrix","setSubMatrix","mulS","rowVector","getRow","row1","row2","column","columnVector","getColumn","column1","column2","diag","vector2","isMatrix","vector1","checkMatrix","Bcolj","Float64Array","c00","c01","c10","c11","m16","m17","m18","c02","c12","c20","c21","c22","embed","resultat","zeros","blockMult","mmul","halfRows","halfCols","subMatrix","newMatrix","setRow","setColumn","middle","AxI","kroneckerProduct","IxB","compareFunction","compareNumbers","checkIndices","rowIndex","columnIndex","sumByRow","sumByColumn","sumAll","productByRow","productByColumn","productAll","newRows","newColumns","newData","matrix1","matrix2","klass","rand","randomInt","randInt","diagonal","neg","tensorProduct","nRows","nColumns","arrayData","addS","addM","subS","subM","subtractS","subtractM","mulM","multiplyS","multiplyM","divS","divM","divideS","divideM","modS","modM","modulus","modulusS","modulusM","and","andS","andM","or","orS","orM","xor","xorS","xorM","leftShift","leftShiftS","leftShiftM","signPropagatingRightShift","signPropagatingRightShiftS","signPropagatingRightShiftM","rightShift","rightShiftS","rightShiftM","zeroFillRightShift","zeroFillRightShiftS","zeroFillRightShiftM","not","acosh","asinh","atanh","cbrt","clz32","cosh","expm1","fround","log1p","log10","log2","sinh","tanh","trunc","powS","powM","WrapperMatrix2D","hypotenuse","SingularValueDecomposition","computeLeftSingularVectors","computeRightSingularVectors","autoTranspose","wantu","Boolean","wantv","swapped","aux","nu","ni","work","si","nct","nrt","mrc","pp","eps","kase","MIN_VALUE","sn","sp","spm1","epm1","sk","ek","scols","Ls","rightSingularVectors","VL","vrows","urows","VLU","solve","vcols","ucols","tol","createVec3","Landmark","forward","focalPoint","distanceVector","dollyingStep","azimuth","elevation","roll","relAzimuth","relElevation","relRoll","CAMERA_TYPE","CAMERA_TRACKING_MODE","CAMERA_PROJECTION_MODE","DEG_2_RAD","RAD_2_DEG","Camera","trackingMode","fullWidth","fullHeight","projectionMode","rright","scaleW","scaleH","rotX","rotateWorld","rotY","rotZ","rotQ","rotMatrix","coords","tx","ty","updatedDistance","landmark","landmarks","landmarkAnimationID","destPosition","destFocalPoint","destRoll","timestamp","timeStart","interRoll","interFocalPoint","interPosition","ORTHOGRAPHIC","PERSPECTIVE","createCanvas","Kernel","configService","engineOptions","swapChainFormat","WebGPUConstants","antialiasing","compiledBundle","isNumberLikeData","existedDefine","existedBinding","iteration","supportWebGPU","useWGSL","shader","shaders","valuePlaceHolder","uniform","sizePerElement","createComputeModel","meshComponent","parentRenderable","convertAttributeName2UniformName","ReglAttribute","normalized","primitiveMap","usageMap","dataTypeMap","formatMap","mipmapMap","filterMap","wrapModeMap","colorSpaceMap","depthFuncMap","blendEquationMap","blendFuncMap","stencilFuncMap","stencilOpMap","cullFaceMap","ReglBuffer","reGl","textureId","ReglComputeModel","texFBO","computeCommand","textureCache","outputTextureName","swapOutputTextureName","compiledPingpong","dynamicPingpong","isReferer","storageClass","isOutput","textureWidth","texelCount","drawParams","a_TexCoord","frag","primitive","getOuputDataTexture","texture","pixels","originalDataLength","elementsPerTexel","typedArrayConstructor","formattedPixels","inputName","inputModel","bufferName","calcDataTexture","paddingData","outputTextureUniformName","cloneDataTexture","paddingTexelCount","ReglElements","ReglFramebuffer","framebufferOptions","extractedUniforms","extractUniformsRecursively","uniformValue","ReglModel","drawCommand","instances","viewport","reglUniforms","reglAttributes","defineStmts","generateDefines","reglDrawProps","equation","srcRGB","srcAlpha","dstRGB","dstAlpha","cmp","ref","opFront","fail","zfail","zpass","KEEP","opBack","ReglTexture2D","flipY","mipmap","aniso","premultiplyAlpha","colorSpace","textureOptions","reglClearOptions","readPixelsOptions","regl","antialias","premultipliedAlpha","pixelRatio","extensions","optionalExtensions","profile","onDone","limits","loadScript","script","onSuccess","onError","loadScriptAsync","glslang","WebGPUAttribute","WebGPUBuffer","flags","verticesBufferDescriptor","device","destBuffer","destOffset","srcArrayBuffer","WebGPUComputeModel","uniformGPUBufferLayout","uniformBuffer","vertexBuffers","outputBuffer","bindGroupEntries","bindGroup","computePipeline","compileComputePipelineStageDescriptor","computeStage","buffers","bufferBindingIndex","mergedUniformData","originDataLength","space","CopyDst","gpuBuffer","CopySrc","refer","createComputePipeline","createBindGroup","getBindGroupLayout","byteCount","BYTES_PER_ELEMENT","gpuReadBuffer","GPUBufferUsage","MAP_READ","encoder","createCommandEncoder","defaultQueue","arraybuffer","inputBuffer","shaderVersion","compileRawShaderToSpirV","compileGLSL","computeCode","computeShader","compileShaderToSpirV","createShaderModule","code","isWHLSL","entryPoint","WebGPUElements","indexCount","Uint16Array","WebGPUFramebuffer","colorTexture","depthTexture","getCullMode","getDepthStencilStateDescriptor","stencilFrontBack","depthFailOp","failOp","passOp","Keep","depthWriteEnabled","depthCompare","stencilFront","stencilBack","stencilReadMask","stencilWriteMask","getColorStateDescriptors","alphaBlend","srcFactor","dstFactor","operation","colorBlend","writeMask","All","concatenate","resultConstructor","totalLength","WebGPUModel","pipelineLayout","renderPipeline","uniformsBindGroupLayout","uniformBindGroup","attributeCache","indexBuffer","compilePipelineStageDescriptor","vertexStage","fragmentStage","vertexState","ats","sampleCount","primitiveTopology","rasterizationState","cullMode","depthStencilState","colorStates","createRenderPipeline","bindGroupBindings","textureOrFramebuffer","sampler","vertexCode","fragmentCode","vertexShader","createPipelineStageDescriptor","frontFace","depthBias","depthBiasSlopeScale","depthBiasClamp","hasUniform","visibility","UniformBuffer","Sampler","SampledTexture","createBindGroupLayout","createPipelineLayout","bindGroupLayouts","WebGPUTexture2D","createTexture","mipLevelCount","dimension","createSampler","addressModeU","addressModeV","addressModeW","magFilter","minFilter","maxAnisotropy","arrayLayerCount","drawCommands","config","uploadEncoder","renderEncoder","computeEncoder","renderTargetEncoder","commandBuffers","currentRenderTarget","adapter","getContext","configureSwapChain","mainTextureDescriptor","OutputAttachment","attachment","mainTexture","loadValue","storeOp","Store","swapChain","getCurrentTexture","depthTextureDescriptor","depthLoadValue","depthStoreOp","stencilLoadValue","stencilStoreOp","currentRenderPass","beginRenderPass","colorAttachments","depthStencilAttachment","clearStencil","gpuTexture","colorTextureView","depthStencilTexture","depthStencilTextureView","clearColor","clearDepth","Box","widthSegments","heightSegments","depthSegments","hs","ds","hey","hez","corners","faceAxes","faceNormals","sides","normals","uvs","uvs1","vcounter","generateFace","temp3","side","Merged","geometries","mergedComponent","mergedAttributes","mergedIndices","indexOffset","lengthSegments","Sphere","latitudeBands","longitudeBands","lat","sinTheta","cosTheta","lon","phi","sinPhi","Basic","shaderModuleService","USE_UV","USE_MAP","uvTransform","Grid","materialSystem","createShaderMaterial","geometrySystem","createBufferGeometry","LESS","gridColor","gridSize","extrusions","addNext","_lastFlip","_started","_normal","attrPos","attrIndex","attrCounters","total","miterLen","bevel","getNormals","dashArray","dashOffset","dashRatio","thickness","attrNormal","attrMiter","norm","pointShapes","Point","u_device_pixel_ratio","devicePixelRatio","createInstancedBufferGeometry","featureIdx","instancedOffsets","instancedColors","instancedSizes","instancedShapes","instancedPickingColors","Renderer","systems","system","pendings","pending","Scene","renderable","TextureCache","Texture2D","View","rendererSystem","manager","kernel","precompiledBundle","interactor","engineClazz","world","displacements","proccessToFunc","defaultV","buildTextureData","dataArray","nodeDict","mapIdPos","maxEdgePerVetex","dests","dest","buildTextureDataWithOneEdgeAttr","buildTextureDataWithTwoEdgeAttr","attrs1","attrs2","attributesToTextureData","attributeNames","attributeNum","attributteStringMap","arrayToTextureData","valueArrays","itemNum","valueArray","radialLayout","rScale","radScale","avgRad","radDiff","radial","gpuDetector","CanvasRenderingContext2D","webgl","WebGLRenderingContext","workers","Worker","fileapi","File","FileReader","FileList","Blob","getWebGLErrorMessage","margin","addGetWebGLMessage","parameters","G6Util","LayoutUtil","GpuUtil","TreeLayout","layoutData","Hierarchy","oRegisterLayout","GridLayout","RandomLayout","ForceLayout","CircularLayout","DagreLayout","RadialLayout","ConcentricLayout","MDSLayout","FruchtermanLayout","FruchtermanGPULayout","GForceLayout","GForceGPULayout","ComboForceLayout","ForceAtlas2Layout","registerLayout","layoutOverride","WebWorker","workerScirptURL","blob","URL","createObjectURL","LayoutWorker","workerScriptURL","isLayoutMessage","layoutMethod_1","LayoutClass","getLayoutByName","executeWithWorker","handleLayoutMessage","mockRaf","cb","mockCaf","reqId","helper","webkitRequestAnimationFrame","requestId","webkitCancelAnimationFrame","GPU_LAYOUT_NAMES","LAYOUT_PIPES_ADJUST_NAMES","workerData","getWorker","stopWorker","requestId2","execLayoutMethod","onTick_1","onTick_2","isGPU","hasGPUVersion","onTick","Layout","enableTick","addLayoutOrder","updateLayoutMethod","success","enableGPU","layoutEndFormatted","adjustPipesBox","layoutWithWorker","currentTick","currentTickData","runWebworker","allData","offScreenCanvas","gpuWorkerAbility","filteredLayoutCfg","filterObject","offscreen","transferControlToOffscreen","handleWorkerMessage","eventData","updateLayoutPosition","totalTicks","vertexEdgeData","updateGPUWorkerLayoutPosition","preventOverlap","preNodes","ele","layoutName","AbstractLayout","_extendStatics","eventController","getElementById","clientWidth","clientHeight","GSVGCanvas","canvasCfg","GCanvas","initPlugin","downloadImageWatermark","watermarker","watermarkStr","watermarkbase64","backgroundImage","Image","onload","pat","createPattern","fillStyle","asyncToDataUrl","widths","heights","vCanvasEl","getRenderer","canvasDom","dataURL","svgDocType","svgDoc","svgData","imageData","compositeOperation","implementation","createDocumentType","createDocument","replaceChild","documentElement","XMLSerializer","serializeToString","encodeURIComponent","getImageData","globalCompositeOperation","fillRect","toDataURL","clearRect","putImageData","toFullDataURL","imageConfig","vContainerDOM","createDom","vHeight","vWidth","canvasOptions","quickHit","vCanvas","vGroup","downloadFullImage","wmWidth","wmHeight","fileName","dataURLToImage","createEvent","initEvent","dispatchEvent","downloadImage","mime","bstr","atob","u8arr","blobObj_1","msSaveBlob","download","href","addPlugin","removePlugin","destroyPlugin","setImageWaterMarker","imgURL","waterMarkerConfig","capture","display","crossOrigin","drawImage","setTextWaterMarker","texts","fillText","tooltipDOMs","parentElement","TreeGraph","layoutAnimating","getLayout","indexOfChild","former","innerAddChild","treeData","origin_1","childrenList","innerUpdateChild","innerRemoveChild","parentData","findDataById","updateChildren","updateChild","siblings","sourceAnchor","origin_2","ease","stopLayoutAnimate","isLayoutAnimating","PluginBase","cfgs","_cfgs","getDefaultCfgs","_events","bindEvents","GRID_PNG","follow","graphContainer","gridContainer","gridContainerWidth","gridContainerHeight","viewportchange","updateGrid","isFollow","Menu","handleMenuClick","getContent","onHide","itemTypes","trigger","click","contextmenu","menu","onMenuShow","preventDefault","onMenuHide","menuDom","outerHTML","removeMenuEventListener","handleMenuClickWrapper","getBoundingClientRect","graphTop","offsetTop","graphLeft","offsetLeft","triggeredByFirstClick","removeEventListener","MiniMap","handleUpdateCanvas","debounce","updateCanvas","viewportClassName","beforepaint","beforeanimate","afteranimate","disableRefresh","enableRefresh","disableOneRefresh","initViewport","containerDOM","isFireFox","dataTransfer","setDragImage","setData","updateViewport","totaldx","totaldy","graphWidth","graphHeight","updateGraphShapes","graphGroup","clonedGroup","updateVisible","isGroup","updateKeyShapes","updateOneEdgeKeyShape","updateOneNodeKeyShape","comboGroup_1","updateOneComboKeyShape","clearDestroyedShapes","mappedItem","cKeyShape","zIndex","updateDelegateShapes","updateOneNodeDelegateShape","comboGroup_2","initContainer","graphBBox","graphZoom","getCanvas","getViewport","getEucliDis","pointA","pointB","projectPointToEdge","Bundling","edgeBundles","edgePoints","lambda","divisions","divRate","cycles","iterRate","bundleThreshold","bundling","isTicking","nodeIdMap","divideEdges","getEdgeBundles","getEdgeForces","updateBundling","graph_1","divisionLength_1","getEdgeLength","currentDivisonLength_1","newEdgePoints_1","ep","oriDivisionLength","edgePoint","ei","iSource","iTarget","ej","jSource","jTarget","getBundleScore","getAngleScore","getScaleScore","getPositionScore","getVisibilityScore","getDotProduct","vij","getEdgeVisibility","vji","ps","pt","pMid","iMid","eidx","kp","edgePointForces","spring","getSpringForce","pre","electrostatic","getElectrostaticForce","pidx","edgeBundle","resForce","eb","getSimulation","lensDelegateStyle","Fisheye","showLabel","maxD","minD","scaleRBy","scaleDBy","showDPercent","mousemove","createDelegate","lensDelegate","magnify","scaleDByWheel","scaleRByWheel","originalEvent","mousePos","maxR","minR","scaleRByDrag","dragPrePos","newD","lensCenter","scaleDByDrag","restoreCache","cachedMagnifiedModels","cachedOriginPositions","molecularParam","mCenter","delegateCenterDiff","updateDelegate","dist2","magnifiedDist","shapes","shapeLength","cacheLength","ori","textLength","updateParams","dPercentText","nd","nr","textY","ToolBar","handleClick","zoomSensitivity","toolBar","toolBarDOM","composedPath","getEventPath","nodeName","handleDefaultOperator","bindUndoRedo","undoDom","undoDomIcon","redoDom","redoDomIcon","undoStackLen","redoStackLen","removeAttribute","currentData","data_1","redo","data_2","currentZoom","ratioOut","ratioIn","Tooltip","fixToNode","afterremoveitem","drag","tooltip","hideTooltip","onClick","showTooltip","onMouseEnter","onMouseMove","onMouseLeave","itemBBox","token","word","literal","shorten","sLen","monthUpdate","arrName","i18n","origObj","dayNames","monthNames","monthNamesShort","defaultI18n","dayNamesShort","amPm","DoFn","dayOfMonth","globalI18n","setGlobalDateI18n","regexEscape","pad","formatFlags","dateObj","getDate","DD","Do","getDay","dd","ddd","dddd","getMonth","MM","MMM","MMMM","YY","getFullYear","YYYY","getHours","hh","HH","getMinutes","mm","getSeconds","ss","getMilliseconds","SS","SSS","ZZ","getTimezoneOffset","monthParse","emptyDigits","emptyWord","timezoneOffset","minutes","parseFlags","cent","globalMasks","shortDate","mediumDate","longDate","fullDate","isoDate","isoDateTime","shortTime","mediumTime","longTime","setGlobalDateMasks","masks","getTime","literals","$0","$1","combinedI18nSettings","dateStr","dateInfo","year","month","day","hour","minute","millisecond","isPm","parseInfo","newFormat","specifiedFields","requiredFields","field","requiredField","matches","parser","dateWithoutTZ","validateFields","UTC","appendPercent","ticks","registerTickMethod","lastValue","tickInterval","getLinePath","pointsToPath","getSmoothLinePath","isEqual","pathUtil","dataToRectPath","barWidth","Linear","Category","rectPoints","rectPoint","getRectPoints","isClosed","firstPoint","getRectPath","linePathToAreaPath","areaPath","lineYPx","lineY","getAreaLineY","pointInfo","yMin","yMax","xMin","xMax","LINE_STYLE","AREA_STYLE","Trend","smooth","isArea","lineStyle","areaStyle","_h","intervalConfig","renderLine","trendGroup","dataToPath","destory","DEFAULT_STYLE","cursor","highLightFill","SIMPLE_DEFAULT_STYLE","Handler","handleType","renderHandle","setX","setXY","setY","updateXY","handleGroup","verticalLine","topCircle","bottomCircle","bindTrendEvents","bindSimpleEvents","Button","updateElement","renderMarker","initElement","buttonGroup","startMarkerGroup","startMarker","getStartMarkerPath","pauseMarkerGroup","pauseLeftMarker","pauseRightMarker","isPlay","sideLength","DEFAULT_PLAYBTN_STYLE","DEFAULT_PREBTN_STYLE","DEFAULT_NEXTBTN_STYLE","DEFAULT_SPEED_CONTROLLER_STYLE","pointer","scroller","DEFAULT_TIMETYPE_CONTROLLER_STYLE","check","DEFAULT_CONTROLLER_CONFIG","speed","loop","hideTimeTypeController","preBtnStyle","nextBtnStyle","playBtnStyle","speedControllerStyle","timeTypeControllerStyle","ControllerBtn","controllerCfg","controllerGroup","speedAxisY","currentSpeed","currentType","renderPlayButton","getNextMarkerPath","getPreMarkerPath","realY","playButton","prePaddingX","prePaddingY","preR","nxtPaddingX","nxtPaddingY","nxtR","renderSpeedBtn","renderToggleTime","bindEvent","currentBBox","speedGroup","speedNum","maxSpeed","axisY","speedText","speedPoint","getPointerPath","toggleGroup","isChecked","checkedIcon","checkedText","timePointControllerText","currentPointerY","pointerMatrix","currentYIdx","targetYIdx","yDiff","minDist_1","deltaY","timeRangeControllerText","BACKGROUND_STYLE","SIMPLE_BACKGROUND_STYLE","FOREGROUND_STYLE","HANDLER_STYLE","TEXT_STYLE","TICK_LABEL_STYLE","TICK_LINE_STYLE","TrendTimeBar","onMouseDown","currentHandler","stopPropagation","pageX","onMouseUp","offsetXRange","adjustOffsetRange","updateStartEnd","updateUI","trendCfg","foregroundStyle","handlerStyle","_j","textStyle","_k","_l","_m","minText","_o","maxText","_p","tickLabelStyle","tickLineStyle","tickLabelFormatter","timeBarType","renderSlider","setText","minTextShape","maxTextShape","trendComponent","sliderGroup","textGroup","silent","foregroundShape","handlerWidth","handlerHeight","minHandleGroup","minHandlerShape","maxHandleGroup","maxHandlerShape","tickData","tickPosList","textList","lastX","controllerBtnGroup","minHandleShapeGroup","maxHandleShapeGroup","PLAY_PAUSE_BTN","changePlayStatus","NEXT_STEP_BTN","PRE_STEP_BTN","adjustTickIndex","timeSelectX","offsetRange","minData","maxData","dodgeText","minAttrs","maxAttrs","minBBox","maxBBox","startPlay","playHandler","isSync","TimeBarTooltip","textColor","parentHeight","offsetHeight","parentWidth","offsetWidth","backgroundDOM","arrow","arrowDOM","arrowWidth","arrowHeight","DEFAULT_SELECTEDTICK_STYLE","DEFAULT_UNSELECTEDTICK_STYLE","TimeBarSlice","frameCount","selectedTickStyle","unselectedTickStyle","tooltipBackgroundColor","tooltipFomatter","sliceGroup","renderSlices","realWidth","ticksAreaHeight","ticksLength","tickWidth","tickRects","startTickId","endTickId","startTickRectId","endTickRectId","tickStyle","pickRect","rectBBox","lineStartY","labelStartY","textBBox","targetRect","tickRects_1","unselectedTickStyle_1","tickRect","clientPoint","previousEndTickRectId","TimeBar","trend","slider","filterEdge","timeBarContainer","timeBarGroup","renderTrend","defaultHeight","timebar","filterData","trendData","rangeChange","cacheGraphData","nodeIds_1","fileterEdges","ImageMiniMap","cWidth","cHeight","aspectRatio","graphCanvasBBox","graphCanvasBBoxMean","graphCanvasBBoxSize","expandedGraphCanvasBBox","graphMatrix","invertGraphMatrix","minXY","vpToMc","span","updateImgSize","imgDOM","naturalSize","nWidth","nHeight","naturalWidth","naturalHeight","image_1","getImgNaturalDimension","updateGraphImg","EdgeFilterLens","showNodeLabel","showEdgeLabel","hitNodesMap","fCenter","shouldShow","vShapes","hitEdges","vShape","alignLineStyle","SnapLine","itemAlignType","tolerance","horizontalLines","verticalLines","alignLines","onDragStart","initBoxLine","onDrag","onDragEnd","originPoint","itemAlign","lc","rc","horizontalDis","verticalDis","alignCfg","clearAlignLine","getLineDisObject","horizontals","verticals","addAlignLine","horizontal","refLine","refPoint","lineCenterX","lineAttrs","vertical","lineCenterY","lineAtts","ALLOW_EVENTS","Plugin","Minimap","ImageMinimap","Legend","flipPage","containerStyle","horiSep","vertiSep","formatArray","multiple","getContainerPos","posIdxMap","containerCSS","marginValue","clearFilter","clearActiveLegend","isCanvas","activateLegend","shapeGroup","findLegendItemsByState","subGroup","lengedStateStyles","legendInactive","legendTextInactive","legendActive","legendTextActive","itemGroup","filterFunctions","activeState","graphActiveState","inactiveState","graphInactiveState","activeNodeLegend","activeEdgeLegend","activeCount","typeFuncs","typeFunc","graphItem","processData","rootGroup","itemsData","getShapeSize","getStyle","oriAttrs","keyShapeBBox","attrs_1","titleShape","titleGroup","titleGroupBBox","defaultTitleStyle","titleConfig","layoutItems","lcBBox","nodeGroupBBox","nodeGroupBeginX","nodeGroupBeginY","nodeGroupMatrix","titleGroupMatrix","edgeGroupMatrix_1","edgeGroupMatrix_2","edgeGroupMatrix","edgeGroupBBox","beginPos","nodeLegendSize","rowMaxY","cNodeGroup","keyShapeWidth","keyShapeHeight","curHeight","nw","edgeLegendSize","ew","widthDiff","movement_1","defaultIcon","drawLinkPoints","markR","markStyle","defaultDirection","iconW","iconH","leftPos","diffY","rightPos","topPos","bottomPos","existLinkPoint","paddingTop","preRect","logoIcon","stateIcon","preRectShow","preRectStyle","drawLogoIcon","drawStateIcon","logoIconStyle","iconStyle","fontStyle","descriptionStyle","descriptionPaddingTop","description","logoIconShape","preRectShape","logoW","logoOffset","stateIconShape","stateW","stateOffset","stateIconStyle","leftBottom","outerR","defaultInnerR","innerR","markLeftBottom","markRightBottom","donutR","arcR","donutAttrs","donutColorMap","attrNum","totalValue_1","lineWidth_1","arcBegin_1","beginAngle_1","beginAgnle","arcBegin","arcEnd","isBig","getBBoxFromPoint","filterConnectPoints","pointsMap","simplifyPolyline","getExpandedBBox","getExpandedBBoxPoint","anotherPoint","isHorizontal","port","isHorizontalPort","mergeBBox","getPointsFromBBox","isPointOutsideBBox","heuristicCostEstimate","_costByPoints","reconstructPath","pathPoints","pointById","cameFrom","currentId","isSegmentsIntersected","v1x","v1y","v2x","v2y","v3x","v3y","v4x","v4y","isSegmentCrossingBBox","pb","pc","pd","getNeighborPoints","getPathWithBorderRadiusByPolyline","borderRadius","pathSegments","isBending","d1","getBorderRadiusPoints","getPolylinePoints","sNode","tNode","sBBox","tBBox","tKeyShapeBBox","sxBBox","txBBox","sPoint","tPoint","lineBBox","ys","getBBoxFromPoints","sMixBBox","tMixBBox","connectPoints","centerPoint","getBBoxXCrossPoints","getBBoxYCrossPoints","getBBoxCrossPointsByPoint","goal","ot","closedSet","openSet","gScore","fScore","lowestFScore","tentativeGScore","pathFinder","maxAllowedDirectionChange","maximumLoops","stepX","stepY","0","45","90","distFunc","fallbackRoute","endNode","getDirectionAngle","deltaX","getAngleDiff","angle1","angle2","directionChange","estimateCost","endPoints","cost","getBoxPoints","oriPoint","isInside","expandBBox","directions_1","bounds","boundLine","insterctP_1","insterctP","getDirectionChange","scaleStartPoint","directionAngle","prevDirectionAngle","scaleEndPoint","currentX","currentY","lastPoint","preId","preX","preY","routerCfg","obstacles","getObstacleMap","startPoints","firstStep","curCost","neighborCost","costFromStart","remainLoops","penalties","simple","pathArray_1","polylinePoints","enableOptimize","scalableRange","allowDragOnItem","dragstart","dragend","keyup","touchstart","touchmove","touchend","expandWidth","expandHeight","onTouchStart","touches","event1","event2","TOUCHSTART","button","buttons","targetIsCanvas","nodeLen","onTouchMove","zoomCanvas","optimizeZoom","children_2","endDrag","dragbegin","onKeyDown","onKeyUp","updateEdge","enableDelegate","onlyChangeComboSize","comboActiveState","selectedState","enableDebounce","enableStack","validationCombo","currentShouldEnd","cachedCaptureItems","targets","targetCombo","currentNodeId","beforeDragNodes","hidenEdge","debounceUpdate","delegateRect","stackData_1","onDropCombo","updatePositions","targetComboModel_1","onDropCanvas","onDropNode","newParentCombo","nodeModel","onDragEnter","onDragLeave","restore","updateFunc","calculationGroupPosition","resetSelected","setOnTouchStart","setAllItemStates","clearOnTouchStart","clearActiveState","vEdges","vEdgeLength","hasSelected","vEdge","rEdges","rEdgeLegnth","otherEnd","brushStyle","onSelect","onDeselect","includeEdges","selectedNodes","brush","createBrush","updateBrush","getSelectedNodes","selectedItems","select","selectedIds","triggerLowerCase","codeLowerCase","selectedCombos","onCanvasClick","sensitivity","fixSelectedItems","fixAll","fixLineWidth","fixLabel","fixState","wheel","pageY","moveable","originScale","currentScale","getDistance","onTouchEnd","onWheel","optimizeZoom_1","optimized","nodesLength_1","edgesLength_1","childrenLength","destoryed","edgeIndex","oriVis","fixNodes","fixEdges","fixNodesLength","originStyle","groupMatrix","itemStyle","itemFontSize","shapeFontSize","oriFontSize","oriLineWidth","fixEdgesLength","fe","createTooltip","formatText","onChange","onNodeClick","sourceData","currentCombo","currentItemChildCombos","traverseCombo","model_1","sourceBBox","centerX_1","centerY_1","width_1","cmodel","disX","disY","onDrop","endComparison","onNodeDrop","droppedCombo","getParentCombo","comboDropedOn","delegateShape","updateSignleItem","onComboClick","ALLOW_KEYS","DragCanvas","ZoomCanvas","DragNode","ActivateRelations","BrushSelect","ClickSelect","lasso","createLasso","onDragMove","updateLasso","getSelectedItems","getLassoPath","lassoContour","isItemIntersecPolygon","EdgeTooltip","CollapseExpand","DragCombo","CollapseExpandCombo","edgeConfig","getEdgeConfig","ev","cancelCreating","addingEdge","updateEndPoint","currentEdge","combinedKey","functionName","functionParams","triggerKeydown","combinedKeyLowerCase","zoomKey","keyDown","ctrlKey","movementX","movementY","Algorithm","AlgorithmSync","AlgorithmAsync","Arrow"],"mappings":"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,I,+CAAAA,I,+DAAAA,I,iDAAAA,I,2EAAAA,I,uEAAAA,I,yDAAAA,I,mEAAAA,I,iCAAAA,I,qCAAAA,I,iCAAAA,I,yCAAAA,I,2CAAAA,I,yCAAAA,I,6CAAAA,I,2DAAAA,I,yCAAAA,I,mBAAAA,I,iBAAAA,I,mBAAAA,I,qBAAAA,I,uBAAAA,I,yBAAAA,I,qBAAAA,I,qBAAAA,I,kBAAAA,I,wBAAAA,I,kBAAAA,I,kBAAAA,I,sBAAAA,I,6BAAAA,I,6BAAAA,I,sBAAAA,I,0BAAAA,I,wBAAAA,I,wBAAAA,I,sBAAAA,I,sDAAAA,I,oDAAAA,I,oDAAAA,I,kDAAAA,I,+CAAAA,I,+CAAAA,I,uCAAAA,I,uCAAAA,I,8BAAAA,I,wBAAAA,I,2CAAAA,I,2DAAAA,I,iEAAAA,I,iEAAAA,I,iEAAAA,I,iEAAAA,I,iEAAAA,I,iEAAAA,I,6DAAAA,I,2BAAAA,I,2BAAAA,I,2BAAAA,I,2BAAAA,I,2BAAAA,I,2BAAAA,I,2BAAAA,I,2BAAAA,I,2BAAAA,I,2BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,4BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,uCAAAA,I,uBAAAA,I,qCAAAA,I,yCAAAA,I,+BAAAA,I,+BAAAA,I,+BAAAA,I,2BAAAA,I,2BAAAA,I,2BAAAA,I,mBAAAA,I,6BAAAA,I,6BAAAA,I,6BAAAA,I,+BAAAA,I,+BAAAA,I,+BAAAA,I,+BAAAA,I,mCAAAA,I,iEAAAA,I,2DAAAA,I,+DAAAA,I,2DAAAA,I,uEAAAA,I,iEAAAA,I,+EAAAA,I,uCAAAA,I,6BAAAA,I,mCAAAA,I,+BAAAA,I,yBAAAA,I,+BAAAA,I,2BAAAA,I,iCAAAA,I,mCAAAA,I,qBAAAA,I,yBAAAA,I,uBAAAA,I,6CAAAA,I,oCAAAA,I,uCAAAA,I,qCAAAA,I,+CAAAA,I,iDAAAA,I,mEAAAA,I,qDAAAA,I,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,YAOA,kC,6BCNA,gBACA,eACA,wDACA,WAJA,IASA,kBAIA,OAHA,UACA,UACA,UACA,I,gBCbA,YAEA,QACA,KACA,KACA,KACA,IACA,KAEA,kBAMA,OAEAA,EAAA,wBACA,qBAGA,GAFA,eARA,YACA,uBAOA,IAEA,qBACA,6CAGA,YAEA,YACA,YAEA,OACA,oBACA,YAEA,YACA,YAEA,OACA,oBACA,uBAGA,aACA,SACA,UAGA,OACA,OACA,6CAEA,6BAEA,QACA,QACA,yBAEA,eACA,SACA,sBAGA,UACA,uBAMA,kBAOA,YANA,cAEA,GACA,8DAGA,I,gBC3EA,WAKA,GACA,kBACA,qBAEA,oBACA,kBAEA,oBACA,kBAEA,oBACA,eAdA,IAgBA,oBACA,eAjBA,IAmBA,wBACA,mBAEA,sBACA,iBAtBA,IAwBA,qBACA,mBACA,gBA3BA,GA2BA,qBAIA,gBACA,WAEA,GADA,gBACA,wBACA,SAeA,mBACA,eAgBA,OAfA,oBACA,oBACA,sBACA,wBACA,gBACA,iBACA,gBACA,UACA,UAEA,aACA,eAGA,cACA,EAGA8+B,EAAA,oBACA,kBACA,uBAEA,kBACA,iCAEA,qBACA,KACA,QADA,KAEA,QAFA,KAGA,WAHA,KAIA,aAEA,qBAMA,IAJA,IAEA,EADA,GADA,MAIA,aACA,KACA,wBAGA,uBAEA,kBAEA,uBAMA,IAJA,IAEA,EADA,GADA,MAIA,aACA,KACA,wBAGA,0BAEA,OACA,sBACA,qBACA,QACA,UAQA,OANA,2BACA,4BACA,0BACA,sCACA,4CAEA,GAGA,6BACA,QACA,UAGA,QACA,KAGA,2BACA,OACA,OACA,YACA,gBAGA,sBACA,IACA,EADA,KACA,iBADA,KAEA,sBACA,kCAHA,KAKA,sBAEA,sBACA,IACA,EADA,KACA,iBADA,KAEA,sBACA,kCAHA,KAKA,yBAqCA9+B,EAAA,QAjCA,qBACA,QACA,MAIA,IAEA,EAFA,UADA,oBAEA,MAGA,oBACA,kBACA,sBACA,4BACA,eAGA,GAFA,wBAEA,KACA,qBACA,oBACA,gBACA,UACA,WACA,mBAOA,W,6BClMA,mBAoBA,IAjBA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,oCAEA,kBAIA,I,6BCrBA,WAQA,oBAIA,IAHA,QACA,gCAEA,eACA,YAGA,oC,6BChBA,0BAUA,oBACA,QACA,gCAaA,OAZA,yBAEA,cACA,oBACA,gCAGA,QAEA,UAGA,I,6BCzBA,kBAEA,kCACA,kBACA,6BACA,SAGA,SAMA,OALA,2BACA,cACA,cAGA,I,6BCdA,oBACA,YACA,IACA,UAEA,iBACA,8BACA,OACA,eACA,eAGA,aACA,iBACA,yBACA,cAiBA,OAhBA,OACA,YAEA,WACA,IACA,gBACA,QAGA,IACA,eACA,eACA,qBACA,mBAGA,GASA,OANA,oBACA,gBACA,IACA,YAGA,I,6BCzCA,WACA,gBACA,yD,6BCFA,SACA,gBASA,OANA,EAFA,UAKA,QAFA,OAKA,S,6BCVA,kB,6BAAA,gBCCA,W,6BCDA,IAEA,YACA,sBACA,EAGA,eACA,SAGA,uBAXA,mB,6BCGA,MAEA,WACA,aACA,YA4BA,OAzBA,4BACA,6BAGA,8BACA,kBACA,uBAGA,8BACA,eAGA,6BACA,aAGA,sCACA,aAGA,4BACA,qCAGA,EA9BA,GAiCA,O,cCrCA,yBACA,QACA,MAGA,WAEA,SACA,SAEA,SACA,MAEA,UACA,cAEA,WACA,QACA,UACA,WAEA,UACA,UAEA,UACA,UAEA,SACA,SAkCA,gBACA,MATA,gBACA,gBAIA,OAHA,gCACA,wBAEA,EAIA,OArBA,kBACA,EACA,OAEA,OAGA,gCACA,YAcA,SAjCA24B,EAAA,uBACA,kBACA,SAIA,OAHA,gCACA,2BAEA,gCACA,+BA+DA/+B,EAAA,2BACA,QACA,MAGA,qBAsBA,cACA,UACA,OACA,OACA,kBAEA,eACA,mBACA,oBACA,yBAIA,kBAMA,IALA,eACA,QACA,SACA,QAEA,qBACA,sBACA,kCAEA,MACA,KACA,kBAGA,WACA,OAEA,MAEA,QADA,UACA,UAGA,MAEA,QADA,UACA,WAIA,KA0BA,kBACA,gBACA,OACA,0BACA,SACA,YACA,oBACA,wBAhCA,UACA,OAkCA,kBACA,gBACA,OACA,0BACA,SACA,YACA,sBACA,0BAxCA,UAIA,oBACA,cACA,e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","file":"g6.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"G6\"] = factory();\n\telse\n\t\troot[\"G6\"] = factory();\n})(this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 547);\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n","import * as glMatrix from \"./common.js\";\n/**\r\n * 3x3 Matrix\r\n * @module mat3\r\n */\n\n/**\r\n * Creates a new identity mat3\r\n *\r\n * @returns {mat3} a new 3x3 matrix\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(9);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n }\n\n out[0] = 1;\n out[4] = 1;\n out[8] = 1;\n return out;\n}\n/**\r\n * Copies the upper-left 3x3 values into the given mat3.\r\n *\r\n * @param {mat3} out the receiving 3x3 matrix\r\n * @param {ReadonlyMat4} a the source 4x4 matrix\r\n * @returns {mat3} out\r\n */\n\nexport function fromMat4(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[4];\n out[4] = a[5];\n out[5] = a[6];\n out[6] = a[8];\n out[7] = a[9];\n out[8] = a[10];\n return out;\n}\n/**\r\n * Creates a new mat3 initialized with values from an existing matrix\r\n *\r\n * @param {ReadonlyMat3} a matrix to clone\r\n * @returns {mat3} a new 3x3 matrix\r\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(9);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\r\n * Copy the values from one mat3 to another\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {mat3} out\r\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\r\n * Create a new mat3 with the given values\r\n *\r\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\r\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\r\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\r\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\r\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\r\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\r\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\r\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\r\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\r\n * @returns {mat3} A new mat3\r\n */\n\nexport function fromValues(m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n var out = new glMatrix.ARRAY_TYPE(9);\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\r\n * Set the components of a mat3 to the given values\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\r\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\r\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\r\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\r\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\r\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\r\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\r\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\r\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\r\n * @returns {mat3} out\r\n */\n\nexport function set(out, m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\r\n * Set a mat3 to the identity matrix\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @returns {mat3} out\r\n */\n\nexport function identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\r\n * Transpose the values of a mat3\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {mat3} out\r\n */\n\nexport function transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1],\n a02 = a[2],\n a12 = a[5];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a01;\n out[5] = a[7];\n out[6] = a02;\n out[7] = a12;\n } else {\n out[0] = a[0];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a[1];\n out[4] = a[4];\n out[5] = a[7];\n out[6] = a[2];\n out[7] = a[5];\n out[8] = a[8];\n }\n\n return out;\n}\n/**\r\n * Inverts a mat3\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {mat3} out\r\n */\n\nexport function invert(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n var b01 = a22 * a11 - a12 * a21;\n var b11 = -a22 * a10 + a12 * a20;\n var b21 = a21 * a10 - a11 * a20; // Calculate the determinant\n\n var det = a00 * b01 + a01 * b11 + a02 * b21;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = b01 * det;\n out[1] = (-a22 * a01 + a02 * a21) * det;\n out[2] = (a12 * a01 - a02 * a11) * det;\n out[3] = b11 * det;\n out[4] = (a22 * a00 - a02 * a20) * det;\n out[5] = (-a12 * a00 + a02 * a10) * det;\n out[6] = b21 * det;\n out[7] = (-a21 * a00 + a01 * a20) * det;\n out[8] = (a11 * a00 - a01 * a10) * det;\n return out;\n}\n/**\r\n * Calculates the adjugate of a mat3\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {mat3} out\r\n */\n\nexport function adjoint(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n out[0] = a11 * a22 - a12 * a21;\n out[1] = a02 * a21 - a01 * a22;\n out[2] = a01 * a12 - a02 * a11;\n out[3] = a12 * a20 - a10 * a22;\n out[4] = a00 * a22 - a02 * a20;\n out[5] = a02 * a10 - a00 * a12;\n out[6] = a10 * a21 - a11 * a20;\n out[7] = a01 * a20 - a00 * a21;\n out[8] = a00 * a11 - a01 * a10;\n return out;\n}\n/**\r\n * Calculates the determinant of a mat3\r\n *\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {Number} determinant of a\r\n */\n\nexport function determinant(a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20);\n}\n/**\r\n * Multiplies two mat3's\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the first operand\r\n * @param {ReadonlyMat3} b the second operand\r\n * @returns {mat3} out\r\n */\n\nexport function multiply(out, a, b) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n var b00 = b[0],\n b01 = b[1],\n b02 = b[2];\n var b10 = b[3],\n b11 = b[4],\n b12 = b[5];\n var b20 = b[6],\n b21 = b[7],\n b22 = b[8];\n out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n return out;\n}\n/**\r\n * Translate a mat3 by the given vector\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the matrix to translate\r\n * @param {ReadonlyVec2} v vector to translate by\r\n * @returns {mat3} out\r\n */\n\nexport function translate(out, a, v) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a10 = a[3],\n a11 = a[4],\n a12 = a[5],\n a20 = a[6],\n a21 = a[7],\n a22 = a[8],\n x = v[0],\n y = v[1];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a10;\n out[4] = a11;\n out[5] = a12;\n out[6] = x * a00 + y * a10 + a20;\n out[7] = x * a01 + y * a11 + a21;\n out[8] = x * a02 + y * a12 + a22;\n return out;\n}\n/**\r\n * Rotates a mat3 by the given angle\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat3} out\r\n */\n\nexport function rotate(out, a, rad) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a10 = a[3],\n a11 = a[4],\n a12 = a[5],\n a20 = a[6],\n a21 = a[7],\n a22 = a[8],\n s = Math.sin(rad),\n c = Math.cos(rad);\n out[0] = c * a00 + s * a10;\n out[1] = c * a01 + s * a11;\n out[2] = c * a02 + s * a12;\n out[3] = c * a10 - s * a00;\n out[4] = c * a11 - s * a01;\n out[5] = c * a12 - s * a02;\n out[6] = a20;\n out[7] = a21;\n out[8] = a22;\n return out;\n}\n/**\r\n * Scales the mat3 by the dimensions in the given vec2\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the matrix to rotate\r\n * @param {ReadonlyVec2} v the vec2 to scale the matrix by\r\n * @returns {mat3} out\r\n **/\n\nexport function scale(out, a, v) {\n var x = v[0],\n y = v[1];\n out[0] = x * a[0];\n out[1] = x * a[1];\n out[2] = x * a[2];\n out[3] = y * a[3];\n out[4] = y * a[4];\n out[5] = y * a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\r\n * Creates a matrix from a vector translation\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat3.identity(dest);\r\n * mat3.translate(dest, dest, vec);\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {ReadonlyVec2} v Translation vector\r\n * @returns {mat3} out\r\n */\n\nexport function fromTranslation(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = v[0];\n out[7] = v[1];\n out[8] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a given angle\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat3.identity(dest);\r\n * mat3.rotate(dest, dest, rad);\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat3} out\r\n */\n\nexport function fromRotation(out, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad);\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = -s;\n out[4] = c;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a vector scaling\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat3.identity(dest);\r\n * mat3.scale(dest, dest, vec);\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {ReadonlyVec2} v Scaling vector\r\n * @returns {mat3} out\r\n */\n\nexport function fromScaling(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = v[1];\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\r\n * Copies the values from a mat2d into a mat3\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat2d} a the matrix to copy\r\n * @returns {mat3} out\r\n **/\n\nexport function fromMat2d(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = 0;\n out[3] = a[2];\n out[4] = a[3];\n out[5] = 0;\n out[6] = a[4];\n out[7] = a[5];\n out[8] = 1;\n return out;\n}\n/**\r\n * Calculates a 3x3 matrix from the given quaternion\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {ReadonlyQuat} q Quaternion to create matrix from\r\n *\r\n * @returns {mat3} out\r\n */\n\nexport function fromQuat(out, q) {\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var yx = y * x2;\n var yy = y * y2;\n var zx = z * x2;\n var zy = z * y2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - yy - zz;\n out[3] = yx - wz;\n out[6] = zx + wy;\n out[1] = yx + wz;\n out[4] = 1 - xx - zz;\n out[7] = zy - wx;\n out[2] = zx - wy;\n out[5] = zy + wx;\n out[8] = 1 - xx - yy;\n return out;\n}\n/**\r\n * Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {ReadonlyMat4} a Mat4 to derive the normal matrix from\r\n *\r\n * @returns {mat3} out\r\n */\n\nexport function normalFromMat4(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n return out;\n}\n/**\r\n * Generates a 2D projection matrix with the given bounds\r\n *\r\n * @param {mat3} out mat3 frustum matrix will be written into\r\n * @param {number} width Width of your gl context\r\n * @param {number} height Height of gl context\r\n * @returns {mat3} out\r\n */\n\nexport function projection(out, width, height) {\n out[0] = 2 / width;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = -2 / height;\n out[5] = 0;\n out[6] = -1;\n out[7] = 1;\n out[8] = 1;\n return out;\n}\n/**\r\n * Returns a string representation of a mat3\r\n *\r\n * @param {ReadonlyMat3} a matrix to represent as a string\r\n * @returns {String} string representation of the matrix\r\n */\n\nexport function str(a) {\n return \"mat3(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \", \" + a[6] + \", \" + a[7] + \", \" + a[8] + \")\";\n}\n/**\r\n * Returns Frobenius norm of a mat3\r\n *\r\n * @param {ReadonlyMat3} a the matrix to calculate Frobenius norm of\r\n * @returns {Number} Frobenius norm\r\n */\n\nexport function frob(a) {\n return Math.hypot(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8]);\n}\n/**\r\n * Adds two mat3's\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the first operand\r\n * @param {ReadonlyMat3} b the second operand\r\n * @returns {mat3} out\r\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n out[8] = a[8] + b[8];\n return out;\n}\n/**\r\n * Subtracts matrix b from matrix a\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the first operand\r\n * @param {ReadonlyMat3} b the second operand\r\n * @returns {mat3} out\r\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n out[6] = a[6] - b[6];\n out[7] = a[7] - b[7];\n out[8] = a[8] - b[8];\n return out;\n}\n/**\r\n * Multiply each element of the matrix by a scalar.\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the matrix to scale\r\n * @param {Number} b amount to scale the matrix's elements by\r\n * @returns {mat3} out\r\n */\n\nexport function multiplyScalar(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n out[8] = a[8] * b;\n return out;\n}\n/**\r\n * Adds two mat3's after multiplying each element of the second operand by a scalar value.\r\n *\r\n * @param {mat3} out the receiving vector\r\n * @param {ReadonlyMat3} a the first operand\r\n * @param {ReadonlyMat3} b the second operand\r\n * @param {Number} scale the amount to scale b's elements by before adding\r\n * @returns {mat3} out\r\n */\n\nexport function multiplyScalarAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n out[6] = a[6] + b[6] * scale;\n out[7] = a[7] + b[7] * scale;\n out[8] = a[8] + b[8] * scale;\n return out;\n}\n/**\r\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyMat3} a The first matrix.\r\n * @param {ReadonlyMat3} b The second matrix.\r\n * @returns {Boolean} True if the matrices are equal, false otherwise.\r\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5] && a[6] === b[6] && a[7] === b[7] && a[8] === b[8];\n}\n/**\r\n * Returns whether or not the matrices have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyMat3} a The first matrix.\r\n * @param {ReadonlyMat3} b The second matrix.\r\n * @returns {Boolean} True if the matrices are equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5],\n a6 = a[6],\n a7 = a[7],\n a8 = a[8];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) && Math.abs(a6 - b6) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) && Math.abs(a7 - b7) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7)) && Math.abs(a8 - b8) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a8), Math.abs(b8));\n}\n/**\r\n * Alias for {@link mat3.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Alias for {@link mat3.subtract}\r\n * @function\r\n */\n\nexport var sub = subtract;","import * as glMatrix from \"./common.js\";\n/**\r\n * 4x4 Matrix<br>Format: column-major, when typed out it looks like row-major<br>The matrices are being post multiplied.\r\n * @module mat4\r\n */\n\n/**\r\n * Creates a new identity mat4\r\n *\r\n * @returns {mat4} a new 4x4 matrix\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(16);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n }\n\n out[0] = 1;\n out[5] = 1;\n out[10] = 1;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a new mat4 initialized with values from an existing matrix\r\n *\r\n * @param {ReadonlyMat4} a matrix to clone\r\n * @returns {mat4} a new 4x4 matrix\r\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(16);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\r\n * Copy the values from one mat4 to another\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {mat4} out\r\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\r\n * Create a new mat4 with the given values\r\n *\r\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\r\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\r\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\r\n * @param {Number} m03 Component in column 0, row 3 position (index 3)\r\n * @param {Number} m10 Component in column 1, row 0 position (index 4)\r\n * @param {Number} m11 Component in column 1, row 1 position (index 5)\r\n * @param {Number} m12 Component in column 1, row 2 position (index 6)\r\n * @param {Number} m13 Component in column 1, row 3 position (index 7)\r\n * @param {Number} m20 Component in column 2, row 0 position (index 8)\r\n * @param {Number} m21 Component in column 2, row 1 position (index 9)\r\n * @param {Number} m22 Component in column 2, row 2 position (index 10)\r\n * @param {Number} m23 Component in column 2, row 3 position (index 11)\r\n * @param {Number} m30 Component in column 3, row 0 position (index 12)\r\n * @param {Number} m31 Component in column 3, row 1 position (index 13)\r\n * @param {Number} m32 Component in column 3, row 2 position (index 14)\r\n * @param {Number} m33 Component in column 3, row 3 position (index 15)\r\n * @returns {mat4} A new mat4\r\n */\n\nexport function fromValues(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n var out = new glMatrix.ARRAY_TYPE(16);\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m03;\n out[4] = m10;\n out[5] = m11;\n out[6] = m12;\n out[7] = m13;\n out[8] = m20;\n out[9] = m21;\n out[10] = m22;\n out[11] = m23;\n out[12] = m30;\n out[13] = m31;\n out[14] = m32;\n out[15] = m33;\n return out;\n}\n/**\r\n * Set the components of a mat4 to the given values\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\r\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\r\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\r\n * @param {Number} m03 Component in column 0, row 3 position (index 3)\r\n * @param {Number} m10 Component in column 1, row 0 position (index 4)\r\n * @param {Number} m11 Component in column 1, row 1 position (index 5)\r\n * @param {Number} m12 Component in column 1, row 2 position (index 6)\r\n * @param {Number} m13 Component in column 1, row 3 position (index 7)\r\n * @param {Number} m20 Component in column 2, row 0 position (index 8)\r\n * @param {Number} m21 Component in column 2, row 1 position (index 9)\r\n * @param {Number} m22 Component in column 2, row 2 position (index 10)\r\n * @param {Number} m23 Component in column 2, row 3 position (index 11)\r\n * @param {Number} m30 Component in column 3, row 0 position (index 12)\r\n * @param {Number} m31 Component in column 3, row 1 position (index 13)\r\n * @param {Number} m32 Component in column 3, row 2 position (index 14)\r\n * @param {Number} m33 Component in column 3, row 3 position (index 15)\r\n * @returns {mat4} out\r\n */\n\nexport function set(out, m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m03;\n out[4] = m10;\n out[5] = m11;\n out[6] = m12;\n out[7] = m13;\n out[8] = m20;\n out[9] = m21;\n out[10] = m22;\n out[11] = m23;\n out[12] = m30;\n out[13] = m31;\n out[14] = m32;\n out[15] = m33;\n return out;\n}\n/**\r\n * Set a mat4 to the identity matrix\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @returns {mat4} out\r\n */\n\nexport function identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Transpose the values of a mat4\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {mat4} out\r\n */\n\nexport function transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a12 = a[6],\n a13 = a[7];\n var a23 = a[11];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a01;\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a02;\n out[9] = a12;\n out[11] = a[14];\n out[12] = a03;\n out[13] = a13;\n out[14] = a23;\n } else {\n out[0] = a[0];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a[1];\n out[5] = a[5];\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a[2];\n out[9] = a[6];\n out[10] = a[10];\n out[11] = a[14];\n out[12] = a[3];\n out[13] = a[7];\n out[14] = a[11];\n out[15] = a[15];\n }\n\n return out;\n}\n/**\r\n * Inverts a mat4\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {mat4} out\r\n */\n\nexport function invert(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n return out;\n}\n/**\r\n * Calculates the adjugate of a mat4\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {mat4} out\r\n */\n\nexport function adjoint(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n out[0] = a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22);\n out[1] = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n out[2] = a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12);\n out[3] = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n out[4] = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n out[5] = a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22);\n out[6] = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n out[7] = a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12);\n out[8] = a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21);\n out[9] = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n out[10] = a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11);\n out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n out[13] = a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21);\n out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n out[15] = a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11);\n return out;\n}\n/**\r\n * Calculates the determinant of a mat4\r\n *\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {Number} determinant of a\r\n */\n\nexport function determinant(a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n}\n/**\r\n * Multiplies two mat4s\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the first operand\r\n * @param {ReadonlyMat4} b the second operand\r\n * @returns {mat4} out\r\n */\n\nexport function multiply(out, a, b) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15]; // Cache only the current line of the second matrix\n\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n out[0] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[1] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[2] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[3] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[4];\n b1 = b[5];\n b2 = b[6];\n b3 = b[7];\n out[4] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[5] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[6] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[7] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[8];\n b1 = b[9];\n b2 = b[10];\n b3 = b[11];\n out[8] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[9] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[10] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[11] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[12];\n b1 = b[13];\n b2 = b[14];\n b3 = b[15];\n out[12] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[13] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[14] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[15] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n return out;\n}\n/**\r\n * Translate a mat4 by the given vector\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to translate\r\n * @param {ReadonlyVec3} v vector to translate by\r\n * @returns {mat4} out\r\n */\n\nexport function translate(out, a, v) {\n var x = v[0],\n y = v[1],\n z = v[2];\n var a00, a01, a02, a03;\n var a10, a11, a12, a13;\n var a20, a21, a22, a23;\n\n if (a === out) {\n out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n } else {\n a00 = a[0];\n a01 = a[1];\n a02 = a[2];\n a03 = a[3];\n a10 = a[4];\n a11 = a[5];\n a12 = a[6];\n a13 = a[7];\n a20 = a[8];\n a21 = a[9];\n a22 = a[10];\n a23 = a[11];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a03;\n out[4] = a10;\n out[5] = a11;\n out[6] = a12;\n out[7] = a13;\n out[8] = a20;\n out[9] = a21;\n out[10] = a22;\n out[11] = a23;\n out[12] = a00 * x + a10 * y + a20 * z + a[12];\n out[13] = a01 * x + a11 * y + a21 * z + a[13];\n out[14] = a02 * x + a12 * y + a22 * z + a[14];\n out[15] = a03 * x + a13 * y + a23 * z + a[15];\n }\n\n return out;\n}\n/**\r\n * Scales the mat4 by the dimensions in the given vec3 not using vectorization\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to scale\r\n * @param {ReadonlyVec3} v the vec3 to scale the matrix by\r\n * @returns {mat4} out\r\n **/\n\nexport function scale(out, a, v) {\n var x = v[0],\n y = v[1],\n z = v[2];\n out[0] = a[0] * x;\n out[1] = a[1] * x;\n out[2] = a[2] * x;\n out[3] = a[3] * x;\n out[4] = a[4] * y;\n out[5] = a[5] * y;\n out[6] = a[6] * y;\n out[7] = a[7] * y;\n out[8] = a[8] * z;\n out[9] = a[9] * z;\n out[10] = a[10] * z;\n out[11] = a[11] * z;\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\r\n * Rotates a mat4 by the given angle around the given axis\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @param {ReadonlyVec3} axis the axis to rotate around\r\n * @returns {mat4} out\r\n */\n\nexport function rotate(out, a, rad, axis) {\n var x = axis[0],\n y = axis[1],\n z = axis[2];\n var len = Math.hypot(x, y, z);\n var s, c, t;\n var a00, a01, a02, a03;\n var a10, a11, a12, a13;\n var a20, a21, a22, a23;\n var b00, b01, b02;\n var b10, b11, b12;\n var b20, b21, b22;\n\n if (len < glMatrix.EPSILON) {\n return null;\n }\n\n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c;\n a00 = a[0];\n a01 = a[1];\n a02 = a[2];\n a03 = a[3];\n a10 = a[4];\n a11 = a[5];\n a12 = a[6];\n a13 = a[7];\n a20 = a[8];\n a21 = a[9];\n a22 = a[10];\n a23 = a[11]; // Construct the elements of the rotation matrix\n\n b00 = x * x * t + c;\n b01 = y * x * t + z * s;\n b02 = z * x * t - y * s;\n b10 = x * y * t - z * s;\n b11 = y * y * t + c;\n b12 = z * y * t + x * s;\n b20 = x * z * t + y * s;\n b21 = y * z * t - x * s;\n b22 = z * z * t + c; // Perform rotation-specific matrix multiplication\n\n out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged last row\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n return out;\n}\n/**\r\n * Rotates a matrix by the given angle around the X axis\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function rotateX(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n var a20 = a[8];\n var a21 = a[9];\n var a22 = a[10];\n var a23 = a[11];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged rows\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[4] = a10 * c + a20 * s;\n out[5] = a11 * c + a21 * s;\n out[6] = a12 * c + a22 * s;\n out[7] = a13 * c + a23 * s;\n out[8] = a20 * c - a10 * s;\n out[9] = a21 * c - a11 * s;\n out[10] = a22 * c - a12 * s;\n out[11] = a23 * c - a13 * s;\n return out;\n}\n/**\r\n * Rotates a matrix by the given angle around the Y axis\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function rotateY(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a03 = a[3];\n var a20 = a[8];\n var a21 = a[9];\n var a22 = a[10];\n var a23 = a[11];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged rows\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[0] = a00 * c - a20 * s;\n out[1] = a01 * c - a21 * s;\n out[2] = a02 * c - a22 * s;\n out[3] = a03 * c - a23 * s;\n out[8] = a00 * s + a20 * c;\n out[9] = a01 * s + a21 * c;\n out[10] = a02 * s + a22 * c;\n out[11] = a03 * s + a23 * c;\n return out;\n}\n/**\r\n * Rotates a matrix by the given angle around the Z axis\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function rotateZ(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a03 = a[3];\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged last row\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[0] = a00 * c + a10 * s;\n out[1] = a01 * c + a11 * s;\n out[2] = a02 * c + a12 * s;\n out[3] = a03 * c + a13 * s;\n out[4] = a10 * c - a00 * s;\n out[5] = a11 * c - a01 * s;\n out[6] = a12 * c - a02 * s;\n out[7] = a13 * c - a03 * s;\n return out;\n}\n/**\r\n * Creates a matrix from a vector translation\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.translate(dest, dest, vec);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {ReadonlyVec3} v Translation vector\r\n * @returns {mat4} out\r\n */\n\nexport function fromTranslation(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a vector scaling\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.scale(dest, dest, vec);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {ReadonlyVec3} v Scaling vector\r\n * @returns {mat4} out\r\n */\n\nexport function fromScaling(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = v[1];\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = v[2];\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a given angle around a given axis\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.rotate(dest, dest, rad, axis);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @param {ReadonlyVec3} axis the axis to rotate around\r\n * @returns {mat4} out\r\n */\n\nexport function fromRotation(out, rad, axis) {\n var x = axis[0],\n y = axis[1],\n z = axis[2];\n var len = Math.hypot(x, y, z);\n var s, c, t;\n\n if (len < glMatrix.EPSILON) {\n return null;\n }\n\n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c; // Perform rotation-specific matrix multiplication\n\n out[0] = x * x * t + c;\n out[1] = y * x * t + z * s;\n out[2] = z * x * t - y * s;\n out[3] = 0;\n out[4] = x * y * t - z * s;\n out[5] = y * y * t + c;\n out[6] = z * y * t + x * s;\n out[7] = 0;\n out[8] = x * z * t + y * s;\n out[9] = y * z * t - x * s;\n out[10] = z * z * t + c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from the given angle around the X axis\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.rotateX(dest, dest, rad);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function fromXRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = c;\n out[6] = s;\n out[7] = 0;\n out[8] = 0;\n out[9] = -s;\n out[10] = c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from the given angle around the Y axis\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.rotateY(dest, dest, rad);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function fromYRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = c;\n out[1] = 0;\n out[2] = -s;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = s;\n out[9] = 0;\n out[10] = c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from the given angle around the Z axis\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.rotateZ(dest, dest, rad);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function fromZRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = 0;\n out[4] = -s;\n out[5] = c;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a quaternion rotation and vector translation\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.translate(dest, vec);\r\n * let quatMat = mat4.create();\r\n * quat4.toMat4(quat, quatMat);\r\n * mat4.multiply(dest, quatMat);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {quat4} q Rotation quaternion\r\n * @param {ReadonlyVec3} v Translation vector\r\n * @returns {mat4} out\r\n */\n\nexport function fromRotationTranslation(out, q, v) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - (yy + zz);\n out[1] = xy + wz;\n out[2] = xz - wy;\n out[3] = 0;\n out[4] = xy - wz;\n out[5] = 1 - (xx + zz);\n out[6] = yz + wx;\n out[7] = 0;\n out[8] = xz + wy;\n out[9] = yz - wx;\n out[10] = 1 - (xx + yy);\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a new mat4 from a dual quat.\r\n *\r\n * @param {mat4} out Matrix\r\n * @param {ReadonlyQuat2} a Dual Quaternion\r\n * @returns {mat4} mat4 receiving operation result\r\n */\n\nexport function fromQuat2(out, a) {\n var translation = new glMatrix.ARRAY_TYPE(3);\n var bx = -a[0],\n by = -a[1],\n bz = -a[2],\n bw = a[3],\n ax = a[4],\n ay = a[5],\n az = a[6],\n aw = a[7];\n var magnitude = bx * bx + by * by + bz * bz + bw * bw; //Only scale if it makes sense\n\n if (magnitude > 0) {\n translation[0] = (ax * bw + aw * bx + ay * bz - az * by) * 2 / magnitude;\n translation[1] = (ay * bw + aw * by + az * bx - ax * bz) * 2 / magnitude;\n translation[2] = (az * bw + aw * bz + ax * by - ay * bx) * 2 / magnitude;\n } else {\n translation[0] = (ax * bw + aw * bx + ay * bz - az * by) * 2;\n translation[1] = (ay * bw + aw * by + az * bx - ax * bz) * 2;\n translation[2] = (az * bw + aw * bz + ax * by - ay * bx) * 2;\n }\n\n fromRotationTranslation(out, a, translation);\n return out;\n}\n/**\r\n * Returns the translation vector component of a transformation\r\n * matrix. If a matrix is built with fromRotationTranslation,\r\n * the returned vector will be the same as the translation vector\r\n * originally supplied.\r\n * @param {vec3} out Vector to receive translation component\r\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\r\n * @return {vec3} out\r\n */\n\nexport function getTranslation(out, mat) {\n out[0] = mat[12];\n out[1] = mat[13];\n out[2] = mat[14];\n return out;\n}\n/**\r\n * Returns the scaling factor component of a transformation\r\n * matrix. If a matrix is built with fromRotationTranslationScale\r\n * with a normalized Quaternion paramter, the returned vector will be\r\n * the same as the scaling vector\r\n * originally supplied.\r\n * @param {vec3} out Vector to receive scaling factor component\r\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\r\n * @return {vec3} out\r\n */\n\nexport function getScaling(out, mat) {\n var m11 = mat[0];\n var m12 = mat[1];\n var m13 = mat[2];\n var m21 = mat[4];\n var m22 = mat[5];\n var m23 = mat[6];\n var m31 = mat[8];\n var m32 = mat[9];\n var m33 = mat[10];\n out[0] = Math.hypot(m11, m12, m13);\n out[1] = Math.hypot(m21, m22, m23);\n out[2] = Math.hypot(m31, m32, m33);\n return out;\n}\n/**\r\n * Returns a quaternion representing the rotational component\r\n * of a transformation matrix. If a matrix is built with\r\n * fromRotationTranslation, the returned quaternion will be the\r\n * same as the quaternion originally supplied.\r\n * @param {quat} out Quaternion to receive the rotation component\r\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\r\n * @return {quat} out\r\n */\n\nexport function getRotation(out, mat) {\n var scaling = new glMatrix.ARRAY_TYPE(3);\n getScaling(scaling, mat);\n var is1 = 1 / scaling[0];\n var is2 = 1 / scaling[1];\n var is3 = 1 / scaling[2];\n var sm11 = mat[0] * is1;\n var sm12 = mat[1] * is2;\n var sm13 = mat[2] * is3;\n var sm21 = mat[4] * is1;\n var sm22 = mat[5] * is2;\n var sm23 = mat[6] * is3;\n var sm31 = mat[8] * is1;\n var sm32 = mat[9] * is2;\n var sm33 = mat[10] * is3;\n var trace = sm11 + sm22 + sm33;\n var S = 0;\n\n if (trace > 0) {\n S = Math.sqrt(trace + 1.0) * 2;\n out[3] = 0.25 * S;\n out[0] = (sm23 - sm32) / S;\n out[1] = (sm31 - sm13) / S;\n out[2] = (sm12 - sm21) / S;\n } else if (sm11 > sm22 && sm11 > sm33) {\n S = Math.sqrt(1.0 + sm11 - sm22 - sm33) * 2;\n out[3] = (sm23 - sm32) / S;\n out[0] = 0.25 * S;\n out[1] = (sm12 + sm21) / S;\n out[2] = (sm31 + sm13) / S;\n } else if (sm22 > sm33) {\n S = Math.sqrt(1.0 + sm22 - sm11 - sm33) * 2;\n out[3] = (sm31 - sm13) / S;\n out[0] = (sm12 + sm21) / S;\n out[1] = 0.25 * S;\n out[2] = (sm23 + sm32) / S;\n } else {\n S = Math.sqrt(1.0 + sm33 - sm11 - sm22) * 2;\n out[3] = (sm12 - sm21) / S;\n out[0] = (sm31 + sm13) / S;\n out[1] = (sm23 + sm32) / S;\n out[2] = 0.25 * S;\n }\n\n return out;\n}\n/**\r\n * Creates a matrix from a quaternion rotation, vector translation and vector scale\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.translate(dest, vec);\r\n * let quatMat = mat4.create();\r\n * quat4.toMat4(quat, quatMat);\r\n * mat4.multiply(dest, quatMat);\r\n * mat4.scale(dest, scale)\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {quat4} q Rotation quaternion\r\n * @param {ReadonlyVec3} v Translation vector\r\n * @param {ReadonlyVec3} s Scaling vector\r\n * @returns {mat4} out\r\n */\n\nexport function fromRotationTranslationScale(out, q, v, s) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n var sx = s[0];\n var sy = s[1];\n var sz = s[2];\n out[0] = (1 - (yy + zz)) * sx;\n out[1] = (xy + wz) * sx;\n out[2] = (xz - wy) * sx;\n out[3] = 0;\n out[4] = (xy - wz) * sy;\n out[5] = (1 - (xx + zz)) * sy;\n out[6] = (yz + wx) * sy;\n out[7] = 0;\n out[8] = (xz + wy) * sz;\n out[9] = (yz - wx) * sz;\n out[10] = (1 - (xx + yy)) * sz;\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a quaternion rotation, vector translation and vector scale, rotating and scaling around the given origin\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.translate(dest, vec);\r\n * mat4.translate(dest, origin);\r\n * let quatMat = mat4.create();\r\n * quat4.toMat4(quat, quatMat);\r\n * mat4.multiply(dest, quatMat);\r\n * mat4.scale(dest, scale)\r\n * mat4.translate(dest, negativeOrigin);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {quat4} q Rotation quaternion\r\n * @param {ReadonlyVec3} v Translation vector\r\n * @param {ReadonlyVec3} s Scaling vector\r\n * @param {ReadonlyVec3} o The origin vector around which to scale and rotate\r\n * @returns {mat4} out\r\n */\n\nexport function fromRotationTranslationScaleOrigin(out, q, v, s, o) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n var sx = s[0];\n var sy = s[1];\n var sz = s[2];\n var ox = o[0];\n var oy = o[1];\n var oz = o[2];\n var out0 = (1 - (yy + zz)) * sx;\n var out1 = (xy + wz) * sx;\n var out2 = (xz - wy) * sx;\n var out4 = (xy - wz) * sy;\n var out5 = (1 - (xx + zz)) * sy;\n var out6 = (yz + wx) * sy;\n var out8 = (xz + wy) * sz;\n var out9 = (yz - wx) * sz;\n var out10 = (1 - (xx + yy)) * sz;\n out[0] = out0;\n out[1] = out1;\n out[2] = out2;\n out[3] = 0;\n out[4] = out4;\n out[5] = out5;\n out[6] = out6;\n out[7] = 0;\n out[8] = out8;\n out[9] = out9;\n out[10] = out10;\n out[11] = 0;\n out[12] = v[0] + ox - (out0 * ox + out4 * oy + out8 * oz);\n out[13] = v[1] + oy - (out1 * ox + out5 * oy + out9 * oz);\n out[14] = v[2] + oz - (out2 * ox + out6 * oy + out10 * oz);\n out[15] = 1;\n return out;\n}\n/**\r\n * Calculates a 4x4 matrix from the given quaternion\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {ReadonlyQuat} q Quaternion to create matrix from\r\n *\r\n * @returns {mat4} out\r\n */\n\nexport function fromQuat(out, q) {\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var yx = y * x2;\n var yy = y * y2;\n var zx = z * x2;\n var zy = z * y2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - yy - zz;\n out[1] = yx + wz;\n out[2] = zx - wy;\n out[3] = 0;\n out[4] = yx - wz;\n out[5] = 1 - xx - zz;\n out[6] = zy + wx;\n out[7] = 0;\n out[8] = zx + wy;\n out[9] = zy - wx;\n out[10] = 1 - xx - yy;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Generates a frustum matrix with the given bounds\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {Number} left Left bound of the frustum\r\n * @param {Number} right Right bound of the frustum\r\n * @param {Number} bottom Bottom bound of the frustum\r\n * @param {Number} top Top bound of the frustum\r\n * @param {Number} near Near bound of the frustum\r\n * @param {Number} far Far bound of the frustum\r\n * @returns {mat4} out\r\n */\n\nexport function frustum(out, left, right, bottom, top, near, far) {\n var rl = 1 / (right - left);\n var tb = 1 / (top - bottom);\n var nf = 1 / (near - far);\n out[0] = near * 2 * rl;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = near * 2 * tb;\n out[6] = 0;\n out[7] = 0;\n out[8] = (right + left) * rl;\n out[9] = (top + bottom) * tb;\n out[10] = (far + near) * nf;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[14] = far * near * 2 * nf;\n out[15] = 0;\n return out;\n}\n/**\r\n * Generates a perspective projection matrix with the given bounds.\r\n * Passing null/undefined/no value for far will generate infinite projection matrix.\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {number} fovy Vertical field of view in radians\r\n * @param {number} aspect Aspect ratio. typically viewport width/height\r\n * @param {number} near Near bound of the frustum\r\n * @param {number} far Far bound of the frustum, can be null or Infinity\r\n * @returns {mat4} out\r\n */\n\nexport function perspective(out, fovy, aspect, near, far) {\n var f = 1.0 / Math.tan(fovy / 2),\n nf;\n out[0] = f / aspect;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = f;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[15] = 0;\n\n if (far != null && far !== Infinity) {\n nf = 1 / (near - far);\n out[10] = (far + near) * nf;\n out[14] = 2 * far * near * nf;\n } else {\n out[10] = -1;\n out[14] = -2 * near;\n }\n\n return out;\n}\n/**\r\n * Generates a perspective projection matrix with the given field of view.\r\n * This is primarily useful for generating projection matrices to be used\r\n * with the still experiemental WebVR API.\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {Object} fov Object containing the following values: upDegrees, downDegrees, leftDegrees, rightDegrees\r\n * @param {number} near Near bound of the frustum\r\n * @param {number} far Far bound of the frustum\r\n * @returns {mat4} out\r\n */\n\nexport function perspectiveFromFieldOfView(out, fov, near, far) {\n var upTan = Math.tan(fov.upDegrees * Math.PI / 180.0);\n var downTan = Math.tan(fov.downDegrees * Math.PI / 180.0);\n var leftTan = Math.tan(fov.leftDegrees * Math.PI / 180.0);\n var rightTan = Math.tan(fov.rightDegrees * Math.PI / 180.0);\n var xScale = 2.0 / (leftTan + rightTan);\n var yScale = 2.0 / (upTan + downTan);\n out[0] = xScale;\n out[1] = 0.0;\n out[2] = 0.0;\n out[3] = 0.0;\n out[4] = 0.0;\n out[5] = yScale;\n out[6] = 0.0;\n out[7] = 0.0;\n out[8] = -((leftTan - rightTan) * xScale * 0.5);\n out[9] = (upTan - downTan) * yScale * 0.5;\n out[10] = far / (near - far);\n out[11] = -1.0;\n out[12] = 0.0;\n out[13] = 0.0;\n out[14] = far * near / (near - far);\n out[15] = 0.0;\n return out;\n}\n/**\r\n * Generates a orthogonal projection matrix with the given bounds\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {number} left Left bound of the frustum\r\n * @param {number} right Right bound of the frustum\r\n * @param {number} bottom Bottom bound of the frustum\r\n * @param {number} top Top bound of the frustum\r\n * @param {number} near Near bound of the frustum\r\n * @param {number} far Far bound of the frustum\r\n * @returns {mat4} out\r\n */\n\nexport function ortho(out, left, right, bottom, top, near, far) {\n var lr = 1 / (left - right);\n var bt = 1 / (bottom - top);\n var nf = 1 / (near - far);\n out[0] = -2 * lr;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = -2 * bt;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 2 * nf;\n out[11] = 0;\n out[12] = (left + right) * lr;\n out[13] = (top + bottom) * bt;\n out[14] = (far + near) * nf;\n out[15] = 1;\n return out;\n}\n/**\r\n * Generates a look-at matrix with the given eye position, focal point, and up axis.\r\n * If you want a matrix that actually makes an object look at another object, you should use targetTo instead.\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {ReadonlyVec3} eye Position of the viewer\r\n * @param {ReadonlyVec3} center Point the viewer is looking at\r\n * @param {ReadonlyVec3} up vec3 pointing up\r\n * @returns {mat4} out\r\n */\n\nexport function lookAt(out, eye, center, up) {\n var x0, x1, x2, y0, y1, y2, z0, z1, z2, len;\n var eyex = eye[0];\n var eyey = eye[1];\n var eyez = eye[2];\n var upx = up[0];\n var upy = up[1];\n var upz = up[2];\n var centerx = center[0];\n var centery = center[1];\n var centerz = center[2];\n\n if (Math.abs(eyex - centerx) < glMatrix.EPSILON && Math.abs(eyey - centery) < glMatrix.EPSILON && Math.abs(eyez - centerz) < glMatrix.EPSILON) {\n return identity(out);\n }\n\n z0 = eyex - centerx;\n z1 = eyey - centery;\n z2 = eyez - centerz;\n len = 1 / Math.hypot(z0, z1, z2);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n x0 = upy * z2 - upz * z1;\n x1 = upz * z0 - upx * z2;\n x2 = upx * z1 - upy * z0;\n len = Math.hypot(x0, x1, x2);\n\n if (!len) {\n x0 = 0;\n x1 = 0;\n x2 = 0;\n } else {\n len = 1 / len;\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n y0 = z1 * x2 - z2 * x1;\n y1 = z2 * x0 - z0 * x2;\n y2 = z0 * x1 - z1 * x0;\n len = Math.hypot(y0, y1, y2);\n\n if (!len) {\n y0 = 0;\n y1 = 0;\n y2 = 0;\n } else {\n len = 1 / len;\n y0 *= len;\n y1 *= len;\n y2 *= len;\n }\n\n out[0] = x0;\n out[1] = y0;\n out[2] = z0;\n out[3] = 0;\n out[4] = x1;\n out[5] = y1;\n out[6] = z1;\n out[7] = 0;\n out[8] = x2;\n out[9] = y2;\n out[10] = z2;\n out[11] = 0;\n out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n out[15] = 1;\n return out;\n}\n/**\r\n * Generates a matrix that makes something look at something else.\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {ReadonlyVec3} eye Position of the viewer\r\n * @param {ReadonlyVec3} center Point the viewer is looking at\r\n * @param {ReadonlyVec3} up vec3 pointing up\r\n * @returns {mat4} out\r\n */\n\nexport function targetTo(out, eye, target, up) {\n var eyex = eye[0],\n eyey = eye[1],\n eyez = eye[2],\n upx = up[0],\n upy = up[1],\n upz = up[2];\n var z0 = eyex - target[0],\n z1 = eyey - target[1],\n z2 = eyez - target[2];\n var len = z0 * z0 + z1 * z1 + z2 * z2;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n }\n\n var x0 = upy * z2 - upz * z1,\n x1 = upz * z0 - upx * z2,\n x2 = upx * z1 - upy * z0;\n len = x0 * x0 + x1 * x1 + x2 * x2;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n out[0] = x0;\n out[1] = x1;\n out[2] = x2;\n out[3] = 0;\n out[4] = z1 * x2 - z2 * x1;\n out[5] = z2 * x0 - z0 * x2;\n out[6] = z0 * x1 - z1 * x0;\n out[7] = 0;\n out[8] = z0;\n out[9] = z1;\n out[10] = z2;\n out[11] = 0;\n out[12] = eyex;\n out[13] = eyey;\n out[14] = eyez;\n out[15] = 1;\n return out;\n}\n/**\r\n * Returns a string representation of a mat4\r\n *\r\n * @param {ReadonlyMat4} a matrix to represent as a string\r\n * @returns {String} string representation of the matrix\r\n */\n\nexport function str(a) {\n return \"mat4(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \", \" + a[6] + \", \" + a[7] + \", \" + a[8] + \", \" + a[9] + \", \" + a[10] + \", \" + a[11] + \", \" + a[12] + \", \" + a[13] + \", \" + a[14] + \", \" + a[15] + \")\";\n}\n/**\r\n * Returns Frobenius norm of a mat4\r\n *\r\n * @param {ReadonlyMat4} a the matrix to calculate Frobenius norm of\r\n * @returns {Number} Frobenius norm\r\n */\n\nexport function frob(a) {\n return Math.hypot(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8], a[9], a[10], a[11], a[12], a[13], a[14], a[15]);\n}\n/**\r\n * Adds two mat4's\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the first operand\r\n * @param {ReadonlyMat4} b the second operand\r\n * @returns {mat4} out\r\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n out[8] = a[8] + b[8];\n out[9] = a[9] + b[9];\n out[10] = a[10] + b[10];\n out[11] = a[11] + b[11];\n out[12] = a[12] + b[12];\n out[13] = a[13] + b[13];\n out[14] = a[14] + b[14];\n out[15] = a[15] + b[15];\n return out;\n}\n/**\r\n * Subtracts matrix b from matrix a\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the first operand\r\n * @param {ReadonlyMat4} b the second operand\r\n * @returns {mat4} out\r\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n out[6] = a[6] - b[6];\n out[7] = a[7] - b[7];\n out[8] = a[8] - b[8];\n out[9] = a[9] - b[9];\n out[10] = a[10] - b[10];\n out[11] = a[11] - b[11];\n out[12] = a[12] - b[12];\n out[13] = a[13] - b[13];\n out[14] = a[14] - b[14];\n out[15] = a[15] - b[15];\n return out;\n}\n/**\r\n * Multiply each element of the matrix by a scalar.\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to scale\r\n * @param {Number} b amount to scale the matrix's elements by\r\n * @returns {mat4} out\r\n */\n\nexport function multiplyScalar(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n out[8] = a[8] * b;\n out[9] = a[9] * b;\n out[10] = a[10] * b;\n out[11] = a[11] * b;\n out[12] = a[12] * b;\n out[13] = a[13] * b;\n out[14] = a[14] * b;\n out[15] = a[15] * b;\n return out;\n}\n/**\r\n * Adds two mat4's after multiplying each element of the second operand by a scalar value.\r\n *\r\n * @param {mat4} out the receiving vector\r\n * @param {ReadonlyMat4} a the first operand\r\n * @param {ReadonlyMat4} b the second operand\r\n * @param {Number} scale the amount to scale b's elements by before adding\r\n * @returns {mat4} out\r\n */\n\nexport function multiplyScalarAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n out[6] = a[6] + b[6] * scale;\n out[7] = a[7] + b[7] * scale;\n out[8] = a[8] + b[8] * scale;\n out[9] = a[9] + b[9] * scale;\n out[10] = a[10] + b[10] * scale;\n out[11] = a[11] + b[11] * scale;\n out[12] = a[12] + b[12] * scale;\n out[13] = a[13] + b[13] * scale;\n out[14] = a[14] + b[14] * scale;\n out[15] = a[15] + b[15] * scale;\n return out;\n}\n/**\r\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyMat4} a The first matrix.\r\n * @param {ReadonlyMat4} b The second matrix.\r\n * @returns {Boolean} True if the matrices are equal, false otherwise.\r\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5] && a[6] === b[6] && a[7] === b[7] && a[8] === b[8] && a[9] === b[9] && a[10] === b[10] && a[11] === b[11] && a[12] === b[12] && a[13] === b[13] && a[14] === b[14] && a[15] === b[15];\n}\n/**\r\n * Returns whether or not the matrices have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyMat4} a The first matrix.\r\n * @param {ReadonlyMat4} b The second matrix.\r\n * @returns {Boolean} True if the matrices are equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var a4 = a[4],\n a5 = a[5],\n a6 = a[6],\n a7 = a[7];\n var a8 = a[8],\n a9 = a[9],\n a10 = a[10],\n a11 = a[11];\n var a12 = a[12],\n a13 = a[13],\n a14 = a[14],\n a15 = a[15];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n var b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7];\n var b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11];\n var b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) && Math.abs(a6 - b6) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) && Math.abs(a7 - b7) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7)) && Math.abs(a8 - b8) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a8), Math.abs(b8)) && Math.abs(a9 - b9) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a9), Math.abs(b9)) && Math.abs(a10 - b10) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a10), Math.abs(b10)) && Math.abs(a11 - b11) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a11), Math.abs(b11)) && Math.abs(a12 - b12) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a12), Math.abs(b12)) && Math.abs(a13 - b13) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a13), Math.abs(b13)) && Math.abs(a14 - b14) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a14), Math.abs(b14)) && Math.abs(a15 - b15) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a15), Math.abs(b15));\n}\n/**\r\n * Alias for {@link mat4.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Alias for {@link mat4.subtract}\r\n * @function\r\n */\n\nexport var sub = subtract;","import * as glMatrix from \"./common.js\";\n/**\r\n * 4 Dimensional Vector\r\n * @module vec4\r\n */\n\n/**\r\n * Creates a new, empty vec4\r\n *\r\n * @returns {vec4} a new 4D vector\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(4);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n }\n\n return out;\n}\n/**\r\n * Creates a new vec4 initialized with values from an existing vector\r\n *\r\n * @param {ReadonlyVec4} a vector to clone\r\n * @returns {vec4} a new 4D vector\r\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(4);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\r\n * Creates a new vec4 initialized with the given values\r\n *\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @param {Number} w W component\r\n * @returns {vec4} a new 4D vector\r\n */\n\nexport function fromValues(x, y, z, w) {\n var out = new glMatrix.ARRAY_TYPE(4);\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = w;\n return out;\n}\n/**\r\n * Copy the values from one vec4 to another\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the source vector\r\n * @returns {vec4} out\r\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\r\n * Set the components of a vec4 to the given values\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @param {Number} w W component\r\n * @returns {vec4} out\r\n */\n\nexport function set(out, x, y, z, w) {\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = w;\n return out;\n}\n/**\r\n * Adds two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n return out;\n}\n/**\r\n * Subtracts vector b from vector a\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n return out;\n}\n/**\r\n * Multiplies two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function multiply(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n out[2] = a[2] * b[2];\n out[3] = a[3] * b[3];\n return out;\n}\n/**\r\n * Divides two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function divide(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n out[2] = a[2] / b[2];\n out[3] = a[3] / b[3];\n return out;\n}\n/**\r\n * Math.ceil the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to ceil\r\n * @returns {vec4} out\r\n */\n\nexport function ceil(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n out[2] = Math.ceil(a[2]);\n out[3] = Math.ceil(a[3]);\n return out;\n}\n/**\r\n * Math.floor the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to floor\r\n * @returns {vec4} out\r\n */\n\nexport function floor(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n out[2] = Math.floor(a[2]);\n out[3] = Math.floor(a[3]);\n return out;\n}\n/**\r\n * Returns the minimum of two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function min(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n out[2] = Math.min(a[2], b[2]);\n out[3] = Math.min(a[3], b[3]);\n return out;\n}\n/**\r\n * Returns the maximum of two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function max(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n out[2] = Math.max(a[2], b[2]);\n out[3] = Math.max(a[3], b[3]);\n return out;\n}\n/**\r\n * Math.round the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to round\r\n * @returns {vec4} out\r\n */\n\nexport function round(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n out[2] = Math.round(a[2]);\n out[3] = Math.round(a[3]);\n return out;\n}\n/**\r\n * Scales a vec4 by a scalar number\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the vector to scale\r\n * @param {Number} b amount to scale the vector by\r\n * @returns {vec4} out\r\n */\n\nexport function scale(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n return out;\n}\n/**\r\n * Adds two vec4's after scaling the second operand by a scalar value\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @param {Number} scale the amount to scale b by before adding\r\n * @returns {vec4} out\r\n */\n\nexport function scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n return out;\n}\n/**\r\n * Calculates the euclidian distance between two vec4's\r\n *\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {Number} distance between a and b\r\n */\n\nexport function distance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n var w = b[3] - a[3];\n return Math.hypot(x, y, z, w);\n}\n/**\r\n * Calculates the squared euclidian distance between two vec4's\r\n *\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {Number} squared distance between a and b\r\n */\n\nexport function squaredDistance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n var w = b[3] - a[3];\n return x * x + y * y + z * z + w * w;\n}\n/**\r\n * Calculates the length of a vec4\r\n *\r\n * @param {ReadonlyVec4} a vector to calculate length of\r\n * @returns {Number} length of a\r\n */\n\nexport function length(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n return Math.hypot(x, y, z, w);\n}\n/**\r\n * Calculates the squared length of a vec4\r\n *\r\n * @param {ReadonlyVec4} a vector to calculate squared length of\r\n * @returns {Number} squared length of a\r\n */\n\nexport function squaredLength(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n return x * x + y * y + z * z + w * w;\n}\n/**\r\n * Negates the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to negate\r\n * @returns {vec4} out\r\n */\n\nexport function negate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = -a[3];\n return out;\n}\n/**\r\n * Returns the inverse of the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to invert\r\n * @returns {vec4} out\r\n */\n\nexport function inverse(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n out[2] = 1.0 / a[2];\n out[3] = 1.0 / a[3];\n return out;\n}\n/**\r\n * Normalize a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to normalize\r\n * @returns {vec4} out\r\n */\n\nexport function normalize(out, a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n var len = x * x + y * y + z * z + w * w;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = x * len;\n out[1] = y * len;\n out[2] = z * len;\n out[3] = w * len;\n return out;\n}\n/**\r\n * Calculates the dot product of two vec4's\r\n *\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {Number} dot product of a and b\r\n */\n\nexport function dot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n}\n/**\r\n * Returns the cross-product of three vectors in a 4-dimensional space\r\n *\r\n * @param {ReadonlyVec4} result the receiving vector\r\n * @param {ReadonlyVec4} U the first vector\r\n * @param {ReadonlyVec4} V the second vector\r\n * @param {ReadonlyVec4} W the third vector\r\n * @returns {vec4} result\r\n */\n\nexport function cross(out, u, v, w) {\n var A = v[0] * w[1] - v[1] * w[0],\n B = v[0] * w[2] - v[2] * w[0],\n C = v[0] * w[3] - v[3] * w[0],\n D = v[1] * w[2] - v[2] * w[1],\n E = v[1] * w[3] - v[3] * w[1],\n F = v[2] * w[3] - v[3] * w[2];\n var G = u[0];\n var H = u[1];\n var I = u[2];\n var J = u[3];\n out[0] = H * F - I * E + J * D;\n out[1] = -(G * F) + I * C - J * B;\n out[2] = G * E - H * C + J * A;\n out[3] = -(G * D) + H * B - I * A;\n return out;\n}\n/**\r\n * Performs a linear interpolation between two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {vec4} out\r\n */\n\nexport function lerp(out, a, b, t) {\n var ax = a[0];\n var ay = a[1];\n var az = a[2];\n var aw = a[3];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n out[2] = az + t * (b[2] - az);\n out[3] = aw + t * (b[3] - aw);\n return out;\n}\n/**\r\n * Generates a random vector with the given scale\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\r\n * @returns {vec4} out\r\n */\n\nexport function random(out, scale) {\n scale = scale || 1.0; // Marsaglia, George. Choosing a Point from the Surface of a\n // Sphere. Ann. Math. Statist. 43 (1972), no. 2, 645--646.\n // http://projecteuclid.org/euclid.aoms/1177692644;\n\n var v1, v2, v3, v4;\n var s1, s2;\n\n do {\n v1 = glMatrix.RANDOM() * 2 - 1;\n v2 = glMatrix.RANDOM() * 2 - 1;\n s1 = v1 * v1 + v2 * v2;\n } while (s1 >= 1);\n\n do {\n v3 = glMatrix.RANDOM() * 2 - 1;\n v4 = glMatrix.RANDOM() * 2 - 1;\n s2 = v3 * v3 + v4 * v4;\n } while (s2 >= 1);\n\n var d = Math.sqrt((1 - s1) / s2);\n out[0] = scale * v1;\n out[1] = scale * v2;\n out[2] = scale * v3 * d;\n out[3] = scale * v4 * d;\n return out;\n}\n/**\r\n * Transforms the vec4 with a mat4.\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the vector to transform\r\n * @param {ReadonlyMat4} m matrix to transform with\r\n * @returns {vec4} out\r\n */\n\nexport function transformMat4(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n return out;\n}\n/**\r\n * Transforms the vec4 with a quat\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the vector to transform\r\n * @param {ReadonlyQuat} q quaternion to transform with\r\n * @returns {vec4} out\r\n */\n\nexport function transformQuat(out, a, q) {\n var x = a[0],\n y = a[1],\n z = a[2];\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3]; // calculate quat * vec\n\n var ix = qw * x + qy * z - qz * y;\n var iy = qw * y + qz * x - qx * z;\n var iz = qw * z + qx * y - qy * x;\n var iw = -qx * x - qy * y - qz * z; // calculate result * inverse quat\n\n out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n out[3] = a[3];\n return out;\n}\n/**\r\n * Set the components of a vec4 to zero\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @returns {vec4} out\r\n */\n\nexport function zero(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n out[2] = 0.0;\n out[3] = 0.0;\n return out;\n}\n/**\r\n * Returns a string representation of a vector\r\n *\r\n * @param {ReadonlyVec4} a vector to represent as a string\r\n * @returns {String} string representation of the vector\r\n */\n\nexport function str(a) {\n return \"vec4(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n/**\r\n * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyVec4} a The first vector.\r\n * @param {ReadonlyVec4} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];\n}\n/**\r\n * Returns whether or not the vectors have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyVec4} a The first vector.\r\n * @param {ReadonlyVec4} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3));\n}\n/**\r\n * Alias for {@link vec4.subtract}\r\n * @function\r\n */\n\nexport var sub = subtract;\n/**\r\n * Alias for {@link vec4.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Alias for {@link vec4.divide}\r\n * @function\r\n */\n\nexport var div = divide;\n/**\r\n * Alias for {@link vec4.distance}\r\n * @function\r\n */\n\nexport var dist = distance;\n/**\r\n * Alias for {@link vec4.squaredDistance}\r\n * @function\r\n */\n\nexport var sqrDist = squaredDistance;\n/**\r\n * Alias for {@link vec4.length}\r\n * @function\r\n */\n\nexport var len = length;\n/**\r\n * Alias for {@link vec4.squaredLength}\r\n * @function\r\n */\n\nexport var sqrLen = squaredLength;\n/**\r\n * Perform some operation over an array of vec4s.\r\n *\r\n * @param {Array} a the array of vectors to iterate over\r\n * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed\r\n * @param {Number} offset Number of elements to skip at the beginning of the array\r\n * @param {Number} count Number of vec4s to iterate over. If 0 iterates over entire array\r\n * @param {Function} fn Function to call for each vector in the array\r\n * @param {Object} [arg] additional argument to pass to fn\r\n * @returns {Array} a\r\n * @function\r\n */\n\nexport var forEach = function () {\n var vec = create();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 4;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n vec[3] = a[i + 3];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n a[i + 3] = vec[3];\n }\n\n return a;\n };\n}();","import * as glMatrix from \"./common.js\";\nimport * as mat3 from \"./mat3.js\";\nimport * as vec3 from \"./vec3.js\";\nimport * as vec4 from \"./vec4.js\";\n/**\r\n * Quaternion\r\n * @module quat\r\n */\n\n/**\r\n * Creates a new identity quat\r\n *\r\n * @returns {quat} a new quaternion\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(4);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n }\n\n out[3] = 1;\n return out;\n}\n/**\r\n * Set a quat to the identity quaternion\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @returns {quat} out\r\n */\n\nexport function identity(out) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n}\n/**\r\n * Sets a quat from the given angle and rotation axis,\r\n * then returns it.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyVec3} axis the axis around which to rotate\r\n * @param {Number} rad the angle in radians\r\n * @returns {quat} out\r\n **/\n\nexport function setAxisAngle(out, axis, rad) {\n rad = rad * 0.5;\n var s = Math.sin(rad);\n out[0] = s * axis[0];\n out[1] = s * axis[1];\n out[2] = s * axis[2];\n out[3] = Math.cos(rad);\n return out;\n}\n/**\r\n * Gets the rotation axis and angle for a given\r\n * quaternion. If a quaternion is created with\r\n * setAxisAngle, this method will return the same\r\n * values as providied in the original parameter list\r\n * OR functionally equivalent values.\r\n * Example: The quaternion formed by axis [0, 0, 1] and\r\n * angle -90 is the same as the quaternion formed by\r\n * [0, 0, 1] and 270. This method favors the latter.\r\n * @param {vec3} out_axis Vector receiving the axis of rotation\r\n * @param {ReadonlyQuat} q Quaternion to be decomposed\r\n * @return {Number} Angle, in radians, of the rotation\r\n */\n\nexport function getAxisAngle(out_axis, q) {\n var rad = Math.acos(q[3]) * 2.0;\n var s = Math.sin(rad / 2.0);\n\n if (s > glMatrix.EPSILON) {\n out_axis[0] = q[0] / s;\n out_axis[1] = q[1] / s;\n out_axis[2] = q[2] / s;\n } else {\n // If s is zero, return any axis (no rotation - axis does not matter)\n out_axis[0] = 1;\n out_axis[1] = 0;\n out_axis[2] = 0;\n }\n\n return rad;\n}\n/**\r\n * Gets the angular distance between two unit quaternions\r\n *\r\n * @param {ReadonlyQuat} a Origin unit quaternion\r\n * @param {ReadonlyQuat} b Destination unit quaternion\r\n * @return {Number} Angle, in radians, between the two quaternions\r\n */\n\nexport function getAngle(a, b) {\n var dotproduct = dot(a, b);\n return Math.acos(2 * dotproduct * dotproduct - 1);\n}\n/**\r\n * Multiplies two quat's\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @returns {quat} out\r\n */\n\nexport function multiply(out, a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bx = b[0],\n by = b[1],\n bz = b[2],\n bw = b[3];\n out[0] = ax * bw + aw * bx + ay * bz - az * by;\n out[1] = ay * bw + aw * by + az * bx - ax * bz;\n out[2] = az * bw + aw * bz + ax * by - ay * bx;\n out[3] = aw * bw - ax * bx - ay * by - az * bz;\n return out;\n}\n/**\r\n * Rotates a quaternion by the given angle about the X axis\r\n *\r\n * @param {quat} out quat receiving operation result\r\n * @param {ReadonlyQuat} a quat to rotate\r\n * @param {number} rad angle (in radians) to rotate\r\n * @returns {quat} out\r\n */\n\nexport function rotateX(out, a, rad) {\n rad *= 0.5;\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bx = Math.sin(rad),\n bw = Math.cos(rad);\n out[0] = ax * bw + aw * bx;\n out[1] = ay * bw + az * bx;\n out[2] = az * bw - ay * bx;\n out[3] = aw * bw - ax * bx;\n return out;\n}\n/**\r\n * Rotates a quaternion by the given angle about the Y axis\r\n *\r\n * @param {quat} out quat receiving operation result\r\n * @param {ReadonlyQuat} a quat to rotate\r\n * @param {number} rad angle (in radians) to rotate\r\n * @returns {quat} out\r\n */\n\nexport function rotateY(out, a, rad) {\n rad *= 0.5;\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var by = Math.sin(rad),\n bw = Math.cos(rad);\n out[0] = ax * bw - az * by;\n out[1] = ay * bw + aw * by;\n out[2] = az * bw + ax * by;\n out[3] = aw * bw - ay * by;\n return out;\n}\n/**\r\n * Rotates a quaternion by the given angle about the Z axis\r\n *\r\n * @param {quat} out quat receiving operation result\r\n * @param {ReadonlyQuat} a quat to rotate\r\n * @param {number} rad angle (in radians) to rotate\r\n * @returns {quat} out\r\n */\n\nexport function rotateZ(out, a, rad) {\n rad *= 0.5;\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bz = Math.sin(rad),\n bw = Math.cos(rad);\n out[0] = ax * bw + ay * bz;\n out[1] = ay * bw - ax * bz;\n out[2] = az * bw + aw * bz;\n out[3] = aw * bw - az * bz;\n return out;\n}\n/**\r\n * Calculates the W component of a quat from the X, Y, and Z components.\r\n * Assumes that quaternion is 1 unit in length.\r\n * Any existing W component will be ignored.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate W component of\r\n * @returns {quat} out\r\n */\n\nexport function calculateW(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2];\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));\n return out;\n}\n/**\r\n * Calculate the exponential of a unit quaternion.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate the exponential of\r\n * @returns {quat} out\r\n */\n\nexport function exp(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n var r = Math.sqrt(x * x + y * y + z * z);\n var et = Math.exp(w);\n var s = r > 0 ? et * Math.sin(r) / r : 0;\n out[0] = x * s;\n out[1] = y * s;\n out[2] = z * s;\n out[3] = et * Math.cos(r);\n return out;\n}\n/**\r\n * Calculate the natural logarithm of a unit quaternion.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate the exponential of\r\n * @returns {quat} out\r\n */\n\nexport function ln(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n var r = Math.sqrt(x * x + y * y + z * z);\n var t = r > 0 ? Math.atan2(r, w) / r : 0;\n out[0] = x * t;\n out[1] = y * t;\n out[2] = z * t;\n out[3] = 0.5 * Math.log(x * x + y * y + z * z + w * w);\n return out;\n}\n/**\r\n * Calculate the scalar power of a unit quaternion.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate the exponential of\r\n * @param {Number} b amount to scale the quaternion by\r\n * @returns {quat} out\r\n */\n\nexport function pow(out, a, b) {\n ln(out, a);\n scale(out, out, b);\n exp(out, out);\n return out;\n}\n/**\r\n * Performs a spherical linear interpolation between two quat\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {quat} out\r\n */\n\nexport function slerp(out, a, b, t) {\n // benchmarks:\n // http://jsperf.com/quaternion-slerp-implementations\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bx = b[0],\n by = b[1],\n bz = b[2],\n bw = b[3];\n var omega, cosom, sinom, scale0, scale1; // calc cosine\n\n cosom = ax * bx + ay * by + az * bz + aw * bw; // adjust signs (if necessary)\n\n if (cosom < 0.0) {\n cosom = -cosom;\n bx = -bx;\n by = -by;\n bz = -bz;\n bw = -bw;\n } // calculate coefficients\n\n\n if (1.0 - cosom > glMatrix.EPSILON) {\n // standard case (slerp)\n omega = Math.acos(cosom);\n sinom = Math.sin(omega);\n scale0 = Math.sin((1.0 - t) * omega) / sinom;\n scale1 = Math.sin(t * omega) / sinom;\n } else {\n // \"from\" and \"to\" quaternions are very close\n // ... so we can do a linear interpolation\n scale0 = 1.0 - t;\n scale1 = t;\n } // calculate final values\n\n\n out[0] = scale0 * ax + scale1 * bx;\n out[1] = scale0 * ay + scale1 * by;\n out[2] = scale0 * az + scale1 * bz;\n out[3] = scale0 * aw + scale1 * bw;\n return out;\n}\n/**\r\n * Generates a random unit quaternion\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @returns {quat} out\r\n */\n\nexport function random(out) {\n // Implementation of http://planning.cs.uiuc.edu/node198.html\n // TODO: Calling random 3 times is probably not the fastest solution\n var u1 = glMatrix.RANDOM();\n var u2 = glMatrix.RANDOM();\n var u3 = glMatrix.RANDOM();\n var sqrt1MinusU1 = Math.sqrt(1 - u1);\n var sqrtU1 = Math.sqrt(u1);\n out[0] = sqrt1MinusU1 * Math.sin(2.0 * Math.PI * u2);\n out[1] = sqrt1MinusU1 * Math.cos(2.0 * Math.PI * u2);\n out[2] = sqrtU1 * Math.sin(2.0 * Math.PI * u3);\n out[3] = sqrtU1 * Math.cos(2.0 * Math.PI * u3);\n return out;\n}\n/**\r\n * Calculates the inverse of a quat\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate inverse of\r\n * @returns {quat} out\r\n */\n\nexport function invert(out, a) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var dot = a0 * a0 + a1 * a1 + a2 * a2 + a3 * a3;\n var invDot = dot ? 1.0 / dot : 0; // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0\n\n out[0] = -a0 * invDot;\n out[1] = -a1 * invDot;\n out[2] = -a2 * invDot;\n out[3] = a3 * invDot;\n return out;\n}\n/**\r\n * Calculates the conjugate of a quat\r\n * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate conjugate of\r\n * @returns {quat} out\r\n */\n\nexport function conjugate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = a[3];\n return out;\n}\n/**\r\n * Creates a quaternion from the given 3x3 rotation matrix.\r\n *\r\n * NOTE: The resultant quaternion is not normalized, so you should be sure\r\n * to renormalize the quaternion yourself where necessary.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyMat3} m rotation matrix\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport function fromMat3(out, m) {\n // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes\n // article \"Quaternion Calculus and Fast Animation\".\n var fTrace = m[0] + m[4] + m[8];\n var fRoot;\n\n if (fTrace > 0.0) {\n // |w| > 1/2, may as well choose w > 1/2\n fRoot = Math.sqrt(fTrace + 1.0); // 2w\n\n out[3] = 0.5 * fRoot;\n fRoot = 0.5 / fRoot; // 1/(4w)\n\n out[0] = (m[5] - m[7]) * fRoot;\n out[1] = (m[6] - m[2]) * fRoot;\n out[2] = (m[1] - m[3]) * fRoot;\n } else {\n // |w| <= 1/2\n var i = 0;\n if (m[4] > m[0]) i = 1;\n if (m[8] > m[i * 3 + i]) i = 2;\n var j = (i + 1) % 3;\n var k = (i + 2) % 3;\n fRoot = Math.sqrt(m[i * 3 + i] - m[j * 3 + j] - m[k * 3 + k] + 1.0);\n out[i] = 0.5 * fRoot;\n fRoot = 0.5 / fRoot;\n out[3] = (m[j * 3 + k] - m[k * 3 + j]) * fRoot;\n out[j] = (m[j * 3 + i] + m[i * 3 + j]) * fRoot;\n out[k] = (m[k * 3 + i] + m[i * 3 + k]) * fRoot;\n }\n\n return out;\n}\n/**\r\n * Creates a quaternion from the given euler angle x, y, z.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {x} Angle to rotate around X axis in degrees.\r\n * @param {y} Angle to rotate around Y axis in degrees.\r\n * @param {z} Angle to rotate around Z axis in degrees.\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport function fromEuler(out, x, y, z) {\n var halfToRad = 0.5 * Math.PI / 180.0;\n x *= halfToRad;\n y *= halfToRad;\n z *= halfToRad;\n var sx = Math.sin(x);\n var cx = Math.cos(x);\n var sy = Math.sin(y);\n var cy = Math.cos(y);\n var sz = Math.sin(z);\n var cz = Math.cos(z);\n out[0] = sx * cy * cz - cx * sy * sz;\n out[1] = cx * sy * cz + sx * cy * sz;\n out[2] = cx * cy * sz - sx * sy * cz;\n out[3] = cx * cy * cz + sx * sy * sz;\n return out;\n}\n/**\r\n * Returns a string representation of a quatenion\r\n *\r\n * @param {ReadonlyQuat} a vector to represent as a string\r\n * @returns {String} string representation of the vector\r\n */\n\nexport function str(a) {\n return \"quat(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n/**\r\n * Creates a new quat initialized with values from an existing quaternion\r\n *\r\n * @param {ReadonlyQuat} a quaternion to clone\r\n * @returns {quat} a new quaternion\r\n * @function\r\n */\n\nexport var clone = vec4.clone;\n/**\r\n * Creates a new quat initialized with the given values\r\n *\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @param {Number} w W component\r\n * @returns {quat} a new quaternion\r\n * @function\r\n */\n\nexport var fromValues = vec4.fromValues;\n/**\r\n * Copy the values from one quat to another\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the source quaternion\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var copy = vec4.copy;\n/**\r\n * Set the components of a quat to the given values\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @param {Number} w W component\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var set = vec4.set;\n/**\r\n * Adds two quat's\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var add = vec4.add;\n/**\r\n * Alias for {@link quat.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Scales a quat by a scalar number\r\n *\r\n * @param {quat} out the receiving vector\r\n * @param {ReadonlyQuat} a the vector to scale\r\n * @param {Number} b amount to scale the vector by\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var scale = vec4.scale;\n/**\r\n * Calculates the dot product of two quat's\r\n *\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @returns {Number} dot product of a and b\r\n * @function\r\n */\n\nexport var dot = vec4.dot;\n/**\r\n * Performs a linear interpolation between two quat's\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var lerp = vec4.lerp;\n/**\r\n * Calculates the length of a quat\r\n *\r\n * @param {ReadonlyQuat} a vector to calculate length of\r\n * @returns {Number} length of a\r\n */\n\nexport var length = vec4.length;\n/**\r\n * Alias for {@link quat.length}\r\n * @function\r\n */\n\nexport var len = length;\n/**\r\n * Calculates the squared length of a quat\r\n *\r\n * @param {ReadonlyQuat} a vector to calculate squared length of\r\n * @returns {Number} squared length of a\r\n * @function\r\n */\n\nexport var squaredLength = vec4.squaredLength;\n/**\r\n * Alias for {@link quat.squaredLength}\r\n * @function\r\n */\n\nexport var sqrLen = squaredLength;\n/**\r\n * Normalize a quat\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quaternion to normalize\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var normalize = vec4.normalize;\n/**\r\n * Returns whether or not the quaternions have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyQuat} a The first quaternion.\r\n * @param {ReadonlyQuat} b The second quaternion.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport var exactEquals = vec4.exactEquals;\n/**\r\n * Returns whether or not the quaternions have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyQuat} a The first vector.\r\n * @param {ReadonlyQuat} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport var equals = vec4.equals;\n/**\r\n * Sets a quaternion to represent the shortest rotation from one\r\n * vector to another.\r\n *\r\n * Both vectors are assumed to be unit length.\r\n *\r\n * @param {quat} out the receiving quaternion.\r\n * @param {ReadonlyVec3} a the initial vector\r\n * @param {ReadonlyVec3} b the destination vector\r\n * @returns {quat} out\r\n */\n\nexport var rotationTo = function () {\n var tmpvec3 = vec3.create();\n var xUnitVec3 = vec3.fromValues(1, 0, 0);\n var yUnitVec3 = vec3.fromValues(0, 1, 0);\n return function (out, a, b) {\n var dot = vec3.dot(a, b);\n\n if (dot < -0.999999) {\n vec3.cross(tmpvec3, xUnitVec3, a);\n if (vec3.len(tmpvec3) < 0.000001) vec3.cross(tmpvec3, yUnitVec3, a);\n vec3.normalize(tmpvec3, tmpvec3);\n setAxisAngle(out, tmpvec3, Math.PI);\n return out;\n } else if (dot > 0.999999) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n } else {\n vec3.cross(tmpvec3, a, b);\n out[0] = tmpvec3[0];\n out[1] = tmpvec3[1];\n out[2] = tmpvec3[2];\n out[3] = 1 + dot;\n return normalize(out, out);\n }\n };\n}();\n/**\r\n * Performs a spherical linear interpolation with two control points\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @param {ReadonlyQuat} c the third operand\r\n * @param {ReadonlyQuat} d the fourth operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {quat} out\r\n */\n\nexport var sqlerp = function () {\n var temp1 = create();\n var temp2 = create();\n return function (out, a, b, c, d, t) {\n slerp(temp1, a, d, t);\n slerp(temp2, b, c, t);\n slerp(out, temp1, temp2, 2 * t * (1 - t));\n return out;\n };\n}();\n/**\r\n * Sets the specified quaternion with values corresponding to the given\r\n * axes. Each axis is a vec3 and is expected to be unit length and\r\n * perpendicular to all other specified axes.\r\n *\r\n * @param {ReadonlyVec3} view the vector representing the viewing direction\r\n * @param {ReadonlyVec3} right the vector representing the local \"right\" direction\r\n * @param {ReadonlyVec3} up the vector representing the local \"up\" direction\r\n * @returns {quat} out\r\n */\n\nexport var setAxes = function () {\n var matr = mat3.create();\n return function (out, view, right, up) {\n matr[0] = right[0];\n matr[3] = right[1];\n matr[6] = right[2];\n matr[1] = up[0];\n matr[4] = up[1];\n matr[7] = up[2];\n matr[2] = -view[0];\n matr[5] = -view[1];\n matr[8] = -view[2];\n return normalize(out, fromMat3(out, matr));\n };\n}();","import Scale from './base';\nimport Category from './category/base';\nimport TimeCat from './category/time';\nimport Linear from './continuous/linear';\nimport Log from './continuous/log';\nimport Pow from './continuous/pow';\nimport Time from './continuous/time';\nimport Quantize from './continuous/quantize';\nimport Quantile from './continuous/quantile';\nimport { getScale, registerScale } from './factory';\nimport Identity from './identity/index';\nimport { getTickMethod, registerTickMethod } from './tick-method/index';\nregisterScale('cat', Category);\nregisterScale('category', Category);\nregisterScale('identity', Identity);\nregisterScale('linear', Linear);\nregisterScale('log', Log);\nregisterScale('pow', Pow);\nregisterScale('time', Time);\nregisterScale('timeCat', TimeCat);\nregisterScale('quantize', Quantize);\nregisterScale('quantile', Quantile);\nexport { Category, Identity, Linear, Log, Pow, Time, TimeCat, Quantile, Quantize, Scale, getScale, registerScale, getTickMethod, registerTickMethod, };\n//# sourceMappingURL=index.js.map","var isArrayLike = function (value) {\n /**\n * isArrayLike([1, 2, 3]) => true\n * isArrayLike(document.body.children) => true\n * isArrayLike('abc') => true\n * isArrayLike(Function) => false\n */\n return value !== null && typeof value !== 'function' && isFinite(value.length);\n};\nexport default isArrayLike;\n//# sourceMappingURL=is-array-like.js.map","import isArrayLike from './is-array-like';\nvar contains = function (arr, value) {\n if (!isArrayLike(arr)) {\n return false;\n }\n return arr.indexOf(value) > -1;\n};\nexport default contains;\n//# sourceMappingURL=contains.js.map","import isArrayLike from './is-array-like';\nvar filter = function (arr, func) {\n if (!isArrayLike(arr)) {\n return arr;\n }\n var result = [];\n for (var index = 0; index < arr.length; index++) {\n var value = arr[index];\n if (func(value, index)) {\n result.push(value);\n }\n }\n return result;\n};\nexport default filter;\n//# sourceMappingURL=filter.js.map","import filter from './filter';\nimport contains from './contains';\n/**\n * Flattens `array` a single level deep.\n *\n * @param {Array} arr The array to inspect.\n * @param {Array} values The values to exclude.\n * @return {Array} Returns the new array of filtered values.\n * @example\n * difference([2, 1], [2, 3]); // => [1]\n */\nvar difference = function (arr, values) {\n if (values === void 0) { values = []; }\n return filter(arr, function (value) { return !contains(values, value); });\n};\nexport default difference;\n//# sourceMappingURL=difference.js.map","var toString = {}.toString;\nvar isType = function (value, type) { return toString.call(value) === '[object ' + type + ']'; };\nexport default isType;\n//# sourceMappingURL=is-type.js.map","/**\n * 是否为函数\n * @param {*} fn 对象\n * @return {Boolean} 是否函数\n */\nimport isType from './is-type';\nexport default (function (value) {\n return isType(value, 'Function');\n});\n//# sourceMappingURL=is-function.js.map","// isFinite,\nvar isNil = function (value) {\n /**\n * isNil(null) => true\n * isNil() => true\n */\n return value === null || value === undefined;\n};\nexport default isNil;\n//# sourceMappingURL=is-nil.js.map","import isType from './is-type';\nexport default (function (value) {\n return Array.isArray ?\n Array.isArray(value) :\n isType(value, 'Array');\n});\n//# sourceMappingURL=is-array.js.map","export default (function (value) {\n /**\n * isObject({}) => true\n * isObject([1, 2, 3]) => true\n * isObject(Function) => true\n * isObject(null) => false\n */\n var type = typeof value;\n return value !== null && type === 'object' || type === 'function';\n});\n//# sourceMappingURL=is-object.js.map","import isArray from './is-array';\nimport isObject from './is-object';\nfunction each(elements, func) {\n if (!elements) {\n return;\n }\n var rst;\n if (isArray(elements)) {\n for (var i = 0, len = elements.length; i < len; i++) {\n rst = func(elements[i], i);\n if (rst === false) {\n break;\n }\n }\n }\n else if (isObject(elements)) {\n for (var k in elements) {\n if (elements.hasOwnProperty(k)) {\n rst = func(elements[k], k);\n if (rst === false) {\n break;\n }\n }\n }\n }\n}\nexport default each;\n//# sourceMappingURL=each.js.map","import each from './each';\nimport isFunction from './is-function';\nvar keys = Object.keys ? function (obj) { return Object.keys(obj); } : function (obj) {\n var result = [];\n each(obj, function (value, key) {\n if (!(isFunction(obj) && key === 'prototype')) {\n result.push(key);\n }\n });\n return result;\n};\nexport default keys;\n//# sourceMappingURL=keys.js.map","import isNil from './is-nil';\nimport keys from './keys';\nfunction isMatch(obj, attrs) {\n var _keys = keys(attrs);\n var length = _keys.length;\n if (isNil(obj))\n return !length;\n for (var i = 0; i < length; i += 1) {\n var key = _keys[i];\n if (attrs[key] !== obj[key] || !(key in obj)) {\n return false;\n }\n }\n return true;\n}\nexport default isMatch;\n//# sourceMappingURL=is-match.js.map","var isObjectLike = function (value) {\n /**\n * isObjectLike({}) => true\n * isObjectLike([1, 2, 3]) => true\n * isObjectLike(Function) => false\n * isObjectLike(null) => false\n */\n return typeof value === 'object' && value !== null;\n};\nexport default isObjectLike;\n//# sourceMappingURL=is-object-like.js.map","import isObjectLike from './is-object-like';\nimport isType from './is-type';\nvar isPlainObject = function (value) {\n /**\n * isObjectLike(new Foo) => false\n * isObjectLike([1, 2, 3]) => false\n * isObjectLike({ x: 0, y: 0 }) => true\n * isObjectLike(Object.create(null)) => true\n */\n if (!isObjectLike(value) || !isType(value, 'Object')) {\n return false;\n }\n if (Object.getPrototypeOf(value) === null) {\n return true;\n }\n var proto = value;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(value) === proto;\n};\nexport default isPlainObject;\n//# sourceMappingURL=is-plain-object.js.map","import isFunction from './is-function';\nimport isMatch from './is-match';\nimport isArray from './is-array';\nimport isPlainObject from './is-plain-object';\nfunction find(arr, predicate) {\n if (!isArray(arr))\n return null;\n var _predicate;\n if (isFunction(predicate)) {\n _predicate = predicate;\n }\n if (isPlainObject(predicate)) {\n _predicate = function (a) { return isMatch(a, predicate); };\n }\n if (_predicate) {\n for (var i = 0; i < arr.length; i += 1) {\n if (_predicate(arr[i])) {\n return arr[i];\n }\n }\n }\n return null;\n}\nexport default find;\n//# sourceMappingURL=find.js.map","function findIndex(arr, predicate, fromIndex) {\n if (fromIndex === void 0) { fromIndex = 0; }\n for (var i = fromIndex; i < arr.length; i++) {\n if (predicate(arr[i], i)) {\n // 找到终止循环\n return i;\n }\n }\n return -1;\n}\nexport default findIndex;\n//# sourceMappingURL=find-index.js.map","import isNil from './is-nil';\nimport isArray from './is-array';\nvar firstValue = function (data, name) {\n var rst = null;\n for (var i = 0; i < data.length; i++) {\n var obj = data[i];\n var value = obj[name];\n if (!isNil(value)) {\n if (isArray(value)) {\n rst = value[0]; // todo 这里是否应该使用递归,调用 firstValue @绝云\n }\n else {\n rst = value;\n }\n break;\n }\n }\n return rst;\n};\nexport default firstValue;\n//# sourceMappingURL=first-value.js.map","import isArray from './is-array';\n/**\n * Flattens `array` a single level deep.\n *\n * @param {Array} arr The array to flatten.\n * @return {Array} Returns the new flattened array.\n * @example\n *\n * flatten([1, [2, [3, [4]], 5]]); // => [1, 2, [3, [4]], 5]\n */\nvar flatten = function (arr) {\n if (!isArray(arr)) {\n return [];\n }\n var rst = [];\n for (var i = 0; i < arr.length; i++) {\n rst = rst.concat(arr[i]);\n }\n return rst;\n};\nexport default flatten;\n//# sourceMappingURL=flatten.js.map","import isArray from './is-array';\n/**\n * Flattens `array` a single level deep.\n *\n * @param {Array} arr The array to flatten.\n * @param {Array} result The array to return.\n * @return {Array} Returns the new flattened array.\n * @example\n *\n * flattenDeep([1, [2, [3, [4]], 5]]); // => [1, 2, 3, 4, 5]\n */\nvar flattenDeep = function (arr, result) {\n if (result === void 0) { result = []; }\n if (!isArray(arr)) {\n result.push(arr);\n }\n else {\n for (var i = 0; i < arr.length; i += 1) {\n flattenDeep(arr[i], result);\n }\n }\n return result;\n};\nexport default flattenDeep;\n//# sourceMappingURL=flatten-deep.js.map","import isArray from './is-array';\n/**\n * @param {Array} arr The array to iterate over.\n * @return {*} Returns the maximum value.\n * @example\n *\n * max([1, 2]);\n * // => 2\n *\n * max([]);\n * // => undefined\n *\n * const data = new Array(1250010).fill(1).map((d,idx) => idx);\n *\n * max(data);\n * // => 1250010\n * // Math.max(...data) will encounter \"Maximum call stack size exceeded\" error\n */\nexport default (function (arr) {\n if (!isArray(arr)) {\n return undefined;\n }\n return arr.reduce(function (prev, curr) {\n return Math.max(prev, curr);\n }, arr[0]);\n});\n//# sourceMappingURL=max.js.map","import isArray from './is-array';\n/**\n * @param {Array} arr The array to iterate over.\n * @return {*} Returns the minimum value.\n * @example\n *\n * min([1, 2]);\n * // => 1\n *\n * min([]);\n * // => undefined\n *\n * const data = new Array(1250010).fill(1).map((d,idx) => idx);\n *\n * min(data);\n * // => 1250010\n * // Math.min(...data) will encounter \"Maximum call stack size exceeded\" error\n */\nexport default (function (arr) {\n if (!isArray(arr)) {\n return undefined;\n }\n return arr.reduce(function (prev, curr) {\n return Math.min(prev, curr);\n }, arr[0]);\n});\n//# sourceMappingURL=min.js.map","import isArray from './is-array';\nimport { default as getMax } from './max';\nimport { default as getMin } from './min';\nvar getRange = function (values) {\n // 存在 NaN 时,min,max 判定会出问题\n var filterValues = values.filter(function (v) { return !isNaN(v); });\n if (!filterValues.length) {\n // 如果没有数值则直接返回0\n return {\n min: 0,\n max: 0,\n };\n }\n if (isArray(values[0])) {\n var tmp = [];\n for (var i = 0; i < values.length; i++) {\n tmp = tmp.concat(values[i]);\n }\n filterValues = tmp;\n }\n var max = getMax(filterValues);\n var min = getMin(filterValues);\n return {\n min: min,\n max: max,\n };\n};\nexport default getRange;\n//# sourceMappingURL=get-range.js.map","var arrPrototype = Array.prototype;\nvar splice = arrPrototype.splice;\nvar indexOf = arrPrototype.indexOf;\nvar pull = function (arr) {\n var values = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n values[_i - 1] = arguments[_i];\n }\n for (var i = 0; i < values.length; i++) {\n var value = values[i];\n var fromIndex = -1;\n while ((fromIndex = indexOf.call(arr, value)) > -1) {\n splice.call(arr, fromIndex, 1);\n }\n }\n return arr;\n};\nexport default pull;\n//# sourceMappingURL=pull.js.map","import isArrayLike from './is-array-like';\nvar splice = Array.prototype.splice;\nvar pullAt = function pullAt(arr, indexes) {\n if (!isArrayLike(arr)) {\n return [];\n }\n var length = arr ? indexes.length : 0;\n var last = length - 1;\n while (length--) {\n var previous = void 0;\n var index = indexes[length];\n if (length === last || index !== previous) {\n previous = index;\n splice.call(arr, index, 1);\n }\n }\n return arr;\n};\nexport default pullAt;\n//# sourceMappingURL=pull-at.js.map","import each from './each';\nimport isArray from './is-array';\nimport isPlainObject from './is-plain-object';\nvar reduce = function (arr, fn, init) {\n if (!isArray(arr) && !isPlainObject(arr)) {\n return arr;\n }\n var result = init;\n each(arr, function (data, i) {\n result = fn(result, data, i);\n });\n return result;\n};\nexport default reduce;\n//# sourceMappingURL=reduce.js.map","import isArrayLike from './is-array-like';\nimport pullAt from './pull-at';\nvar remove = function (arr, predicate) {\n /**\n * const arr = [1, 2, 3, 4]\n * const evens = remove(arr, n => n % 2 == 0)\n * console.log(arr) // => [1, 3]\n * console.log(evens) // => [2, 4]\n */\n var result = [];\n if (!isArrayLike(arr)) {\n return result;\n }\n var i = -1;\n var indexes = [];\n var length = arr.length;\n while (++i < length) {\n var value = arr[i];\n if (predicate(value, i, arr)) {\n result.push(value);\n indexes.push(i);\n }\n }\n pullAt(arr, indexes);\n return result;\n};\nexport default remove;\n//# sourceMappingURL=remove.js.map","import isType from './is-type';\nexport default (function (str) {\n return isType(str, 'String');\n});\n//# sourceMappingURL=is-string.js.map","import isArray from './is-array';\nimport isString from './is-string';\nimport isFunction from './is-function';\nfunction sortBy(arr, key) {\n var comparer;\n if (isFunction(key)) {\n comparer = function (a, b) { return key(a) - key(b); };\n }\n else {\n var keys_1 = [];\n if (isString(key)) {\n keys_1.push(key);\n }\n else if (isArray(key)) {\n keys_1 = key;\n }\n comparer = function (a, b) {\n for (var i = 0; i < keys_1.length; i += 1) {\n var prop = keys_1[i];\n if (a[prop] > b[prop]) {\n return 1;\n }\n if (a[prop] < b[prop]) {\n return -1;\n }\n }\n return 0;\n };\n }\n arr.sort(comparer);\n return arr;\n}\nexport default sortBy;\n//# sourceMappingURL=sort-by.js.map","export default function uniq(arr, cache) {\n if (cache === void 0) { cache = new Map(); }\n var r = [];\n if (Array.isArray(arr)) {\n for (var i = 0, len = arr.length; i < len; i++) {\n var item = arr[i];\n // 加一个 cache,提升性能\n if (!cache.has(item)) {\n r.push(item);\n cache.set(item, true);\n }\n }\n }\n return r;\n}\n//# sourceMappingURL=uniq.js.map","import uniq from './uniq';\nvar union = function () {\n var sources = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n sources[_i] = arguments[_i];\n }\n return uniq([].concat.apply([], sources));\n};\nexport default union;\n//# sourceMappingURL=union.js.map","import isArray from './is-array';\nimport isNil from './is-nil';\nexport default (function (data, name) {\n var rst = [];\n var tmpMap = {};\n for (var i = 0; i < data.length; i++) {\n var obj = data[i];\n var value = obj[name];\n if (!isNil(value)) {\n // flatten\n if (!isArray(value)) {\n value = [value];\n }\n for (var j = 0; j < value.length; j++) {\n var val = value[j];\n // unique\n if (!tmpMap[val]) {\n rst.push(val);\n tmpMap[val] = true;\n }\n }\n }\n }\n return rst;\n});\n//# sourceMappingURL=values-of-key.js.map","import isArrayLike from './is-array-like';\nexport default function head(o) {\n if (isArrayLike(o)) {\n return o[0];\n }\n return undefined;\n}\n//# sourceMappingURL=head.js.map","import isArrayLike from './is-array-like';\nexport default function last(o) {\n if (isArrayLike(o)) {\n var arr = o;\n return arr[arr.length - 1];\n }\n return undefined;\n}\n//# sourceMappingURL=last.js.map","import isArray from './is-array';\nimport isString from './is-string';\nfunction startsWith(arr, e) {\n return (isArray(arr) || isString(arr)) ? arr[0] === e : false;\n}\nexport default startsWith;\n//# sourceMappingURL=starts-with.js.map","import isArray from './is-array';\nimport isString from './is-string';\nfunction endsWith(arr, e) {\n return (isArray(arr) || isString(arr)) ? arr[arr.length - 1] === e : false;\n}\nexport default endsWith;\n//# sourceMappingURL=ends-with.js.map","/**\n * 只要有一个不满足条件就返回 false\n * @param arr\n * @param func\n */\nvar every = function (arr, func) {\n for (var i = 0; i < arr.length; i++) {\n if (!func(arr[i], i))\n return false;\n }\n return true;\n};\nexport default every;\n//# sourceMappingURL=every.js.map","/**\n * 只要有一个满足条件就返回 true\n * @param arr\n * @param func\n */\nvar some = function (arr, func) {\n for (var i = 0; i < arr.length; i++) {\n if (func(arr[i], i))\n return true;\n }\n return false;\n};\nexport default some;\n//# sourceMappingURL=some.js.map","import isArray from './is-array';\nimport isFunction from './is-function';\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction groupBy(data, condition) {\n if (!condition || !isArray(data)) {\n return {};\n }\n var result = {};\n // 兼容方法和 字符串的写法\n var predicate = isFunction(condition) ? condition : function (item) { return item[condition]; };\n var key;\n for (var i = 0; i < data.length; i++) {\n var item = data[i];\n key = predicate(item);\n if (hasOwnProperty.call(result, key)) {\n result[key].push(item);\n }\n else {\n result[key] = [item];\n }\n }\n return result;\n}\nexport default groupBy;\n//# sourceMappingURL=group-by.js.map","import isArray from './is-array';\nimport isFunction from './is-function';\nimport groupBy from './group-by';\n/**\n * 将数据分组成 map\n * @param data\n * @param condition\n */\nexport default function groupToMap(data, condition) {\n if (!condition) {\n return {\n 0: data,\n };\n }\n if (!isFunction(condition)) {\n // 如果是字符串,则按照 a*b 风格成数组\n var paramscondition_1 = isArray(condition) ? condition : condition.replace(/\\s+/g, '').split('*');\n condition = function (row) {\n var unique = '_'; // 避免出现数字作为Key的情况,会进行按照数字的排序\n // 根据字段列表的值,拼接成 key\n for (var i = 0, l = paramscondition_1.length; i < l; i++) {\n unique += row[paramscondition_1[i]] && row[paramscondition_1[i]].toString();\n }\n return unique;\n };\n }\n return groupBy(data, condition);\n}\n//# sourceMappingURL=group-to-map.js.map","import groupToMap from './group-to-map';\nexport default (function (data, condition) {\n if (!condition) {\n // 没有条件,则自身改成数组\n return [data];\n }\n var groups = groupToMap(data, condition);\n var array = [];\n for (var i in groups) {\n array.push(groups[i]);\n }\n return array;\n});\n//# sourceMappingURL=group.js.map","/**\n * 获取封装的事件\n * @protected\n * @param {Object} obj 对象\n * @param {String} action 事件名称\n * @return {Function} 返回事件处理函数\n */\nfunction getWrapBehavior(obj, action) {\n return obj['_wrap_' + action];\n}\nexport default getWrapBehavior;\n//# sourceMappingURL=get-wrap-behavior.js.map","/**\n * 封装事件,便于使用上下文this,和便于解除事件时使用\n * @protected\n * @param {Object} obj 对象\n * @param {String} action 事件名称\n * @return {Function} 返回事件处理函数\n */\nfunction wrapBehavior(obj, action) {\n if (obj['_wrap_' + action]) {\n return obj['_wrap_' + action];\n }\n var method = function (e) {\n obj[action](e);\n };\n obj['_wrap_' + action] = method;\n return method;\n}\nexport default wrapBehavior;\n//# sourceMappingURL=wrap-behavior.js.map","var numColorCache = {};\nfunction numberToColor(num) {\n // 增加缓存\n var color = numColorCache[num];\n if (!color) {\n var str = num.toString(16);\n for (var i = str.length; i < 6; i++) {\n str = '0' + str;\n }\n color = '#' + str;\n numColorCache[num] = color;\n }\n return color;\n}\nexport default numberToColor;\n//# sourceMappingURL=number2color.js.map","import isArray from './is-array';\nfunction parseRadius(radius) {\n var r1 = 0, r2 = 0, r3 = 0, r4 = 0;\n if (isArray(radius)) {\n if (radius.length === 1) {\n r1 = r2 = r3 = r4 = radius[0];\n }\n else if (radius.length === 2) {\n r1 = r3 = radius[0];\n r2 = r4 = radius[1];\n }\n else if (radius.length === 3) {\n r1 = radius[0];\n r2 = r4 = radius[1];\n r3 = radius[2];\n }\n else {\n r1 = radius[0];\n r2 = radius[1];\n r3 = radius[2];\n r4 = radius[3];\n }\n }\n else {\n r1 = r2 = r3 = r4 = radius;\n }\n return {\n r1: r1,\n r2: r2,\n r3: r3,\n r4: r4\n };\n}\nexport default parseRadius;\n//# sourceMappingURL=parse-radius.js.map","var clamp = function (a, min, max) {\n if (a < min) {\n return min;\n }\n else if (a > max) {\n return max;\n }\n return a;\n};\nexport default clamp;\n//# sourceMappingURL=clamp.js.map","var fixedBase = function (v, base) {\n var str = base.toString();\n var index = str.indexOf('.');\n if (index === -1) {\n return Math.round(v);\n }\n var length = str.substr(index + 1).length;\n if (length > 20) {\n length = 20;\n }\n return parseFloat(v.toFixed(length));\n};\nexport default fixedBase;\n//# sourceMappingURL=fixed-base.js.map","/**\n * 判断是否数字\n * @return {Boolean} 是否数字\n */\nimport isType from './is-type';\nvar isNumber = function (value) {\n return isType(value, 'Number');\n};\nexport default isNumber;\n//# sourceMappingURL=is-number.js.map","import isNumber from './is-number';\nvar isDecimal = function (num) {\n return isNumber(num) && num % 1 !== 0;\n};\nexport default isDecimal;\n//# sourceMappingURL=is-decimal.js.map","import isNumber from './is-number';\nvar isEven = function (num) {\n return isNumber(num) && num % 2 === 0;\n};\nexport default isEven;\n//# sourceMappingURL=is-even.js.map","import isNumber from './is-number';\nvar isInteger = Number.isInteger ? Number.isInteger : function (num) {\n return isNumber(num) && num % 1 === 0;\n};\nexport default isInteger;\n//# sourceMappingURL=is-integer.js.map","import isNumber from './is-number';\nvar isNegative = function (num) {\n return isNumber(num) && num < 0;\n};\nexport default isNegative;\n//# sourceMappingURL=is-negative.js.map","var PRECISION = 0.00001; // numbers less than this is considered as 0\nexport default function isNumberEqual(a, b, precision) {\n if (precision === void 0) { precision = PRECISION; }\n return Math.abs((a - b)) < precision;\n}\n;\n//# sourceMappingURL=is-number-equal.js.map","import isNumber from './is-number';\nvar isOdd = function (num) {\n return isNumber(num) && num % 2 !== 0;\n};\nexport default isOdd;\n//# sourceMappingURL=is-odd.js.map","import isNumber from './is-number';\nvar isPositive = function (num) {\n return isNumber(num) && num > 0;\n};\nexport default isPositive;\n//# sourceMappingURL=is-positive.js.map","import isArray from './is-array';\nimport isFunction from './is-function';\n/**\n * @param {Array} arr The array to iterate over.\n * @param {Function} [fn] The iteratee invoked per element.\n * @return {*} Returns the maximum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * maxBy(objects, function(o) { return o.n; });\n * // => { 'n': 2 }\n *\n * maxBy(objects, 'n');\n * // => { 'n': 2 }\n */\nexport default (function (arr, fn) {\n if (!isArray(arr)) {\n return undefined;\n }\n var maxItem;\n var max = -Infinity;\n for (var i = 0; i < arr.length; i++) {\n var item = arr[i];\n var v = isFunction(fn) ? fn(item) : item[fn];\n if (v > max) {\n maxItem = item;\n max = v;\n }\n }\n return maxItem;\n});\n//# sourceMappingURL=max-by.js.map","import isArray from './is-array';\nimport isFunction from './is-function';\n/**\n * @param {Array} arr The array to iterate over.\n * @param {Function} [fn] The iteratee invoked per element.\n * @return {*} Returns the minimum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * minBy(objects, function(o) { return o.n; });\n * // => { 'n': 1 }\n *\n * minBy(objects, 'n');\n * // => { 'n': 1 }\n */\nexport default (function (arr, fn) {\n if (!isArray(arr)) {\n return undefined;\n }\n var minItem;\n var min = Infinity;\n for (var i = 0; i < arr.length; i++) {\n var item = arr[i];\n var v = isFunction(fn) ? fn(item) : item[fn];\n if (v < min) {\n minItem = item;\n min = v;\n }\n }\n return minItem;\n});\n//# sourceMappingURL=min-by.js.map","var mod = function (n, m) {\n return ((n % m) + m) % m;\n};\nexport default mod;\n//# sourceMappingURL=mod.js.map","var DEGREE = 180 / Math.PI;\nvar toDegree = function (radian) {\n return DEGREE * radian;\n};\nexport default toDegree;\n//# sourceMappingURL=to-degree.js.map","export default parseInt;\n//# sourceMappingURL=to-integer.js.map","var RADIAN = Math.PI / 180;\nvar toRadian = function (degree) {\n return RADIAN * degree;\n};\nexport default toRadian;\n//# sourceMappingURL=to-radian.js.map","import each from './each';\nexport default each;\n//# sourceMappingURL=for-in.js.map","export default (function (obj, key) { return obj.hasOwnProperty(key); });\n//# sourceMappingURL=has.js.map","import has from './has';\nexport default has;\n//# sourceMappingURL=has-key.js.map","import each from './each';\nimport isFunction from './is-function';\n// @ts-ignore\nvar values = Object.values ? function (obj) { return Object.values(obj); } : function (obj) {\n var result = [];\n each(obj, function (value, key) {\n if (!(isFunction(obj) && key === 'prototype')) {\n result.push(value);\n }\n });\n return result;\n};\nexport default values;\n//# sourceMappingURL=values.js.map","import contains from './contains';\nimport values from './values';\nexport default (function (obj, value) { return contains(values(obj), value); });\n//# sourceMappingURL=has-value.js.map","import isNil from './is-nil';\nexport default (function (value) {\n if (isNil(value))\n return '';\n return value.toString();\n});\n//# sourceMappingURL=to-string.js.map","import toString from './to-string';\nvar lowerCase = function (str) {\n return toString(str).toLowerCase();\n};\nexport default lowerCase;\n//# sourceMappingURL=lower-case.js.map","import toString from './to-string';\nvar lowerFirst = function (value) {\n var str = toString(value);\n return str.charAt(0).toLowerCase() + str.substring(1);\n};\nexport default lowerFirst;\n//# sourceMappingURL=lower-first.js.map","function substitute(str, o) {\n if (!str || !o) {\n return str;\n }\n return str.replace(/\\\\?\\{([^{}]+)\\}/g, function (match, name) {\n if (match.charAt(0) === '\\\\') {\n return match.slice(1);\n }\n return (o[name] === undefined) ? '' : o[name];\n });\n}\nexport default substitute;\n//# sourceMappingURL=substitute.js.map","import toString from './to-string';\nvar upperCase = function (str) {\n return toString(str).toUpperCase();\n};\nexport default upperCase;\n//# sourceMappingURL=upper-case.js.map","import toString from './to-string';\nvar upperFirst = function (value) {\n var str = toString(value);\n return str.charAt(0).toUpperCase() + str.substring(1);\n};\nexport default upperFirst;\n//# sourceMappingURL=upper-first.js.map","var toString = {}.toString;\nvar getType = function (value) {\n return toString.call(value).replace(/^\\[object /, '').replace(/]$/, '');\n};\nexport default getType;\n//# sourceMappingURL=get-type.js.map","/**\n * 是否是参数类型\n *\n * @param {Object} value 测试的值\n * @return {Boolean}\n */\nimport isType from './is-type';\nvar isArguments = function (value) {\n return isType(value, 'Arguments');\n};\nexport default isArguments;\n//# sourceMappingURL=is-arguments.js.map","/**\n * 是否是布尔类型\n *\n * @param {Object} value 测试的值\n * @return {Boolean}\n */\nimport isType from './is-type';\nvar isBoolean = function (value) {\n return isType(value, 'Boolean');\n};\nexport default isBoolean;\n//# sourceMappingURL=is-boolean.js.map","import isType from './is-type';\nvar isDate = function (value) {\n return isType(value, 'Date');\n};\nexport default isDate;\n//# sourceMappingURL=is-date.js.map","/**\n * 是否是参数类型\n *\n * @param {Object} value 测试的值\n * @return {Boolean}\n */\nimport isType from './is-type';\nvar isError = function (value) {\n return isType(value, 'Error');\n};\nexport default isError;\n//# sourceMappingURL=is-error.js.map","/**\n * 判断是否为有限数\n * @return {Boolean}\n */\nimport isNumber from './is-number';\nexport default function (value) {\n return isNumber(value) && isFinite(value);\n}\n//# sourceMappingURL=is-finite.js.map","var isNull = function (value) {\n return value === null;\n};\nexport default isNull;\n//# sourceMappingURL=is-null.js.map","var objectProto = Object.prototype;\nvar isPrototype = function (value) {\n var Ctor = value && value.constructor;\n var proto = (typeof Ctor === 'function' && Ctor.prototype) || objectProto;\n return value === proto;\n};\nexport default isPrototype;\n//# sourceMappingURL=is-prototype.js.map","import isType from './is-type';\nvar isRegExp = function (str) {\n return isType(str, 'RegExp');\n};\nexport default isRegExp;\n//# sourceMappingURL=is-reg-exp.js.map","var isUndefined = function (value) {\n return value === undefined;\n};\nexport default isUndefined;\n//# sourceMappingURL=is-undefined.js.map","/**\n * 判断是否HTML元素\n * @return {Boolean} 是否HTML元素\n */\nvar isElement = function (o) {\n return o instanceof Element || o instanceof HTMLDocument;\n};\nexport default isElement;\n//# sourceMappingURL=is-element.js.map","export default function requestAnimationFrame(fn) {\n var method = window.requestAnimationFrame ||\n window.webkitRequestAnimationFrame ||\n // @ts-ignore\n window.mozRequestAnimationFrame ||\n // @ts-ignore\n window.msRequestAnimationFrame ||\n function (f) {\n return setTimeout(f, 16);\n };\n return method(fn);\n}\n;\n//# sourceMappingURL=request-animation-frame.js.map","export default function cancelAnimationFrame(handler) {\n var method = window.cancelAnimationFrame ||\n window.webkitCancelAnimationFrame ||\n // @ts-ignore\n window.mozCancelAnimationFrame ||\n // @ts-ignore\n window.msCancelAnimationFrame ||\n clearTimeout;\n method(handler);\n}\n;\n//# sourceMappingURL=clear-animation-frame.js.map","// FIXME: Mutable param should be forbidden in static lang.\nfunction _mix(dist, obj) {\n for (var key in obj) {\n if (obj.hasOwnProperty(key) && key !== 'constructor' && obj[key] !== undefined) {\n dist[key] = obj[key];\n }\n }\n}\nexport default function mix(dist, src1, src2, src3) {\n if (src1)\n _mix(dist, src1);\n if (src2)\n _mix(dist, src2);\n if (src3)\n _mix(dist, src3);\n return dist;\n}\n//# sourceMappingURL=mix.js.map","import mix from './mix';\nimport isFunction from './is-function';\nvar augment = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var c = args[0];\n for (var i = 1; i < args.length; i++) {\n var obj = args[i];\n if (isFunction(obj)) {\n obj = obj.prototype;\n }\n mix(c.prototype, obj);\n }\n};\nexport default augment;\n//# sourceMappingURL=augment.js.map","import isArray from './is-array';\nvar clone = function (obj) {\n if (typeof obj !== 'object' || obj === null) {\n return obj;\n }\n var rst;\n if (isArray(obj)) {\n rst = [];\n for (var i = 0, l = obj.length; i < l; i++) {\n if (typeof obj[i] === 'object' && obj[i] != null) {\n rst[i] = clone(obj[i]);\n }\n else {\n rst[i] = obj[i];\n }\n }\n }\n else {\n rst = {};\n for (var k in obj) {\n if (typeof obj[k] === 'object' && obj[k] != null) {\n rst[k] = clone(obj[k]);\n }\n else {\n rst[k] = obj[k];\n }\n }\n }\n return rst;\n};\nexport default clone;\n//# sourceMappingURL=clone.js.map","function debounce(func, wait, immediate) {\n var timeout;\n return function () {\n var context = this, args = arguments;\n var later = function () {\n timeout = null;\n if (!immediate) {\n func.apply(context, args);\n }\n };\n var callNow = immediate && !timeout;\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n if (callNow) {\n func.apply(context, args);\n }\n };\n}\nexport default debounce;\n//# sourceMappingURL=debounce.js.map","import isFunction from './is-function';\n/**\n * _.memoize(calColor);\n * _.memoize(calColor, (...args) => args[0]);\n * @param f\n * @param resolver\n */\nexport default (function (f, resolver) {\n if (!isFunction(f)) {\n throw new TypeError('Expected a function');\n }\n var memoized = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n // 使用方法构造 key,如果不存在 resolver,则直接取第一个参数作为 key\n var key = resolver ? resolver.apply(this, args) : args[0];\n var cache = memoized.cache;\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = f.apply(this, args);\n // 缓存起来\n cache.set(key, result);\n return result;\n };\n memoized.cache = new Map();\n return memoized;\n});\n//# sourceMappingURL=memoize.js.map","import isArray from './is-array';\nimport isPlainObject from './is-plain-object';\nvar MAX_MIX_LEVEL = 5;\nfunction _deepMix(dist, src, level, maxLevel) {\n level = level || 0;\n maxLevel = maxLevel || MAX_MIX_LEVEL;\n for (var key in src) {\n if (src.hasOwnProperty(key)) {\n var value = src[key];\n if (value !== null && isPlainObject(value)) {\n if (!isPlainObject(dist[key])) {\n dist[key] = {};\n }\n if (level < maxLevel) {\n _deepMix(dist[key], value, level + 1, maxLevel);\n }\n else {\n dist[key] = src[key];\n }\n }\n else if (isArray(value)) {\n dist[key] = [];\n dist[key] = dist[key].concat(value);\n }\n else if (value !== undefined) {\n dist[key] = value;\n }\n }\n }\n}\n// todo 重写\nvar deepMix = function (rst) {\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n for (var i = 0; i < args.length; i += 1) {\n _deepMix(rst, args[i]);\n }\n return rst;\n};\nexport default deepMix;\n//# sourceMappingURL=deep-mix.js.map","import mix from './mix';\nimport isFunction from './is-function';\nvar extend = function (subclass, superclass, overrides, staticOverrides) {\n // 如果只提供父类构造函数,则自动生成子类构造函数\n if (!isFunction(superclass)) {\n overrides = superclass;\n superclass = subclass;\n subclass = function () { };\n }\n var create = Object.create ?\n function (proto, c) {\n return Object.create(proto, {\n constructor: {\n value: c\n }\n });\n } :\n function (proto, c) {\n function Tmp() { }\n Tmp.prototype = proto;\n var o = new Tmp();\n o.constructor = c;\n return o;\n };\n var superObj = create(superclass.prototype, subclass); // new superclass(),//实例化父类作为子类的prototype\n subclass.prototype = mix(superObj, subclass.prototype); // 指定子类的prototype\n subclass.superclass = create(superclass.prototype, superclass);\n mix(superObj, overrides);\n mix(subclass, staticOverrides);\n return subclass;\n};\nexport default extend;\n//# sourceMappingURL=extend.js.map","import isArrayLike from './is-array-like';\nvar indexOf = function (arr, obj) {\n if (!isArrayLike(arr)) {\n return -1;\n }\n var m = Array.prototype.indexOf;\n if (m) {\n return m.call(arr, obj);\n }\n var index = -1;\n for (var i = 0; i < arr.length; i++) {\n if (arr[i] === obj) {\n index = i;\n break;\n }\n }\n return index;\n};\nexport default indexOf;\n//# sourceMappingURL=index-of.js.map","import isNil from './is-nil';\nimport isArrayLike from './is-array-like';\nimport getType from './get-type';\nimport isPrototype from './is-prototype';\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction isEmpty(value) {\n /**\n * isEmpty(null) => true\n * isEmpty() => true\n * isEmpty(true) => true\n * isEmpty(1) => true\n * isEmpty([1, 2, 3]) => false\n * isEmpty('abc') => false\n * isEmpty({ a: 1 }) => false\n */\n if (isNil(value)) {\n return true;\n }\n if (isArrayLike(value)) {\n return !value.length;\n }\n var type = getType(value);\n if (type === 'Map' || type === 'Set') {\n return !value.size;\n }\n if (isPrototype(value)) {\n return !Object.keys(value).length;\n }\n for (var key in value) {\n if (hasOwnProperty.call(value, key)) {\n return false;\n }\n }\n return true;\n}\nexport default isEmpty;\n//# sourceMappingURL=is-empty.js.map","import isObjectLike from './is-object-like';\nimport isArrayLike from './is-array-like';\nimport isString from './is-string';\nvar isEqual = function (value, other) {\n if (value === other) {\n return true;\n }\n if (!value || !other) {\n return false;\n }\n if (isString(value) || isString(other)) {\n return false;\n }\n if (isArrayLike(value) || isArrayLike(other)) {\n if (value.length !== other.length) {\n return false;\n }\n var rst = true;\n for (var i = 0; i < value.length; i++) {\n rst = isEqual(value[i], other[i]);\n if (!rst) {\n break;\n }\n }\n return rst;\n }\n if (isObjectLike(value) || isObjectLike(other)) {\n var valueKeys = Object.keys(value);\n var otherKeys = Object.keys(other);\n if (valueKeys.length !== otherKeys.length) {\n return false;\n }\n var rst = true;\n for (var i = 0; i < valueKeys.length; i++) {\n rst = isEqual(value[valueKeys[i]], other[valueKeys[i]]);\n if (!rst) {\n break;\n }\n }\n return rst;\n }\n return false;\n};\nexport default isEqual;\n//# sourceMappingURL=is-equal.js.map","import isFunction from './is-function';\nimport isEqual from './is-equal';\n/**\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {Function} [fn] The function to customize comparisons.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, othValue) {\n * if (isGreeting(objValue) && isGreeting(othValue)) {\n * return true;\n * }\n * }\n *\n * var array = ['hello', 'goodbye'];\n * var other = ['hi', 'goodbye'];\n *\n * isEqualWith(array, other, customizer); // => true\n */\nexport default (function (value, other, fn) {\n if (!isFunction(fn)) {\n return isEqual(value, other);\n }\n return !!fn(value, other);\n});\n//# sourceMappingURL=is-equal-with.js.map","import isArrayLike from './is-array-like';\nvar map = function (arr, func) {\n if (!isArrayLike(arr)) {\n // @ts-ignore\n return arr;\n }\n var result = [];\n for (var index = 0; index < arr.length; index++) {\n var value = arr[index];\n result.push(func(value, index));\n }\n return result;\n};\nexport default map;\n//# sourceMappingURL=map.js.map","import isNil from './is-nil';\nimport isObject from './is-object';\nvar identity = function (v) { return v; };\nexport default (function (object, func) {\n if (func === void 0) { func = identity; }\n var r = {};\n if (isObject(object) && !isNil(object)) {\n Object.keys(object).forEach(function (key) {\n // @ts-ignore\n r[key] = func(object[key], key);\n });\n }\n return r;\n});\n//# sourceMappingURL=map-values.js.map","import isString from './is-string';\n/**\n * https://github.com/developit/dlv/blob/master/index.js\n * @param obj\n * @param key\n * @param defaultValue\n */\nexport default (function (obj, key, defaultValue) {\n var p = 0;\n var keyArr = isString(key) ? key.split('.') : key;\n while (obj && p < keyArr.length) {\n obj = obj[keyArr[p++]];\n }\n return (obj === undefined || p < keyArr.length) ? defaultValue : obj;\n});\n//# sourceMappingURL=get.js.map","import isObject from './is-object';\nimport isString from './is-string';\nimport isNumber from './is-number';\n/**\n * https://github.com/developit/dlv/blob/master/index.js\n * @param obj\n * @param path\n * @param value\n */\nexport default (function (obj, path, value) {\n var o = obj;\n var keyArr = isString(path) ? path.split('.') : path;\n keyArr.forEach(function (key, idx) {\n // 不是最后一个\n if (idx < keyArr.length - 1) {\n if (!isObject(o[key])) {\n o[key] = isNumber(keyArr[idx + 1]) ? [] : {};\n }\n o = o[key];\n }\n else {\n o[key] = value;\n }\n });\n return obj;\n});\n//# sourceMappingURL=set.js.map","import each from './each';\nimport isPlainObject from './is-plain-object';\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nexport default (function (object, keys) {\n if (object === null || !isPlainObject(object)) {\n return {};\n }\n var result = {};\n each(keys, function (key) {\n if (hasOwnProperty.call(object, key)) {\n result[key] = object[key];\n }\n });\n return result;\n});\n//# sourceMappingURL=pick.js.map","import reduce from './reduce';\nexport default (function (obj, keys) {\n return reduce(obj, function (r, curr, key) {\n if (!keys.includes(key)) {\n r[key] = curr;\n }\n return r;\n }, {});\n});\n//# sourceMappingURL=omit.js.map","export default (function (func, wait, options) {\n var timeout, context, args, result;\n var previous = 0;\n if (!options)\n options = {};\n var later = function () {\n previous = options.leading === false ? 0 : Date.now();\n timeout = null;\n result = func.apply(context, args);\n if (!timeout)\n context = args = null;\n };\n var throttled = function () {\n var now = Date.now();\n if (!previous && options.leading === false)\n previous = now;\n var remaining = wait - (now - previous);\n context = this;\n args = arguments;\n if (remaining <= 0 || remaining > wait) {\n if (timeout) {\n clearTimeout(timeout);\n timeout = null;\n }\n previous = now;\n result = func.apply(context, args);\n if (!timeout)\n context = args = null;\n }\n else if (!timeout && options.trailing !== false) {\n timeout = setTimeout(later, remaining);\n }\n return result;\n };\n throttled.cancel = function () {\n clearTimeout(timeout);\n previous = 0;\n timeout = context = args = null;\n };\n return throttled;\n});\n//# sourceMappingURL=throttle.js.map","import isArrayLike from './is-array-like';\nexport default (function (value) {\n return isArrayLike(value) ? Array.prototype.slice.call(value) : [];\n});\n//# sourceMappingURL=to-array.js.map","var map = {};\nexport default (function (prefix) {\n prefix = prefix || 'g';\n if (!map[prefix]) {\n map[prefix] = 1;\n }\n else {\n map[prefix] += 1;\n }\n return prefix + map[prefix];\n});\n//# sourceMappingURL=unique-id.js.map","export default (function () { });\n//# sourceMappingURL=noop.js.map","export default (function (v) { return v; });\n//# sourceMappingURL=identity.js.map","import isNil from './is-nil';\nimport isArraylike from './is-array-like';\nexport default function size(o) {\n if (isNil(o)) {\n return 0;\n }\n if (isArraylike(o)) {\n return o.length;\n }\n return Object.keys(o).length;\n}\n//# sourceMappingURL=size.js.map","/**\n * k-v 存储\n */\nvar default_1 = /** @class */ (function () {\n function default_1() {\n this.map = {};\n }\n default_1.prototype.has = function (key) {\n return this.map[key] !== undefined;\n };\n default_1.prototype.get = function (key, def) {\n var v = this.map[key];\n return v === undefined ? def : v;\n };\n default_1.prototype.set = function (key, value) {\n this.map[key] = value;\n };\n default_1.prototype.clear = function () {\n this.map = {};\n };\n default_1.prototype.delete = function (key) {\n delete this.map[key];\n };\n default_1.prototype.size = function () {\n return Object.keys(this.map).length;\n };\n return default_1;\n}());\nexport default default_1;\n//# sourceMappingURL=cache.js.map","function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nmodule.exports = _defineProperty;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.multiBindToService = exports.getServiceIdentifierAsString = exports.typeConstraint = exports.namedConstraint = exports.taggedConstraint = exports.traverseAncerstors = exports.decorate = exports.id = exports.MetadataReader = exports.postConstruct = exports.targetName = exports.multiInject = exports.unmanaged = exports.optional = exports.LazyServiceIdentifer = exports.inject = exports.named = exports.tagged = exports.injectable = exports.ContainerModule = exports.AsyncContainerModule = exports.TargetTypeEnum = exports.BindingTypeEnum = exports.BindingScopeEnum = exports.Container = exports.METADATA_KEY = void 0;\nvar keys = require(\"./constants/metadata_keys\");\nexports.METADATA_KEY = keys;\nvar container_1 = require(\"./container/container\");\nObject.defineProperty(exports, \"Container\", { enumerable: true, get: function () { return container_1.Container; } });\nvar literal_types_1 = require(\"./constants/literal_types\");\nObject.defineProperty(exports, \"BindingScopeEnum\", { enumerable: true, get: function () { return literal_types_1.BindingScopeEnum; } });\nObject.defineProperty(exports, \"BindingTypeEnum\", { enumerable: true, get: function () { return literal_types_1.BindingTypeEnum; } });\nObject.defineProperty(exports, \"TargetTypeEnum\", { enumerable: true, get: function () { return literal_types_1.TargetTypeEnum; } });\nvar container_module_1 = require(\"./container/container_module\");\nObject.defineProperty(exports, \"AsyncContainerModule\", { enumerable: true, get: function () { return container_module_1.AsyncContainerModule; } });\nObject.defineProperty(exports, \"ContainerModule\", { enumerable: true, get: function () { return container_module_1.ContainerModule; } });\nvar injectable_1 = require(\"./annotation/injectable\");\nObject.defineProperty(exports, \"injectable\", { enumerable: true, get: function () { return injectable_1.injectable; } });\nvar tagged_1 = require(\"./annotation/tagged\");\nObject.defineProperty(exports, \"tagged\", { enumerable: true, get: function () { return tagged_1.tagged; } });\nvar named_1 = require(\"./annotation/named\");\nObject.defineProperty(exports, \"named\", { enumerable: true, get: function () { return named_1.named; } });\nvar inject_1 = require(\"./annotation/inject\");\nObject.defineProperty(exports, \"inject\", { enumerable: true, get: function () { return inject_1.inject; } });\nObject.defineProperty(exports, \"LazyServiceIdentifer\", { enumerable: true, get: function () { return inject_1.LazyServiceIdentifer; } });\nvar optional_1 = require(\"./annotation/optional\");\nObject.defineProperty(exports, \"optional\", { enumerable: true, get: function () { return optional_1.optional; } });\nvar unmanaged_1 = require(\"./annotation/unmanaged\");\nObject.defineProperty(exports, \"unmanaged\", { enumerable: true, get: function () { return unmanaged_1.unmanaged; } });\nvar multi_inject_1 = require(\"./annotation/multi_inject\");\nObject.defineProperty(exports, \"multiInject\", { enumerable: true, get: function () { return multi_inject_1.multiInject; } });\nvar target_name_1 = require(\"./annotation/target_name\");\nObject.defineProperty(exports, \"targetName\", { enumerable: true, get: function () { return target_name_1.targetName; } });\nvar post_construct_1 = require(\"./annotation/post_construct\");\nObject.defineProperty(exports, \"postConstruct\", { enumerable: true, get: function () { return post_construct_1.postConstruct; } });\nvar metadata_reader_1 = require(\"./planning/metadata_reader\");\nObject.defineProperty(exports, \"MetadataReader\", { enumerable: true, get: function () { return metadata_reader_1.MetadataReader; } });\nvar id_1 = require(\"./utils/id\");\nObject.defineProperty(exports, \"id\", { enumerable: true, get: function () { return id_1.id; } });\nvar decorator_utils_1 = require(\"./annotation/decorator_utils\");\nObject.defineProperty(exports, \"decorate\", { enumerable: true, get: function () { return decorator_utils_1.decorate; } });\nvar constraint_helpers_1 = require(\"./syntax/constraint_helpers\");\nObject.defineProperty(exports, \"traverseAncerstors\", { enumerable: true, get: function () { return constraint_helpers_1.traverseAncerstors; } });\nObject.defineProperty(exports, \"taggedConstraint\", { enumerable: true, get: function () { return constraint_helpers_1.taggedConstraint; } });\nObject.defineProperty(exports, \"namedConstraint\", { enumerable: true, get: function () { return constraint_helpers_1.namedConstraint; } });\nObject.defineProperty(exports, \"typeConstraint\", { enumerable: true, get: function () { return constraint_helpers_1.typeConstraint; } });\nvar serialization_1 = require(\"./utils/serialization\");\nObject.defineProperty(exports, \"getServiceIdentifierAsString\", { enumerable: true, get: function () { return serialization_1.getServiceIdentifierAsString; } });\nvar binding_utils_1 = require(\"./utils/binding_utils\");\nObject.defineProperty(exports, \"multiBindToService\", { enumerable: true, get: function () { return binding_utils_1.multiBindToService; } });\n//# sourceMappingURL=inversify.js.map","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nmodule.exports = _classCallCheck;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}\n\nmodule.exports = _createClass;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","\"use strict\";\n// https://github.com/gpuweb/gpuweb/blob/01b20b4ad93fabae1e8e0d7752515f69708d33e0/spec/index.bs\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// tslint:disable:variable-name\n// String enums\nvar ExtensionName;\n(function (ExtensionName) {\n ExtensionName[\"TextureCompressionBC\"] = \"texture-compression-bc\";\n})(ExtensionName = exports.ExtensionName || (exports.ExtensionName = {}));\nvar AddressMode;\n(function (AddressMode) {\n AddressMode[\"ClampToEdge\"] = \"clamp-to-edge\";\n AddressMode[\"Repeat\"] = \"repeat\";\n AddressMode[\"MirrorRepeat\"] = \"mirror-repeat\";\n})(AddressMode = exports.AddressMode || (exports.AddressMode = {}));\nvar BindingType;\n(function (BindingType) {\n BindingType[\"UniformBuffer\"] = \"uniform-buffer\";\n BindingType[\"StorageBuffer\"] = \"storage-buffer\";\n BindingType[\"ReadonlyStorageBuffer\"] = \"readonly-storage-buffer\";\n BindingType[\"Sampler\"] = \"sampler\";\n BindingType[\"ComparisonSampler\"] = \"comparison-sampler\";\n BindingType[\"SampledTexture\"] = \"sampled-texture\";\n BindingType[\"ReadonlyStorageTexture\"] = \"readonly-storage-texture\";\n BindingType[\"WriteonlyStorageTexture\"] = \"writeonly-storage-texture\";\n})(BindingType = exports.BindingType || (exports.BindingType = {}));\nvar BlendFactor;\n(function (BlendFactor) {\n BlendFactor[\"Zero\"] = \"zero\";\n BlendFactor[\"One\"] = \"one\";\n BlendFactor[\"SrcColor\"] = \"src-color\";\n BlendFactor[\"OneMinusSrcColor\"] = \"one-minus-src-color\";\n BlendFactor[\"SrcAlpha\"] = \"src-alpha\";\n BlendFactor[\"OneMinusSrcAlpha\"] = \"one-minus-src-alpha\";\n BlendFactor[\"DstColor\"] = \"dst-color\";\n BlendFactor[\"OneMinusDstColor\"] = \"one-minus-dst-color\";\n BlendFactor[\"DstAlpha\"] = \"dst-alpha\";\n BlendFactor[\"OneMinusDstAlpha\"] = \"one-minus-dst-alpha\";\n BlendFactor[\"SrcAlphaSaturated\"] = \"src-alpha-saturated\";\n BlendFactor[\"BlendColor\"] = \"blend-color\";\n BlendFactor[\"OneMinusBlendColor\"] = \"one-minus-blend-color\";\n})(BlendFactor = exports.BlendFactor || (exports.BlendFactor = {}));\nvar BlendOperation;\n(function (BlendOperation) {\n BlendOperation[\"Add\"] = \"add\";\n BlendOperation[\"Subtract\"] = \"subtract\";\n BlendOperation[\"ReverseSubtract\"] = \"reverse-subtract\";\n BlendOperation[\"Min\"] = \"min\";\n BlendOperation[\"Max\"] = \"max\";\n})(BlendOperation = exports.BlendOperation || (exports.BlendOperation = {}));\nvar CompareFunction;\n(function (CompareFunction) {\n CompareFunction[\"Never\"] = \"never\";\n CompareFunction[\"Less\"] = \"less\";\n CompareFunction[\"Equal\"] = \"equal\";\n CompareFunction[\"LessEqual\"] = \"less-equal\";\n CompareFunction[\"Greater\"] = \"greater\";\n CompareFunction[\"NotEqual\"] = \"not-equal\";\n CompareFunction[\"GreaterEqual\"] = \"greater-equal\";\n CompareFunction[\"Always\"] = \"always\";\n})(CompareFunction = exports.CompareFunction || (exports.CompareFunction = {}));\nvar CullMode;\n(function (CullMode) {\n CullMode[\"None\"] = \"none\";\n CullMode[\"Front\"] = \"front\";\n CullMode[\"Back\"] = \"back\";\n})(CullMode = exports.CullMode || (exports.CullMode = {}));\nvar FilterMode;\n(function (FilterMode) {\n FilterMode[\"Nearest\"] = \"nearest\";\n FilterMode[\"Linear\"] = \"linear\";\n})(FilterMode = exports.FilterMode || (exports.FilterMode = {}));\nvar FrontFace;\n(function (FrontFace) {\n FrontFace[\"CCW\"] = \"ccw\";\n FrontFace[\"CW\"] = \"cw\";\n})(FrontFace = exports.FrontFace || (exports.FrontFace = {}));\nvar IndexFormat;\n(function (IndexFormat) {\n IndexFormat[\"Uint16\"] = \"uint16\";\n IndexFormat[\"Uint32\"] = \"uint32\";\n})(IndexFormat = exports.IndexFormat || (exports.IndexFormat = {}));\nvar InputStepMode;\n(function (InputStepMode) {\n InputStepMode[\"Vertex\"] = \"vertex\";\n InputStepMode[\"Instance\"] = \"instance\";\n})(InputStepMode = exports.InputStepMode || (exports.InputStepMode = {}));\nvar LoadOp;\n(function (LoadOp) {\n LoadOp[\"Load\"] = \"load\";\n})(LoadOp = exports.LoadOp || (exports.LoadOp = {}));\nvar PrimitiveTopology;\n(function (PrimitiveTopology) {\n PrimitiveTopology[\"PointList\"] = \"point-list\";\n PrimitiveTopology[\"LineList\"] = \"line-list\";\n PrimitiveTopology[\"LineStrip\"] = \"line-strip\";\n PrimitiveTopology[\"TriangleList\"] = \"triangle-list\";\n PrimitiveTopology[\"TriangleStrip\"] = \"triangle-strip\";\n})(PrimitiveTopology = exports.PrimitiveTopology || (exports.PrimitiveTopology = {}));\nvar StencilOperation;\n(function (StencilOperation) {\n StencilOperation[\"Keep\"] = \"keep\";\n StencilOperation[\"Zero\"] = \"zero\";\n StencilOperation[\"Replace\"] = \"replace\";\n StencilOperation[\"Invert\"] = \"invert\";\n StencilOperation[\"IncrementClamp\"] = \"increment-clamp\";\n StencilOperation[\"DecrementClamp\"] = \"decrement-clamp\";\n StencilOperation[\"IncrementWrap\"] = \"increment-wrap\";\n StencilOperation[\"DecrementWrap\"] = \"decrement-wrap\";\n})(StencilOperation = exports.StencilOperation || (exports.StencilOperation = {}));\nvar StoreOp;\n(function (StoreOp) {\n StoreOp[\"Store\"] = \"store\";\n StoreOp[\"Clear\"] = \"clear\";\n})(StoreOp = exports.StoreOp || (exports.StoreOp = {}));\nvar TextureDimension;\n(function (TextureDimension) {\n TextureDimension[\"E1d\"] = \"1d\";\n TextureDimension[\"E2d\"] = \"2d\";\n TextureDimension[\"E3d\"] = \"3d\";\n})(TextureDimension = exports.TextureDimension || (exports.TextureDimension = {}));\nvar TextureFormat;\n(function (TextureFormat) {\n TextureFormat[\"R8Unorm\"] = \"r8unorm\";\n TextureFormat[\"R8Snorm\"] = \"r8snorm\";\n TextureFormat[\"R8Uint\"] = \"r8uint\";\n TextureFormat[\"R8Sint\"] = \"r8sint\";\n TextureFormat[\"R16Uint\"] = \"r16uint\";\n TextureFormat[\"R16Sint\"] = \"r16sint\";\n TextureFormat[\"R16Float\"] = \"r16float\";\n TextureFormat[\"RG8Unorm\"] = \"rg8unorm\";\n TextureFormat[\"RG8Snorm\"] = \"rg8snorm\";\n TextureFormat[\"RG8Uint\"] = \"rg8uint\";\n TextureFormat[\"RG8Sint\"] = \"rg8sint\";\n TextureFormat[\"R32Uint\"] = \"r32uint\";\n TextureFormat[\"R32Sint\"] = \"r32sint\";\n TextureFormat[\"R32Float\"] = \"r32float\";\n TextureFormat[\"RG16Uint\"] = \"rg16uint\";\n TextureFormat[\"RG16Sint\"] = \"rg16sint\";\n TextureFormat[\"RG16Float\"] = \"rg16float\";\n TextureFormat[\"RGBA8Unorm\"] = \"rgba8unorm\";\n TextureFormat[\"RGBA8UnormSRGB\"] = \"rgba8unorm-srgb\";\n TextureFormat[\"RGBA8Snorm\"] = \"rgba8snorm\";\n TextureFormat[\"RGBA8Uint\"] = \"rgba8uint\";\n TextureFormat[\"RGBA8Sint\"] = \"rgba8sint\";\n TextureFormat[\"BGRA8Unorm\"] = \"bgra8unorm\";\n TextureFormat[\"BGRA8UnormSRGB\"] = \"bgra8unorm-srgb\";\n TextureFormat[\"RGB10A2Unorm\"] = \"rgb10a2unorm\";\n TextureFormat[\"RG11B10Float\"] = \"rg11b10float\";\n TextureFormat[\"RG32Uint\"] = \"rg32uint\";\n TextureFormat[\"RG32Sint\"] = \"rg32sint\";\n TextureFormat[\"RG32Float\"] = \"rg32float\";\n TextureFormat[\"RGBA16Uint\"] = \"rgba16uint\";\n TextureFormat[\"RGBA16Sint\"] = \"rgba16sint\";\n TextureFormat[\"RGBA16Float\"] = \"rgba16float\";\n TextureFormat[\"RGBA32Uint\"] = \"rgba32uint\";\n TextureFormat[\"RGBA32Sint\"] = \"rgba32sint\";\n TextureFormat[\"RGBA32Float\"] = \"rgba32float\";\n TextureFormat[\"Depth32Float\"] = \"depth32float\";\n TextureFormat[\"Depth24Plus\"] = \"depth24plus\";\n TextureFormat[\"Depth24PlusStencil8\"] = \"depth24plus-stencil8\";\n})(TextureFormat = exports.TextureFormat || (exports.TextureFormat = {}));\nvar TextureComponentType;\n(function (TextureComponentType) {\n TextureComponentType[\"Float\"] = \"float\";\n TextureComponentType[\"Sint\"] = \"sint\";\n TextureComponentType[\"Uint\"] = \"uint\";\n})(TextureComponentType = exports.TextureComponentType || (exports.TextureComponentType = {}));\nvar TextureViewDimension;\n(function (TextureViewDimension) {\n TextureViewDimension[\"E1d\"] = \"1d\";\n TextureViewDimension[\"E2d\"] = \"2d\";\n TextureViewDimension[\"E2dArray\"] = \"2d-array\";\n TextureViewDimension[\"Cube\"] = \"cube\";\n TextureViewDimension[\"CubeArray\"] = \"cube-array\";\n TextureViewDimension[\"E3d\"] = \"3d\";\n})(TextureViewDimension = exports.TextureViewDimension || (exports.TextureViewDimension = {}));\nvar VertexFormat;\n(function (VertexFormat) {\n VertexFormat[\"Uchar2\"] = \"uchar2\";\n VertexFormat[\"Uchar4\"] = \"uchar4\";\n VertexFormat[\"Char2\"] = \"char2\";\n VertexFormat[\"Char4\"] = \"char4\";\n VertexFormat[\"Uchar2Norm\"] = \"uchar2norm\";\n VertexFormat[\"Uchar4Norm\"] = \"uchar4norm\";\n VertexFormat[\"Char2Norm\"] = \"char2norm\";\n VertexFormat[\"Char4Norm\"] = \"char4norm\";\n VertexFormat[\"Ushort2\"] = \"ushort2\";\n VertexFormat[\"Ushort4\"] = \"ushort4\";\n VertexFormat[\"Short2\"] = \"short2\";\n VertexFormat[\"Short4\"] = \"short4\";\n VertexFormat[\"Ushort2Norm\"] = \"ushort2norm\";\n VertexFormat[\"Ushort4Norm\"] = \"ushort4norm\";\n VertexFormat[\"Short2Norm\"] = \"short2norm\";\n VertexFormat[\"Short4Norm\"] = \"short4norm\";\n VertexFormat[\"Half2\"] = \"half2\";\n VertexFormat[\"Half4\"] = \"half4\";\n VertexFormat[\"Float\"] = \"float\";\n VertexFormat[\"Float2\"] = \"float2\";\n VertexFormat[\"Float3\"] = \"float3\";\n VertexFormat[\"Float4\"] = \"float4\";\n VertexFormat[\"Uint\"] = \"uint\";\n VertexFormat[\"Uint2\"] = \"uint2\";\n VertexFormat[\"Uint3\"] = \"uint3\";\n VertexFormat[\"Uint4\"] = \"uint4\";\n VertexFormat[\"Int\"] = \"int\";\n VertexFormat[\"Int2\"] = \"int2\";\n VertexFormat[\"Int3\"] = \"int3\";\n VertexFormat[\"Int4\"] = \"int4\";\n})(VertexFormat = exports.VertexFormat || (exports.VertexFormat = {}));\nvar TextureAspect;\n(function (TextureAspect) {\n TextureAspect[\"All\"] = \"all\";\n TextureAspect[\"StencilOnly\"] = \"stencil-only\";\n TextureAspect[\"DepthOnly\"] = \"depth-only\";\n})(TextureAspect = exports.TextureAspect || (exports.TextureAspect = {}));\nvar CompilationMessageType;\n(function (CompilationMessageType) {\n CompilationMessageType[\"Error\"] = \"error\";\n CompilationMessageType[\"Warning\"] = \"warning\";\n CompilationMessageType[\"Info\"] = \"info\";\n})(CompilationMessageType = exports.CompilationMessageType || (exports.CompilationMessageType = {}));\nvar QueryType;\n(function (QueryType) {\n QueryType[\"Occlusion\"] = \"occlusion\";\n})(QueryType = exports.QueryType || (exports.QueryType = {}));\n// Bit fields\nvar BufferUsage;\n(function (BufferUsage) {\n BufferUsage[BufferUsage[\"MapRead\"] = 1] = \"MapRead\";\n BufferUsage[BufferUsage[\"MapWrite\"] = 2] = \"MapWrite\";\n BufferUsage[BufferUsage[\"CopySrc\"] = 4] = \"CopySrc\";\n BufferUsage[BufferUsage[\"CopyDst\"] = 8] = \"CopyDst\";\n BufferUsage[BufferUsage[\"Index\"] = 16] = \"Index\";\n BufferUsage[BufferUsage[\"Vertex\"] = 32] = \"Vertex\";\n BufferUsage[BufferUsage[\"Uniform\"] = 64] = \"Uniform\";\n BufferUsage[BufferUsage[\"Storage\"] = 128] = \"Storage\";\n BufferUsage[BufferUsage[\"Indirect\"] = 256] = \"Indirect\";\n BufferUsage[BufferUsage[\"QueryResolve\"] = 512] = \"QueryResolve\";\n})(BufferUsage = exports.BufferUsage || (exports.BufferUsage = {}));\nvar ColorWrite;\n(function (ColorWrite) {\n ColorWrite[ColorWrite[\"Red\"] = 1] = \"Red\";\n ColorWrite[ColorWrite[\"Green\"] = 2] = \"Green\";\n ColorWrite[ColorWrite[\"Blue\"] = 4] = \"Blue\";\n ColorWrite[ColorWrite[\"Alpha\"] = 8] = \"Alpha\";\n ColorWrite[ColorWrite[\"All\"] = 15] = \"All\";\n})(ColorWrite = exports.ColorWrite || (exports.ColorWrite = {}));\nvar ShaderStage;\n(function (ShaderStage) {\n ShaderStage[ShaderStage[\"Vertex\"] = 1] = \"Vertex\";\n ShaderStage[ShaderStage[\"Fragment\"] = 2] = \"Fragment\";\n ShaderStage[ShaderStage[\"Compute\"] = 4] = \"Compute\";\n})(ShaderStage = exports.ShaderStage || (exports.ShaderStage = {}));\nvar TextureUsage;\n(function (TextureUsage) {\n TextureUsage[TextureUsage[\"CopySrc\"] = 1] = \"CopySrc\";\n TextureUsage[TextureUsage[\"CopyDst\"] = 2] = \"CopyDst\";\n TextureUsage[TextureUsage[\"Sampled\"] = 4] = \"Sampled\";\n TextureUsage[TextureUsage[\"Storage\"] = 8] = \"Storage\";\n TextureUsage[TextureUsage[\"OutputAttachment\"] = 16] = \"OutputAttachment\";\n})(TextureUsage = exports.TextureUsage || (exports.TextureUsage = {}));\nvar MapMode;\n(function (MapMode) {\n MapMode[MapMode[\"Read\"] = 1] = \"Read\";\n MapMode[MapMode[\"Write\"] = 2] = \"Write\";\n})(MapMode = exports.MapMode || (exports.MapMode = {}));\n","module.exports = require(\"regenerator-runtime\");\n","function _initializerDefineProperty(target, property, descriptor, context) {\n if (!descriptor) return;\n Object.defineProperty(target, property, {\n enumerable: descriptor.enumerable,\n configurable: descriptor.configurable,\n writable: descriptor.writable,\n value: descriptor.initializer ? descriptor.initializer.call(context) : void 0\n });\n}\n\nmodule.exports = _initializerDefineProperty;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _applyDecoratedDescriptor(target, property, decorators, descriptor, context) {\n var desc = {};\n Object.keys(descriptor).forEach(function (key) {\n desc[key] = descriptor[key];\n });\n desc.enumerable = !!desc.enumerable;\n desc.configurable = !!desc.configurable;\n\n if ('value' in desc || desc.initializer) {\n desc.writable = true;\n }\n\n desc = decorators.slice().reverse().reduce(function (desc, decorator) {\n return decorator(target, property, desc) || desc;\n }, desc);\n\n if (context && desc.initializer !== void 0) {\n desc.value = desc.initializer ? desc.initializer.call(context) : void 0;\n desc.initializer = undefined;\n }\n\n if (desc.initializer === void 0) {\n Object.defineProperty(target, property, desc);\n desc = null;\n }\n\n return desc;\n}\n\nmodule.exports = _applyDecoratedDescriptor;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","/**\r\n * Common utilities\r\n * @module glMatrix\r\n */\n// Configuration Constants\nexport var EPSILON = 0.000001;\nexport var ARRAY_TYPE = typeof Float32Array !== 'undefined' ? Float32Array : Array;\nexport var RANDOM = Math.random;\n/**\r\n * Sets the type of array used when creating new vectors and matrices\r\n *\r\n * @param {Float32ArrayConstructor | ArrayConstructor} type Array type, such as Float32Array or Array\r\n */\n\nexport function setMatrixArrayType(type) {\n ARRAY_TYPE = type;\n}\nvar degree = Math.PI / 180;\n/**\r\n * Convert Degree To Radian\r\n *\r\n * @param {Number} a Angle in Degrees\r\n */\n\nexport function toRadian(a) {\n return a * degree;\n}\n/**\r\n * Tests whether or not the arguments have approximately the same value, within an absolute\r\n * or relative tolerance of glMatrix.EPSILON (an absolute tolerance is used for values less\r\n * than or equal to 1.0, and a relative tolerance is used for larger values)\r\n *\r\n * @param {Number} a The first number to test.\r\n * @param {Number} b The second number to test.\r\n * @returns {Boolean} True if the numbers are approximately equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n return Math.abs(a - b) <= EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));\n}\nif (!Math.hypot) Math.hypot = function () {\n var y = 0,\n i = arguments.length;\n\n while (i--) {\n y += arguments[i] * arguments[i];\n }\n\n return Math.sqrt(y);\n};","export const IDENTIFIER = {\n // SceneGraph\n HierarchyComponentManager: Symbol('HierarchyComponentManager'),\n TransformComponentManager: Symbol('TransformComponentManager'),\n NameComponentManager: Symbol('NameComponentManager'),\n SceneGraphSystem: Symbol('SceneGraphSystem'),\n\n // FrameGraph\n FrameGraphSystem: Symbol('FrameGraphSystem'),\n ResourcePool: Symbol('ResourcePool'),\n ResourceHandleComponentManager: Symbol('ResourceHandleComponentManager'),\n PassNodeComponentManager: Symbol('PassNodeComponentManager'),\n\n // Renderer\n RendererSystem: Symbol('RendererSystem'),\n RenderPass: Symbol('RenderPass'),\n RenderPassFactory: Symbol('Factory<IRenderPass>'),\n Renderable: Symbol('Factory<IRenderPass>'),\n\n // Mesh\n MeshSystem: Symbol('MeshSystem'),\n MeshComponentManager: Symbol('MeshComponentManager'),\n CullableComponentManager: Symbol('CullableComponentManager'),\n\n // Geometry\n Geometry: Symbol('Geometry'),\n GeometrySystem: Symbol('GeometrySystem'),\n GeometryComponentManager: Symbol('GeometryComponentManager'),\n\n // Material\n Material: Symbol('Material'),\n MaterialSystem: Symbol('MaterialSystem'),\n MaterialComponentManager: Symbol('MaterialComponentManager'),\n\n // RenderPath\n ForwardRenderPath: Symbol('ForwardRenderPath'),\n\n // ComputeSystem\n ComputeSystem: Symbol('ComputeSystem'),\n ComputeComponentManager: Symbol('ComputeComponentManager'),\n ComputeStrategy: Symbol('ComputeStrategy'),\n\n Systems: Symbol('Systems'),\n World: Symbol('World'),\n\n // RenderEngine\n RenderEngine: Symbol('RenderEngine'),\n WebGPUEngine: Symbol('WebGPUEngine'),\n WebGLEngine: Symbol('WebGLEngine'),\n\n // Shader Module\n ShaderModuleService: Symbol('ShaderModuleService'),\n ConfigService: Symbol('ConfigService'),\n InteractorService: Symbol('InteractorService'),\n IEventEmitter: Symbol('IEventEmitter'),\n\n // Light\n Light: Symbol('Light'),\n};\n","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nfunction _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}\n\nmodule.exports = _asyncToGenerator;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","export function removeFromArray(arr, obj) {\n var index = arr.indexOf(obj);\n if (index !== -1) {\n arr.splice(index, 1);\n }\n}\nexport var isBrowser = typeof window !== 'undefined' && typeof window.document !== 'undefined';\nexport { isNil, isFunction, isString, isObject, isArray, mix, each, upperFirst } from '@antv/util';\n// 是否元素的父容器\nexport function isParent(container, shape) {\n // 所有 shape 都是 canvas 的子元素\n if (container.isCanvas()) {\n return true;\n }\n var parent = shape.getParent();\n var isParent = false;\n while (parent) {\n if (parent === container) {\n isParent = true;\n break;\n }\n parent = parent.getParent();\n }\n return isParent;\n}\nexport function isAllowCapture(element) {\n // @ts-ignore\n return element.cfg.visible && element.cfg.capture;\n}\n//# sourceMappingURL=util.js.map","export var SHAPE_TO_TAGS = {\n rect: 'path',\n circle: 'circle',\n line: 'line',\n path: 'path',\n marker: 'path',\n text: 'text',\n polyline: 'polyline',\n polygon: 'polygon',\n image: 'image',\n ellipse: 'ellipse',\n dom: 'foreignObject',\n};\nexport var SVG_ATTR_MAP = {\n opacity: 'opacity',\n fillStyle: 'fill',\n fill: 'fill',\n fillOpacity: 'fill-opacity',\n strokeStyle: 'stroke',\n strokeOpacity: 'stroke-opacity',\n stroke: 'stroke',\n x: 'x',\n y: 'y',\n r: 'r',\n rx: 'rx',\n ry: 'ry',\n width: 'width',\n height: 'height',\n x1: 'x1',\n x2: 'x2',\n y1: 'y1',\n y2: 'y2',\n lineCap: 'stroke-linecap',\n lineJoin: 'stroke-linejoin',\n lineWidth: 'stroke-width',\n lineDash: 'stroke-dasharray',\n lineDashOffset: 'stroke-dashoffset',\n miterLimit: 'stroke-miterlimit',\n font: 'font',\n fontSize: 'font-size',\n fontStyle: 'font-style',\n fontVariant: 'font-variant',\n fontWeight: 'font-weight',\n fontFamily: 'font-family',\n startArrow: 'marker-start',\n endArrow: 'marker-end',\n path: 'd',\n class: 'class',\n id: 'id',\n style: 'style',\n preserveAspectRatio: 'preserveAspectRatio',\n};\nexport var EVENTS = [\n 'click',\n 'mousedown',\n 'mouseup',\n 'dblclick',\n 'contextmenu',\n 'mouseenter',\n 'mouseleave',\n 'mouseover',\n 'mouseout',\n 'mousemove',\n 'wheel',\n];\n//# sourceMappingURL=constant.js.map","/**\n * @description 扩展方法,提供 gl-matrix 为提供的方法\n * */\nimport { mat3, vec2 } from 'gl-matrix';\nexport function leftTranslate(out, a, v) {\n var transMat = [0, 0, 0, 0, 0, 0, 0, 0, 0];\n mat3.fromTranslation(transMat, v);\n return mat3.multiply(out, transMat, a);\n}\nexport function leftRotate(out, a, rad) {\n var rotateMat = [0, 0, 0, 0, 0, 0, 0, 0, 0];\n mat3.fromRotation(rotateMat, rad);\n return mat3.multiply(out, rotateMat, a);\n}\nexport function leftScale(out, a, v) {\n var scaleMat = [0, 0, 0, 0, 0, 0, 0, 0, 0];\n mat3.fromScaling(scaleMat, v);\n return mat3.multiply(out, scaleMat, a);\n}\nfunction leftMultiply(out, a, a1) {\n return mat3.multiply(out, a1, a);\n}\n/**\n * 根据 actions 来做 transform\n * @param m\n * @param actions\n */\nexport function transform(m, actions) {\n var matrix = m ? [].concat(m) : [1, 0, 0, 0, 1, 0, 0, 0, 1];\n for (var i = 0, len = actions.length; i < len; i++) {\n var action = actions[i];\n switch (action[0]) {\n case 't':\n leftTranslate(matrix, matrix, [action[1], action[2]]);\n break;\n case 's':\n leftScale(matrix, matrix, [action[1], action[2]]);\n break;\n case 'r':\n leftRotate(matrix, matrix, action[1]);\n break;\n case 'm':\n leftMultiply(matrix, matrix, action[1]);\n break;\n default:\n break;\n }\n }\n return matrix;\n}\n/**\n * 向量 v1 到 向量 v2 夹角的方向\n * @param {Array} v1 向量\n * @param {Array} v2 向量\n * @return {Boolean} >= 0 顺时针 < 0 逆时针\n */\nexport function direction(v1, v2) {\n return v1[0] * v2[1] - v2[0] * v1[1];\n}\n/**\n * 二维向量 v1 到 v2 的夹角\n * @param v1\n * @param v2\n * @param direct\n */\nexport function angleTo(v1, v2, direct) {\n var ang = vec2.angle(v1, v2);\n var angleLargeThanPI = direction(v1, v2) >= 0;\n if (direct) {\n if (angleLargeThanPI) {\n return Math.PI * 2 - ang;\n }\n return ang;\n }\n if (angleLargeThanPI) {\n return ang;\n }\n return Math.PI * 2 - ang;\n}\n/**\n * 计算二维向量的垂直向量\n * @param out\n * @param v\n * @param flag\n */\nexport function vertical(out, v, flag) {\n if (flag) {\n out[0] = v[1];\n out[1] = -1 * v[0];\n }\n else {\n out[0] = -1 * v[1];\n out[1] = v[0];\n }\n return out;\n}\n//# sourceMappingURL=ext.js.map","function _getPrototypeOf(o) {\n module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n module.exports[\"default\"] = module.exports, module.exports.__esModule = true;\n return _getPrototypeOf(o);\n}\n\nmodule.exports = _getPrototypeOf;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function minNum(array) {\n return Math.min.apply(null, array);\n}\nfunction maxNum(array) {\n return Math.max.apply(null, array);\n}\n/**\n * 两点之间的距离\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 结束点 x\n * @param {number} y2 结束点 y\n * @return {number} 距离\n */\nexport function distance(x1, y1, x2, y2) {\n var dx = x1 - x2;\n var dy = y1 - y2;\n return Math.sqrt(dx * dx + dy * dy);\n}\nexport function isNumberEqual(v1, v2) {\n return Math.abs(v1 - v2) < 0.001;\n}\nexport function getBBoxByArray(xArr, yArr) {\n var minX = minNum(xArr);\n var minY = minNum(yArr);\n var maxX = maxNum(xArr);\n var maxY = maxNum(yArr);\n return {\n x: minX,\n y: minY,\n width: maxX - minX,\n height: maxY - minY,\n };\n}\nexport function getBBoxRange(x1, y1, x2, y2) {\n return {\n minX: minNum([x1, x2]),\n maxX: maxNum([x1, x2]),\n minY: minNum([y1, y2]),\n maxY: maxNum([y1, y2]),\n };\n}\nexport function piMod(angle) {\n return (angle + Math.PI * 2) % (Math.PI * 2);\n}\n//# sourceMappingURL=util.js.map","import { distance, getBBoxByArray } from './util';\nimport * as vec2 from 'gl-matrix/vec2';\nexport default {\n /**\n * 计算线段的包围盒\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 结束点 x\n * @param {number} y2 结束点 y\n * @return {object} 包围盒对象\n */\n box: function (x1, y1, x2, y2) {\n return getBBoxByArray([x1, x2], [y1, y2]);\n },\n /**\n * 线段的长度\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 结束点 x\n * @param {number} y2 结束点 y\n * @return {number} 距离\n */\n length: function (x1, y1, x2, y2) {\n return distance(x1, y1, x2, y2);\n },\n /**\n * 根据比例获取点\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 结束点 x\n * @param {number} y2 结束点 y\n * @param {number} t 指定比例\n * @return {object} 包含 x, y 的点\n */\n pointAt: function (x1, y1, x2, y2, t) {\n return {\n x: (1 - t) * x1 + t * x2,\n y: (1 - t) * y1 + t * y2,\n };\n },\n /**\n * 点到线段的距离\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 结束点 x\n * @param {number} y2 结束点 y\n * @param {number} x 测试点 x\n * @param {number} y 测试点 y\n * @return {number} 距离\n */\n pointDistance: function (x1, y1, x2, y2, x, y) {\n // 投影距离 x1, y1 的向量,假设 p, p1, p2 三个点,投影点为 a\n // p1a = p1p.p1p2/|p1p2| * (p1p 的单位向量)\n var cross = (x2 - x1) * (x - x1) + (y2 - y1) * (y - y1);\n if (cross < 0) {\n return distance(x1, y1, x, y);\n }\n var lengthSquare = (x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1);\n if (cross > lengthSquare) {\n return distance(x2, y2, x, y);\n }\n return this.pointToLine(x1, y1, x2, y2, x, y);\n },\n /**\n * 点到直线的距离,而不是点到线段的距离\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 结束点 x\n * @param {number} y2 结束点 y\n * @param {number} x 测试点 x\n * @param {number} y 测试点 y\n * @return {number} 距离\n */\n pointToLine: function (x1, y1, x2, y2, x, y) {\n var d = [x2 - x1, y2 - y1];\n // 如果端点相等,则判定点到点的距离\n if (vec2.exactEquals(d, [0, 0])) {\n return Math.sqrt((x - x1) * (x - x1) + (y - y1) * (y - y1));\n }\n var u = [-d[1], d[0]];\n vec2.normalize(u, u);\n var a = [x - x1, y - y1];\n return Math.abs(vec2.dot(a, u));\n },\n /**\n * 线段的角度\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 结束点 x\n * @param {number} y2 结束点 y\n * @return {number} 导数\n */\n tangentAngle: function (x1, y1, x2, y2) {\n return Math.atan2(y2 - y1, x2 - x1);\n },\n};\n//# sourceMappingURL=line.js.map","import { distance } from './util';\nvar EPSILON = 0.0001;\n/**\n * 使用牛顿切割法求最近的点\n * @param {number[]} xArr 点的 x 数组\n * @param {number[]} yArr 点的 y 数组\n * @param {number} x 指定的点 x\n * @param {number} y 指定的点 y\n * @param {Function} tCallback 差值函数\n */\nexport function nearestPoint(xArr, yArr, x, y, tCallback, length) {\n var t;\n var d = Infinity;\n var v0 = [x, y];\n var segNum = 20;\n if (length && length > 200) {\n segNum = length / 10;\n }\n var increaseRate = 1 / segNum;\n var interval = increaseRate / 10;\n for (var i = 0; i <= segNum; i++) {\n var _t = i * increaseRate;\n var v1 = [tCallback.apply(null, xArr.concat([_t])), tCallback.apply(null, yArr.concat([_t]))];\n var d1 = distance(v0[0], v0[1], v1[0], v1[1]);\n if (d1 < d) {\n t = _t;\n d = d1;\n }\n }\n // 提前终止\n if (t === 0) {\n return {\n x: xArr[0],\n y: yArr[0],\n };\n }\n if (t === 1) {\n var count = xArr.length;\n return {\n x: xArr[count - 1],\n y: yArr[count - 1],\n };\n }\n d = Infinity;\n for (var i = 0; i < 32; i++) {\n if (interval < EPSILON) {\n break;\n }\n var prev = t - interval;\n var next = t + interval;\n var v1 = [tCallback.apply(null, xArr.concat([prev])), tCallback.apply(null, yArr.concat([prev]))];\n var d1 = distance(v0[0], v0[1], v1[0], v1[1]);\n if (prev >= 0 && d1 < d) {\n t = prev;\n d = d1;\n }\n else {\n var v2 = [tCallback.apply(null, xArr.concat([next])), tCallback.apply(null, yArr.concat([next]))];\n var d2 = distance(v0[0], v0[1], v2[0], v2[1]);\n if (next <= 1 && d2 < d) {\n t = next;\n d = d2;\n }\n else {\n interval *= 0.5;\n }\n }\n }\n return {\n x: tCallback.apply(null, xArr.concat([t])),\n y: tCallback.apply(null, yArr.concat([t])),\n };\n}\n// 近似求解 https://community.khronos.org/t/3d-cubic-bezier-segment-length/62363/2\nexport function snapLength(xArr, yArr) {\n var totalLength = 0;\n var count = xArr.length;\n for (var i = 0; i < count; i++) {\n var x = xArr[i];\n var y = yArr[i];\n var nextX = xArr[(i + 1) % count];\n var nextY = yArr[(i + 1) % count];\n totalLength += distance(x, y, nextX, nextY);\n }\n return totalLength / 2;\n}\n//# sourceMappingURL=bezier.js.map","import line from './line';\nimport { distance, isNumberEqual, getBBoxByArray, piMod } from './util';\nimport { nearestPoint } from './bezier';\n// 差值公式\nfunction quadraticAt(p0, p1, p2, t) {\n var onet = 1 - t;\n return onet * onet * p0 + 2 * t * onet * p1 + t * t * p2;\n}\n// 求极值\nfunction extrema(p0, p1, p2) {\n var a = p0 + p2 - 2 * p1;\n if (isNumberEqual(a, 0)) {\n return [0.5];\n }\n var rst = (p0 - p1) / a;\n if (rst <= 1 && rst >= 0) {\n return [rst];\n }\n return [];\n}\nfunction derivativeAt(p0, p1, p2, t) {\n return 2 * (1 - t) * (p1 - p0) + 2 * t * (p2 - p1);\n}\n// 分割贝塞尔曲线\nfunction divideQuadratic(x1, y1, x2, y2, x3, y3, t) {\n // 划分点\n var xt = quadraticAt(x1, x2, x3, t);\n var yt = quadraticAt(y1, y2, y3, t);\n // 分割的第一条曲线的控制点\n var controlPoint1 = line.pointAt(x1, y1, x2, y2, t);\n // 分割的第二条曲线的控制点\n var controlPoint2 = line.pointAt(x2, y2, x3, y3, t);\n return [\n [x1, y1, controlPoint1.x, controlPoint1.y, xt, yt],\n [xt, yt, controlPoint2.x, controlPoint2.y, x3, y3],\n ];\n}\n// 使用迭代法取贝塞尔曲线的长度\nfunction quadraticLength(x1, y1, x2, y2, x3, y3, iterationCount) {\n if (iterationCount === 0) {\n return (distance(x1, y1, x2, y2) + distance(x2, y2, x3, y3) + distance(x1, y1, x3, y3)) / 2;\n }\n var quadratics = divideQuadratic(x1, y1, x2, y2, x3, y3, 0.5);\n var left = quadratics[0];\n var right = quadratics[1];\n left.push(iterationCount - 1);\n right.push(iterationCount - 1);\n return quadraticLength.apply(null, left) + quadraticLength.apply(null, right);\n}\nexport default {\n box: function (x1, y1, x2, y2, x3, y3) {\n var xExtrema = extrema(x1, x2, x3)[0];\n var yExtrema = extrema(y1, y2, y3)[0];\n // 控制点不加入 box 的计算\n var xArr = [x1, x3];\n var yArr = [y1, y3];\n if (xExtrema !== undefined) {\n xArr.push(quadraticAt(x1, x2, x3, xExtrema));\n }\n if (yExtrema !== undefined) {\n yArr.push(quadraticAt(y1, y2, y3, yExtrema));\n }\n return getBBoxByArray(xArr, yArr);\n },\n length: function (x1, y1, x2, y2, x3, y3) {\n return quadraticLength(x1, y1, x2, y2, x3, y3, 3);\n },\n nearestPoint: function (x1, y1, x2, y2, x3, y3, x0, y0) {\n return nearestPoint([x1, x2, x3], [y1, y2, y3], x0, y0, quadraticAt);\n },\n pointDistance: function (x1, y1, x2, y2, x3, y3, x0, y0) {\n var point = this.nearestPoint(x1, y1, x2, y2, x3, y3, x0, y0);\n return distance(point.x, point.y, x0, y0);\n },\n interpolationAt: quadraticAt,\n pointAt: function (x1, y1, x2, y2, x3, y3, t) {\n return {\n x: quadraticAt(x1, x2, x3, t),\n y: quadraticAt(y1, y2, y3, t),\n };\n },\n divide: function (x1, y1, x2, y2, x3, y3, t) {\n return divideQuadratic(x1, y1, x2, y2, x3, y3, t);\n },\n tangentAngle: function (x1, y1, x2, y2, x3, y3, t) {\n var dx = derivativeAt(x1, x2, x3, t);\n var dy = derivativeAt(y1, y2, y3, t);\n var angle = Math.atan2(dy, dx);\n return piMod(angle);\n },\n};\n//# sourceMappingURL=quadratic.js.map","import { distance, isNumberEqual, getBBoxByArray, piMod } from './util';\nimport line from './line';\nimport { snapLength, nearestPoint } from './bezier';\nfunction cubicAt(p0, p1, p2, p3, t) {\n var onet = 1 - t; // t * t * t 的性能大概是 Math.pow(t, 3) 的三倍\n return onet * onet * onet * p0 + 3 * p1 * t * onet * onet + 3 * p2 * t * t * onet + p3 * t * t * t;\n}\nfunction derivativeAt(p0, p1, p2, p3, t) {\n var onet = 1 - t;\n return 3 * (onet * onet * (p1 - p0) + 2 * onet * t * (p2 - p1) + t * t * (p3 - p2));\n}\nfunction extrema(p0, p1, p2, p3) {\n var a = -3 * p0 + 9 * p1 - 9 * p2 + 3 * p3;\n var b = 6 * p0 - 12 * p1 + 6 * p2;\n var c = 3 * p1 - 3 * p0;\n var extremas = [];\n var t1;\n var t2;\n var discSqrt;\n if (isNumberEqual(a, 0)) {\n if (!isNumberEqual(b, 0)) {\n t1 = -c / b;\n if (t1 >= 0 && t1 <= 1) {\n extremas.push(t1);\n }\n }\n }\n else {\n var disc = b * b - 4 * a * c;\n if (isNumberEqual(disc, 0)) {\n extremas.push(-b / (2 * a));\n }\n else if (disc > 0) {\n discSqrt = Math.sqrt(disc);\n t1 = (-b + discSqrt) / (2 * a);\n t2 = (-b - discSqrt) / (2 * a);\n if (t1 >= 0 && t1 <= 1) {\n extremas.push(t1);\n }\n if (t2 >= 0 && t2 <= 1) {\n extremas.push(t2);\n }\n }\n }\n return extremas;\n}\n// 分割贝塞尔曲线\nfunction divideCubic(x1, y1, x2, y2, x3, y3, x4, y4, t) {\n // 划分点\n var xt = cubicAt(x1, x2, x3, x4, t);\n var yt = cubicAt(y1, y2, y3, y4, t);\n // 计算两点之间的差值点\n var c1 = line.pointAt(x1, y1, x2, y2, t);\n var c2 = line.pointAt(x2, y2, x3, y3, t);\n var c3 = line.pointAt(x3, y3, x4, y4, t);\n var c12 = line.pointAt(c1.x, c1.y, c2.x, c2.y, t);\n var c23 = line.pointAt(c2.x, c2.y, c3.x, c3.y, t);\n return [\n [x1, y1, c1.x, c1.y, c12.x, c12.y, xt, yt],\n [xt, yt, c23.x, c23.y, c3.x, c3.y, x4, y4],\n ];\n}\n// 使用迭代法取贝塞尔曲线的长度,二阶和三阶分开写,更清晰和便于调试\nfunction cubicLength(x1, y1, x2, y2, x3, y3, x4, y4, iterationCount) {\n if (iterationCount === 0) {\n return snapLength([x1, x2, x3, x4], [y1, y2, y3, y4]);\n }\n var cubics = divideCubic(x1, y1, x2, y2, x3, y3, x4, y4, 0.5);\n var left = cubics[0];\n var right = cubics[1];\n left.push(iterationCount - 1);\n right.push(iterationCount - 1);\n return cubicLength.apply(null, left) + cubicLength.apply(null, right);\n}\nexport default {\n extrema: extrema,\n box: function (x1, y1, x2, y2, x3, y3, x4, y4) {\n var xArr = [x1, x4];\n var yArr = [y1, y4];\n var xExtrema = extrema(x1, x2, x3, x4);\n var yExtrema = extrema(y1, y2, y3, y4);\n for (var i = 0; i < xExtrema.length; i++) {\n xArr.push(cubicAt(x1, x2, x3, x4, xExtrema[i]));\n }\n for (var i = 0; i < yExtrema.length; i++) {\n yArr.push(cubicAt(y1, y2, y3, y4, yExtrema[i]));\n }\n return getBBoxByArray(xArr, yArr);\n },\n length: function (x1, y1, x2, y2, x3, y3, x4, y4) {\n // 迭代三次,划分成 8 段求长度\n return cubicLength(x1, y1, x2, y2, x3, y3, x4, y4, 3);\n },\n nearestPoint: function (x1, y1, x2, y2, x3, y3, x4, y4, x0, y0, length) {\n return nearestPoint([x1, x2, x3, x4], [y1, y2, y3, y4], x0, y0, cubicAt, length);\n },\n pointDistance: function (x1, y1, x2, y2, x3, y3, x4, y4, x0, y0, length) {\n var point = this.nearestPoint(x1, y1, x2, y2, x3, y3, x4, y4, x0, y0, length);\n return distance(point.x, point.y, x0, y0);\n },\n interpolationAt: cubicAt,\n pointAt: function (x1, y1, x2, y2, x3, y3, x4, y4, t) {\n return {\n x: cubicAt(x1, x2, x3, x4, t),\n y: cubicAt(y1, y2, y3, y4, t),\n };\n },\n divide: function (x1, y1, x2, y2, x3, y3, x4, y4, t) {\n return divideCubic(x1, y1, x2, y2, x3, y3, x4, y4, t);\n },\n tangentAngle: function (x1, y1, x2, y2, x3, y3, x4, y4, t) {\n var dx = derivativeAt(x1, x2, x3, x4, t);\n var dy = derivativeAt(y1, y2, y3, y4, t);\n return piMod(Math.atan2(dy, dx));\n },\n};\n//# sourceMappingURL=cubic.js.map","/**\n * @fileoverview 椭圆的一些计算,\n * - 周长计算参考:https://www.mathsisfun.com/geometry/ellipse-perimeter.html\n * - 距离计算参考:https://wet-robots.ghost.io/simple-method-for-distance-to-ellipse/\n * @author dxq613@gmail.com\n */\nimport { distance, piMod } from './util';\nfunction copysign(v1, v2) {\n var absv = Math.abs(v1);\n return v2 > 0 ? absv : absv * -1;\n}\nexport default {\n /**\n * 包围盒计算\n * @param {number} x 椭圆中心 x\n * @param {number} y 椭圆中心 y\n * @param {number} rx 椭圆 x 方向半径\n * @param {number} ry 椭圆 y 方向半径\n * @return {object} 包围盒\n */\n box: function (x, y, rx, ry) {\n return {\n x: x - rx,\n y: y - ry,\n width: rx * 2,\n height: ry * 2,\n };\n },\n /**\n * 计算周长,使用近似法\n * @param {number} x 椭圆中心 x\n * @param {number} y 椭圆中心 y\n * @param {number} rx 椭圆 x 方向半径\n * @param {number} ry 椭圆 y 方向半径\n * @return {number} 椭圆周长\n */\n length: function (x, y, rx, ry) {\n return Math.PI * (3 * (rx + ry) - Math.sqrt((3 * rx + ry) * (rx + 3 * ry)));\n },\n /**\n * 距离椭圆最近的点\n * @param {number} x 椭圆中心 x\n * @param {number} y 椭圆中心 y\n * @param {number} rx 椭圆 x 方向半径\n * @param {number} ry 椭圆 y 方向半径\n * @param {number} x0 指定的点 x\n * @param {number} y0 指定的点 y\n * @return {object} 椭圆上距离指定点最近的点\n */\n nearestPoint: function (x, y, rx, ry, x0, y0) {\n var a = rx;\n var b = ry;\n // 假如椭圆半径为0则返回圆心\n if (a === 0 || b === 0) {\n return {\n x: x,\n y: y,\n };\n }\n // 转换成 0, 0 为中心的椭圆计算\n var relativeX = x0 - x;\n var relativeY = y0 - y;\n var px = Math.abs(relativeX);\n var py = Math.abs(relativeY);\n var squareA = a * a;\n var squareB = b * b;\n // const angle0 = Math.atan2(relativeY, relativeX);\n var t = Math.PI / 4;\n var nearestX; // 椭圆上的任一点\n var nearestY;\n // 迭代 4 次\n for (var i = 0; i < 4; i++) {\n nearestX = a * Math.cos(t);\n nearestY = b * Math.sin(t);\n var ex = ((squareA - squareB) * Math.pow(Math.cos(t), 3)) / a;\n var ey = ((squareB - squareA) * Math.pow(Math.sin(t), 3)) / b;\n var rx1 = nearestX - ex;\n var ry1 = nearestY - ey;\n var qx = px - ex;\n var qy = py - ey;\n var r = Math.hypot(ry1, rx1);\n var q = Math.hypot(qy, qx);\n var delta_c = r * Math.asin((rx1 * qy - ry1 * qx) / (r * q));\n var delta_t = delta_c / Math.sqrt(squareA + squareB - nearestX * nearestX - nearestY * nearestY);\n t += delta_t;\n t = Math.min(Math.PI / 2, Math.max(0, t));\n }\n return {\n x: x + copysign(nearestX, relativeX),\n y: y + copysign(nearestY, relativeY),\n };\n },\n /**\n * 点到椭圆最近的距离\n * @param {number} x 椭圆中心 x\n * @param {number} y 椭圆中心 y\n * @param {number} rx 椭圆 x 方向半径\n * @param {number} ry 椭圆 y 方向半径\n * @param {number} x0 指定的点 x\n * @param {number} y0 指定的点 y\n * @return {number} 点到椭圆的距离\n */\n pointDistance: function (x, y, rx, ry, x0, y0) {\n var nearestPoint = this.nearestPoint(x, y, rx, ry, x0, y0);\n return distance(nearestPoint.x, nearestPoint.y, x0, y0);\n },\n /**\n * 根据比例获取点\n * @param {number} x 椭圆中心 x\n * @param {number} y 椭圆中心 y\n * @param {number} rx 椭圆 x 方向半径\n * @param {number} ry 椭圆 y 方向半径\n * @param {number} t 指定比例,x轴方向为 0\n * @return {object} 点\n */\n pointAt: function (x, y, rx, ry, t) {\n var angle = 2 * Math.PI * t; // 按照角度进行计算,而不按照周长计算\n return {\n x: x + rx * Math.cos(angle),\n y: y + ry * Math.sin(angle),\n };\n },\n /**\n * 根据比例计算切线角度\n * @param {number} x 椭圆中心 x\n * @param {number} y 椭圆中心 y\n * @param {number} rx 椭圆 x 方向半径\n * @param {number} ry 椭圆 y 方向半径\n * @param {number} t 指定比例 0 - 1 之间,x轴方向为 0。在 0-1 范围之外是循环还是返回 null,还需要调整\n * @return {number} 角度,在 0 - 2PI 之间\n */\n tangentAngle: function (x, y, rx, ry, t) {\n var angle = 2 * Math.PI * t; // 按照角度进行计算,而不按照周长计算\n // 直接使用 x,y 的导数计算, x' = -rx * sin(t); y' = ry * cos(t);\n var tangentAngle = Math.atan2(ry * Math.cos(angle), -rx * Math.sin(angle));\n // 也可以使用指定点的切线方程计算,成本有些高\n // const point = this.pointAt(0, 0, rx, ry, t); // 椭圆的切线同椭圆的中心不相关\n // let tangentAngle = -1 * Math.atan((ry * ry * point.x) / (rx * rx * point.y));\n // if (angle >= 0 && angle <= Math.PI) {\n // tangentAngle += Math.PI;\n // }\n return piMod(tangentAngle);\n },\n};\n//# sourceMappingURL=ellipse.js.map","import { distance, piMod } from './util';\nimport ellipse from './ellipse';\n// 偏导数 x\nfunction derivativeXAt(cx, cy, rx, ry, xRotation, startAngle, endAngle, angle) {\n return -1 * rx * Math.cos(xRotation) * Math.sin(angle) - ry * Math.sin(xRotation) * Math.cos(angle);\n}\n// 偏导数 y\nfunction derivativeYAt(cx, cy, rx, ry, xRotation, startAngle, endAngle, angle) {\n return -1 * rx * Math.sin(xRotation) * Math.sin(angle) + ry * Math.cos(xRotation) * Math.cos(angle);\n}\n// x 的极值\nfunction xExtrema(rx, ry, xRotation) {\n return Math.atan((-ry / rx) * Math.tan(xRotation));\n}\n// y 的极值\nfunction yExtrema(rx, ry, xRotation) {\n return Math.atan(ry / (rx * Math.tan(xRotation)));\n}\n// 根据角度求 x 坐标\nfunction xAt(cx, cy, rx, ry, xRotation, angle) {\n return rx * Math.cos(xRotation) * Math.cos(angle) - ry * Math.sin(xRotation) * Math.sin(angle) + cx;\n}\n// 根据角度求 y 坐标\nfunction yAt(cx, cy, rx, ry, xRotation, angle) {\n return rx * Math.sin(xRotation) * Math.cos(angle) + ry * Math.cos(xRotation) * Math.sin(angle) + cy;\n}\n// 获取点在椭圆上的角度\nfunction getAngle(rx, ry, x0, y0) {\n var angle = Math.atan2(y0 * rx, x0 * ry);\n // 转换到 0 - 2PI 内\n return (angle + Math.PI * 2) % (Math.PI * 2);\n}\n// 根据角度获取,x,y\nfunction getPoint(rx, ry, angle) {\n return {\n x: rx * Math.cos(angle),\n y: ry * Math.sin(angle),\n };\n}\n// 旋转\nfunction rotate(x, y, angle) {\n var cos = Math.cos(angle);\n var sin = Math.sin(angle);\n return [x * cos - y * sin, x * sin + y * cos];\n}\nexport default {\n /**\n * 计算包围盒\n * @param {number} cx 圆心 x\n * @param {number} cy 圆心 y\n * @param {number} rx x 轴方向的半径\n * @param {number} ry y 轴方向的半径\n * @param {number} xRotation 旋转角度\n * @param {number} startAngle 起始角度\n * @param {number} endAngle 结束角度\n * @return {object} 包围盒对象\n */\n box: function (cx, cy, rx, ry, xRotation, startAngle, endAngle) {\n var xDim = xExtrema(rx, ry, xRotation);\n var minX = Infinity;\n var maxX = -Infinity;\n var xs = [startAngle, endAngle];\n for (var i = -Math.PI * 2; i <= Math.PI * 2; i += Math.PI) {\n var xAngle = xDim + i;\n if (startAngle < endAngle) {\n if (startAngle < xAngle && xAngle < endAngle) {\n xs.push(xAngle);\n }\n }\n else {\n if (endAngle < xAngle && xAngle < startAngle) {\n xs.push(xAngle);\n }\n }\n }\n for (var i = 0; i < xs.length; i++) {\n var x = xAt(cx, cy, rx, ry, xRotation, xs[i]);\n if (x < minX) {\n minX = x;\n }\n if (x > maxX) {\n maxX = x;\n }\n }\n var yDim = yExtrema(rx, ry, xRotation);\n var minY = Infinity;\n var maxY = -Infinity;\n var ys = [startAngle, endAngle];\n for (var i = -Math.PI * 2; i <= Math.PI * 2; i += Math.PI) {\n var yAngle = yDim + i;\n if (startAngle < endAngle) {\n if (startAngle < yAngle && yAngle < endAngle) {\n ys.push(yAngle);\n }\n }\n else {\n if (endAngle < yAngle && yAngle < startAngle) {\n ys.push(yAngle);\n }\n }\n }\n for (var i = 0; i < ys.length; i++) {\n var y = yAt(cx, cy, rx, ry, xRotation, ys[i]);\n if (y < minY) {\n minY = y;\n }\n if (y > maxY) {\n maxY = y;\n }\n }\n return {\n x: minX,\n y: minY,\n width: maxX - minX,\n height: maxY - minY,\n };\n },\n /**\n * 获取圆弧的长度,计算圆弧长度时不考虑旋转角度,\n * 仅跟 rx, ry, startAngle, endAngle 相关\n * @param {number} cx 圆心 x\n * @param {number} cy 圆心 y\n * @param {number} rx x 轴方向的半径\n * @param {number} ry y 轴方向的半径\n * @param {number} xRotation 旋转角度\n * @param {number} startAngle 起始角度\n * @param {number} endAngle 结束角度\n */\n length: function (cx, cy, rx, ry, xRotation, startAngle, endAngle) { },\n /**\n * 获取指定点到圆弧的最近距离的点\n * @param {number} cx 圆心 x\n * @param {number} cy 圆心 y\n * @param {number} rx x 轴方向的半径\n * @param {number} ry y 轴方向的半径\n * @param {number} xRotation 旋转角度\n * @param {number} startAngle 起始角度\n * @param {number} endAngle 结束角度\n * @param {number} x0 指定点的 x\n * @param {number} y0 指定点的 y\n * @return {object} 到指定点最近距离的点\n */\n nearestPoint: function (cx, cy, rx, ry, xRotation, startAngle, endAngle, x0, y0) {\n // 将最近距离问题转换成到椭圆中心 0,0 没有旋转的椭圆问题\n var relativeVector = rotate(x0 - cx, y0 - cy, -xRotation);\n var x1 = relativeVector[0], y1 = relativeVector[1];\n // 计算点到椭圆的最近的点\n var relativePoint = ellipse.nearestPoint(0, 0, rx, ry, x1, y1);\n // 获取点在椭圆上的角度\n var angle = getAngle(rx, ry, relativePoint.x, relativePoint.y);\n // 点没有在圆弧上\n if (angle < startAngle) {\n // 小于起始圆弧\n relativePoint = getPoint(rx, ry, startAngle);\n }\n else if (angle > endAngle) {\n // 大于结束圆弧\n relativePoint = getPoint(rx, ry, endAngle);\n }\n // 旋转到 xRotation 的角度\n var vector = rotate(relativePoint.x, relativePoint.y, xRotation);\n return {\n x: vector[0] + cx,\n y: vector[1] + cy,\n };\n },\n pointDistance: function (cx, cy, rx, ry, xRotation, startAngle, endAngle, x0, y0) {\n var nearestPoint = this.nearestPoint(cx, cy, rx, ry, x0, y0);\n return distance(nearestPoint.x, nearestPoint.y, x0, y0);\n },\n pointAt: function (cx, cy, rx, ry, xRotation, startAngle, endAngle, t) {\n var angle = (endAngle - startAngle) * t + startAngle;\n return {\n x: xAt(cx, cy, rx, ry, xRotation, angle),\n y: yAt(cx, cy, rx, ry, xRotation, angle),\n };\n },\n tangentAngle: function (cx, cy, rx, ry, xRotation, startAngle, endAngle, t) {\n var angle = (endAngle - startAngle) * t + startAngle;\n var dx = derivativeXAt(cx, cy, rx, ry, xRotation, startAngle, endAngle, angle);\n var dy = derivativeYAt(cx, cy, rx, ry, xRotation, startAngle, endAngle, angle);\n return piMod(Math.atan2(dy, dx));\n },\n};\n//# sourceMappingURL=arc.js.map","import line from './line';\nimport { distance } from './util';\nfunction analyzePoints(points) {\n // 计算每段的长度和总的长度\n var totalLength = 0;\n var segments = [];\n for (var i = 0; i < points.length - 1; i++) {\n var from = points[i];\n var to = points[i + 1];\n var length_1 = distance(from[0], from[1], to[0], to[1]);\n var seg = {\n from: from,\n to: to,\n length: length_1,\n };\n segments.push(seg);\n totalLength += length_1;\n }\n return { segments: segments, totalLength: totalLength };\n}\nexport function lengthOfSegment(points) {\n if (points.length < 2) {\n return 0;\n }\n var totalLength = 0;\n for (var i = 0; i < points.length - 1; i++) {\n var from = points[i];\n var to = points[i + 1];\n totalLength += distance(from[0], from[1], to[0], to[1]);\n }\n return totalLength;\n}\n/**\n * 按照比例在数据片段中获取点\n * @param {array} points 点的集合\n * @param {number} t 百分比 0-1\n * @return {object} 点的坐标\n */\nexport function pointAtSegments(points, t) {\n // 边界判断\n if (t > 1 || t < 0 || points.length < 2) {\n return null;\n }\n var _a = analyzePoints(points), segments = _a.segments, totalLength = _a.totalLength;\n // 多个点有可能重合\n if (totalLength === 0) {\n return {\n x: points[0][0],\n y: points[0][1],\n };\n }\n // 计算比例\n var startRatio = 0;\n var point = null;\n for (var i = 0; i < segments.length; i++) {\n var seg = segments[i];\n var from = seg.from, to = seg.to;\n var currentRatio = seg.length / totalLength;\n if (t >= startRatio && t <= startRatio + currentRatio) {\n var localRatio = (t - startRatio) / currentRatio;\n point = line.pointAt(from[0], from[1], to[0], to[1], localRatio);\n break;\n }\n startRatio += currentRatio;\n }\n return point;\n}\n/**\n * 按照比例在数据片段中获取切线的角度\n * @param {array} points 点的集合\n * @param {number} t 百分比 0-1\n */\nexport function angleAtSegments(points, t) {\n // 边界判断\n if (t > 1 || t < 0 || points.length < 2) {\n return 0;\n }\n var _a = analyzePoints(points), segments = _a.segments, totalLength = _a.totalLength;\n // 计算比例\n var startRatio = 0;\n var angle = 0;\n for (var i = 0; i < segments.length; i++) {\n var seg = segments[i];\n var from = seg.from, to = seg.to;\n var currentRatio = seg.length / totalLength;\n if (t >= startRatio && t <= startRatio + currentRatio) {\n angle = Math.atan2(to[1] - from[1], to[0] - from[0]);\n break;\n }\n startRatio += currentRatio;\n }\n return angle;\n}\nexport function distanceAtSegment(points, x, y) {\n var minDistance = Infinity;\n for (var i = 0; i < points.length - 1; i++) {\n var point = points[i];\n var nextPoint = points[i + 1];\n var distance_1 = line.pointDistance(point[0], point[1], nextPoint[0], nextPoint[1], x, y);\n if (distance_1 < minDistance) {\n minDistance = distance_1;\n }\n }\n return minDistance;\n}\n//# sourceMappingURL=segments.js.map","import { pointAtSegments, angleAtSegments, distanceAtSegment, lengthOfSegment } from './segments';\nimport { getBBoxByArray } from './util';\nexport default {\n /**\n * 计算多折线的包围盒\n * @param {array} points 点的集合 [x,y] 的形式\n * @return {object} 包围盒\n */\n box: function (points) {\n var xArr = [];\n var yArr = [];\n for (var i = 0; i < points.length; i++) {\n var point = points[i];\n xArr.push(point[0]);\n yArr.push(point[1]);\n }\n return getBBoxByArray(xArr, yArr);\n },\n /**\n * 计算多折线的长度\n * @param {array} points 点的集合 [x,y] 的形式\n * @return {object} 多条边的长度\n */\n length: function (points) {\n return lengthOfSegment(points);\n },\n /**\n * 根据比例获取多折线的点\n * @param {array} points 点的集合 [x,y] 的形式\n * @param {number} t 在多折线的长度上的比例\n * @return {object} 根据比例值计算出来的点\n */\n pointAt: function (points, t) {\n return pointAtSegments(points, t);\n },\n /**\n * 指定点到多折线的距离\n * @param {array} points 点的集合 [x,y] 的形式\n * @param {number} x 指定点的 x\n * @param {number} y 指定点的 y\n * @return {number} 点到多折线的距离\n */\n pointDistance: function (points, x, y) {\n return distanceAtSegment(points, x, y);\n },\n /**\n * 根据比例获取多折线的切线角度\n * @param {array} points 点的集合 [x,y] 的形式\n * @param {number} t 在多折线的长度上的比例\n * @return {object} 根据比例值计算出来的角度\n */\n tangentAngle: function (points, t) {\n return angleAtSegments(points, t);\n },\n};\n//# sourceMappingURL=polyline.js.map","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nmodule.exports = _assertThisInitialized;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}\n\nmodule.exports = _inherits;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","var _typeof = require(\"@babel/runtime/helpers/typeof\")[\"default\"];\n\nvar assertThisInitialized = require(\"./assertThisInitialized.js\");\n\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n\n return assertThisInitialized(self);\n}\n\nmodule.exports = _possibleConstructorReturn;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","import { Entity } from '.';\nimport { EMPTY } from './Entity';\n\ntype NonFunctionPropertyNames<T> = {\n [K in keyof T]: T[K] extends (args: unknown) => void ? never : K;\n}[keyof T];\nexport type NonFunctionProperties<T> = Pick<T, NonFunctionPropertyNames<T>>;\n\nexport type ComponentClassType<P> = new (\n data: Partial<NonFunctionProperties<P>>,\n) => Component<P> & P;\n\nexport abstract class Component<P> {\n constructor(data?: Partial<NonFunctionProperties<P>>) {\n //\n }\n}\n\n/**\n * 管理某一类 Component,尽可能做到 AoS 而非 SoA\n * @see https://wickedengine.net/2019/09/29/entity-component-system/\n * @see https://github.com/turanszkij/WickedEngine/blob/master/WickedEngine/wiECS.h\n */\n// tslint:disable-next-line:max-classes-per-file\nexport class ComponentManager<P> {\n private clazz: ComponentClassType<P>;\n private components: Array<Component<P> & P> = [];\n private entities: Entity[] = [];\n\n /**\n * 不在 Entity 中维护拥有的 Component 列表,反之亦然\n */\n private lookup: Record<Entity, number> = {};\n\n constructor(clazz: ComponentClassType<P>) {\n this.clazz = clazz;\n }\n\n public clear() {\n this.components = [];\n this.entities = [];\n this.lookup = {};\n }\n\n public contains(entity: Entity) {\n return this.lookup[entity] > -1;\n }\n\n public create(entity: Entity, data?: Partial<NonFunctionProperties<P>>) {\n this.lookup[entity] = this.components.length;\n const component = new this.clazz(data || {});\n this.components.push(component);\n this.entities.push(entity);\n return component;\n }\n\n public remove(entity: Entity) {\n const componentIndex = this.lookup[entity];\n if (componentIndex > -1) {\n if (componentIndex < this.components.length - 1) {\n // 将待删除元素和最后一个元素交换\n // C++ 中有 std::move 这样的操作,避免数据的拷贝\n // @see https://github.com/turanszkij/WickedEngine/blob/master/WickedEngine/wiECS.h#L169\n this.components[componentIndex] = this.components[\n this.components.length - 1\n ];\n this.entities[componentIndex] = this.entities[this.entities.length - 1];\n this.lookup[this.entities[componentIndex]] = componentIndex;\n }\n }\n\n // 待删除元素已经移动到了最后一个\n this.components.pop();\n this.entities.pop();\n delete this.lookup[entity];\n }\n\n public removeKeepSorted(entity: Entity) {\n const componentIndex = this.lookup[entity];\n if (componentIndex > -1) {\n const entity2 = this.entities[componentIndex];\n\n if (componentIndex < this.components.length - 1) {\n // Move every component left by one that is after this element:\n for (let i = componentIndex + 1; i < this.components.length; ++i) {\n this.components[i - 1] = this.components[i];\n }\n // Move every entity left by one that is after this element and update lut:\n for (let i = componentIndex + 1; i < this.entities.length; ++i) {\n this.entities[i - 1] = this.entities[i];\n this.lookup[this.entities[i - 1]] = i - 1;\n }\n }\n\n this.components.pop();\n this.entities.pop();\n delete this.lookup[entity2];\n }\n }\n\n public moveItem(srcIndex: number, destIndex: number) {\n if (srcIndex === destIndex) {\n return;\n }\n\n // Save the moved component and entity:\n const srcComponent = this.components[srcIndex];\n const srcEntity = this.entities[srcIndex];\n\n // Every other entity-component that's in the way gets moved by one and lut is kept updated:\n const direction = srcIndex < destIndex ? 1 : -1;\n for (let i = srcIndex; i !== destIndex; i += direction) {\n const next = i + direction;\n this.components[i] = this.components[next];\n this.entities[i] = this.entities[next];\n this.lookup[this.entities[i]] = i;\n }\n\n // Saved entity-component moved to the required position:\n this.components[destIndex] = srcComponent;\n this.entities[destIndex] = srcEntity;\n this.lookup[srcEntity] = destIndex;\n }\n\n public getEntity(index: number) {\n return this.entities[index];\n }\n\n /**\n * 由于缺少类似 C++ 的重载操作符,没法通过 [下标] 直接访问。因此只能增加该方法用于遍历。\n */\n public getComponent(index: number) {\n return this.components[index];\n }\n\n public getComponentByEntity(entity: Entity) {\n const componentIndex = this.lookup[entity];\n if (componentIndex > -1) {\n return this.components[componentIndex];\n }\n return null;\n }\n\n public getCount() {\n return this.components.length;\n }\n\n public getEntityByComponentIndex(componentIdx: number) {\n for (const entity of Object.keys(this.lookup)) {\n const entityInNum = Number(entity);\n if (this.lookup[entityInNum] === componentIdx) {\n return entityInNum;\n }\n }\n return EMPTY;\n }\n\n public find(callback: (component: Component<P> & P, i: number) => boolean) {\n for (let i = 0; i < this.getCount(); i++) {\n const component = this.getComponent(i);\n if (callback(component, i)) {\n return component;\n }\n }\n return null;\n }\n\n public findIndex(\n callback: (component: Component<P> & P, i: number) => boolean,\n ) {\n for (let i = 0; i < this.getCount(); i++) {\n const component = this.getComponent(i);\n if (callback(component, i)) {\n return i;\n }\n }\n return -1;\n }\n\n public forEach(\n callback: (entity: Entity, component: Component<P> & P) => void,\n ) {\n for (const entity of Object.keys(this.lookup)) {\n const entityInNum = Number(entity);\n const componentIndex = this.lookup[entityInNum];\n callback(entityInNum, this.getComponent(componentIndex));\n }\n }\n\n public async forEachAsync(\n callback: (entity: Entity, component: Component<P> & P) => Promise<void>,\n ) {\n for (const entity of Object.keys(this.lookup)) {\n const entityInNum = Number(entity);\n const componentIndex = this.lookup[entityInNum];\n await callback(entityInNum, this.getComponent(componentIndex));\n }\n }\n\n public map(callback: (entity: Entity, component: Component<P> & P) => void) {\n const result = [];\n for (const entity of Object.keys(this.lookup)) {\n const entityInNum = Number(entity);\n const componentIndex = this.lookup[entityInNum];\n result.push(callback(entityInNum, this.getComponent(componentIndex)));\n }\n return result;\n }\n}\n","import { toArray } from '@antv/util';\nimport { SHAPE_TO_TAGS } from '../constant';\n/**\n * 创建并返回图形的 svg 元素\n * @param type svg类型\n */\nexport function createSVGElement(type) {\n return document.createElementNS('http://www.w3.org/2000/svg', type);\n}\n/**\n * 创建并返回图形的 dom 元素\n * @param {IShape} shape 图形\n * @return {SVGElement}\n */\nexport function createDom(shape) {\n var type = SHAPE_TO_TAGS[shape.type];\n var parent = shape.getParent();\n if (!type) {\n throw new Error(\"the type \" + shape.type + \" is not supported by svg\");\n }\n var element = createSVGElement(type);\n if (shape.get('id')) {\n element.id = shape.get('id');\n }\n shape.set('el', element);\n shape.set('attrs', {});\n // 对于 defs 下的 dom 节点,parent 为空,通过 context 统一挂载到 defs 节点下\n if (parent) {\n var parentNode = parent.get('el');\n if (parentNode) {\n parentNode.appendChild(element);\n }\n else {\n // parentNode maybe null for group\n parentNode = parent.createDom();\n parent.set('el', parentNode);\n parentNode.appendChild(element);\n }\n }\n return element;\n}\n/**\n * 对 dom 元素进行排序\n * @param {IElement} element 元素\n * @param {sorter} function 排序函数\n */\nexport function sortDom(element, sorter) {\n var el = element.get('el');\n var childList = toArray(el.children).sort(sorter);\n // create empty fragment\n var fragment = document.createDocumentFragment();\n childList.forEach(function (child) {\n fragment.appendChild(child);\n });\n el.appendChild(fragment);\n}\n/**\n * 将 dom 元素移动到父元素下的指定位置\n * @param {SVGElement} element dom 元素\n * @param {number} targetIndex 目标位置(从 0 开始)\n */\nexport function moveTo(element, targetIndex) {\n var parentNode = element.parentNode;\n var siblings = Array.from(parentNode.childNodes).filter(\n // 要求为元素节点,且不能为 defs 节点\n function (node) { return node.nodeType === 1 && node.nodeName.toLowerCase() !== 'defs'; });\n // 获取目标节点\n var target = siblings[targetIndex];\n var currentIndex = siblings.indexOf(element);\n // 如果目标节点存在\n if (target) {\n // 当前索引 > 目标索引,直接插入到目标节点之前即可\n if (currentIndex > targetIndex) {\n parentNode.insertBefore(element, target);\n }\n else if (currentIndex < targetIndex) {\n // 当前索引 < 目标索引\n // 获取目标节点的下一个节点\n var targetNext = siblings[targetIndex + 1];\n // 如果目标节点的下一个节点存在,插入到该节点之前\n if (targetNext) {\n parentNode.insertBefore(element, targetNext);\n }\n else {\n // 如果该节点不存在,则追加到末尾\n parentNode.appendChild(element);\n }\n }\n }\n else {\n parentNode.appendChild(element);\n }\n}\n//# sourceMappingURL=dom.js.map","var arrayWithoutHoles = require(\"./arrayWithoutHoles.js\");\n\nvar iterableToArray = require(\"./iterableToArray.js\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\n\nvar nonIterableSpread = require(\"./nonIterableSpread.js\");\n\nfunction _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}\n\nmodule.exports = _toConsumableArray;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","/* global window */\n\nvar lodash;\n\nif (typeof require === \"function\") {\n try {\n lodash = {\n cloneDeep: require(\"lodash/cloneDeep\"),\n constant: require(\"lodash/constant\"),\n defaults: require(\"lodash/defaults\"),\n each: require(\"lodash/each\"),\n filter: require(\"lodash/filter\"),\n find: require(\"lodash/find\"),\n flatten: require(\"lodash/flatten\"),\n forEach: require(\"lodash/forEach\"),\n forIn: require(\"lodash/forIn\"),\n has: require(\"lodash/has\"),\n isUndefined: require(\"lodash/isUndefined\"),\n last: require(\"lodash/last\"),\n map: require(\"lodash/map\"),\n mapValues: require(\"lodash/mapValues\"),\n max: require(\"lodash/max\"),\n merge: require(\"lodash/merge\"),\n min: require(\"lodash/min\"),\n minBy: require(\"lodash/minBy\"),\n now: require(\"lodash/now\"),\n pick: require(\"lodash/pick\"),\n range: require(\"lodash/range\"),\n reduce: require(\"lodash/reduce\"),\n sortBy: require(\"lodash/sortBy\"),\n uniqueId: require(\"lodash/uniqueId\"),\n values: require(\"lodash/values\"),\n zipObject: require(\"lodash/zipObject\"),\n };\n } catch (e) {\n // continue regardless of error\n }\n}\n\nif (!lodash) {\n lodash = window._;\n}\n\nmodule.exports = lodash;\n","function _initializerWarningHelper(descriptor, context) {\n throw new Error('Decorating class property failed. Please ensure that ' + 'proposal-class-properties is enabled and runs after the decorators transform.');\n}\n\nmodule.exports = _initializerWarningHelper;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","import { setTransform, setClip } from './svg';\nimport { sortDom, moveTo } from './dom';\nexport function drawChildren(context, children) {\n children.forEach(function (child) {\n child.draw(context);\n });\n}\n/**\n * 更新元素,包括 group 和 shape\n * @param {IElement} element SVG 元素\n * @param {ChangeType} changeType 更新类型\n */\nexport function refreshElement(element, changeType) {\n // 对于还没有挂载到画布下的元素,canvas 可能为空\n var canvas = element.get('canvas');\n // 只有挂载到画布下,才对元素进行实际渲染\n if (canvas && canvas.get('autoDraw')) {\n var context = canvas.get('context');\n var parent_1 = element.getParent();\n var parentChildren = parent_1 ? parent_1.getChildren() : [canvas];\n var el = element.get('el');\n if (changeType === 'remove') {\n var isClipShape = element.get('isClipShape');\n // 对于 clip,不仅需要将 clipShape 对于的 SVG 元素删除,还需要将上层的 clipPath 元素也删除\n if (isClipShape) {\n var clipPathEl = el && el.parentNode;\n var defsEl = clipPathEl && clipPathEl.parentNode;\n if (clipPathEl && defsEl) {\n defsEl.removeChild(clipPathEl);\n }\n }\n else if (el && el.parentNode) {\n el.parentNode.removeChild(el);\n }\n }\n else if (changeType === 'show') {\n el.setAttribute('visibility', 'visible');\n }\n else if (changeType === 'hide') {\n el.setAttribute('visibility', 'hidden');\n }\n else if (changeType === 'zIndex') {\n moveTo(el, parentChildren.indexOf(element));\n }\n else if (changeType === 'sort') {\n var children_1 = element.get('children');\n if (children_1 && children_1.length) {\n sortDom(element, function (a, b) {\n return children_1.indexOf(a) - children_1.indexOf(b) ? 1 : 0;\n });\n }\n }\n else if (changeType === 'clear') {\n // el maybe null for group\n if (el) {\n el.innerHTML = '';\n }\n }\n else if (changeType === 'matrix') {\n setTransform(element);\n }\n else if (changeType === 'clip') {\n setClip(element, context);\n }\n else if (changeType === 'attr') {\n // 已在 afterAttrsChange 进行了处理,此处 do nothing\n }\n else if (changeType === 'add') {\n element.draw(context);\n }\n }\n}\n//# sourceMappingURL=draw.js.map","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.NON_CUSTOM_TAG_KEYS = exports.POST_CONSTRUCT = exports.DESIGN_PARAM_TYPES = exports.PARAM_TYPES = exports.TAGGED_PROP = exports.TAGGED = exports.MULTI_INJECT_TAG = exports.INJECT_TAG = exports.OPTIONAL_TAG = exports.UNMANAGED_TAG = exports.NAME_TAG = exports.NAMED_TAG = void 0;\nexports.NAMED_TAG = \"named\";\nexports.NAME_TAG = \"name\";\nexports.UNMANAGED_TAG = \"unmanaged\";\nexports.OPTIONAL_TAG = \"optional\";\nexports.INJECT_TAG = \"inject\";\nexports.MULTI_INJECT_TAG = \"multi_inject\";\nexports.TAGGED = \"inversify:tagged\";\nexports.TAGGED_PROP = \"inversify:tagged_props\";\nexports.PARAM_TYPES = \"inversify:paramtypes\";\nexports.DESIGN_PARAM_TYPES = \"design:paramtypes\";\nexports.POST_CONSTRUCT = \"post_construct\";\nfunction getNonCustomTagKeys() {\n return [\n exports.INJECT_TAG,\n exports.MULTI_INJECT_TAG,\n exports.NAME_TAG,\n exports.UNMANAGED_TAG,\n exports.NAMED_TAG,\n exports.OPTIONAL_TAG,\n ];\n}\nexports.NON_CUSTOM_TAG_KEYS = getNonCustomTagKeys();\n//# sourceMappingURL=metadata_keys.js.map","import { __assign, __rest } from \"tslib\";\nimport { Path } from '../shape';\nvar sin = Math.sin, cos = Math.cos, atan2 = Math.atan2, PI = Math.PI;\nfunction _addDefaultArrow(shape, attrs, x1, y1, x2, y2, isStart) {\n var stroke = attrs.stroke, lineWidth = attrs.lineWidth;\n var x = x1 - x2;\n var y = y1 - y2;\n var rad = atan2(y, x);\n var arrowShape = new Path({\n type: 'path',\n canvas: shape.get('canvas'),\n isArrowShape: true,\n attrs: {\n // 默认箭头的边长为 10,夹角为 60 度\n path: \"M\" + 10 * cos(PI / 6) + \",\" + 10 * sin(PI / 6) + \" L0,0 L\" + 10 * cos(PI / 6) + \",-\" + 10 * sin(PI / 6),\n // 使用 shape stroke 值\n stroke: stroke,\n lineWidth: lineWidth,\n },\n });\n arrowShape.translate(x2, y2);\n arrowShape.rotateAtPoint(x2, y2, rad);\n shape.set(isStart ? 'startArrowShape' : 'endArrowShape', arrowShape);\n}\n/**\n * 箭头 path 的设置要求\n * 1. 箭头顶点坐标需要为 (0, 0)\n * 2. 箭头夹角的中心分割线需要与 X 轴正方向对齐\n */\nfunction _addCustomizedArrow(shape, attrs, x1, y1, x2, y2, isStart) {\n var startArrow = attrs.startArrow, endArrow = attrs.endArrow, stroke = attrs.stroke, lineWidth = attrs.lineWidth;\n var arrowAttrs = isStart ? startArrow : endArrow;\n var d = arrowAttrs.d, arrowFill = arrowAttrs.fill, arrowStroke = arrowAttrs.stroke, arrowLineWidth = arrowAttrs.lineWidth, restAttrs = __rest(arrowAttrs, [\"d\", \"fill\", \"stroke\", \"lineWidth\"]);\n var x = x1 - x2;\n var y = y1 - y2;\n var rad = atan2(y, x);\n if (d) {\n x2 = x2 - cos(rad) * d;\n y2 = y2 - sin(rad) * d;\n }\n var arrowShape = new Path({\n type: 'path',\n canvas: shape.get('canvas'),\n isArrowShape: true,\n attrs: __assign(__assign({}, restAttrs), { \n // 支持单独设置箭头的 stroke 和 lineWidth,若为空则使用 shape 的值\n stroke: arrowStroke || stroke, lineWidth: arrowLineWidth || lineWidth, \n // 箭头是否填充需要手动设置,不会继承自 shape 的值\n fill: arrowFill }),\n });\n arrowShape.translate(x2, y2);\n arrowShape.rotateAtPoint(x2, y2, rad);\n shape.set(isStart ? 'startArrowShape' : 'endArrowShape', arrowShape);\n}\n/**\n * 如果自定义箭头并且有 d 需要做偏移,如果直接画,线条会超出箭头尖端,因此需要根据箭头偏移 d, 返回线需要缩短的距离\n * |----------------\n * |<|--------------\n * |\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 箭头作用点 x\n * @param {number} y2 箭头作用点 y\n * @param {number} d 箭头沿线条方向的偏移距离\n * @return {{dx: number, dy: number}} 返回线条偏移距离\n */\nexport function getShortenOffset(x1, y1, x2, y2, d) {\n var rad = atan2(y2 - y1, x2 - x1);\n return {\n dx: cos(rad) * d,\n dy: sin(rad) * d,\n };\n}\n/**\n * 绘制起始箭头\n * @param {IShape} shape 图形\n * @param {ShapeAttrs} attrs shape 的绘图属性\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 箭头作用点 x\n * @param {number} y2 箭头作用点 y\n */\nexport function addStartArrow(shape, attrs, x1, y1, x2, y2) {\n if (typeof attrs.startArrow === 'object') {\n _addCustomizedArrow(shape, attrs, x1, y1, x2, y2, true);\n }\n else if (attrs.startArrow) {\n _addDefaultArrow(shape, attrs, x1, y1, x2, y2, true);\n }\n else {\n shape.set('startArrowShape', null);\n }\n}\n/**\n * 绘制结束箭头\n * @param {IShape} shape 图形\n * @param {ShapeAttrs} attrs shape 的绘图属性\n * @param {number} x1 起始点 x\n * @param {number} y1 起始点 y\n * @param {number} x2 箭头作用点 x\n * @param {number} y2 箭头作用点 y\n */\nexport function addEndArrow(shape, attrs, x1, y1, x2, y2) {\n if (typeof attrs.endArrow === 'object') {\n _addCustomizedArrow(shape, attrs, x1, y1, x2, y2, false);\n }\n else if (attrs.endArrow) {\n _addDefaultArrow(shape, attrs, x1, y1, x2, y2, false);\n }\n else {\n shape.set('startArrowShape', null);\n }\n}\n//# sourceMappingURL=arrow.js.map","import { createDom } from './dom';\nexport function setShadow(model, context) {\n var el = model.cfg.el;\n var attrs = model.attr();\n var cfg = {\n dx: attrs.shadowOffsetX,\n dy: attrs.shadowOffsetY,\n blur: attrs.shadowBlur,\n color: attrs.shadowColor,\n };\n if (!cfg.dx && !cfg.dy && !cfg.blur && !cfg.color) {\n el.removeAttribute('filter');\n }\n else {\n var id = context.find('filter', cfg);\n if (!id) {\n id = context.addShadow(cfg);\n }\n el.setAttribute('filter', \"url(#\" + id + \")\");\n }\n}\nexport function setTransform(model) {\n var matrix = model.attr().matrix;\n if (matrix) {\n var el = model.cfg.el;\n var transform = [];\n for (var i = 0; i < 9; i += 3) {\n transform.push(matrix[i] + \",\" + matrix[i + 1]);\n }\n transform = transform.join(',');\n if (transform.indexOf('NaN') === -1) {\n el.setAttribute('transform', \"matrix(\" + transform + \")\");\n }\n else {\n console.warn('invalid matrix:', matrix);\n }\n }\n}\nexport function setClip(model, context) {\n var clip = model.getClip();\n var el = model.get('el');\n if (!clip) {\n el.removeAttribute('clip-path');\n }\n else if (clip && !el.hasAttribute('clip-path')) {\n createDom(clip);\n clip.createPath(context);\n var id = context.addClip(clip);\n el.setAttribute('clip-path', \"url(#\" + id + \")\");\n }\n}\n//# sourceMappingURL=svg.js.map","/**\n * WebGL 枚举值\n * @see http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14\n * 使用 babel 插件对常量进行内联,以减少最终打包产物大小\n * @see https://github.com/uber/deck.gl/blob/7.1-release/dev-docs/roadmaps/dist-size-roadmap.md#inline-gl-constants\n * 为了支持 WebGPU,新增 TextureUsage\n * @see https://gpuweb.github.io/gpuweb/#gputextureusage\n */\nexport enum gl {\n /* ClearBufferMask */\n DEPTH_BUFFER_BIT = 0x00000100,\n STENCIL_BUFFER_BIT = 0x00000400,\n COLOR_BUFFER_BIT = 0x00004000,\n\n /* BeginMode */\n POINTS = 0x0000,\n LINES = 0x0001,\n LINE_LOOP = 0x0002,\n LINE_STRIP = 0x0003,\n TRIANGLES = 0x0004,\n TRIANGLE_STRIP = 0x0005,\n TRIANGLE_FAN = 0x0006,\n\n /* AlphaFunction (not supported in ES20) */\n /* NEVER */\n /* LESS */\n /* EQUAL */\n /* LEQUAL */\n /* GREATER */\n /* NOTEQUAL */\n /* GEQUAL */\n /* ALWAYS */\n\n /* BlendingFactorDest */\n ZERO = 0,\n ONE = 1,\n SRC_COLOR = 0x0300,\n ONE_MINUS_SRC_COLOR = 0x0301,\n SRC_ALPHA = 0x0302,\n ONE_MINUS_SRC_ALPHA = 0x0303,\n DST_ALPHA = 0x0304,\n ONE_MINUS_DST_ALPHA = 0x0305,\n\n /* BlendingFactorSrc */\n /* ZERO */\n /* ONE */\n DST_COLOR = 0x0306,\n ONE_MINUS_DST_COLOR = 0x0307,\n SRC_ALPHA_SATURATE = 0x0308,\n /* SRC_ALPHA */\n /* ONE_MINUS_SRC_ALPHA */\n /* DST_ALPHA */\n /* ONE_MINUS_DST_ALPHA */\n\n /* BlendEquationSeparate */\n FUNC_ADD = 0x8006,\n BLEND_EQUATION = 0x8009,\n BLEND_EQUATION_RGB = 0x8009 /* same as BLEND_EQUATION */,\n BLEND_EQUATION_ALPHA = 0x883d,\n\n /* BlendSubtract */\n FUNC_SUBTRACT = 0x800a,\n FUNC_REVERSE_SUBTRACT = 0x800b,\n\n /** Blend Min Max */\n MAX_EXT = 0x8008,\n MIN_EXT = 0x8007,\n\n /* Separate Blend Functions */\n BLEND_DST_RGB = 0x80c8,\n BLEND_SRC_RGB = 0x80c9,\n BLEND_DST_ALPHA = 0x80ca,\n BLEND_SRC_ALPHA = 0x80cb,\n CONSTANT_COLOR = 0x8001,\n ONE_MINUS_CONSTANT_COLOR = 0x8002,\n CONSTANT_ALPHA = 0x8003,\n ONE_MINUS_CONSTANT_ALPHA = 0x8004,\n BLEND_COLOR = 0x8005,\n\n /* Buffer Objects */\n ARRAY_BUFFER = 0x8892,\n ELEMENT_ARRAY_BUFFER = 0x8893,\n ARRAY_BUFFER_BINDING = 0x8894,\n ELEMENT_ARRAY_BUFFER_BINDING = 0x8895,\n\n STREAM_DRAW = 0x88e0,\n STATIC_DRAW = 0x88e4,\n DYNAMIC_DRAW = 0x88e8,\n\n BUFFER_SIZE = 0x8764,\n BUFFER_USAGE = 0x8765,\n\n CURRENT_VERTEX_ATTRIB = 0x8626,\n\n /* CullFaceMode */\n FRONT = 0x0404,\n BACK = 0x0405,\n FRONT_AND_BACK = 0x0408,\n\n /* DepthFunction */\n /* NEVER */\n /* LESS */\n /* EQUAL */\n /* LEQUAL */\n /* GREATER */\n /* NOTEQUAL */\n /* GEQUAL */\n /* ALWAYS */\n\n /* EnableCap */\n /* TEXTURE_2D */\n CULL_FACE = 0x0b44,\n BLEND = 0x0be2,\n DITHER = 0x0bd0,\n STENCIL_TEST = 0x0b90,\n DEPTH_TEST = 0x0b71,\n SCISSOR_TEST = 0x0c11,\n POLYGON_OFFSET_FILL = 0x8037,\n SAMPLE_ALPHA_TO_COVERAGE = 0x809e,\n SAMPLE_COVERAGE = 0x80a0,\n\n /* ErrorCode */\n NO_ERROR = 0,\n INVALID_ENUM = 0x0500,\n INVALID_VALUE = 0x0501,\n INVALID_OPERATION = 0x0502,\n OUT_OF_MEMORY = 0x0505,\n\n /* FrontFaceDirection */\n CW = 0x0900,\n CCW = 0x0901,\n\n /* GetPName */\n LINE_WIDTH = 0x0b21,\n ALIASED_POINT_SIZE_RANGE = 0x846d,\n ALIASED_LINE_WIDTH_RANGE = 0x846e,\n CULL_FACE_MODE = 0x0b45,\n FRONT_FACE = 0x0b46,\n DEPTH_RANGE = 0x0b70,\n DEPTH_WRITEMASK = 0x0b72,\n DEPTH_CLEAR_VALUE = 0x0b73,\n DEPTH_FUNC = 0x0b74,\n STENCIL_CLEAR_VALUE = 0x0b91,\n STENCIL_FUNC = 0x0b92,\n STENCIL_FAIL = 0x0b94,\n STENCIL_PASS_DEPTH_FAIL = 0x0b95,\n STENCIL_PASS_DEPTH_PASS = 0x0b96,\n STENCIL_REF = 0x0b97,\n STENCIL_VALUE_MASK = 0x0b93,\n STENCIL_WRITEMASK = 0x0b98,\n STENCIL_BACK_FUNC = 0x8800,\n STENCIL_BACK_FAIL = 0x8801,\n STENCIL_BACK_PASS_DEPTH_FAIL = 0x8802,\n STENCIL_BACK_PASS_DEPTH_PASS = 0x8803,\n STENCIL_BACK_REF = 0x8ca3,\n STENCIL_BACK_VALUE_MASK = 0x8ca4,\n STENCIL_BACK_WRITEMASK = 0x8ca5,\n VIEWPORT = 0x0ba2,\n SCISSOR_BOX = 0x0c10,\n /* SCISSOR_TEST */\n COLOR_CLEAR_VALUE = 0x0c22,\n COLOR_WRITEMASK = 0x0c23,\n UNPACK_ALIGNMENT = 0x0cf5,\n PACK_ALIGNMENT = 0x0d05,\n MAX_TEXTURE_SIZE = 0x0d33,\n MAX_VIEWPORT_DIMS = 0x0d3a,\n SUBPIXEL_BITS = 0x0d50,\n RED_BITS = 0x0d52,\n GREEN_BITS = 0x0d53,\n BLUE_BITS = 0x0d54,\n ALPHA_BITS = 0x0d55,\n DEPTH_BITS = 0x0d56,\n STENCIL_BITS = 0x0d57,\n POLYGON_OFFSET_UNITS = 0x2a00,\n /* POLYGON_OFFSET_FILL */\n POLYGON_OFFSET_FACTOR = 0x8038,\n TEXTURE_BINDING_2D = 0x8069,\n SAMPLE_BUFFERS = 0x80a8,\n SAMPLES = 0x80a9,\n SAMPLE_COVERAGE_VALUE = 0x80aa,\n SAMPLE_COVERAGE_INVERT = 0x80ab,\n\n /* GetTextureParameter */\n /* TEXTURE_MAG_FILTER */\n /* TEXTURE_MIN_FILTER */\n /* TEXTURE_WRAP_S */\n /* TEXTURE_WRAP_T */\n\n COMPRESSED_TEXTURE_FORMATS = 0x86a3,\n\n /* HintMode */\n DONT_CARE = 0x1100,\n FASTEST = 0x1101,\n NICEST = 0x1102,\n\n /* HintTarget */\n GENERATE_MIPMAP_HINT = 0x8192,\n\n /* DataType */\n BYTE = 0x1400,\n UNSIGNED_BYTE = 0x1401,\n SHORT = 0x1402,\n UNSIGNED_SHORT = 0x1403,\n INT = 0x1404,\n UNSIGNED_INT = 0x1405,\n FLOAT = 0x1406,\n\n /* PixelFormat */\n DEPTH_COMPONENT = 0x1902,\n ALPHA = 0x1906,\n RGB = 0x1907,\n RGBA = 0x1908,\n LUMINANCE = 0x1909,\n LUMINANCE_ALPHA = 0x190a,\n\n /* PixelType */\n /* UNSIGNED_BYTE */\n UNSIGNED_SHORT_4_4_4_4 = 0x8033,\n UNSIGNED_SHORT_5_5_5_1 = 0x8034,\n UNSIGNED_SHORT_5_6_5 = 0x8363,\n\n /* Shaders */\n FRAGMENT_SHADER = 0x8b30,\n VERTEX_SHADER = 0x8b31,\n MAX_VERTEX_ATTRIBS = 0x8869,\n MAX_VERTEX_UNIFORM_VECTORS = 0x8dfb,\n MAX_VARYING_VECTORS = 0x8dfc,\n MAX_COMBINED_TEXTURE_IMAGE_UNITS = 0x8b4d,\n MAX_VERTEX_TEXTURE_IMAGE_UNITS = 0x8b4c,\n MAX_TEXTURE_IMAGE_UNITS = 0x8872,\n MAX_FRAGMENT_UNIFORM_VECTORS = 0x8dfd,\n SHADER_TYPE = 0x8b4f,\n DELETE_STATUS = 0x8b80,\n LINK_STATUS = 0x8b82,\n VALIDATE_STATUS = 0x8b83,\n ATTACHED_SHADERS = 0x8b85,\n ACTIVE_UNIFORMS = 0x8b86,\n ACTIVE_ATTRIBUTES = 0x8b89,\n SHADING_LANGUAGE_VERSION = 0x8b8c,\n CURRENT_PROGRAM = 0x8b8d,\n\n /* StencilFunction */\n NEVER = 0x0200,\n LESS = 0x0201,\n EQUAL = 0x0202,\n LEQUAL = 0x0203,\n GREATER = 0x0204,\n NOTEQUAL = 0x0205,\n GEQUAL = 0x0206,\n ALWAYS = 0x0207,\n\n /* StencilOp */\n /* ZERO */\n KEEP = 0x1e00,\n REPLACE = 0x1e01,\n INCR = 0x1e02,\n DECR = 0x1e03,\n INVERT = 0x150a,\n INCR_WRAP = 0x8507,\n DECR_WRAP = 0x8508,\n\n /* StringName */\n VENDOR = 0x1f00,\n RENDERER = 0x1f01,\n VERSION = 0x1f02,\n\n /* TextureMagFilter */\n NEAREST = 0x2600,\n LINEAR = 0x2601,\n\n /* TextureMinFilter */\n /* NEAREST */\n /* LINEAR */\n NEAREST_MIPMAP_NEAREST = 0x2700,\n LINEAR_MIPMAP_NEAREST = 0x2701,\n NEAREST_MIPMAP_LINEAR = 0x2702,\n LINEAR_MIPMAP_LINEAR = 0x2703,\n\n /* TextureParameterName */\n TEXTURE_MAG_FILTER = 0x2800,\n TEXTURE_MIN_FILTER = 0x2801,\n TEXTURE_WRAP_S = 0x2802,\n TEXTURE_WRAP_T = 0x2803,\n\n /* TextureTarget */\n TEXTURE_2D = 0x0de1,\n TEXTURE = 0x1702,\n\n TEXTURE_CUBE_MAP = 0x8513,\n TEXTURE_BINDING_CUBE_MAP = 0x8514,\n TEXTURE_CUBE_MAP_POSITIVE_X = 0x8515,\n TEXTURE_CUBE_MAP_NEGATIVE_X = 0x8516,\n TEXTURE_CUBE_MAP_POSITIVE_Y = 0x8517,\n TEXTURE_CUBE_MAP_NEGATIVE_Y = 0x8518,\n TEXTURE_CUBE_MAP_POSITIVE_Z = 0x8519,\n TEXTURE_CUBE_MAP_NEGATIVE_Z = 0x851a,\n MAX_CUBE_MAP_TEXTURE_SIZE = 0x851c,\n\n /* TextureUnit */\n TEXTURE0 = 0x84c0,\n TEXTURE1 = 0x84c1,\n TEXTURE2 = 0x84c2,\n TEXTURE3 = 0x84c3,\n TEXTURE4 = 0x84c4,\n TEXTURE5 = 0x84c5,\n TEXTURE6 = 0x84c6,\n TEXTURE7 = 0x84c7,\n TEXTURE8 = 0x84c8,\n TEXTURE9 = 0x84c9,\n TEXTURE10 = 0x84ca,\n TEXTURE11 = 0x84cb,\n TEXTURE12 = 0x84cc,\n TEXTURE13 = 0x84cd,\n TEXTURE14 = 0x84ce,\n TEXTURE15 = 0x84cf,\n TEXTURE16 = 0x84d0,\n TEXTURE17 = 0x84d1,\n TEXTURE18 = 0x84d2,\n TEXTURE19 = 0x84d3,\n TEXTURE20 = 0x84d4,\n TEXTURE21 = 0x84d5,\n TEXTURE22 = 0x84d6,\n TEXTURE23 = 0x84d7,\n TEXTURE24 = 0x84d8,\n TEXTURE25 = 0x84d9,\n TEXTURE26 = 0x84da,\n TEXTURE27 = 0x84db,\n TEXTURE28 = 0x84dc,\n TEXTURE29 = 0x84dd,\n TEXTURE30 = 0x84de,\n TEXTURE31 = 0x84df,\n ACTIVE_TEXTURE = 0x84e0,\n\n /* TextureWrapMode */\n REPEAT = 0x2901,\n CLAMP_TO_EDGE = 0x812f,\n MIRRORED_REPEAT = 0x8370,\n\n /* Uniform Types */\n FLOAT_VEC2 = 0x8b50,\n FLOAT_VEC3 = 0x8b51,\n FLOAT_VEC4 = 0x8b52,\n INT_VEC2 = 0x8b53,\n INT_VEC3 = 0x8b54,\n INT_VEC4 = 0x8b55,\n BOOL = 0x8b56,\n BOOL_VEC2 = 0x8b57,\n BOOL_VEC3 = 0x8b58,\n BOOL_VEC4 = 0x8b59,\n FLOAT_MAT2 = 0x8b5a,\n FLOAT_MAT3 = 0x8b5b,\n FLOAT_MAT4 = 0x8b5c,\n SAMPLER_2D = 0x8b5e,\n SAMPLER_CUBE = 0x8b60,\n\n /* Vertex Arrays */\n VERTEX_ATTRIB_ARRAY_ENABLED = 0x8622,\n VERTEX_ATTRIB_ARRAY_SIZE = 0x8623,\n VERTEX_ATTRIB_ARRAY_STRIDE = 0x8624,\n VERTEX_ATTRIB_ARRAY_TYPE = 0x8625,\n VERTEX_ATTRIB_ARRAY_NORMALIZED = 0x886a,\n VERTEX_ATTRIB_ARRAY_POINTER = 0x8645,\n VERTEX_ATTRIB_ARRAY_BUFFER_BINDING = 0x889f,\n\n /* Shader Source */\n COMPILE_STATUS = 0x8b81,\n\n /* Shader Precision-Specified Types */\n LOW_FLOAT = 0x8df0,\n MEDIUM_FLOAT = 0x8df1,\n HIGH_FLOAT = 0x8df2,\n LOW_INT = 0x8df3,\n MEDIUM_INT = 0x8df4,\n HIGH_INT = 0x8df5,\n\n /* Framebuffer Object. */\n FRAMEBUFFER = 0x8d40,\n RENDERBUFFER = 0x8d41,\n\n RGBA4 = 0x8056,\n RGB5_A1 = 0x8057,\n RGB565 = 0x8d62,\n DEPTH_COMPONENT16 = 0x81a5,\n STENCIL_INDEX = 0x1901,\n STENCIL_INDEX8 = 0x8d48,\n DEPTH_STENCIL = 0x84f9,\n\n RENDERBUFFER_WIDTH = 0x8d42,\n RENDERBUFFER_HEIGHT = 0x8d43,\n RENDERBUFFER_INTERNAL_FORMAT = 0x8d44,\n RENDERBUFFER_RED_SIZE = 0x8d50,\n RENDERBUFFER_GREEN_SIZE = 0x8d51,\n RENDERBUFFER_BLUE_SIZE = 0x8d52,\n RENDERBUFFER_ALPHA_SIZE = 0x8d53,\n RENDERBUFFER_DEPTH_SIZE = 0x8d54,\n RENDERBUFFER_STENCIL_SIZE = 0x8d55,\n\n FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE = 0x8cd0,\n FRAMEBUFFER_ATTACHMENT_OBJECT_NAME = 0x8cd1,\n FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL = 0x8cd2,\n FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE = 0x8cd3,\n\n COLOR_ATTACHMENT0 = 0x8ce0,\n DEPTH_ATTACHMENT = 0x8d00,\n STENCIL_ATTACHMENT = 0x8d20,\n DEPTH_STENCIL_ATTACHMENT = 0x821a,\n\n NONE = 0,\n\n FRAMEBUFFER_COMPLETE = 0x8cd5,\n FRAMEBUFFER_INCOMPLETE_ATTACHMENT = 0x8cd6,\n FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT = 0x8cd7,\n FRAMEBUFFER_INCOMPLETE_DIMENSIONS = 0x8cd9,\n FRAMEBUFFER_UNSUPPORTED = 0x8cdd,\n\n FRAMEBUFFER_BINDING = 0x8ca6,\n RENDERBUFFER_BINDING = 0x8ca7,\n MAX_RENDERBUFFER_SIZE = 0x84e8,\n\n INVALID_FRAMEBUFFER_OPERATION = 0x0506,\n\n /* WebGL-specific enums */\n UNPACK_FLIP_Y_WEBGL = 0x9240,\n UNPACK_PREMULTIPLY_ALPHA_WEBGL = 0x9241,\n CONTEXT_LOST_WEBGL = 0x9242,\n UNPACK_COLORSPACE_CONVERSION_WEBGL = 0x9243,\n BROWSER_DEFAULT_WEBGL = 0x9244,\n\n // GPUFlagsConstant @see https://gpuweb.github.io/gpuweb/#gputextureusage\n COPY_SRC = 0x01,\n COPY_DST = 0x02,\n SAMPLED = 0x04,\n STORAGE = 0x08,\n RENDER_ATTACHMENT = 0x10,\n}\n","/* eslint \"no-console\": off */\n\n\"use strict\";\n\nvar _ = require(\"./lodash\");\nvar Graph = require(\"./graphlib\").Graph;\n\nmodule.exports = {\n addDummyNode: addDummyNode,\n simplify: simplify,\n asNonCompoundGraph: asNonCompoundGraph,\n successorWeights: successorWeights,\n predecessorWeights: predecessorWeights,\n intersectRect: intersectRect,\n buildLayerMatrix: buildLayerMatrix,\n normalizeRanks: normalizeRanks,\n removeEmptyRanks: removeEmptyRanks,\n addBorderNode: addBorderNode,\n maxRank: maxRank,\n partition: partition,\n time: time,\n notime: notime\n};\n\n/*\n * Adds a dummy node to the graph and return v.\n */\nfunction addDummyNode(g, type, attrs, name) {\n var v;\n do {\n v = _.uniqueId(name);\n } while (g.hasNode(v));\n\n attrs.dummy = type;\n g.setNode(v, attrs);\n return v;\n}\n\n/*\n * Returns a new graph with only simple edges. Handles aggregation of data\n * associated with multi-edges.\n */\nfunction simplify(g) {\n var simplified = new Graph().setGraph(g.graph());\n _.forEach(g.nodes(), function(v) { simplified.setNode(v, g.node(v)); });\n _.forEach(g.edges(), function(e) {\n var simpleLabel = simplified.edge(e.v, e.w) || { weight: 0, minlen: 1 };\n var label = g.edge(e);\n simplified.setEdge(e.v, e.w, {\n weight: simpleLabel.weight + label.weight,\n minlen: Math.max(simpleLabel.minlen, label.minlen)\n });\n });\n return simplified;\n}\n\nfunction asNonCompoundGraph(g) {\n var simplified = new Graph({ multigraph: g.isMultigraph() }).setGraph(g.graph());\n _.forEach(g.nodes(), function(v) {\n if (!g.children(v).length) {\n simplified.setNode(v, g.node(v));\n }\n });\n _.forEach(g.edges(), function(e) {\n simplified.setEdge(e, g.edge(e));\n });\n return simplified;\n}\n\nfunction successorWeights(g) {\n var weightMap = _.map(g.nodes(), function(v) {\n var sucs = {};\n _.forEach(g.outEdges(v), function(e) {\n sucs[e.w] = (sucs[e.w] || 0) + g.edge(e).weight;\n });\n return sucs;\n });\n return _.zipObject(g.nodes(), weightMap);\n}\n\nfunction predecessorWeights(g) {\n var weightMap = _.map(g.nodes(), function(v) {\n var preds = {};\n _.forEach(g.inEdges(v), function(e) {\n preds[e.v] = (preds[e.v] || 0) + g.edge(e).weight;\n });\n return preds;\n });\n return _.zipObject(g.nodes(), weightMap);\n}\n\n/*\n * Finds where a line starting at point ({x, y}) would intersect a rectangle\n * ({x, y, width, height}) if it were pointing at the rectangle's center.\n */\nfunction intersectRect(rect, point) {\n var x = rect.x;\n var y = rect.y;\n\n // Rectangle intersection algorithm from:\n // http://math.stackexchange.com/questions/108113/find-edge-between-two-boxes\n var dx = point.x - x;\n var dy = point.y - y;\n var w = rect.width / 2;\n var h = rect.height / 2;\n\n if (!dx && !dy) {\n throw new Error(\"Not possible to find intersection inside of the rectangle\");\n }\n\n var sx, sy;\n if (Math.abs(dy) * w > Math.abs(dx) * h) {\n // Intersection is top or bottom of rect.\n if (dy < 0) {\n h = -h;\n }\n sx = h * dx / dy;\n sy = h;\n } else {\n // Intersection is left or right of rect.\n if (dx < 0) {\n w = -w;\n }\n sx = w;\n sy = w * dy / dx;\n }\n\n return { x: x + sx, y: y + sy };\n}\n\n/*\n * Given a DAG with each node assigned \"rank\" and \"order\" properties, this\n * function will produce a matrix with the ids of each node.\n */\nfunction buildLayerMatrix(g) {\n var layering = _.map(_.range(maxRank(g) + 1), function() { return []; });\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n var rank = node.rank;\n if (!_.isUndefined(rank)) {\n layering[rank][node.order] = v;\n }\n });\n return layering;\n}\n\n/*\n * Adjusts the ranks for all nodes in the graph such that all nodes v have\n * rank(v) >= 0 and at least one node w has rank(w) = 0.\n */\nfunction normalizeRanks(g) {\n var min = _.min(_.map(g.nodes(), function(v) { return g.node(v).rank; }));\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n if (_.has(node, \"rank\")) {\n node.rank -= min;\n }\n });\n}\n\nfunction removeEmptyRanks(g) {\n // Ranks may not start at 0, so we need to offset them\n var offset = _.min(_.map(g.nodes(), function(v) { return g.node(v).rank; }));\n\n var layers = [];\n _.forEach(g.nodes(), function(v) {\n var rank = g.node(v).rank - offset;\n if (!layers[rank]) {\n layers[rank] = [];\n }\n layers[rank].push(v);\n });\n\n var delta = 0;\n var nodeRankFactor = g.graph().nodeRankFactor;\n _.forEach(layers, function(vs, i) {\n if (_.isUndefined(vs) && i % nodeRankFactor !== 0) {\n --delta;\n } else if (delta) {\n _.forEach(vs, function(v) { g.node(v).rank += delta; });\n }\n });\n}\n\nfunction addBorderNode(g, prefix, rank, order) {\n var node = {\n width: 0,\n height: 0\n };\n if (arguments.length >= 4) {\n node.rank = rank;\n node.order = order;\n }\n return addDummyNode(g, \"border\", node, prefix);\n}\n\nfunction maxRank(g) {\n return _.max(_.map(g.nodes(), function(v) {\n var rank = g.node(v).rank;\n if (!_.isUndefined(rank)) {\n return rank;\n }\n }));\n}\n\n/*\n * Partition a collection into two groups: `lhs` and `rhs`. If the supplied\n * function returns true for an entry it goes into `lhs`. Otherwise it goes\n * into `rhs.\n */\nfunction partition(collection, fn) {\n var result = { lhs: [], rhs: [] };\n _.forEach(collection, function(value) {\n if (fn(value)) {\n result.lhs.push(value);\n } else {\n result.rhs.push(value);\n }\n });\n return result;\n}\n\n/*\n * Returns a new function that wraps `fn` with a timer. The wrapper logs the\n * time it takes to execute the function.\n */\nfunction time(name, fn) {\n var start = _.now();\n try {\n return fn();\n } finally {\n console.log(name + \" time: \" + (_.now() - start) + \"ms\");\n }\n}\n\nfunction notime(name, fn) {\n return fn();\n}\n","/**\n * @fileoverview 矩阵运算,本来是要引入 gl-matrix, 但是考虑到 g-mobile 对大小有限制,同时 g-webgl 使用的 matrix 不一致\n * 所以,这里仅实现 2D 几个运算,上层自己引入 gl-matrix\n * @author dxq613@gmail.com\n */\n/**\n * 3阶矩阵相乘\n * @param {number[]} a 矩阵1\n * @param {number[]} b 矩阵2\n */\nexport function multiplyMatrix(a, b) {\n var out = [];\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a10 = a[3];\n var a11 = a[4];\n var a12 = a[5];\n var a20 = a[6];\n var a21 = a[7];\n var a22 = a[8];\n var b00 = b[0];\n var b01 = b[1];\n var b02 = b[2];\n var b10 = b[3];\n var b11 = b[4];\n var b12 = b[5];\n var b20 = b[6];\n var b21 = b[7];\n var b22 = b[8];\n out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n return out;\n}\n/**\n * 3阶矩阵同2阶向量相乘\n * @param {number[]} m 矩阵\n * @param {number[]} v 二阶向量\n */\nexport function multiplyVec2(m, v) {\n var out = [];\n var x = v[0];\n var y = v[1];\n out[0] = m[0] * x + m[3] * y + m[6];\n out[1] = m[1] * x + m[4] * y + m[7];\n return out;\n}\n/**\n * 矩阵的逆\n * @param {number[]} a 矩阵\n */\nexport function invert(a) {\n var out = [];\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a10 = a[3];\n var a11 = a[4];\n var a12 = a[5];\n var a20 = a[6];\n var a21 = a[7];\n var a22 = a[8];\n var b01 = a22 * a11 - a12 * a21;\n var b11 = -a22 * a10 + a12 * a20;\n var b21 = a21 * a10 - a11 * a20;\n // Calculate the determinant\n var det = a00 * b01 + a01 * b11 + a02 * b21;\n if (!det) {\n return null;\n }\n det = 1.0 / det;\n out[0] = b01 * det;\n out[1] = (-a22 * a01 + a02 * a21) * det;\n out[2] = (a12 * a01 - a02 * a11) * det;\n out[3] = b11 * det;\n out[4] = (a22 * a00 - a02 * a20) * det;\n out[5] = (-a12 * a00 + a02 * a10) * det;\n out[6] = b21 * det;\n out[7] = (-a21 * a00 + a01 * a20) * det;\n out[8] = (a11 * a00 - a01 * a10) * det;\n return out;\n}\n//# sourceMappingURL=matrix.js.map","import * as glMatrix from \"./common.js\";\n/**\r\n * 3 Dimensional Vector\r\n * @module vec3\r\n */\n\n/**\r\n * Creates a new, empty vec3\r\n *\r\n * @returns {vec3} a new 3D vector\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(3);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n }\n\n return out;\n}\n/**\r\n * Creates a new vec3 initialized with values from an existing vector\r\n *\r\n * @param {ReadonlyVec3} a vector to clone\r\n * @returns {vec3} a new 3D vector\r\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(3);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n return out;\n}\n/**\r\n * Calculates the length of a vec3\r\n *\r\n * @param {ReadonlyVec3} a vector to calculate length of\r\n * @returns {Number} length of a\r\n */\n\nexport function length(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n return Math.hypot(x, y, z);\n}\n/**\r\n * Creates a new vec3 initialized with the given values\r\n *\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @returns {vec3} a new 3D vector\r\n */\n\nexport function fromValues(x, y, z) {\n var out = new glMatrix.ARRAY_TYPE(3);\n out[0] = x;\n out[1] = y;\n out[2] = z;\n return out;\n}\n/**\r\n * Copy the values from one vec3 to another\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the source vector\r\n * @returns {vec3} out\r\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n return out;\n}\n/**\r\n * Set the components of a vec3 to the given values\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @returns {vec3} out\r\n */\n\nexport function set(out, x, y, z) {\n out[0] = x;\n out[1] = y;\n out[2] = z;\n return out;\n}\n/**\r\n * Adds two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n return out;\n}\n/**\r\n * Subtracts vector b from vector a\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n return out;\n}\n/**\r\n * Multiplies two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function multiply(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n out[2] = a[2] * b[2];\n return out;\n}\n/**\r\n * Divides two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function divide(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n out[2] = a[2] / b[2];\n return out;\n}\n/**\r\n * Math.ceil the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to ceil\r\n * @returns {vec3} out\r\n */\n\nexport function ceil(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n out[2] = Math.ceil(a[2]);\n return out;\n}\n/**\r\n * Math.floor the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to floor\r\n * @returns {vec3} out\r\n */\n\nexport function floor(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n out[2] = Math.floor(a[2]);\n return out;\n}\n/**\r\n * Returns the minimum of two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function min(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n out[2] = Math.min(a[2], b[2]);\n return out;\n}\n/**\r\n * Returns the maximum of two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function max(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n out[2] = Math.max(a[2], b[2]);\n return out;\n}\n/**\r\n * Math.round the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to round\r\n * @returns {vec3} out\r\n */\n\nexport function round(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n out[2] = Math.round(a[2]);\n return out;\n}\n/**\r\n * Scales a vec3 by a scalar number\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the vector to scale\r\n * @param {Number} b amount to scale the vector by\r\n * @returns {vec3} out\r\n */\n\nexport function scale(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n return out;\n}\n/**\r\n * Adds two vec3's after scaling the second operand by a scalar value\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @param {Number} scale the amount to scale b by before adding\r\n * @returns {vec3} out\r\n */\n\nexport function scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n return out;\n}\n/**\r\n * Calculates the euclidian distance between two vec3's\r\n *\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {Number} distance between a and b\r\n */\n\nexport function distance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n return Math.hypot(x, y, z);\n}\n/**\r\n * Calculates the squared euclidian distance between two vec3's\r\n *\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {Number} squared distance between a and b\r\n */\n\nexport function squaredDistance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n return x * x + y * y + z * z;\n}\n/**\r\n * Calculates the squared length of a vec3\r\n *\r\n * @param {ReadonlyVec3} a vector to calculate squared length of\r\n * @returns {Number} squared length of a\r\n */\n\nexport function squaredLength(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n return x * x + y * y + z * z;\n}\n/**\r\n * Negates the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to negate\r\n * @returns {vec3} out\r\n */\n\nexport function negate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n return out;\n}\n/**\r\n * Returns the inverse of the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to invert\r\n * @returns {vec3} out\r\n */\n\nexport function inverse(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n out[2] = 1.0 / a[2];\n return out;\n}\n/**\r\n * Normalize a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to normalize\r\n * @returns {vec3} out\r\n */\n\nexport function normalize(out, a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var len = x * x + y * y + z * z;\n\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = a[0] * len;\n out[1] = a[1] * len;\n out[2] = a[2] * len;\n return out;\n}\n/**\r\n * Calculates the dot product of two vec3's\r\n *\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {Number} dot product of a and b\r\n */\n\nexport function dot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\n/**\r\n * Computes the cross product of two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function cross(out, a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2];\n var bx = b[0],\n by = b[1],\n bz = b[2];\n out[0] = ay * bz - az * by;\n out[1] = az * bx - ax * bz;\n out[2] = ax * by - ay * bx;\n return out;\n}\n/**\r\n * Performs a linear interpolation between two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {vec3} out\r\n */\n\nexport function lerp(out, a, b, t) {\n var ax = a[0];\n var ay = a[1];\n var az = a[2];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n out[2] = az + t * (b[2] - az);\n return out;\n}\n/**\r\n * Performs a hermite interpolation with two control points\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @param {ReadonlyVec3} c the third operand\r\n * @param {ReadonlyVec3} d the fourth operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {vec3} out\r\n */\n\nexport function hermite(out, a, b, c, d, t) {\n var factorTimes2 = t * t;\n var factor1 = factorTimes2 * (2 * t - 3) + 1;\n var factor2 = factorTimes2 * (t - 2) + t;\n var factor3 = factorTimes2 * (t - 1);\n var factor4 = factorTimes2 * (3 - 2 * t);\n out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n return out;\n}\n/**\r\n * Performs a bezier interpolation with two control points\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @param {ReadonlyVec3} c the third operand\r\n * @param {ReadonlyVec3} d the fourth operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {vec3} out\r\n */\n\nexport function bezier(out, a, b, c, d, t) {\n var inverseFactor = 1 - t;\n var inverseFactorTimesTwo = inverseFactor * inverseFactor;\n var factorTimes2 = t * t;\n var factor1 = inverseFactorTimesTwo * inverseFactor;\n var factor2 = 3 * t * inverseFactorTimesTwo;\n var factor3 = 3 * factorTimes2 * inverseFactor;\n var factor4 = factorTimes2 * t;\n out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n return out;\n}\n/**\r\n * Generates a random vector with the given scale\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\r\n * @returns {vec3} out\r\n */\n\nexport function random(out, scale) {\n scale = scale || 1.0;\n var r = glMatrix.RANDOM() * 2.0 * Math.PI;\n var z = glMatrix.RANDOM() * 2.0 - 1.0;\n var zScale = Math.sqrt(1.0 - z * z) * scale;\n out[0] = Math.cos(r) * zScale;\n out[1] = Math.sin(r) * zScale;\n out[2] = z * scale;\n return out;\n}\n/**\r\n * Transforms the vec3 with a mat4.\r\n * 4th vector component is implicitly '1'\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the vector to transform\r\n * @param {ReadonlyMat4} m matrix to transform with\r\n * @returns {vec3} out\r\n */\n\nexport function transformMat4(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2];\n var w = m[3] * x + m[7] * y + m[11] * z + m[15];\n w = w || 1.0;\n out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w;\n out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w;\n out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w;\n return out;\n}\n/**\r\n * Transforms the vec3 with a mat3.\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the vector to transform\r\n * @param {ReadonlyMat3} m the 3x3 matrix to transform with\r\n * @returns {vec3} out\r\n */\n\nexport function transformMat3(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2];\n out[0] = x * m[0] + y * m[3] + z * m[6];\n out[1] = x * m[1] + y * m[4] + z * m[7];\n out[2] = x * m[2] + y * m[5] + z * m[8];\n return out;\n}\n/**\r\n * Transforms the vec3 with a quat\r\n * Can also be used for dual quaternions. (Multiply it with the real part)\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the vector to transform\r\n * @param {ReadonlyQuat} q quaternion to transform with\r\n * @returns {vec3} out\r\n */\n\nexport function transformQuat(out, a, q) {\n // benchmarks: https://jsperf.com/quaternion-transform-vec3-implementations-fixed\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3];\n var x = a[0],\n y = a[1],\n z = a[2]; // var qvec = [qx, qy, qz];\n // var uv = vec3.cross([], qvec, a);\n\n var uvx = qy * z - qz * y,\n uvy = qz * x - qx * z,\n uvz = qx * y - qy * x; // var uuv = vec3.cross([], qvec, uv);\n\n var uuvx = qy * uvz - qz * uvy,\n uuvy = qz * uvx - qx * uvz,\n uuvz = qx * uvy - qy * uvx; // vec3.scale(uv, uv, 2 * w);\n\n var w2 = qw * 2;\n uvx *= w2;\n uvy *= w2;\n uvz *= w2; // vec3.scale(uuv, uuv, 2);\n\n uuvx *= 2;\n uuvy *= 2;\n uuvz *= 2; // return vec3.add(out, a, vec3.add(out, uv, uuv));\n\n out[0] = x + uvx + uuvx;\n out[1] = y + uvy + uuvy;\n out[2] = z + uvz + uuvz;\n return out;\n}\n/**\r\n * Rotate a 3D vector around the x-axis\r\n * @param {vec3} out The receiving vec3\r\n * @param {ReadonlyVec3} a The vec3 point to rotate\r\n * @param {ReadonlyVec3} b The origin of the rotation\r\n * @param {Number} rad The angle of rotation in radians\r\n * @returns {vec3} out\r\n */\n\nexport function rotateX(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[0];\n r[1] = p[1] * Math.cos(rad) - p[2] * Math.sin(rad);\n r[2] = p[1] * Math.sin(rad) + p[2] * Math.cos(rad); //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\r\n * Rotate a 3D vector around the y-axis\r\n * @param {vec3} out The receiving vec3\r\n * @param {ReadonlyVec3} a The vec3 point to rotate\r\n * @param {ReadonlyVec3} b The origin of the rotation\r\n * @param {Number} rad The angle of rotation in radians\r\n * @returns {vec3} out\r\n */\n\nexport function rotateY(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[2] * Math.sin(rad) + p[0] * Math.cos(rad);\n r[1] = p[1];\n r[2] = p[2] * Math.cos(rad) - p[0] * Math.sin(rad); //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\r\n * Rotate a 3D vector around the z-axis\r\n * @param {vec3} out The receiving vec3\r\n * @param {ReadonlyVec3} a The vec3 point to rotate\r\n * @param {ReadonlyVec3} b The origin of the rotation\r\n * @param {Number} rad The angle of rotation in radians\r\n * @returns {vec3} out\r\n */\n\nexport function rotateZ(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[0] * Math.cos(rad) - p[1] * Math.sin(rad);\n r[1] = p[0] * Math.sin(rad) + p[1] * Math.cos(rad);\n r[2] = p[2]; //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\r\n * Get the angle between two 3D vectors\r\n * @param {ReadonlyVec3} a The first operand\r\n * @param {ReadonlyVec3} b The second operand\r\n * @returns {Number} The angle in radians\r\n */\n\nexport function angle(a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2],\n bx = b[0],\n by = b[1],\n bz = b[2],\n mag1 = Math.sqrt(ax * ax + ay * ay + az * az),\n mag2 = Math.sqrt(bx * bx + by * by + bz * bz),\n mag = mag1 * mag2,\n cosine = mag && dot(a, b) / mag;\n return Math.acos(Math.min(Math.max(cosine, -1), 1));\n}\n/**\r\n * Set the components of a vec3 to zero\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @returns {vec3} out\r\n */\n\nexport function zero(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n out[2] = 0.0;\n return out;\n}\n/**\r\n * Returns a string representation of a vector\r\n *\r\n * @param {ReadonlyVec3} a vector to represent as a string\r\n * @returns {String} string representation of the vector\r\n */\n\nexport function str(a) {\n return \"vec3(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \")\";\n}\n/**\r\n * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyVec3} a The first vector.\r\n * @param {ReadonlyVec3} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2];\n}\n/**\r\n * Returns whether or not the vectors have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyVec3} a The first vector.\r\n * @param {ReadonlyVec3} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2));\n}\n/**\r\n * Alias for {@link vec3.subtract}\r\n * @function\r\n */\n\nexport var sub = subtract;\n/**\r\n * Alias for {@link vec3.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Alias for {@link vec3.divide}\r\n * @function\r\n */\n\nexport var div = divide;\n/**\r\n * Alias for {@link vec3.distance}\r\n * @function\r\n */\n\nexport var dist = distance;\n/**\r\n * Alias for {@link vec3.squaredDistance}\r\n * @function\r\n */\n\nexport var sqrDist = squaredDistance;\n/**\r\n * Alias for {@link vec3.length}\r\n * @function\r\n */\n\nexport var len = length;\n/**\r\n * Alias for {@link vec3.squaredLength}\r\n * @function\r\n */\n\nexport var sqrLen = squaredLength;\n/**\r\n * Perform some operation over an array of vec3s.\r\n *\r\n * @param {Array} a the array of vectors to iterate over\r\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\r\n * @param {Number} offset Number of elements to skip at the beginning of the array\r\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\r\n * @param {Function} fn Function to call for each vector in the array\r\n * @param {Object} [arg] additional argument to pass to fn\r\n * @returns {Array} a\r\n * @function\r\n */\n\nexport var forEach = function () {\n var vec = create();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 3;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n }\n\n return a;\n };\n}();","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.STACK_OVERFLOW = exports.CIRCULAR_DEPENDENCY_IN_FACTORY = exports.POST_CONSTRUCT_ERROR = exports.MULTIPLE_POST_CONSTRUCT_METHODS = exports.CONTAINER_OPTIONS_INVALID_SKIP_BASE_CHECK = exports.CONTAINER_OPTIONS_INVALID_AUTO_BIND_INJECTABLE = exports.CONTAINER_OPTIONS_INVALID_DEFAULT_SCOPE = exports.CONTAINER_OPTIONS_MUST_BE_AN_OBJECT = exports.ARGUMENTS_LENGTH_MISMATCH = exports.INVALID_DECORATOR_OPERATION = exports.INVALID_TO_SELF_VALUE = exports.INVALID_FUNCTION_BINDING = exports.INVALID_MIDDLEWARE_RETURN = exports.NO_MORE_SNAPSHOTS_AVAILABLE = exports.INVALID_BINDING_TYPE = exports.NOT_IMPLEMENTED = exports.CIRCULAR_DEPENDENCY = exports.UNDEFINED_INJECT_ANNOTATION = exports.MISSING_INJECT_ANNOTATION = exports.MISSING_INJECTABLE_ANNOTATION = exports.NOT_REGISTERED = exports.CANNOT_UNBIND = exports.AMBIGUOUS_MATCH = exports.KEY_NOT_FOUND = exports.NULL_ARGUMENT = exports.DUPLICATED_METADATA = exports.DUPLICATED_INJECTABLE_DECORATOR = void 0;\nexports.DUPLICATED_INJECTABLE_DECORATOR = \"Cannot apply @injectable decorator multiple times.\";\nexports.DUPLICATED_METADATA = \"Metadata key was used more than once in a parameter:\";\nexports.NULL_ARGUMENT = \"NULL argument\";\nexports.KEY_NOT_FOUND = \"Key Not Found\";\nexports.AMBIGUOUS_MATCH = \"Ambiguous match found for serviceIdentifier:\";\nexports.CANNOT_UNBIND = \"Could not unbind serviceIdentifier:\";\nexports.NOT_REGISTERED = \"No matching bindings found for serviceIdentifier:\";\nexports.MISSING_INJECTABLE_ANNOTATION = \"Missing required @injectable annotation in:\";\nexports.MISSING_INJECT_ANNOTATION = \"Missing required @inject or @multiInject annotation in:\";\nvar UNDEFINED_INJECT_ANNOTATION = function (name) {\n return \"@inject called with undefined this could mean that the class \" + name + \" has \" +\n \"a circular dependency problem. You can use a LazyServiceIdentifer to \" +\n \"overcome this limitation.\";\n};\nexports.UNDEFINED_INJECT_ANNOTATION = UNDEFINED_INJECT_ANNOTATION;\nexports.CIRCULAR_DEPENDENCY = \"Circular dependency found:\";\nexports.NOT_IMPLEMENTED = \"Sorry, this feature is not fully implemented yet.\";\nexports.INVALID_BINDING_TYPE = \"Invalid binding type:\";\nexports.NO_MORE_SNAPSHOTS_AVAILABLE = \"No snapshot available to restore.\";\nexports.INVALID_MIDDLEWARE_RETURN = \"Invalid return type in middleware. Middleware must return!\";\nexports.INVALID_FUNCTION_BINDING = \"Value provided to function binding must be a function!\";\nexports.INVALID_TO_SELF_VALUE = \"The toSelf function can only be applied when a constructor is \" +\n \"used as service identifier\";\nexports.INVALID_DECORATOR_OPERATION = \"The @inject @multiInject @tagged and @named decorators \" +\n \"must be applied to the parameters of a class constructor or a class property.\";\nvar ARGUMENTS_LENGTH_MISMATCH = function () {\n var values = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n values[_i] = arguments[_i];\n }\n return \"The number of constructor arguments in the derived class \" +\n (values[0] + \" must be >= than the number of constructor arguments of its base class.\");\n};\nexports.ARGUMENTS_LENGTH_MISMATCH = ARGUMENTS_LENGTH_MISMATCH;\nexports.CONTAINER_OPTIONS_MUST_BE_AN_OBJECT = \"Invalid Container constructor argument. Container options \" +\n \"must be an object.\";\nexports.CONTAINER_OPTIONS_INVALID_DEFAULT_SCOPE = \"Invalid Container option. Default scope must \" +\n \"be a string ('singleton' or 'transient').\";\nexports.CONTAINER_OPTIONS_INVALID_AUTO_BIND_INJECTABLE = \"Invalid Container option. Auto bind injectable must \" +\n \"be a boolean\";\nexports.CONTAINER_OPTIONS_INVALID_SKIP_BASE_CHECK = \"Invalid Container option. Skip base check must \" +\n \"be a boolean\";\nexports.MULTIPLE_POST_CONSTRUCT_METHODS = \"Cannot apply @postConstruct decorator multiple times in the same class\";\nvar POST_CONSTRUCT_ERROR = function () {\n var values = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n values[_i] = arguments[_i];\n }\n return \"@postConstruct error in class \" + values[0] + \": \" + values[1];\n};\nexports.POST_CONSTRUCT_ERROR = POST_CONSTRUCT_ERROR;\nvar CIRCULAR_DEPENDENCY_IN_FACTORY = function () {\n var values = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n values[_i] = arguments[_i];\n }\n return \"It looks like there is a circular dependency \" +\n (\"in one of the '\" + values[0] + \"' bindings. Please investigate bindings with\") +\n (\"service identifier '\" + values[1] + \"'.\");\n};\nexports.CIRCULAR_DEPENDENCY_IN_FACTORY = CIRCULAR_DEPENDENCY_IN_FACTORY;\nexports.STACK_OVERFLOW = \"Maximum call stack size exceeded\";\n//# sourceMappingURL=error_msgs.js.map","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n module.exports = _typeof = function _typeof(obj) {\n return typeof obj;\n };\n\n module.exports[\"default\"] = module.exports, module.exports.__esModule = true;\n } else {\n module.exports = _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n\n module.exports[\"default\"] = module.exports, module.exports.__esModule = true;\n }\n\n return _typeof(obj);\n}\n\nmodule.exports = _typeof;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","/* global window */\n\nvar lodash;\n\nif (typeof require === \"function\") {\n try {\n lodash = {\n clone: require(\"lodash/clone\"),\n constant: require(\"lodash/constant\"),\n each: require(\"lodash/each\"),\n filter: require(\"lodash/filter\"),\n has: require(\"lodash/has\"),\n isArray: require(\"lodash/isArray\"),\n isEmpty: require(\"lodash/isEmpty\"),\n isFunction: require(\"lodash/isFunction\"),\n isUndefined: require(\"lodash/isUndefined\"),\n keys: require(\"lodash/keys\"),\n map: require(\"lodash/map\"),\n reduce: require(\"lodash/reduce\"),\n size: require(\"lodash/size\"),\n transform: require(\"lodash/transform\"),\n union: require(\"lodash/union\"),\n values: require(\"lodash/values\")\n };\n } catch (e) {\n // continue regardless of error\n }\n}\n\nif (!lodash) {\n lodash = window._;\n}\n\nmodule.exports = lodash;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.uniqueId = exports.getEdgesByNodeId = exports.getOutEdgesNodeId = exports.getNeighbors = void 0;\n\n/**\n * 获取指定节点的所有邻居\n * @param nodeId 节点 ID\n * @param edges 图中的所有边数据\n * @param type 邻居类型\n */\nvar getNeighbors = function getNeighbors(nodeId, edges, type) {\n if (edges === void 0) {\n edges = [];\n }\n\n var currentEdges = edges.filter(function (edge) {\n return edge.source === nodeId || edge.target === nodeId;\n });\n\n if (type === 'target') {\n // 当前节点为 source,它所指向的目标节点\n var neighhborsConverter_1 = function neighhborsConverter_1(edge) {\n return edge.source === nodeId;\n };\n\n return currentEdges.filter(neighhborsConverter_1).map(function (edge) {\n return edge.target;\n });\n }\n\n if (type === 'source') {\n // 当前节点为 target,它所指向的源节点\n var neighhborsConverter_2 = function neighhborsConverter_2(edge) {\n return edge.target === nodeId;\n };\n\n return currentEdges.filter(neighhborsConverter_2).map(function (edge) {\n return edge.source;\n });\n } // 若未指定 type ,则返回所有邻居\n\n\n var neighhborsConverter = function neighhborsConverter(edge) {\n return edge.source === nodeId ? edge.target : edge.source;\n };\n\n return currentEdges.map(neighhborsConverter);\n};\n/**\n * 获取指定节点的出边\n * @param nodeId 节点 ID\n * @param edges 图中的所有边数据\n */\n\n\nexports.getNeighbors = getNeighbors;\n\nvar getOutEdgesNodeId = function getOutEdgesNodeId(nodeId, edges) {\n return edges.filter(function (edge) {\n return edge.source === nodeId;\n });\n};\n/**\n * 获取指定节点的边,包括出边和入边\n * @param nodeId 节点 ID\n * @param edges 图中的所有边数据\n */\n\n\nexports.getOutEdgesNodeId = getOutEdgesNodeId;\n\nvar getEdgesByNodeId = function getEdgesByNodeId(nodeId, edges) {\n return edges.filter(function (edge) {\n return edge.source === nodeId || edge.target === nodeId;\n });\n};\n/**\n * 生成唯一的 ID,规则是序号 + 时间戳\n * @param index 序号\n */\n\n\nexports.getEdgesByNodeId = getEdgesByNodeId;\n\nvar uniqueId = function uniqueId(index) {\n if (index === void 0) {\n index = 0;\n }\n\n var random1 = (\"\" + Math.random()).split('.')[1].substr(0, 5);\n var random2 = (\"\" + Math.random()).split('.')[1].substr(0, 5);\n return index + \"-\" + random1 + random2;\n};\n\nexports.uniqueId = uniqueId;","/* global window */\n\nvar graphlib;\n\nif (typeof require === \"function\") {\n try {\n graphlib = require(\"graphlib\");\n } catch (e) {\n // continue regardless of error\n }\n}\n\nif (!graphlib) {\n graphlib = window.graphlib;\n}\n\nmodule.exports = graphlib;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Metadata = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar Metadata = (function () {\n function Metadata(key, value) {\n this.key = key;\n this.value = value;\n }\n Metadata.prototype.toString = function () {\n if (this.key === METADATA_KEY.NAMED_TAG) {\n return \"named: \" + this.value.toString() + \" \";\n }\n else {\n return \"tagged: { key:\" + this.key.toString() + \", value: \" + this.value + \" }\";\n }\n };\n return Metadata;\n}());\nexports.Metadata = Metadata;\n//# sourceMappingURL=metadata.js.map","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","import { mat4 } from 'gl-matrix';\nimport { inject, injectable, named } from 'inversify';\nimport { Entity } from '../../..';\nimport { ComponentManager } from '../../../ComponentManager';\nimport { IDENTIFIER } from '../../../identifier';\nimport { FrameGraphHandle } from '../../framegraph/FrameGraphHandle';\nimport { FrameGraphPass } from '../../framegraph/FrameGraphPass';\nimport { PassNode } from '../../framegraph/PassNode';\nimport { ResourcePool } from '../../framegraph/ResourcePool';\nimport { FrameGraphSystem } from '../../framegraph/System';\nimport { GeometryComponent } from '../../geometry/GeometryComponent';\nimport { MaterialComponent } from '../../material/MaterialComponent';\nimport { CullableComponent } from '../../mesh/CullableComponent';\nimport { MeshComponent } from '../../mesh/MeshComponent';\nimport { HierarchyComponent } from '../../scenegraph/HierarchyComponent';\nimport { TransformComponent } from '../../scenegraph/TransformComponent';\nimport { gl } from '../gl';\nimport { IAttribute } from '../IAttribute';\nimport { IModel, IModelInitializationOptions } from '../IModel';\nimport { ICamera, IRendererService, IView } from '../IRendererService';\nimport { IUniform } from '../IUniform';\nimport { IRenderPass } from './IRenderPass';\n\nexport interface RenderPassData {\n output: FrameGraphHandle;\n}\n\n@injectable()\nexport class RenderPass implements IRenderPass<RenderPassData> {\n public static IDENTIFIER = 'Render Pass';\n\n @inject(IDENTIFIER.MeshComponentManager)\n private readonly mesh: ComponentManager<MeshComponent>;\n\n @inject(IDENTIFIER.GeometryComponentManager)\n private readonly geometry: ComponentManager<GeometryComponent>;\n\n @inject(IDENTIFIER.MaterialComponentManager)\n private readonly material: ComponentManager<MaterialComponent>;\n\n @inject(IDENTIFIER.CullableComponentManager)\n private readonly cullable: ComponentManager<CullableComponent>;\n\n @inject(IDENTIFIER.TransformComponentManager)\n private readonly transform: ComponentManager<TransformComponent>;\n\n @inject(IDENTIFIER.HierarchyComponentManager)\n private readonly hierarchy: ComponentManager<HierarchyComponent>;\n\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.FrameGraphSystem)\n private readonly frameGraphSystem: FrameGraphSystem;\n\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n @inject(IDENTIFIER.ResourcePool)\n private readonly resourcePool: ResourcePool;\n\n private modelCache: Record<string, IModel> = {};\n\n public setup = (\n fg: FrameGraphSystem,\n passNode: PassNode,\n pass: FrameGraphPass<RenderPassData>,\n ): void => {\n const output = fg.createRenderTarget(passNode, 'color buffer', {\n width: 1,\n height: 1,\n usage: gl.RENDER_ATTACHMENT | gl.SAMPLED | gl.COPY_SRC,\n });\n\n pass.data = {\n output: passNode.write(fg, output),\n };\n };\n\n public execute = async (\n fg: FrameGraphSystem,\n pass: FrameGraphPass<RenderPassData>,\n views: IView[],\n ): Promise<void> => {\n const resourceNode = fg.getResourceNode(pass.data.output);\n const framebuffer = this.resourcePool.getOrCreateResource(\n resourceNode.resource,\n );\n\n // initialize model of each mesh\n for (const view of views) {\n await this.initView(view);\n }\n\n const canvas = this.engine.getCanvas();\n framebuffer.resize({\n width: canvas.width,\n height: canvas.height,\n });\n\n this.engine.setScissor({\n enable: false,\n });\n this.engine.clear({\n framebuffer,\n color: views[0].getClearColor(), // TODO: use clearColor defined in view\n depth: 1,\n });\n\n this.engine.useFramebuffer(framebuffer, () => {\n for (const view of views) {\n // must do rendering in a sync way\n this.renderView(view);\n }\n });\n };\n\n public renderView(view: IView) {\n const scene = view.getScene();\n const camera = view.getCamera();\n\n // get VP matrix from camera\n const viewMatrix = camera.getViewTransform()!;\n const viewProjectionMatrix = mat4.multiply(\n mat4.create(),\n camera.getPerspective(),\n viewMatrix,\n );\n // TODO: use cached planes if camera was not changed\n camera.getFrustum().extractFromVPMatrix(viewProjectionMatrix);\n\n const { x, y, width, height } = view.getViewport();\n this.engine.viewport({\n x,\n y,\n width,\n height,\n });\n // this.engine.setScissor({\n // enable: true,\n // box: { x, y, width, height },\n // });\n // this.engine.clear({\n // // framebuffer,\n // color: [1, 1, 1, 1], // TODO: use clearColor defined in view\n // depth: 1,\n // });\n\n for (const meshEntity of scene.getEntities()) {\n this.renderMesh(meshEntity, {\n camera,\n view,\n viewMatrix,\n });\n }\n }\n\n private renderMesh(\n meshEntity: Entity,\n {\n camera,\n view,\n viewMatrix,\n }: {\n camera: ICamera;\n view: IView;\n viewMatrix: mat4;\n },\n ) {\n const mesh = this.mesh.getComponentByEntity(meshEntity);\n\n if (!mesh || !mesh.visible) {\n return;\n }\n\n // filter meshes with frustum culling\n // if (!this.cullable.getComponentByEntity(meshEntity)?.visible) {\n // return;\n // }\n const material = mesh.material;\n const geometry = mesh.geometry;\n\n // geometry 在自己的 System 中完成脏检查后的更新\n if (!geometry || geometry.dirty || !material) {\n return;\n }\n\n // get model matrix from mesh\n const transform = this.transform.getComponentByEntity(meshEntity)!;\n\n const modelViewMatrix = mat4.multiply(\n mat4.create(),\n viewMatrix,\n transform.worldTransform,\n );\n const { width, height } = view.getViewport();\n\n // set MVP matrix, other builtin uniforms @see https://threejs.org/docs/#api/en/renderers/webgl/WebGLProgram\n material.setUniform({\n projectionMatrix: camera.getPerspective(),\n modelViewMatrix,\n modelMatrix: transform.worldTransform,\n viewMatrix,\n cameraPosition: camera.getPosition(),\n u_viewport: [width, height],\n });\n\n if (mesh.model) {\n mesh.model.draw({\n uniforms: material.uniforms.reduce(\n (cur: { [key: string]: IUniform }, prev) => {\n cur[prev.name] = prev.data;\n return cur;\n },\n {},\n ),\n });\n\n material.uniforms.forEach((u) => {\n u.dirty = false;\n });\n material.dirty = false;\n }\n }\n\n private async initMesh(meshEntity: Entity, view: IView) {\n const mesh = this.mesh.getComponentByEntity(meshEntity);\n\n if (!mesh) {\n return;\n }\n\n const material = mesh.material;\n const geometry = mesh.geometry;\n\n if (!geometry || geometry.dirty || !material) {\n return;\n }\n\n if (!mesh.model) {\n const modelCacheKey = `m-${material.entity}-g-${geometry.entity}`;\n if (this.modelCache[modelCacheKey]) {\n mesh.model = this.modelCache[modelCacheKey];\n return;\n }\n\n material.setUniform({\n projectionMatrix: 1,\n modelViewMatrix: 1,\n modelMatrix: 1,\n viewMatrix: 1,\n cameraPosition: 1,\n u_viewport: 1,\n });\n\n const { createModel, createAttribute } = this.engine;\n const modelInitializationOptions: IModelInitializationOptions = {\n vs: material.vertexShaderGLSL,\n fs: material.fragmentShaderGLSL,\n defines: material.defines,\n attributes: geometry.attributes.reduce(\n (cur: { [key: string]: IAttribute }, prev) => {\n if (prev.data && prev.buffer) {\n cur[prev.name] = createAttribute({\n buffer: prev.buffer,\n attributes: prev.attributes,\n arrayStride: prev.arrayStride,\n stepMode: prev.stepMode,\n divisor: prev.stepMode === 'vertex' ? 0 : 1,\n });\n }\n return cur;\n },\n {},\n ),\n uniforms: material.uniforms.reduce(\n (cur: { [key: string]: IUniform }, prev) => {\n cur[prev.name] = prev.data;\n return cur;\n },\n {},\n ),\n scissor: {\n enable: true,\n // @ts-ignore\n box: () => view.getViewport(),\n },\n };\n\n if (material.cull) {\n modelInitializationOptions.cull = material.cull;\n }\n if (material.depth) {\n modelInitializationOptions.depth = material.depth;\n }\n if (material.blend) {\n modelInitializationOptions.blend = material.blend;\n }\n\n if (geometry.indicesBuffer) {\n modelInitializationOptions.elements = geometry.indicesBuffer;\n }\n\n if (geometry.maxInstancedCount) {\n modelInitializationOptions.instances = geometry.maxInstancedCount;\n modelInitializationOptions.count = geometry.vertexCount || 3;\n }\n\n mesh.model = await createModel(modelInitializationOptions);\n this.modelCache[modelCacheKey] = mesh.model;\n }\n }\n\n private async initView(view: IView) {\n const scene = view.getScene();\n for (const meshEntity of scene.getEntities()) {\n await this.initMesh(meshEntity, view);\n }\n }\n}\n","import { __assign } from \"tslib\";\n/**\n * @fileoverview path 的一些工具\n * @author dxq613@gmail.com\n */\nimport { PathUtil } from '@antv/g-base';\nimport { Quad as QuadUtil } from '@antv/g-math';\nimport { Cubic as CubicUtil } from '@antv/g-math';\nimport { ext } from '@antv/matrix-util';\nimport * as vec3 from 'gl-matrix/vec3';\nimport { inBox } from './util';\nimport inLine from './in-stroke/line';\nimport inArc from './in-stroke/arc';\nvar transform = ext.transform;\nfunction hasArc(path) {\n var hasArc = false;\n var count = path.length;\n for (var i = 0; i < count; i++) {\n var params = path[i];\n var cmd = params[0];\n if (cmd === 'C' || cmd === 'A' || cmd === 'Q') {\n hasArc = true;\n break;\n }\n }\n return hasArc;\n}\nfunction isPointInStroke(segments, lineWidth, x, y, length) {\n var isHit = false;\n var halfWidth = lineWidth / 2;\n for (var i = 0; i < segments.length; i++) {\n var segment = segments[i];\n var currentPoint = segment.currentPoint, params = segment.params, prePoint = segment.prePoint, box = segment.box;\n // 如果在前面已经生成过包围盒,直接按照包围盒计算\n if (box && !inBox(box.x - halfWidth, box.y - halfWidth, box.width + lineWidth, box.height + lineWidth, x, y)) {\n continue;\n }\n switch (segment.command) {\n // L 和 Z 都是直线, M 不进行拾取\n case 'L':\n case 'Z':\n isHit = inLine(prePoint[0], prePoint[1], currentPoint[0], currentPoint[1], lineWidth, x, y);\n break;\n case 'Q':\n var qDistance = QuadUtil.pointDistance(prePoint[0], prePoint[1], params[1], params[2], params[3], params[4], x, y);\n isHit = qDistance <= lineWidth / 2;\n break;\n case 'C':\n var cDistance = CubicUtil.pointDistance(prePoint[0], // 上一段结束位置, 即 C 的起始点\n prePoint[1], params[1], // 'C' 的参数,1、2 为第一个控制点,3、4 为第二个控制点,5、6 为结束点\n params[2], params[3], params[4], params[5], params[6], x, y, length);\n isHit = cDistance <= lineWidth / 2;\n break;\n case 'A':\n // 计算点到椭圆圆弧的距离,暂时使用近似算法,后面可以改成切割法求最近距离\n var arcParams = segment.arcParams;\n var cx = arcParams.cx, cy = arcParams.cy, rx = arcParams.rx, ry = arcParams.ry, startAngle = arcParams.startAngle, endAngle = arcParams.endAngle, xRotation = arcParams.xRotation;\n var p = [x, y, 1];\n var r = rx > ry ? rx : ry;\n var scaleX = rx > ry ? 1 : rx / ry;\n var scaleY = rx > ry ? ry / rx : 1;\n var m = transform(null, [\n ['t', -cx, -cy],\n ['r', -xRotation],\n ['s', 1 / scaleX, 1 / scaleY],\n ]);\n vec3.transformMat3(p, p, m);\n isHit = inArc(0, 0, r, startAngle, endAngle, lineWidth, p[0], p[1]);\n break;\n default:\n break;\n }\n if (isHit) {\n break;\n }\n }\n return isHit;\n}\n/**\n * 提取出内部的闭合多边形和非闭合的多边形,假设 path 不存在圆弧\n * @param {Array} path 路径\n * @returns {Array} 点的集合\n */\nfunction extractPolygons(path) {\n var count = path.length;\n var polygons = [];\n var polylines = [];\n var points = []; // 防止第一个命令不是 'M'\n for (var i = 0; i < count; i++) {\n var params = path[i];\n var cmd = params[0];\n if (cmd === 'M') {\n // 遇到 'M' 判定是否是新数组,新数组中没有点\n if (points.length) {\n // 如果存在点,则说明没有遇到 'Z',开始了一个新的多边形\n polylines.push(points);\n points = []; // 创建新的点\n }\n points.push([params[1], params[2]]);\n }\n else if (cmd === 'Z') {\n if (points.length) {\n // 存在点\n polygons.push(points);\n points = []; // 开始新的点集合\n }\n // 如果不存在点,同时 'Z',则说明是错误,不处理\n }\n else {\n points.push([params[1], params[2]]);\n }\n }\n // 说明 points 未放入 polygons 或者 polyline\n // 仅当只有一个 M,没有 Z 时会发生这种情况\n if (points.length > 0) {\n polylines.push(points);\n }\n return {\n polygons: polygons,\n polylines: polylines,\n };\n}\nexport default __assign({ hasArc: hasArc, extractPolygons: extractPolygons, isPointInStroke: isPointInStroke }, PathUtil);\n//# sourceMappingURL=path.js.map","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","var baseMatches = require('./_baseMatches'),\n baseMatchesProperty = require('./_baseMatchesProperty'),\n identity = require('./identity'),\n isArray = require('./isArray'),\n property = require('./property');\n\n/**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\nfunction baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(value);\n}\n\nmodule.exports = baseIteratee;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.TargetTypeEnum = exports.BindingTypeEnum = exports.BindingScopeEnum = void 0;\nvar BindingScopeEnum = {\n Request: \"Request\",\n Singleton: \"Singleton\",\n Transient: \"Transient\"\n};\nexports.BindingScopeEnum = BindingScopeEnum;\nvar BindingTypeEnum = {\n ConstantValue: \"ConstantValue\",\n Constructor: \"Constructor\",\n DynamicValue: \"DynamicValue\",\n Factory: \"Factory\",\n Function: \"Function\",\n Instance: \"Instance\",\n Invalid: \"Invalid\",\n Provider: \"Provider\"\n};\nexports.BindingTypeEnum = BindingTypeEnum;\nvar TargetTypeEnum = {\n ClassProperty: \"ClassProperty\",\n ConstructorArgument: \"ConstructorArgument\",\n Variable: \"Variable\"\n};\nexports.TargetTypeEnum = TargetTypeEnum;\n//# sourceMappingURL=literal_types.js.map","import { __assign, __extends } from \"tslib\";\nimport { AbstractShape } from '@antv/g-base';\nimport { setShadow, setTransform, setClip } from '../util/svg';\nimport { createDom } from '../util/dom';\nimport { refreshElement } from '../util/draw';\nimport { SVG_ATTR_MAP } from '../constant';\nimport * as Shape from './index';\nimport Group from '../group';\nimport { getBBoxMethod } from '@antv/g-base';\nvar ShapeBase = /** @class */ (function (_super) {\n __extends(ShapeBase, _super);\n function ShapeBase() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'svg';\n _this.canFill = false;\n _this.canStroke = false;\n return _this;\n }\n ShapeBase.prototype.getDefaultAttrs = function () {\n var attrs = _super.prototype.getDefaultAttrs.call(this);\n // 设置默认值\n return __assign(__assign({}, attrs), { lineWidth: 1, lineAppendWidth: 0, strokeOpacity: 1, fillOpacity: 1 });\n };\n // 覆盖基类的 afterAttrsChange 方法\n ShapeBase.prototype.afterAttrsChange = function (targetAttrs) {\n _super.prototype.afterAttrsChange.call(this, targetAttrs);\n var canvas = this.get('canvas');\n // 只有挂载到画布下,才对元素进行实际渲染\n if (canvas && canvas.get('autoDraw')) {\n var context = canvas.get('context');\n this.draw(context, targetAttrs);\n }\n };\n ShapeBase.prototype.getShapeBase = function () {\n return Shape;\n };\n ShapeBase.prototype.getGroupBase = function () {\n return Group;\n };\n /**\n * 一些方法调用会引起画布变化\n * @param {ChangeType} changeType 改变的类型\n */\n ShapeBase.prototype.onCanvasChange = function (changeType) {\n refreshElement(this, changeType);\n };\n ShapeBase.prototype.calculateBBox = function () {\n var el = this.get('el');\n var bbox = null;\n // 包围盒计算依赖于绘制,如果还没有生成对应的 Dom 元素,则包围盒的长宽均为 0\n if (el) {\n bbox = el.getBBox();\n }\n else {\n var bboxMethod = getBBoxMethod(this.get('type'));\n if (bboxMethod) {\n bbox = bboxMethod(this);\n }\n }\n if (bbox) {\n var x = bbox.x, y = bbox.y, width = bbox.width, height = bbox.height;\n var lineWidth = this.getHitLineWidth();\n var halfWidth = lineWidth / 2;\n var minX = x - halfWidth;\n var minY = y - halfWidth;\n var maxX = x + width + halfWidth;\n var maxY = y + height + halfWidth;\n return {\n x: minX,\n y: minY,\n minX: minX,\n minY: minY,\n maxX: maxX,\n maxY: maxY,\n width: width + lineWidth,\n height: height + lineWidth,\n };\n }\n return {\n x: 0,\n y: 0,\n minX: 0,\n minY: 0,\n maxX: 0,\n maxY: 0,\n width: 0,\n height: 0,\n };\n };\n ShapeBase.prototype.isFill = function () {\n var _a = this.attr(), fill = _a.fill, fillStyle = _a.fillStyle;\n return (fill || fillStyle || this.isClipShape()) && this.canFill;\n };\n ShapeBase.prototype.isStroke = function () {\n var _a = this.attr(), stroke = _a.stroke, strokeStyle = _a.strokeStyle;\n return (stroke || strokeStyle) && this.canStroke;\n };\n ShapeBase.prototype.draw = function (context, targetAttrs) {\n var el = this.get('el');\n if (this.get('destroyed')) {\n if (el) {\n el.parentNode.removeChild(el);\n }\n }\n else {\n if (!el) {\n createDom(this);\n }\n setClip(this, context);\n this.createPath(context, targetAttrs);\n this.shadow(context, targetAttrs);\n this.strokeAndFill(context, targetAttrs);\n this.transform(targetAttrs);\n }\n };\n /**\n * @protected\n * 绘制图形的路径\n * @param {Defs} context 上下文\n * @param {ShapeAttrs} targetAttrs 渲染的目标属性\n */\n ShapeBase.prototype.createPath = function (context, targetAttrs) { };\n // stroke and fill\n ShapeBase.prototype.strokeAndFill = function (context, targetAttrs) {\n var attrs = targetAttrs || this.attr();\n var fill = attrs.fill, fillStyle = attrs.fillStyle, stroke = attrs.stroke, strokeStyle = attrs.strokeStyle, fillOpacity = attrs.fillOpacity, strokeOpacity = attrs.strokeOpacity, lineWidth = attrs.lineWidth;\n var el = this.get('el');\n if (this.canFill) {\n // 初次渲染和更新渲染的逻辑有所不同: 初次渲染值为空时,需要设置为 none,否则就会是黑色,而更新渲染则不需要\n if (!targetAttrs) {\n this._setColor(context, 'fill', fill || fillStyle);\n }\n else if ('fill' in attrs) {\n this._setColor(context, 'fill', fill);\n }\n else if ('fillStyle' in attrs) {\n // compatible with fillStyle\n this._setColor(context, 'fill', fillStyle);\n }\n if (fillOpacity) {\n el.setAttribute(SVG_ATTR_MAP['fillOpacity'], fillOpacity);\n }\n }\n if (this.canStroke && lineWidth > 0) {\n if (!targetAttrs) {\n this._setColor(context, 'stroke', stroke || strokeStyle);\n }\n else if ('stroke' in attrs) {\n this._setColor(context, 'stroke', stroke);\n }\n else if ('strokeStyle' in attrs) {\n // compatible with strokeStyle\n this._setColor(context, 'stroke', strokeStyle);\n }\n if (strokeOpacity) {\n el.setAttribute(SVG_ATTR_MAP['strokeOpacity'], strokeOpacity);\n }\n if (lineWidth) {\n el.setAttribute(SVG_ATTR_MAP['lineWidth'], lineWidth);\n }\n }\n };\n ShapeBase.prototype._setColor = function (context, attr, value) {\n var el = this.get('el');\n if (!value) {\n // need to set `none` to avoid default value\n el.setAttribute(SVG_ATTR_MAP[attr], 'none');\n return;\n }\n value = value.trim();\n if (/^[r,R,L,l]{1}[\\s]*\\(/.test(value)) {\n var id = context.find('gradient', value);\n if (!id) {\n id = context.addGradient(value);\n }\n el.setAttribute(SVG_ATTR_MAP[attr], \"url(#\" + id + \")\");\n }\n else if (/^[p,P]{1}[\\s]*\\(/.test(value)) {\n var id = context.find('pattern', value);\n if (!id) {\n id = context.addPattern(value);\n }\n el.setAttribute(SVG_ATTR_MAP[attr], \"url(#\" + id + \")\");\n }\n else {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n };\n ShapeBase.prototype.shadow = function (context, targetAttrs) {\n var attrs = this.attr();\n var _a = targetAttrs || attrs, shadowOffsetX = _a.shadowOffsetX, shadowOffsetY = _a.shadowOffsetY, shadowBlur = _a.shadowBlur, shadowColor = _a.shadowColor;\n if (shadowOffsetX || shadowOffsetY || shadowBlur || shadowColor) {\n setShadow(this, context);\n }\n };\n ShapeBase.prototype.transform = function (targetAttrs) {\n var attrs = this.attr();\n var matrix = (targetAttrs || attrs).matrix;\n if (matrix) {\n setTransform(this);\n }\n };\n ShapeBase.prototype.isInShape = function (refX, refY) {\n return this.isPointInPath(refX, refY);\n };\n ShapeBase.prototype.isPointInPath = function (refX, refY) {\n var el = this.get('el');\n var canvas = this.get('canvas');\n var bbox = canvas.get('el').getBoundingClientRect();\n var clientX = refX + bbox.left;\n var clientY = refY + bbox.top;\n var element = document.elementFromPoint(clientX, clientY);\n if (element && element.isEqualNode(el)) {\n return true;\n }\n return false;\n };\n /**\n * 获取线拾取的宽度\n * @returns {number} 线的拾取宽度\n */\n ShapeBase.prototype.getHitLineWidth = function () {\n var _a = this.attrs, lineWidth = _a.lineWidth, lineAppendWidth = _a.lineAppendWidth;\n if (this.isStroke()) {\n return lineWidth + lineAppendWidth;\n }\n return 0;\n };\n return ShapeBase;\n}(AbstractShape));\nexport default ShapeBase;\n//# sourceMappingURL=base.js.map","/**\n * @fileoverview circle\n * @author dengfuping_develop@163.com\n */\nimport { __assign, __extends } from \"tslib\";\nimport { each } from '@antv/util';\nimport { SVG_ATTR_MAP } from '../constant';\nimport ShapeBase from './base';\nvar Circle = /** @class */ (function (_super) {\n __extends(Circle, _super);\n function Circle() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'circle';\n _this.canFill = true;\n _this.canStroke = true;\n return _this;\n }\n Circle.prototype.getDefaultAttrs = function () {\n var attrs = _super.prototype.getDefaultAttrs.call(this);\n return __assign(__assign({}, attrs), { x: 0, y: 0, r: 0 });\n };\n Circle.prototype.createPath = function (context, targetAttrs) {\n var attrs = this.attr();\n var el = this.get('el');\n each(targetAttrs || attrs, function (value, attr) {\n // 圆和椭圆的点坐标属性不是 x, y,而是 cx, cy\n if (attr === 'x' || attr === 'y') {\n el.setAttribute(\"c\" + attr, value);\n }\n else if (SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n };\n return Circle;\n}(ShapeBase));\nexport default Circle;\n//# sourceMappingURL=circle.js.map","/**\n * @fileoverview ellipse\n * @author dengfuping_develop@163.com\n */\nimport { __assign, __extends } from \"tslib\";\nimport { each } from '@antv/util';\nimport { SVG_ATTR_MAP } from '../constant';\nimport ShapeBase from './base';\nvar Ellipse = /** @class */ (function (_super) {\n __extends(Ellipse, _super);\n function Ellipse() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'ellipse';\n _this.canFill = true;\n _this.canStroke = true;\n return _this;\n }\n Ellipse.prototype.getDefaultAttrs = function () {\n var attrs = _super.prototype.getDefaultAttrs.call(this);\n return __assign(__assign({}, attrs), { x: 0, y: 0, rx: 0, ry: 0 });\n };\n Ellipse.prototype.createPath = function (context, targetAttrs) {\n var attrs = this.attr();\n var el = this.get('el');\n each(targetAttrs || attrs, function (value, attr) {\n // 圆和椭圆的点坐标属性不是 x, y,而是 cx, cy\n if (attr === 'x' || attr === 'y') {\n el.setAttribute(\"c\" + attr, value);\n }\n else if (SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n };\n return Ellipse;\n}(ShapeBase));\nexport default Ellipse;\n//# sourceMappingURL=ellipse.js.map","/**\n * @fileoverview image\n * @author dengfuping_develop@163.com\n */\nimport { __assign, __extends } from \"tslib\";\nimport { each, isString } from '@antv/util';\nimport { SVG_ATTR_MAP } from '../constant';\nimport ShapeBase from './base';\nvar Image = /** @class */ (function (_super) {\n __extends(Image, _super);\n function Image() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'image';\n _this.canFill = false;\n _this.canStroke = false;\n return _this;\n }\n Image.prototype.getDefaultAttrs = function () {\n var attrs = _super.prototype.getDefaultAttrs.call(this);\n return __assign(__assign({}, attrs), { x: 0, y: 0, width: 0, height: 0 });\n };\n Image.prototype.createPath = function (context, targetAttrs) {\n var _this = this;\n var attrs = this.attr();\n var el = this.get('el');\n each(targetAttrs || attrs, function (value, attr) {\n if (attr === 'img') {\n _this._setImage(attrs.img);\n }\n else if (SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n };\n Image.prototype.setAttr = function (name, value) {\n this.attrs[name] = value;\n if (name === 'img') {\n this._setImage(value);\n }\n };\n Image.prototype._setImage = function (img) {\n var attrs = this.attr();\n var el = this.get('el');\n if (isString(img)) {\n el.setAttribute('href', img);\n }\n else if (img instanceof window.Image) {\n if (!attrs.width) {\n el.setAttribute('width', img.width);\n this.attr('width', img.width);\n }\n if (!attrs.height) {\n el.setAttribute('height', img.height);\n this.attr('height', img.height);\n }\n el.setAttribute('href', img.src);\n }\n else if (img instanceof HTMLElement && isString(img.nodeName) && img.nodeName.toUpperCase() === 'CANVAS') {\n // @ts-ignore\n el.setAttribute('href', img.toDataURL());\n }\n else if (img instanceof ImageData) {\n var canvas = document.createElement('canvas');\n canvas.setAttribute('width', \"\" + img.width);\n canvas.setAttribute('height', \"\" + img.height);\n canvas.getContext('2d').putImageData(img, 0, 0);\n if (!attrs.width) {\n el.setAttribute('width', \"\" + img.width);\n this.attr('width', img.width);\n }\n if (!attrs.height) {\n el.setAttribute('height', \"\" + img.height);\n this.attr('height', img.height);\n }\n el.setAttribute('href', canvas.toDataURL());\n }\n };\n return Image;\n}(ShapeBase));\nexport default Image;\n//# sourceMappingURL=image.js.map","import { Line as LineUtil } from '@antv/g-math';\nexport default function inLine(x1, y1, x2, y2, lineWidth, x, y) {\n var minX = Math.min(x1, x2);\n var maxX = Math.max(x1, x2);\n var minY = Math.min(y1, y2);\n var maxY = Math.max(y1, y2);\n var halfWidth = lineWidth / 2;\n // 因为目前的方案是计算点到直线的距离,而有可能会在延长线上,所以要先判断是否在包围盒内\n // 这种方案会在水平或者竖直的情况下载线的延长线上有半 lineWidth 的误差\n if (!(x >= minX - halfWidth && x <= maxX + halfWidth && y >= minY - halfWidth && y <= maxY + halfWidth)) {\n return false;\n }\n // 因为已经计算了包围盒,所以仅需要计算到直线的距离即可,可以显著提升性能\n return LineUtil.pointToLine(x1, y1, x2, y2, x, y) <= lineWidth / 2;\n}\n//# sourceMappingURL=line.js.map","import { __assign, __extends } from \"tslib\";\n/**\n * @fileoverview line\n * @author dengfuping_develop@163.com\n */\nimport { Line as LineUtil } from '@antv/g-math';\nimport { each, isObject } from '@antv/util';\nimport { SVG_ATTR_MAP } from '../constant';\nimport ShapeBase from './base';\nvar Line = /** @class */ (function (_super) {\n __extends(Line, _super);\n function Line() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'line';\n _this.canFill = false;\n _this.canStroke = true;\n return _this;\n }\n Line.prototype.getDefaultAttrs = function () {\n var attrs = _super.prototype.getDefaultAttrs.call(this);\n return __assign(__assign({}, attrs), { x1: 0, y1: 0, x2: 0, y2: 0, startArrow: false, endArrow: false });\n };\n Line.prototype.createPath = function (context, targetAttrs) {\n var attrs = this.attr();\n var el = this.get('el');\n each(targetAttrs || attrs, function (value, attr) {\n if (attr === 'startArrow' || attr === 'endArrow') {\n if (value) {\n var id = isObject(value)\n ? context.addArrow(attrs, SVG_ATTR_MAP[attr])\n : context.getDefaultArrow(attrs, SVG_ATTR_MAP[attr]);\n el.setAttribute(SVG_ATTR_MAP[attr], \"url(#\" + id + \")\");\n }\n else {\n el.removeAttribute(SVG_ATTR_MAP[attr]);\n }\n }\n else if (SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n };\n /**\n * Use math calculation to get length of line\n * @return {number} length\n */\n Line.prototype.getTotalLength = function () {\n var _a = this.attr(), x1 = _a.x1, y1 = _a.y1, x2 = _a.x2, y2 = _a.y2;\n return LineUtil.length(x1, y1, x2, y2);\n };\n /**\n * Use math calculation to get point according to ratio as same sa Canvas version\n * @param {number} ratio\n * @return {Point} point\n */\n Line.prototype.getPoint = function (ratio) {\n var _a = this.attr(), x1 = _a.x1, y1 = _a.y1, x2 = _a.x2, y2 = _a.y2;\n return LineUtil.pointAt(x1, y1, x2, y2, ratio);\n };\n return Line;\n}(ShapeBase));\nexport default Line;\n//# sourceMappingURL=line.js.map","/**\n * @fileoverview Marker\n * @author dxq613@gmail.com\n */\nimport { __extends } from \"tslib\";\nimport { isNil } from '@antv/util';\nimport { path2Absolute } from '@antv/path-util';\nimport ShapeBase from './base';\nimport { isFunction } from '../util/util';\nimport { drawPath } from '../util/draw';\nvar Symbols = {\n // 圆\n circle: function (x, y, r) {\n return [\n ['M', x - r, y],\n ['A', r, r, 0, 1, 0, x + r, y],\n ['A', r, r, 0, 1, 0, x - r, y],\n ];\n },\n // 正方形\n square: function (x, y, r) {\n return [['M', x - r, y - r], ['L', x + r, y - r], ['L', x + r, y + r], ['L', x - r, y + r], ['Z']];\n },\n // 菱形\n diamond: function (x, y, r) {\n return [['M', x - r, y], ['L', x, y - r], ['L', x + r, y], ['L', x, y + r], ['Z']];\n },\n // 三角形\n triangle: function (x, y, r) {\n var diffY = r * Math.sin((1 / 3) * Math.PI);\n return [['M', x - r, y + diffY], ['L', x, y - diffY], ['L', x + r, y + diffY], ['Z']];\n },\n // 倒三角形\n 'triangle-down': function (x, y, r) {\n var diffY = r * Math.sin((1 / 3) * Math.PI);\n return [['M', x - r, y - diffY], ['L', x + r, y - diffY], ['L', x, y + diffY], ['Z']];\n },\n};\nvar Marker = /** @class */ (function (_super) {\n __extends(Marker, _super);\n function Marker() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n Marker.prototype.initAttrs = function (attrs) {\n this._resetParamsCache();\n };\n // 重置绘制 path 存储的缓存\n Marker.prototype._resetParamsCache = function () {\n // 为了加速 path 的绘制、拾取和计算,这个地方可以缓存很多东西\n // 这些缓存都是第一次需要时计算和存储,虽然增加了复杂度,但是频繁调用的方法,性能有很大提升\n this.set('paramsCache', {}); // 清理缓存\n };\n // 更新属性时,检测是否更改了 path\n Marker.prototype.onAttrChange = function (name, value, originValue) {\n _super.prototype.onAttrChange.call(this, name, value, originValue);\n if (['symbol', 'x', 'y', 'r', 'radius'].indexOf(name) !== -1) {\n // path 相关属性更改时,清理缓存\n this._resetParamsCache();\n }\n };\n // 仅仅使用包围盒检测来进行拾取\n // 所以不需要复写 isInStrokeOrPath 的方法\n Marker.prototype.isOnlyHitBox = function () {\n return true;\n };\n Marker.prototype._getR = function (attrs) {\n // 兼容 r 和 radius 两种写法,推荐使用 r\n return isNil(attrs.r) ? attrs.radius : attrs.r;\n };\n Marker.prototype._getPath = function () {\n var attrs = this.attr();\n var x = attrs.x, y = attrs.y;\n var symbol = attrs.symbol || 'circle';\n var r = this._getR(attrs);\n var method;\n var path;\n if (isFunction(symbol)) {\n method = symbol;\n path = method(x, y, r);\n // 将 path 转成绝对路径\n path = path2Absolute(path);\n }\n else {\n // 内置 symbol 的 path 都是绝对路径,直接绘制即可,不需要对 path 进行特殊处理\n method = Marker.Symbols[symbol];\n if (!method) {\n console.warn(symbol + \" marker is not supported.\");\n return null;\n }\n path = method(x, y, r);\n }\n return path;\n };\n Marker.prototype.createPath = function (context) {\n var path = this._getPath();\n var paramsCache = this.get('paramsCache');\n drawPath(this, context, { path: path }, paramsCache);\n };\n Marker.Symbols = Symbols;\n return Marker;\n}(ShapeBase));\nexport default Marker;\n//# sourceMappingURL=marker.js.map","import { getOffScreenContext } from '@antv/g-base';\nexport default function isPointInPath(shape, x, y) {\n var ctx = getOffScreenContext();\n shape.createPath(ctx);\n return ctx.isPointInPath(x, y);\n}\n//# sourceMappingURL=point-in-path.js.map","/**\n * @fileoverview 判断点是否在多边形内\n * @author dxq613@gmail.com\n */\n// 多边形的射线检测,参考:https://blog.csdn.net/WilliamSun0122/article/details/77994526\nvar tolerance = 1e-6;\n// 三态函数,判断两个double在eps精度下的大小关系\nfunction dcmp(x) {\n if (Math.abs(x) < tolerance) {\n return 0;\n }\n return x < 0 ? -1 : 1;\n}\n// 判断点Q是否在p1和p2的线段上\nfunction onSegment(p1, p2, q) {\n if ((q[0] - p1[0]) * (p2[1] - p1[1]) === (p2[0] - p1[0]) * (q[1] - p1[1]) &&\n Math.min(p1[0], p2[0]) <= q[0] &&\n q[0] <= Math.max(p1[0], p2[0]) &&\n Math.min(p1[1], p2[1]) <= q[1] &&\n q[1] <= Math.max(p1[1], p2[1])) {\n return true;\n }\n return false;\n}\n// 判断点P在多边形内-射线法\nexport default function isInPolygon(points, x, y) {\n var isHit = false;\n var n = points.length;\n if (n <= 2) {\n // svg 中点小于 3 个时,不显示,也无法被拾取\n return false;\n }\n for (var i = 0; i < n; i++) {\n var p1 = points[i];\n var p2 = points[(i + 1) % n];\n if (onSegment(p1, p2, [x, y])) {\n // 点在多边形一条边上\n return true;\n }\n // 前一个判断min(p1[1],p2[1])<P.y<=max(p1[1],p2[1])\n // 后一个判断被测点 在 射线与边交点 的左边\n if (dcmp(p1[1] - y) > 0 !== dcmp(p2[1] - y) > 0 &&\n dcmp(x - ((y - p1[1]) * (p1[0] - p2[0])) / (p1[1] - p2[1]) - p1[0]) < 0) {\n isHit = !isHit;\n }\n }\n return isHit;\n}\n//# sourceMappingURL=polygon.js.map","import { distance } from '../util';\nexport default function arc(cx, cy, r, startAngle, endAngle, lineWidth, x, y) {\n var angle = (Math.atan2(y - cy, x - cx) + Math.PI * 2) % (Math.PI * 2); // 转换到 0 - 2 * Math.PI 之间\n if (angle < startAngle || angle > endAngle) {\n return false;\n }\n var point = {\n x: cx + r * Math.cos(angle),\n y: cy + r * Math.sin(angle),\n };\n return distance(point.x, point.y, x, y) <= lineWidth / 2;\n}\n//# sourceMappingURL=arc.js.map","import { __assign, __extends } from \"tslib\";\nimport { each, isArray, isObject } from '@antv/util';\nimport { SVG_ATTR_MAP } from '../constant';\nimport ShapeBase from './base';\nvar Path = /** @class */ (function (_super) {\n __extends(Path, _super);\n function Path() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'path';\n _this.canFill = true;\n _this.canStroke = true;\n return _this;\n }\n Path.prototype.getDefaultAttrs = function () {\n var attrs = _super.prototype.getDefaultAttrs.call(this);\n return __assign(__assign({}, attrs), { startArrow: false, endArrow: false });\n };\n Path.prototype.createPath = function (context, targetAttrs) {\n var _this = this;\n var attrs = this.attr();\n var el = this.get('el');\n each(targetAttrs || attrs, function (value, attr) {\n if (attr === 'path' && isArray(value)) {\n el.setAttribute('d', _this._formatPath(value));\n }\n else if (attr === 'startArrow' || attr === 'endArrow') {\n if (value) {\n var id = isObject(value)\n ? context.addArrow(attrs, SVG_ATTR_MAP[attr])\n : context.getDefaultArrow(attrs, SVG_ATTR_MAP[attr]);\n el.setAttribute(SVG_ATTR_MAP[attr], \"url(#\" + id + \")\");\n }\n else {\n el.removeAttribute(SVG_ATTR_MAP[attr]);\n }\n }\n else if (SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n };\n Path.prototype._formatPath = function (value) {\n var newValue = value\n .map(function (path) {\n return path.join(' ');\n })\n .join('');\n if (~newValue.indexOf('NaN')) {\n return '';\n }\n return newValue;\n };\n /**\n * Get total length of path\n * 尽管通过浏览器的 SVGPathElement.getTotalLength() 接口获取的 path 长度,\n * 与 Canvas 版本通过数学计算的方式得到的长度有一些细微差异,但最大误差在个位数像素,精度上可以能接受\n * @return {number} length\n */\n Path.prototype.getTotalLength = function () {\n var el = this.get('el');\n return el ? el.getTotalLength() : null;\n };\n /**\n * Get point according to ratio\n * @param {number} ratio\n * @return {Point} point\n */\n Path.prototype.getPoint = function (ratio) {\n var el = this.get('el');\n var totalLength = this.getTotalLength();\n // @see https://github.com/antvis/g/issues/634\n if (totalLength === 0) {\n return null;\n }\n var point = el ? el.getPointAtLength(ratio * totalLength) : null;\n return point\n ? {\n x: point.x,\n y: point.y,\n }\n : null;\n };\n return Path;\n}(ShapeBase));\nexport default Path;\n//# sourceMappingURL=path.js.map","import inLine from './line';\nexport default function inPolyline(points, lineWidth, x, y, isClose) {\n var count = points.length;\n if (count < 2) {\n return false;\n }\n for (var i = 0; i < count - 1; i++) {\n var x1 = points[i][0];\n var y1 = points[i][1];\n var x2 = points[i + 1][0];\n var y2 = points[i + 1][1];\n if (inLine(x1, y1, x2, y2, lineWidth, x, y)) {\n return true;\n }\n }\n // 如果封闭,则计算起始点和结束点的边\n if (isClose) {\n var first = points[0];\n var last = points[count - 1];\n if (inLine(first[0], first[1], last[0], last[1], lineWidth, x, y)) {\n return true;\n }\n }\n return false;\n}\n//# sourceMappingURL=polyline.js.map","import { __extends } from \"tslib\";\n/**\n * @fileoverview polygon\n * @author dengfuping_develop@163.com\n */\nimport { each, isArray } from '@antv/util';\nimport { SVG_ATTR_MAP } from '../constant';\nimport ShapeBase from './base';\nvar Polygon = /** @class */ (function (_super) {\n __extends(Polygon, _super);\n function Polygon() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'polygon';\n _this.canFill = true;\n _this.canStroke = true;\n return _this;\n }\n Polygon.prototype.createPath = function (context, targetAttrs) {\n var attrs = this.attr();\n var el = this.get('el');\n each(targetAttrs || attrs, function (value, attr) {\n if (attr === 'points' && isArray(value) && value.length >= 2) {\n el.setAttribute('points', value.map(function (point) { return point[0] + \",\" + point[1]; }).join(' '));\n }\n else if (SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n };\n return Polygon;\n}(ShapeBase));\nexport default Polygon;\n//# sourceMappingURL=polygon.js.map","import { __assign, __extends } from \"tslib\";\nimport { Polyline as PolylineUtil } from '@antv/g-math';\nimport { Line as LineUtil } from '@antv/g-math';\nimport { each, isArray, isNil } from '@antv/util';\nimport { SVG_ATTR_MAP } from '../constant';\nimport ShapeBase from './base';\nvar Polyline = /** @class */ (function (_super) {\n __extends(Polyline, _super);\n function Polyline() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'polyline';\n _this.canFill = true;\n _this.canStroke = true;\n return _this;\n }\n Polyline.prototype.getDefaultAttrs = function () {\n var attrs = _super.prototype.getDefaultAttrs.call(this);\n return __assign(__assign({}, attrs), { startArrow: false, endArrow: false });\n };\n // 更新属性时,检测是否更改了 points\n Polyline.prototype.onAttrChange = function (name, value, originValue) {\n _super.prototype.onAttrChange.call(this, name, value, originValue);\n if (['points'].indexOf(name) !== -1) {\n this._resetCache();\n }\n };\n Polyline.prototype._resetCache = function () {\n this.set('totalLength', null);\n this.set('tCache', null);\n };\n Polyline.prototype.createPath = function (context, targetAttrs) {\n var attrs = this.attr();\n var el = this.get('el');\n each(targetAttrs || attrs, function (value, attr) {\n if (attr === 'points' && isArray(value) && value.length >= 2) {\n el.setAttribute('points', value.map(function (point) { return point[0] + \",\" + point[1]; }).join(' '));\n }\n else if (SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n };\n /**\n * Get length of polyline\n * @return {number} length\n */\n Polyline.prototype.getTotalLength = function () {\n var points = this.attr().points;\n // get totalLength from cache\n var totalLength = this.get('totalLength');\n if (!isNil(totalLength)) {\n return totalLength;\n }\n this.set('totalLength', PolylineUtil.length(points));\n return this.get('totalLength');\n };\n /**\n * Get point according to ratio\n * @param {number} ratio\n * @return {Point} point\n */\n Polyline.prototype.getPoint = function (ratio) {\n var points = this.attr().points;\n // get tCache from cache\n var tCache = this.get('tCache');\n if (!tCache) {\n this._setTcache();\n tCache = this.get('tCache');\n }\n var subt;\n var index;\n each(tCache, function (v, i) {\n if (ratio >= v[0] && ratio <= v[1]) {\n subt = (ratio - v[0]) / (v[1] - v[0]);\n index = i;\n }\n });\n return LineUtil.pointAt(points[index][0], points[index][1], points[index + 1][0], points[index + 1][1], subt);\n };\n Polyline.prototype._setTcache = function () {\n var points = this.attr().points;\n if (!points || points.length === 0) {\n return;\n }\n var totalLength = this.getTotalLength();\n if (totalLength <= 0) {\n return;\n }\n var tempLength = 0;\n var tCache = [];\n var segmentT;\n var segmentL;\n each(points, function (p, i) {\n if (points[i + 1]) {\n segmentT = [];\n segmentT[0] = tempLength / totalLength;\n segmentL = LineUtil.length(p[0], p[1], points[i + 1][0], points[i + 1][1]);\n tempLength += segmentL;\n segmentT[1] = tempLength / totalLength;\n tCache.push(segmentT);\n }\n });\n this.set('tCache', tCache);\n };\n /**\n * Get start tangent vector\n * @return {Array}\n */\n Polyline.prototype.getStartTangent = function () {\n var points = this.attr().points;\n var result = [];\n result.push([points[1][0], points[1][1]]);\n result.push([points[0][0], points[0][1]]);\n return result;\n };\n /**\n * Get end tangent vector\n * @return {Array}\n */\n Polyline.prototype.getEndTangent = function () {\n var points = this.attr().points;\n var l = points.length - 1;\n var result = [];\n result.push([points[l - 1][0], points[l - 1][1]]);\n result.push([points[l][0], points[l][1]]);\n return result;\n };\n return Polyline;\n}(ShapeBase));\nexport default Polyline;\n//# sourceMappingURL=polyline.js.map","/**\n * @fileoverview rect\n * @author dengfuping_develop@163.com\n */\nimport { __assign, __extends } from \"tslib\";\nimport { each, isArray } from '@antv/util';\nimport ShapeBase from './base';\nimport { SVG_ATTR_MAP } from '../constant';\nimport { parseRadius } from '../util/format';\nvar Rect = /** @class */ (function (_super) {\n __extends(Rect, _super);\n function Rect() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'rect';\n _this.canFill = true;\n _this.canStroke = true;\n return _this;\n }\n Rect.prototype.getDefaultAttrs = function () {\n var attrs = _super.prototype.getDefaultAttrs.call(this);\n return __assign(__assign({}, attrs), { x: 0, y: 0, width: 0, height: 0, radius: 0 });\n };\n Rect.prototype.createPath = function (context, targetAttrs) {\n var _this = this;\n var attrs = this.attr();\n var el = this.get('el');\n // 加上状态量,用来标记 path 是否已组装\n var completed = false;\n // 和组装 path 相关的绘图属性\n var pathRelatedAttrs = ['x', 'y', 'width', 'height', 'radius'];\n each(targetAttrs || attrs, function (value, attr) {\n if (pathRelatedAttrs.indexOf(attr) !== -1 && !completed) {\n el.setAttribute('d', _this._assembleRect(attrs));\n completed = true;\n }\n else if (pathRelatedAttrs.indexOf(attr) === -1 && SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n };\n Rect.prototype._assembleRect = function (attrs) {\n var x = attrs.x;\n var y = attrs.y;\n var w = attrs.width;\n var h = attrs.height;\n var radius = attrs.radius;\n if (!radius) {\n return \"M \" + x + \",\" + y + \" l \" + w + \",0 l 0,\" + h + \" l\" + -w + \" 0 z\";\n }\n var r = parseRadius(radius);\n if (isArray(radius)) {\n if (radius.length === 1) {\n r.r1 = r.r2 = r.r3 = r.r4 = radius[0];\n }\n else if (radius.length === 2) {\n r.r1 = r.r3 = radius[0];\n r.r2 = r.r4 = radius[1];\n }\n else if (radius.length === 3) {\n r.r1 = radius[0];\n r.r2 = r.r4 = radius[1];\n r.r3 = radius[2];\n }\n else {\n r.r1 = radius[0];\n r.r2 = radius[1];\n r.r3 = radius[2];\n r.r4 = radius[3];\n }\n }\n else {\n r.r1 = r.r2 = r.r3 = r.r4 = radius;\n }\n var d = [\n [\"M \" + (x + r.r1) + \",\" + y],\n [\"l \" + (w - r.r1 - r.r2) + \",0\"],\n [\"a \" + r.r2 + \",\" + r.r2 + \",0,0,1,\" + r.r2 + \",\" + r.r2],\n [\"l 0,\" + (h - r.r2 - r.r3)],\n [\"a \" + r.r3 + \",\" + r.r3 + \",0,0,1,\" + -r.r3 + \",\" + r.r3],\n [\"l \" + (r.r3 + r.r4 - w) + \",0\"],\n [\"a \" + r.r4 + \",\" + r.r4 + \",0,0,1,\" + -r.r4 + \",\" + -r.r4],\n [\"l 0,\" + (r.r4 + r.r1 - h)],\n [\"a \" + r.r1 + \",\" + r.r1 + \",0,0,1,\" + r.r1 + \",\" + -r.r1],\n ['z'],\n ];\n return d.join(' ');\n };\n return Rect;\n}(ShapeBase));\nexport default Rect;\n//# sourceMappingURL=rect.js.map","import inLine from './line';\nimport inArc from './arc';\nexport default function rectWithRadius(minX, minY, width, height, radius, lineWidth, x, y) {\n var halfWidth = lineWidth / 2;\n return (inLine(minX + radius, minY, minX + width - radius, minY, lineWidth, x, y) ||\n inLine(minX + width, minY + radius, minX + width, minY + height - radius, lineWidth, x, y) ||\n inLine(minX + width - radius, minY + height, minX + radius, minY + height, lineWidth, x, y) ||\n inLine(minX, minY + height - radius, minX, minY + radius, lineWidth, x, y) ||\n inArc(minX + width - radius, minY + radius, radius, 1.5 * Math.PI, 2 * Math.PI, lineWidth, x, y) ||\n inArc(minX + width - radius, minY + height - radius, radius, 0, 0.5 * Math.PI, lineWidth, x, y) ||\n inArc(minX + radius, minY + height - radius, radius, 0.5 * Math.PI, Math.PI, lineWidth, x, y) ||\n inArc(minX + radius, minY + radius, radius, Math.PI, 1.5 * Math.PI, lineWidth, x, y));\n}\n//# sourceMappingURL=rect-radius.js.map","import { inBox } from '../util';\nexport default function inRect(minX, minY, width, height, lineWidth, x, y) {\n var halfWidth = lineWidth / 2;\n // 将四个边看做矩形来检测,比边的检测算法要快\n return (inBox(minX - halfWidth, minY - halfWidth, width, lineWidth, x, y) || // 上边\n inBox(minX + width - halfWidth, minY - halfWidth, lineWidth, height, x, y) || // 右边\n inBox(minX + halfWidth, minY + height - halfWidth, width, lineWidth, x, y) || // 下边\n inBox(minX - halfWidth, minY + halfWidth, lineWidth, height, x, y)); // 左边\n}\n//# sourceMappingURL=rect.js.map","/**\n * @fileoverview text\n * @author dengfuping_develop@163.com\n */\nimport { __assign, __extends } from \"tslib\";\nimport { each } from '@antv/util';\nimport { detect } from 'detect-browser';\nimport { setTransform } from '../util/svg';\nimport { SVG_ATTR_MAP } from '../constant';\nimport ShapeBase from './base';\nvar LETTER_SPACING = 0.3;\nvar BASELINE_MAP = {\n top: 'before-edge',\n middle: 'central',\n bottom: 'after-edge',\n alphabetic: 'baseline',\n hanging: 'hanging',\n};\n// for FireFox\nvar BASELINE_MAP_FOR_FIREFOX = {\n top: 'text-before-edge',\n middle: 'central',\n bottom: 'text-after-edge',\n alphabetic: 'alphabetic',\n hanging: 'hanging',\n};\nvar ANCHOR_MAP = {\n left: 'left',\n start: 'left',\n center: 'middle',\n right: 'end',\n end: 'end',\n};\nvar Text = /** @class */ (function (_super) {\n __extends(Text, _super);\n function Text() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'text';\n _this.canFill = true;\n _this.canStroke = true;\n return _this;\n }\n Text.prototype.getDefaultAttrs = function () {\n var attrs = _super.prototype.getDefaultAttrs.call(this);\n return __assign(__assign({}, attrs), { x: 0, y: 0, text: null, fontSize: 12, fontFamily: 'sans-serif', fontStyle: 'normal', fontWeight: 'normal', fontVariant: 'normal', textAlign: 'start', textBaseline: 'bottom' });\n };\n Text.prototype.createPath = function (context, targetAttrs) {\n var _this = this;\n var attrs = this.attr();\n var el = this.get('el');\n this._setFont();\n each(targetAttrs || attrs, function (value, attr) {\n if (attr === 'text') {\n _this._setText(\"\" + value);\n }\n else if (attr === 'matrix' && value) {\n setTransform(_this);\n }\n else if (SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n el.setAttribute('paint-order', 'stroke');\n el.setAttribute('style', 'stroke-linecap:butt; stroke-linejoin:miter;');\n };\n Text.prototype._setFont = function () {\n var el = this.get('el');\n var _a = this.attr(), textBaseline = _a.textBaseline, textAlign = _a.textAlign;\n var browser = detect();\n if (browser && browser.name === 'firefox') {\n // compatible with FireFox browser, ref: https://github.com/antvis/g/issues/119\n el.setAttribute('dominant-baseline', BASELINE_MAP_FOR_FIREFOX[textBaseline] || 'alphabetic');\n }\n else {\n el.setAttribute('alignment-baseline', BASELINE_MAP[textBaseline] || 'baseline');\n }\n el.setAttribute('text-anchor', ANCHOR_MAP[textAlign] || 'left');\n };\n Text.prototype._setText = function (text) {\n var el = this.get('el');\n var _a = this.attr(), x = _a.x, _b = _a.textBaseline, baseline = _b === void 0 ? 'bottom' : _b;\n if (!text) {\n el.innerHTML = '';\n }\n else if (~text.indexOf('\\n')) {\n var textArr = text.split('\\n');\n var textLen_1 = textArr.length - 1;\n var arr_1 = '';\n each(textArr, function (segment, i) {\n if (i === 0) {\n if (baseline === 'alphabetic') {\n arr_1 += \"<tspan x=\\\"\" + x + \"\\\" dy=\\\"\" + -textLen_1 + \"em\\\">\" + segment + \"</tspan>\";\n }\n else if (baseline === 'top') {\n arr_1 += \"<tspan x=\\\"\" + x + \"\\\" dy=\\\"0.9em\\\">\" + segment + \"</tspan>\";\n }\n else if (baseline === 'middle') {\n arr_1 += \"<tspan x=\\\"\" + x + \"\\\" dy=\\\"\" + -(textLen_1 - 1) / 2 + \"em\\\">\" + segment + \"</tspan>\";\n }\n else if (baseline === 'bottom') {\n arr_1 += \"<tspan x=\\\"\" + x + \"\\\" dy=\\\"-\" + (textLen_1 + LETTER_SPACING) + \"em\\\">\" + segment + \"</tspan>\";\n }\n else if (baseline === 'hanging') {\n arr_1 += \"<tspan x=\\\"\" + x + \"\\\" dy=\\\"\" + (-(textLen_1 - 1) - LETTER_SPACING) + \"em\\\">\" + segment + \"</tspan>\";\n }\n }\n else {\n arr_1 += \"<tspan x=\\\"\" + x + \"\\\" dy=\\\"1em\\\">\" + segment + \"</tspan>\";\n }\n });\n el.innerHTML = arr_1;\n }\n else {\n el.innerHTML = text;\n }\n };\n return Text;\n}(ShapeBase));\nexport default Text;\n//# sourceMappingURL=text.js.map","import { each, isArray, isString } from '@antv/util';\nvar regexTags = /[MLHVQTCSAZ]([^MLHVQTCSAZ]*)/ig;\nvar regexDot = /[^\\s\\,]+/ig;\nfunction parsePath(p) {\n var path = p || [];\n if (isArray(path)) {\n return path;\n }\n if (isString(path)) {\n path = path.match(regexTags);\n each(path, function (item, index) {\n // @ts-ignore\n item = item.match(regexDot);\n if (item[0].length > 1) {\n var tag = item[0].charAt(0);\n // @ts-ignore\n item.splice(1, 0, item[0].substr(1));\n // @ts-ignore\n item[0] = tag;\n }\n // @ts-ignore\n each(item, function (sub, i) {\n if (!isNaN(sub)) {\n // @ts-ignore\n item[i] = +sub;\n }\n });\n // @ts-ignore\n path[index] = item;\n });\n return path;\n }\n}\nexport default parsePath;\n//# sourceMappingURL=parse-path.js.map","// http://schepers.cc/getting-to-the-point\nexport default function catmullRom2Bezier(crp, z) {\n var d = [];\n // @ts-ignore\n for (var i = 0, iLen = crp.length; iLen - 2 * !z > i; i += 2) {\n var p = [{\n x: +crp[i - 2],\n y: +crp[i - 1],\n }, {\n x: +crp[i],\n y: +crp[i + 1],\n }, {\n x: +crp[i + 2],\n y: +crp[i + 3],\n }, {\n x: +crp[i + 4],\n y: +crp[i + 5],\n }];\n if (z) {\n if (!i) {\n p[0] = {\n x: +crp[iLen - 2],\n y: +crp[iLen - 1],\n };\n }\n else if (iLen - 4 === i) {\n p[3] = {\n x: +crp[0],\n y: +crp[1],\n };\n }\n else if (iLen - 2 === i) {\n p[2] = {\n x: +crp[0],\n y: +crp[1],\n };\n p[3] = {\n x: +crp[2],\n y: +crp[3],\n };\n }\n }\n else {\n if (iLen - 4 === i) {\n p[3] = p[2];\n }\n else if (!i) {\n p[0] = {\n x: +crp[i],\n y: +crp[i + 1],\n };\n }\n }\n d.push(['C',\n (-p[0].x + 6 * p[1].x + p[2].x) / 6,\n (-p[0].y + 6 * p[1].y + p[2].y) / 6,\n (p[1].x + 6 * p[2].x - p[3].x) / 6,\n (p[1].y + 6 * p[2].y - p[3].y) / 6,\n p[2].x,\n p[2].y,\n ]);\n }\n return d;\n}\n//# sourceMappingURL=catmull-rom-2-bezier.js.map","import { isArray } from '@antv/util';\nvar SPACES = '\\x09\\x0a\\x0b\\x0c\\x0d\\x20\\xa0\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000\\u2028\\u2029';\nvar PATH_COMMAND = new RegExp('([a-z])[' + SPACES + ',]*((-?\\\\d*\\\\.?\\\\d*(?:e[\\\\-+]?\\\\d+)?[' + SPACES + ']*,?[' + SPACES + ']*)+)', 'ig');\nvar PATH_VALUES = new RegExp('(-?\\\\d*\\\\.?\\\\d*(?:e[\\\\-+]?\\\\d+)?)[' + SPACES + ']*,?[' + SPACES + ']*', 'ig');\n// Parses given path string into an array of arrays of path segments\nexport default function parsePathString(pathString) {\n if (!pathString) {\n return null;\n }\n if (isArray(pathString)) {\n return pathString;\n }\n var paramCounts = {\n a: 7,\n c: 6,\n o: 2,\n h: 1,\n l: 2,\n m: 2,\n r: 4,\n q: 4,\n s: 4,\n t: 2,\n v: 1,\n u: 3,\n z: 0,\n };\n var data = [];\n String(pathString).replace(PATH_COMMAND, function (a, b, c) {\n var params = [];\n var name = b.toLowerCase();\n c.replace(PATH_VALUES, function (a, b) {\n b && params.push(+b);\n });\n if (name === 'm' && params.length > 2) {\n data.push([b].concat(params.splice(0, 2)));\n name = 'l';\n b = b === 'm' ? 'l' : 'L';\n }\n if (name === 'o' && params.length === 1) {\n data.push([b, params[0]]);\n }\n if (name === 'r') {\n data.push([b].concat(params));\n }\n else {\n while (params.length >= paramCounts[name]) {\n data.push([b].concat(params.splice(0, paramCounts[name])));\n if (!paramCounts[name]) {\n break;\n }\n }\n }\n return '';\n });\n return data;\n}\n//# sourceMappingURL=parse-path-string.js.map","import parsePathString from './parse-path-string';\nvar REGEX_MD = /[a-z]/;\nfunction toSymmetry(p, c) {\n return [\n c[0] + (c[0] - p[0]),\n c[1] + (c[1] - p[1]),\n ];\n}\nexport default function pathToAbsolute(pathString) {\n var pathArray = parsePathString(pathString);\n if (!pathArray || !pathArray.length) {\n return [\n ['M', 0, 0],\n ];\n }\n var needProcess = false; // 如果存在小写的命令或者 V,H,T,S 则需要处理\n for (var i = 0; i < pathArray.length; i++) {\n var cmd = pathArray[i][0];\n // 如果存在相对位置的命令,则中断返回\n if (REGEX_MD.test(cmd) || ['V', 'H', 'T', 'S'].indexOf(cmd) >= 0) {\n needProcess = true;\n break;\n }\n }\n // 如果不存在相对命令,则直接返回\n // 如果在业务上都写绝对路径,这种方式最快,仅做了一次检测\n if (!needProcess) {\n return pathArray;\n }\n var res = [];\n var x = 0;\n var y = 0;\n var mx = 0;\n var my = 0;\n var start = 0;\n var pa0;\n var dots;\n var first = pathArray[0];\n if (first[0] === 'M' || first[0] === 'm') {\n x = +first[1];\n y = +first[2];\n mx = x;\n my = y;\n start++;\n res[0] = ['M', x, y];\n }\n for (var i = start, ii = pathArray.length; i < ii; i++) {\n var pa = pathArray[i];\n var preParams = res[i - 1]; // 取前一个已经处理后的节点,否则会出现问题\n var r = [];\n var cmd = pa[0];\n var upCmd = cmd.toUpperCase();\n if (cmd !== upCmd) {\n r[0] = upCmd;\n switch (upCmd) {\n case 'A':\n r[1] = pa[1];\n r[2] = pa[2];\n r[3] = pa[3];\n r[4] = pa[4];\n r[5] = pa[5];\n r[6] = +pa[6] + x;\n r[7] = +pa[7] + y;\n break;\n case 'V':\n r[1] = +pa[1] + y;\n break;\n case 'H':\n r[1] = +pa[1] + x;\n break;\n case 'M':\n mx = +pa[1] + x;\n my = +pa[2] + y;\n r[1] = mx;\n r[2] = my;\n break; // for lint\n default:\n for (var j = 1, jj = pa.length; j < jj; j++) {\n r[j] = +pa[j] + ((j % 2) ? x : y);\n }\n }\n }\n else { // 如果本来已经大写,则不处理\n r = pathArray[i];\n }\n // 需要在外面统一做,同时处理 V,H,S,T 等特殊指令\n switch (upCmd) {\n case 'Z':\n x = +mx;\n y = +my;\n break;\n case 'H':\n x = r[1];\n r = ['L', x, y];\n break;\n case 'V':\n y = r[1];\n r = ['L', x, y];\n break;\n case 'T':\n x = r[1];\n y = r[2];\n // 以 x, y 为中心的,上一个控制点的对称点\n // 需要假设上一个节点的命令为 Q\n var symetricT = toSymmetry([preParams[1], preParams[2]], [preParams[3], preParams[4]]);\n r = ['Q', symetricT[0], symetricT[1], x, y];\n break;\n case 'S':\n x = r[r.length - 2];\n y = r[r.length - 1];\n // 以 x,y 为中心,取上一个控制点,\n // 需要假设上一个线段为 C 或者 S\n var length_1 = preParams.length;\n var symetricS = toSymmetry([preParams[length_1 - 4], preParams[length_1 - 3]], [preParams[length_1 - 2], preParams[length_1 - 1]]);\n r = ['C', symetricS[0], symetricS[1], r[1], r[2], x, y];\n break;\n case 'M':\n mx = r[r.length - 2];\n my = r[r.length - 1];\n break; // for lint\n default:\n x = r[r.length - 2];\n y = r[r.length - 1];\n }\n res.push(r);\n }\n return res;\n}\n//# sourceMappingURL=path-2-absolute.js.map","import { mod, toRadian } from '@antv/util';\n// 向量长度\nfunction vMag(v) {\n return Math.sqrt(v[0] * v[0] + v[1] * v[1]);\n}\n// u.v/|u||v|,计算夹角的余弦值\nfunction vRatio(u, v) {\n // 当存在一个向量的长度为 0 时,夹角也为 0,即夹角的余弦值为 1\n return vMag(u) * vMag(v) ? (u[0] * v[0] + u[1] * v[1]) / (vMag(u) * vMag(v)) : 1;\n}\n// 向量角度\nfunction vAngle(u, v) {\n return (u[0] * v[1] < u[1] * v[0] ? -1 : 1) * Math.acos(vRatio(u, v));\n}\n/**\n * 判断两个点是否重合,点坐标的格式为 [x, y]\n * @param {Array} point1 第一个点\n * @param {Array} point2 第二个点\n */\nexport function isSamePoint(point1, point2) {\n return point1[0] === point2[0] && point1[1] === point2[1];\n}\n// A 0:rx 1:ry 2:x-axis-rotation 3:large-arc-flag 4:sweep-flag 5: x 6: y\nexport default function getArcParams(startPoint, params) {\n var rx = params[1];\n var ry = params[2];\n var xRotation = mod(toRadian(params[3]), Math.PI * 2);\n var arcFlag = params[4];\n var sweepFlag = params[5];\n // 弧形起点坐标\n var x1 = startPoint[0];\n var y1 = startPoint[1];\n // 弧形终点坐标\n var x2 = params[6];\n var y2 = params[7];\n var xp = (Math.cos(xRotation) * (x1 - x2)) / 2.0 + (Math.sin(xRotation) * (y1 - y2)) / 2.0;\n var yp = (-1 * Math.sin(xRotation) * (x1 - x2)) / 2.0 + (Math.cos(xRotation) * (y1 - y2)) / 2.0;\n var lambda = (xp * xp) / (rx * rx) + (yp * yp) / (ry * ry);\n if (lambda > 1) {\n rx *= Math.sqrt(lambda);\n ry *= Math.sqrt(lambda);\n }\n var diff = rx * rx * (yp * yp) + ry * ry * (xp * xp);\n var f = diff ? Math.sqrt((rx * rx * (ry * ry) - diff) / diff) : 1;\n if (arcFlag === sweepFlag) {\n f *= -1;\n }\n if (isNaN(f)) {\n f = 0;\n }\n // 旋转前的起点坐标,且当长半轴和短半轴的长度为 0 时,坐标按 (0, 0) 处理\n var cxp = ry ? (f * rx * yp) / ry : 0;\n var cyp = rx ? (f * -ry * xp) / rx : 0;\n // 椭圆圆心坐标\n var cx = (x1 + x2) / 2.0 + Math.cos(xRotation) * cxp - Math.sin(xRotation) * cyp;\n var cy = (y1 + y2) / 2.0 + Math.sin(xRotation) * cxp + Math.cos(xRotation) * cyp;\n // 起始点的单位向量\n var u = [(xp - cxp) / rx, (yp - cyp) / ry];\n // 终止点的单位向量\n var v = [(-1 * xp - cxp) / rx, (-1 * yp - cyp) / ry];\n // 计算起始点和圆心的连线,与 x 轴正方向的夹角\n var theta = vAngle([1, 0], u);\n // 计算圆弧起始点和终止点与椭圆圆心连线的夹角\n var dTheta = vAngle(u, v);\n if (vRatio(u, v) <= -1) {\n dTheta = Math.PI;\n }\n if (vRatio(u, v) >= 1) {\n dTheta = 0;\n }\n if (sweepFlag === 0 && dTheta > 0) {\n dTheta = dTheta - 2 * Math.PI;\n }\n if (sweepFlag === 1 && dTheta < 0) {\n dTheta = dTheta + 2 * Math.PI;\n }\n return {\n cx: cx,\n cy: cy,\n // 弧形的起点和终点相同时,长轴和短轴的长度按 0 处理\n rx: isSamePoint(startPoint, [x2, y2]) ? 0 : rx,\n ry: isSamePoint(startPoint, [x2, y2]) ? 0 : ry,\n startAngle: theta,\n endAngle: theta + dTheta,\n xRotation: xRotation,\n arcFlag: arcFlag,\n sweepFlag: sweepFlag,\n };\n}\n//# sourceMappingURL=get-arc-params.js.map","import getArcParams from './get-arc-params';\nimport { isSamePoint } from './get-arc-params';\nimport parsePath from './parse-path';\n// 点对称\nfunction toSymmetry(point, center) {\n return [center[0] + (center[0] - point[0]), center[1] + (center[1] - point[1])];\n}\nexport default function getSegments(path) {\n path = parsePath(path);\n var segments = [];\n var currentPoint = null; // 当前图形\n var nextParams = null; // 下一节点的 path 参数\n var startMovePoint = null; // 开始 M 的点,可能会有多个\n var lastStartMovePointIndex = 0; // 最近一个开始点 M 的索引\n var count = path.length;\n for (var i = 0; i < count; i++) {\n var params = path[i];\n nextParams = path[i + 1];\n var command = params[0];\n // 数学定义上的参数,便于后面的计算\n var segment = {\n command: command,\n prePoint: currentPoint,\n params: params,\n startTangent: null,\n endTangent: null,\n };\n switch (command) {\n case 'M':\n startMovePoint = [params[1], params[2]];\n lastStartMovePointIndex = i;\n break;\n case 'A':\n var arcParams = getArcParams(currentPoint, params);\n segment['arcParams'] = arcParams;\n break;\n default:\n break;\n }\n if (command === 'Z') {\n // 有了 Z 后,当前节点从开始 M 的点开始\n currentPoint = startMovePoint;\n // 如果当前点的命令为 Z,相当于当前点为最近一个 M 点,则下一个点直接指向最近一个 M 点的下一个点\n nextParams = path[lastStartMovePointIndex + 1];\n }\n else {\n var len = params.length;\n currentPoint = [params[len - 2], params[len - 1]];\n }\n if (nextParams && nextParams[0] === 'Z') {\n // 如果下一个点的命令为 Z,则下一个点直接指向最近一个 M 点\n nextParams = path[lastStartMovePointIndex];\n if (segments[lastStartMovePointIndex]) {\n // 如果下一个点的命令为 Z,则最近一个 M 点的前一个点为当前点\n segments[lastStartMovePointIndex].prePoint = currentPoint;\n }\n }\n segment['currentPoint'] = currentPoint;\n // 如果当前点与最近一个 M 点相同,则最近一个 M 点的前一个点为当前点的前一个点\n if (segments[lastStartMovePointIndex] &&\n isSamePoint(currentPoint, segments[lastStartMovePointIndex].currentPoint)) {\n segments[lastStartMovePointIndex].prePoint = segment.prePoint;\n }\n var nextPoint = nextParams ? [nextParams[nextParams.length - 2], nextParams[nextParams.length - 1]] : null;\n segment['nextPoint'] = nextPoint;\n // Add startTangent and endTangent\n var prePoint = segment.prePoint;\n if (['L', 'H', 'V'].includes(command)) {\n segment.startTangent = [prePoint[0] - currentPoint[0], prePoint[1] - currentPoint[1]];\n segment.endTangent = [currentPoint[0] - prePoint[0], currentPoint[1] - prePoint[1]];\n }\n else if (command === 'Q') {\n // 二次贝塞尔曲线只有一个控制点\n var cp = [params[1], params[2]];\n // 二次贝塞尔曲线的终点为 currentPoint\n segment.startTangent = [prePoint[0] - cp[0], prePoint[1] - cp[1]];\n segment.endTangent = [currentPoint[0] - cp[0], currentPoint[1] - cp[1]];\n }\n else if (command === 'T') {\n var preSegment = segments[i - 1];\n var cp = toSymmetry(preSegment.currentPoint, prePoint);\n if (preSegment.command === 'Q') {\n segment.command = 'Q';\n segment.startTangent = [prePoint[0] - cp[0], prePoint[1] - cp[1]];\n segment.endTangent = [currentPoint[0] - cp[0], currentPoint[1] - cp[1]];\n }\n else {\n segment.command = 'TL';\n segment.startTangent = [prePoint[0] - currentPoint[0], prePoint[1] - currentPoint[1]];\n segment.endTangent = [currentPoint[0] - prePoint[0], currentPoint[1] - prePoint[1]];\n }\n }\n else if (command === 'C') {\n // 三次贝塞尔曲线有两个控制点\n var cp1 = [params[1], params[2]];\n var cp2 = [params[3], params[4]];\n segment.startTangent = [prePoint[0] - cp1[0], prePoint[1] - cp1[1]];\n segment.endTangent = [currentPoint[0] - cp2[0], currentPoint[1] - cp2[1]];\n // horizontal line, eg. ['C', 100, 100, 100, 100, 200, 200]\n if (segment.startTangent[0] === 0 && segment.startTangent[1] === 0) {\n segment.startTangent = [cp1[0] - cp2[0], cp1[1] - cp2[1]];\n }\n if (segment.endTangent[0] === 0 && segment.endTangent[1] === 0) {\n segment.endTangent = [cp2[0] - cp1[0], cp2[1] - cp1[1]];\n }\n }\n else if (command === 'S') {\n var preSegment = segments[i - 1];\n var cp1 = toSymmetry(preSegment.currentPoint, prePoint);\n var cp2 = [params[1], params[2]];\n if (preSegment.command === 'C') {\n segment.command = 'C'; // 将 S 命令变换为 C 命令\n segment.startTangent = [prePoint[0] - cp1[0], prePoint[1] - cp1[1]];\n segment.endTangent = [currentPoint[0] - cp2[0], currentPoint[1] - cp2[1]];\n }\n else {\n segment.command = 'SQ'; // 将 S 命令变换为 SQ 命令\n segment.startTangent = [prePoint[0] - cp2[0], prePoint[1] - cp2[1]];\n segment.endTangent = [currentPoint[0] - cp2[0], currentPoint[1] - cp2[1]];\n }\n }\n else if (command === 'A') {\n var d = 0.001;\n var _a = segment['arcParams'] || {}, _b = _a.cx, cx = _b === void 0 ? 0 : _b, _c = _a.cy, cy = _c === void 0 ? 0 : _c, _d = _a.rx, rx = _d === void 0 ? 0 : _d, _e = _a.ry, ry = _e === void 0 ? 0 : _e, _f = _a.sweepFlag, sweepFlag = _f === void 0 ? 0 : _f, _g = _a.startAngle, startAngle = _g === void 0 ? 0 : _g, _h = _a.endAngle, endAngle = _h === void 0 ? 0 : _h;\n if (sweepFlag === 0) {\n d *= -1;\n }\n var dx1 = rx * Math.cos(startAngle - d) + cx;\n var dy1 = ry * Math.sin(startAngle - d) + cy;\n segment.startTangent = [dx1 - startMovePoint[0], dy1 - startMovePoint[1]];\n var dx2 = rx * Math.cos(startAngle + endAngle + d) + cx;\n var dy2 = ry * Math.sin(startAngle + endAngle - d) + cy;\n segment.endTangent = [prePoint[0] - dx2, prePoint[1] - dy2];\n }\n segments.push(segment);\n }\n return segments;\n}\n//# sourceMappingURL=path-2-segments.js.map","import { mat4, vec3 } from 'gl-matrix';\nimport { AABB } from './AABB';\nimport { Plane } from './Plane';\n\nexport enum Mask {\n OUTSIDE = 0xffffffff,\n INSIDE = 0x00000000,\n INDETERMINATE = 0x7fffffff,\n}\n\nexport class Frustum {\n public planes: Plane[] = [];\n\n constructor(planes?: Plane[]) {\n if (planes) {\n this.planes = planes;\n } else {\n for (let i = 0; i < 6; i++) {\n this.planes.push(new Plane());\n }\n }\n }\n\n /**\n * extract 6 planes from vpMatrix\n * @see http://www8.cs.umu.se/kurser/5DV051/HT12/lab/plane_extraction.pdf\n * @param vpMatrix viewProjectionMatrix\n */\n public extractFromVPMatrix(vpMatrix: mat4) {\n const [\n m0,\n m1,\n m2,\n m3,\n m4,\n m5,\n m6,\n m7,\n m8,\n m9,\n m10,\n m11,\n m12,\n m13,\n m14,\n m15,\n ] = vpMatrix;\n\n // right\n vec3.set(this.planes[0].normal, m3 - m0, m7 - m4, m11 - m8);\n this.planes[0].distance = -(m15 - m12);\n\n // left\n vec3.set(this.planes[1].normal, m3 + m0, m7 + m4, m11 + m8);\n this.planes[1].distance = -(m15 + m12);\n\n // bottom\n vec3.set(this.planes[2].normal, m3 + m1, m7 + m5, m11 + m9);\n this.planes[2].distance = -(m15 + m13);\n\n // top\n vec3.set(this.planes[3].normal, m3 - m1, m7 - m5, m11 - m9);\n this.planes[3].distance = -(m15 - m13);\n\n // far\n vec3.set(this.planes[4].normal, m3 - m2, m7 - m6, m11 - m10);\n this.planes[4].distance = -(m15 - m14);\n\n // near\n vec3.set(this.planes[5].normal, m3 + m2, m7 + m6, m11 + m10);\n this.planes[5].distance = -(m15 + m14);\n\n this.planes.forEach((plane) => {\n plane.normalize();\n plane.updatePNVertexFlag();\n });\n }\n}\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeys = require('./_baseKeys'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nmodule.exports = keys;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.tagProperty = exports.tagParameter = exports.decorate = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nfunction tagParameter(annotationTarget, propertyName, parameterIndex, metadata) {\n var metadataKey = METADATA_KEY.TAGGED;\n _tagParameterOrProperty(metadataKey, annotationTarget, propertyName, metadata, parameterIndex);\n}\nexports.tagParameter = tagParameter;\nfunction tagProperty(annotationTarget, propertyName, metadata) {\n var metadataKey = METADATA_KEY.TAGGED_PROP;\n _tagParameterOrProperty(metadataKey, annotationTarget.constructor, propertyName, metadata);\n}\nexports.tagProperty = tagProperty;\nfunction _tagParameterOrProperty(metadataKey, annotationTarget, propertyName, metadata, parameterIndex) {\n var paramsOrPropertiesMetadata = {};\n var isParameterDecorator = (typeof parameterIndex === \"number\");\n var key = (parameterIndex !== undefined && isParameterDecorator) ? parameterIndex.toString() : propertyName;\n if (isParameterDecorator && propertyName !== undefined) {\n throw new Error(ERROR_MSGS.INVALID_DECORATOR_OPERATION);\n }\n if (Reflect.hasOwnMetadata(metadataKey, annotationTarget)) {\n paramsOrPropertiesMetadata = Reflect.getMetadata(metadataKey, annotationTarget);\n }\n var paramOrPropertyMetadata = paramsOrPropertiesMetadata[key];\n if (!Array.isArray(paramOrPropertyMetadata)) {\n paramOrPropertyMetadata = [];\n }\n else {\n for (var _i = 0, paramOrPropertyMetadata_1 = paramOrPropertyMetadata; _i < paramOrPropertyMetadata_1.length; _i++) {\n var m = paramOrPropertyMetadata_1[_i];\n if (m.key === metadata.key) {\n throw new Error(ERROR_MSGS.DUPLICATED_METADATA + \" \" + m.key.toString());\n }\n }\n }\n paramOrPropertyMetadata.push(metadata);\n paramsOrPropertiesMetadata[key] = paramOrPropertyMetadata;\n Reflect.defineMetadata(metadataKey, paramsOrPropertiesMetadata, annotationTarget);\n}\nfunction _decorate(decorators, target) {\n Reflect.decorate(decorators, target);\n}\nfunction _param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); };\n}\nfunction decorate(decorator, target, parameterIndex) {\n if (typeof parameterIndex === \"number\") {\n _decorate([_param(parameterIndex, decorator)], target);\n }\n else if (typeof parameterIndex === \"string\") {\n Reflect.decorate([decorator], target, parameterIndex);\n }\n else {\n _decorate([decorator], target);\n }\n}\nexports.decorate = decorate;\n//# sourceMappingURL=decorator_utils.js.map","var arrayWithHoles = require(\"./arrayWithHoles.js\");\n\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\n\nvar nonIterableRest = require(\"./nonIterableRest.js\");\n\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\n\nmodule.exports = _slicedToArray;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","var add = require('gl-vec2/add')\nvar set = require('gl-vec2/set')\nvar normalize = require('gl-vec2/normalize')\nvar subtract = require('gl-vec2/subtract')\nvar dot = require('gl-vec2/dot')\n\nvar tmp = [0, 0]\n\nmodule.exports.computeMiter = function computeMiter(tangent, miter, lineA, lineB, halfThick) {\n //get tangent line\n add(tangent, lineA, lineB)\n normalize(tangent, tangent)\n\n //get miter as a unit vector\n set(miter, -tangent[1], tangent[0])\n set(tmp, -lineA[1], lineA[0])\n\n //get the necessary length of our miter\n return halfThick / dot(miter, tmp)\n}\n\nmodule.exports.normal = function normal(out, dir) {\n //get perpendicular\n set(out, -dir[1], dir[0])\n return out\n}\n\nmodule.exports.direction = function direction(out, a, b) {\n //get unit dir of two lines\n subtract(out, a, b)\n normalize(out, out)\n return out\n}","var baseIsNative = require('./_baseIsNative'),\n getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeysIn = require('./_baseKeysIn'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nmodule.exports = keysIn;\n","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n return value;\n}\n\nmodule.exports = identity;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.id = void 0;\nvar idCounter = 0;\nfunction id() {\n return idCounter++;\n}\nexports.id = id;\n//# sourceMappingURL=id.js.map","import { isNil, each, isString } from './util';\nimport { getOffScreenContext } from './offscreen';\n/**\n * 获取文本的高度\n * @param text 文本\n * @param fontSize 字体大小\n * @param lineHeight 行高,可以为空\n */\nexport function getTextHeight(text, fontSize, lineHeight) {\n var lineCount = 1;\n if (isString(text)) {\n lineCount = text.split('\\n').length;\n }\n if (lineCount > 1) {\n var spaceingY = getLineSpaceing(fontSize, lineHeight);\n return fontSize * lineCount + spaceingY * (lineCount - 1);\n }\n return fontSize;\n}\n/**\n * 获取行间距如果文本多行,需要获取文本间距\n * @param fontSize 字体大小\n * @param lineHeight 行高\n */\nexport function getLineSpaceing(fontSize, lineHeight) {\n return lineHeight ? lineHeight - fontSize : fontSize * 0.14;\n}\n/**\n * 字体宽度\n * @param text 文本\n * @param font 字体\n */\nexport function getTextWidth(text, font) {\n var context = getOffScreenContext(); // 获取离屏的 ctx 进行计算\n var width = 0;\n // null 或者 undefined 时,宽度为 0\n if (isNil(text) || text === '') {\n return width;\n }\n context.save();\n context.font = font;\n if (isString(text) && text.includes('\\n')) {\n var textArr = text.split('\\n');\n each(textArr, function (subText) {\n var measureWidth = context.measureText(subText).width;\n if (width < measureWidth) {\n width = measureWidth;\n }\n });\n }\n else {\n width = context.measureText(text).width;\n }\n context.restore();\n return width;\n}\nexport function assembleFont(attrs) {\n var fontSize = attrs.fontSize, fontFamily = attrs.fontFamily, fontWeight = attrs.fontWeight, fontStyle = attrs.fontStyle, fontVariant = attrs.fontVariant;\n return [fontStyle, fontVariant, fontWeight, fontSize + \"px\", fontFamily].join(' ').trim();\n}\n//# sourceMappingURL=text.js.map","import { inject, injectable, named } from 'inversify';\nimport { ComponentManager } from '../../../ComponentManager';\nimport { IDENTIFIER } from '../../../identifier';\nimport { decodePickingColor } from '../../../utils/math';\nimport { FrameGraphHandle } from '../../framegraph/FrameGraphHandle';\nimport { FrameGraphPass } from '../../framegraph/FrameGraphPass';\nimport { PassNode } from '../../framegraph/PassNode';\nimport { ResourcePool } from '../../framegraph/ResourcePool';\nimport { FrameGraphSystem } from '../../framegraph/System';\nimport { MaterialComponent } from '../../material/MaterialComponent';\nimport { MeshComponent } from '../../mesh/MeshComponent';\nimport { IFramebuffer } from '../IFramebuffer';\nimport { IRendererService, IView } from '../IRendererService';\nimport { IRenderPass } from './IRenderPass';\nimport { RenderPass, RenderPassData } from './RenderPass';\n\nexport interface PixelPickingPassData {\n output: FrameGraphHandle;\n}\n\nconst PickingStage = {\n NONE: 0.0,\n ENCODE: 1.0,\n HIGHLIGHT: 2.0,\n};\n\n/**\n * color-based picking\n * @see https://threejsfundamentals.org/threejs/lessons/threejs-picking.html\n */\n@injectable()\nexport class PixelPickingPass implements IRenderPass<PixelPickingPassData> {\n public static IDENTIFIER = 'PixelPicking Pass';\n\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n @inject(IDENTIFIER.ResourcePool)\n private readonly resourcePool: ResourcePool;\n\n @inject(IDENTIFIER.RenderPassFactory)\n private readonly renderPassFactory: <T>(name: string) => IRenderPass<T>;\n\n @inject(IDENTIFIER.MeshComponentManager)\n private readonly mesh: ComponentManager<MeshComponent>;\n\n private pickingFBO: IFramebuffer;\n private views: IView[];\n private highlightEnabled = true;\n private highlightColor = [255, 0, 0, 255];\n\n /**\n * 简单的 throttle,防止连续触发 hover 时导致频繁渲染到 picking framebuffer\n */\n private alreadyInRendering: boolean = false;\n\n public enableHighlight(enabled: boolean) {\n this.highlightEnabled = enabled;\n }\n\n public setHighlightColor(color: number[]) {\n this.highlightColor = color;\n }\n\n public setup = (\n fg: FrameGraphSystem,\n passNode: PassNode,\n pass: FrameGraphPass<PixelPickingPassData>,\n ): void => {\n const output = fg.createRenderTarget(passNode, 'picking fbo', {\n width: 1,\n height: 1,\n });\n\n pass.data = {\n output: passNode.write(fg, output),\n };\n\n // 防止被 FrameGraph 剔除\n passNode.hasSideEffect = true;\n };\n\n public execute = async (\n fg: FrameGraphSystem,\n pass: FrameGraphPass<PixelPickingPassData>,\n views: IView[],\n ): Promise<void> => {\n this.views = views;\n\n if (this.alreadyInRendering) {\n return;\n }\n\n for (const view of views) {\n const { width, height } = view.getViewport();\n // throttled\n this.alreadyInRendering = true;\n\n // 实例化资源\n const resourceNode = fg.getResourceNode(pass.data.output);\n this.pickingFBO = this.resourcePool.getOrCreateResource(\n resourceNode.resource,\n );\n\n // TODO: only draw 1x1 quad, with offset camera\n this.pickingFBO.resize({ width, height });\n this.engine.useFramebuffer(this.pickingFBO, () => {\n this.engine.clear({\n framebuffer: this.pickingFBO,\n color: [0, 0, 0, 0],\n stencil: 0,\n depth: 1,\n });\n\n // 渲染\n const renderPass = this.renderPassFactory<RenderPassData>(\n RenderPass.IDENTIFIER,\n );\n\n // 修改所有\n const meshes: MeshComponent[] = [];\n const scene = view.getScene();\n for (const meshEntity of scene.getEntities()) {\n const mesh = this.mesh.getComponentByEntity(meshEntity)!;\n const material = mesh.material;\n material.setUniform('u_PickingStage', PickingStage.ENCODE);\n meshes.push(mesh);\n }\n\n // @ts-ignore\n renderPass.renderView(view);\n meshes.forEach((mesh) => {\n const material = mesh.material;\n material.setUniform('u_PickingStage', PickingStage.HIGHLIGHT);\n });\n\n this.alreadyInRendering = false;\n });\n }\n };\n\n public pick = ({ x, y }: { x: number; y: number }, view: IView) => {\n const { readPixels, useFramebuffer } = this.engine;\n const { width, height } = view.getViewport();\n const xInDevicePixel = x * window.devicePixelRatio;\n const yInDevicePixel = y * window.devicePixelRatio;\n // const xInDevicePixel = x;\n // const yInDevicePixel = y;\n if (\n xInDevicePixel > width ||\n xInDevicePixel < 0 ||\n yInDevicePixel > height ||\n yInDevicePixel < 0\n ) {\n return;\n }\n\n let pickedColors: Uint8Array | undefined;\n let pickedFeatureIdx: number | undefined;\n useFramebuffer(this.pickingFBO, () => {\n // avoid realloc\n pickedColors = readPixels({\n x: Math.round(xInDevicePixel),\n // 视口坐标系原点在左上,而 WebGL 在左下,需要翻转 Y 轴\n y: Math.round(height - (y + 1) * window.devicePixelRatio),\n // y: Math.round(height - (y + 1)),\n width: 1,\n height: 1,\n data: new Uint8Array(1 * 1 * 4),\n framebuffer: this.pickingFBO,\n });\n\n if (\n pickedColors[0] !== 0 ||\n pickedColors[1] !== 0 ||\n pickedColors[2] !== 0\n ) {\n pickedFeatureIdx = decodePickingColor(pickedColors);\n\n if (this.highlightEnabled) {\n // 高亮\n this.highlightPickedFeature(pickedColors, view);\n }\n }\n });\n return pickedFeatureIdx;\n };\n\n /**\n * highlight 如果直接修改选中 feature 的 buffer,存在两个问题:\n * 1. 鼠标移走时无法恢复\n * 2. 无法实现高亮颜色与原始原色的 alpha 混合\n * 因此高亮还是放在 shader 中做比较好\n */\n private highlightPickedFeature(\n pickedColors: Uint8Array | undefined,\n view: IView,\n ) {\n if (pickedColors) {\n for (const meshEntity of view.getScene().getEntities()) {\n const mesh = this.mesh.getComponentByEntity(meshEntity)!;\n const material = mesh.material;\n material.setUniform('u_PickingStage', PickingStage.HIGHLIGHT);\n\n material.setUniform('u_PickingColor', [\n pickedColors[0],\n pickedColors[1],\n pickedColors[2],\n ]);\n material.setUniform('u_HighlightColor', this.highlightColor);\n }\n }\n }\n}\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var root = require('./_root'),\n stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n","var DataView = require('./_DataView'),\n Map = require('./_Map'),\n Promise = require('./_Promise'),\n Set = require('./_Set'),\n WeakMap = require('./_WeakMap'),\n baseGetTag = require('./_baseGetTag'),\n toSource = require('./_toSource');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n setTag = '[object Set]',\n weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\nmodule.exports = getTag;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","import { vec3 } from 'gl-matrix';\nimport { Plane } from './Plane';\n\n/**\n * Axis-Aligned Bounding Box\n * 为了便于后续 Frustum Culling,通过查找表定义 p-vertex 和 n-vertex\n * @see https://github.com/antvis/GWebGPUEngine/issues/3\n */\nexport class AABB {\n public center: vec3;\n\n public halfExtents: vec3;\n\n private min: vec3 = vec3.create();\n private max: vec3 = vec3.create();\n\n constructor(center?: vec3, halfExtents?: vec3) {\n this.update(center, halfExtents);\n }\n\n public update(center?: vec3, halfExtents?: vec3) {\n this.center = center || vec3.create();\n this.halfExtents = halfExtents || vec3.fromValues(0.5, 0.5, 0.5);\n this.min = vec3.sub(this.min, this.center, this.halfExtents);\n this.max = vec3.add(this.max, this.center, this.halfExtents);\n }\n\n public setMinMax(min: vec3, max: vec3) {\n vec3.add(this.center, max, min);\n vec3.scale(this.center, this.center, 0.5);\n\n vec3.sub(this.halfExtents, max, min);\n vec3.scale(this.halfExtents, this.halfExtents, 0.5);\n\n vec3.copy(this.min, min);\n vec3.copy(this.max, max);\n }\n\n public getMin() {\n return this.min;\n }\n\n public getMax() {\n return this.max;\n }\n\n public add(aabb: AABB) {\n const tc = this.center;\n const tcx = tc[0];\n const tcy = tc[1];\n const tcz = tc[2];\n const th = this.halfExtents;\n const thx = th[0];\n const thy = th[1];\n const thz = th[2];\n let tminx = tcx - thx;\n let tmaxx = tcx + thx;\n let tminy = tcy - thy;\n let tmaxy = tcy + thy;\n let tminz = tcz - thz;\n let tmaxz = tcz + thz;\n\n const oc = aabb.center;\n const ocx = oc[0];\n const ocy = oc[1];\n const ocz = oc[2];\n const oh = aabb.halfExtents;\n const ohx = oh[0];\n const ohy = oh[1];\n const ohz = oh[2];\n const ominx = ocx - ohx;\n const omaxx = ocx + ohx;\n const ominy = ocy - ohy;\n const omaxy = ocy + ohy;\n const ominz = ocz - ohz;\n const omaxz = ocz + ohz;\n\n if (ominx < tminx) {\n tminx = ominx;\n }\n if (omaxx > tmaxx) {\n tmaxx = omaxx;\n }\n if (ominy < tminy) {\n tminy = ominy;\n }\n if (omaxy > tmaxy) {\n tmaxy = omaxy;\n }\n if (ominz < tminz) {\n tminz = ominz;\n }\n if (omaxz > tmaxz) {\n tmaxz = omaxz;\n }\n\n tc[0] = (tminx + tmaxx) * 0.5;\n tc[1] = (tminy + tmaxy) * 0.5;\n tc[2] = (tminz + tmaxz) * 0.5;\n th[0] = (tmaxx - tminx) * 0.5;\n th[1] = (tmaxy - tminy) * 0.5;\n th[2] = (tmaxz - tminz) * 0.5;\n\n this.min[0] = tminx;\n this.min[1] = tminy;\n this.min[2] = tminz;\n this.max[0] = tmaxx;\n this.max[1] = tmaxy;\n this.max[2] = tmaxz;\n }\n\n public intersects(aabb: AABB) {\n const aMax = this.getMax();\n const aMin = this.getMin();\n const bMax = aabb.getMax();\n const bMin = aabb.getMin();\n\n return (\n aMin[0] <= bMax[0] &&\n aMax[0] >= bMin[0] &&\n aMin[1] <= bMax[1] &&\n aMax[1] >= bMin[1] &&\n aMin[2] <= bMax[2] &&\n aMax[2] >= bMin[2]\n );\n }\n\n public containsPoint(point: vec3) {\n const min = this.getMin();\n const max = this.getMax();\n\n return !(\n point[0] < min[0] ||\n point[0] > max[0] ||\n point[1] < min[1] ||\n point[1] > max[1] ||\n point[2] < min[2] ||\n point[2] > max[2]\n );\n }\n\n /**\n * get n-vertex\n * @param plane plane of CullingVolume\n */\n public getNegativeFarPoint(plane: Plane) {\n if (plane.pnVertexFlag === 0x111) {\n return vec3.copy(vec3.create(), this.min);\n } else if (plane.pnVertexFlag === 0x110) {\n return vec3.fromValues(this.min[0], this.min[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x101) {\n return vec3.fromValues(this.min[0], this.max[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x100) {\n return vec3.fromValues(this.min[0], this.max[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x011) {\n return vec3.fromValues(this.max[0], this.min[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x010) {\n return vec3.fromValues(this.max[0], this.min[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x001) {\n return vec3.fromValues(this.max[0], this.max[1], this.min[2]);\n } else {\n return vec3.fromValues(this.max[0], this.max[1], this.max[2]);\n }\n }\n\n /**\n * get p-vertex\n * @param plane plane of CullingVolume\n */\n public getPositiveFarPoint(plane: Plane) {\n if (plane.pnVertexFlag === 0x111) {\n return vec3.copy(vec3.create(), this.max);\n } else if (plane.pnVertexFlag === 0x110) {\n return vec3.fromValues(this.max[0], this.max[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x101) {\n return vec3.fromValues(this.max[0], this.min[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x100) {\n return vec3.fromValues(this.max[0], this.min[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x011) {\n return vec3.fromValues(this.min[0], this.max[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x010) {\n return vec3.fromValues(this.min[0], this.max[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x001) {\n return vec3.fromValues(this.min[0], this.min[1], this.max[2]);\n } else {\n return vec3.fromValues(this.min[0], this.min[1], this.min[2]);\n }\n }\n}\n","/**\n * @fileoverview dom\n * @author dengfuping_develop@163.com\n */\nimport { __extends } from \"tslib\";\nimport { each } from '@antv/util';\nimport { SVG_ATTR_MAP } from '../constant';\nimport ShapeBase from './base';\nvar Dom = /** @class */ (function (_super) {\n __extends(Dom, _super);\n function Dom() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'dom';\n _this.canFill = false;\n _this.canStroke = false;\n return _this;\n }\n Dom.prototype.createPath = function (context, targetAttrs) {\n var attrs = this.attr();\n var el = this.get('el');\n each(targetAttrs || attrs, function (value, attr) {\n if (SVG_ATTR_MAP[attr]) {\n el.setAttribute(SVG_ATTR_MAP[attr], value);\n }\n });\n if (typeof attrs['html'] === 'function') {\n var element = attrs['html'].call(this, attrs);\n if (element instanceof Element || element instanceof HTMLDocument) {\n var children = el.childNodes;\n for (var i = children.length - 1; i >= 0; i--) {\n el.removeChild(children[i]);\n }\n el.appendChild(element); // append to el if it's an element\n }\n else {\n el.innerHTML = element; // set innerHTML\n }\n }\n else {\n el.innerHTML = attrs['html']; // set innerHTML\n }\n };\n return Dom;\n}(ShapeBase));\nexport default Dom;\n//# sourceMappingURL=dom.js.map","var Symbols = {\n // 圆\n circle: function (x, y, r) {\n return [\n ['M', x, y],\n ['m', -r, 0],\n ['a', r, r, 0, 1, 0, r * 2, 0],\n ['a', r, r, 0, 1, 0, -r * 2, 0],\n ];\n },\n // 正方形\n square: function (x, y, r) {\n return [['M', x - r, y - r], ['L', x + r, y - r], ['L', x + r, y + r], ['L', x - r, y + r], ['Z']];\n },\n // 菱形\n diamond: function (x, y, r) {\n return [['M', x - r, y], ['L', x, y - r], ['L', x + r, y], ['L', x, y + r], ['Z']];\n },\n // 三角形\n triangle: function (x, y, r) {\n var diffY = r * Math.sin((1 / 3) * Math.PI);\n return [['M', x - r, y + diffY], ['L', x, y - diffY], ['L', x + r, y + diffY], ['z']];\n },\n // 倒三角形\n triangleDown: function (x, y, r) {\n var diffY = r * Math.sin((1 / 3) * Math.PI);\n return [['M', x - r, y - diffY], ['L', x + r, y - diffY], ['L', x, y + diffY], ['Z']];\n },\n};\nexport default {\n get: function (type) {\n return Symbols[type];\n },\n register: function (type, func) {\n Symbols[type] = func;\n },\n remove: function (type) {\n delete Symbols[type];\n },\n getAll: function () {\n return Symbols;\n },\n};\n//# sourceMappingURL=symbols.js.map","/**\n * @fileoverview marker\n * @author dengfuping_develop@163.com\n */\nimport { __extends } from \"tslib\";\nimport { isArray, isFunction } from '@antv/util';\nimport ShapeBase from '../base';\nimport symbolsFactory from './symbols';\nvar Marker = /** @class */ (function (_super) {\n __extends(Marker, _super);\n function Marker() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'marker';\n _this.canFill = true;\n _this.canStroke = true;\n return _this;\n }\n Marker.prototype.createPath = function (context) {\n var el = this.get('el');\n el.setAttribute('d', this._assembleMarker());\n };\n Marker.prototype._assembleMarker = function () {\n var d = this._getPath();\n if (isArray(d)) {\n return d\n .map(function (path) {\n return path.join(' ');\n })\n .join('');\n }\n return d;\n };\n Marker.prototype._getPath = function () {\n var attrs = this.attr();\n var x = attrs.x, y = attrs.y;\n // 兼容 r 和 radius 两种写法,推荐使用 r\n var r = attrs.r || attrs.radius;\n var symbol = attrs.symbol || 'circle';\n var method;\n if (isFunction(symbol)) {\n method = symbol;\n }\n else {\n method = symbolsFactory.get(symbol);\n }\n if (!method) {\n console.warn(method + \" symbol is not exist.\");\n return null;\n }\n return method(x, y, r);\n };\n // 作为其静态属性\n Marker.symbolsFactory = symbolsFactory;\n return Marker;\n}(ShapeBase));\nexport default Marker;\n//# sourceMappingURL=index.js.map","import { each, isArray, isString } from '@antv/util';\nvar regexTags = /[MLHVQTCSAZ]([^MLHVQTCSAZ]*)/gi;\nvar regexDot = /[^\\s,]+/gi;\nexport function parseRadius(radius) {\n var r1 = 0;\n var r2 = 0;\n var r3 = 0;\n var r4 = 0;\n if (isArray(radius)) {\n if (radius.length === 1) {\n r1 = r2 = r3 = r4 = radius[0];\n }\n else if (radius.length === 2) {\n r1 = r3 = radius[0];\n r2 = r4 = radius[1];\n }\n else if (radius.length === 3) {\n r1 = radius[0];\n r2 = r4 = radius[1];\n r3 = radius[2];\n }\n else {\n r1 = radius[0];\n r2 = radius[1];\n r3 = radius[2];\n r4 = radius[3];\n }\n }\n else {\n r1 = r2 = r3 = r4 = radius;\n }\n return {\n r1: r1,\n r2: r2,\n r3: r3,\n r4: r4,\n };\n}\nexport function parsePath(path) {\n path = path || [];\n if (isArray(path)) {\n return path;\n }\n if (isString(path)) {\n path = path.match(regexTags);\n each(path, function (item, index) {\n item = item.match(regexDot);\n if (item[0].length > 1) {\n var tag = item[0].charAt(0);\n item.splice(1, 0, item[0].substr(1));\n item[0] = tag;\n }\n each(item, function (sub, i) {\n if (!isNaN(sub)) {\n item[i] = +sub;\n }\n });\n path[index] = item;\n });\n return path;\n }\n}\n//# sourceMappingURL=format.js.map","import * as glMatrix from \"./common.js\";\n/**\r\n * 2 Dimensional Vector\r\n * @module vec2\r\n */\n\n/**\r\n * Creates a new, empty vec2\r\n *\r\n * @returns {vec2} a new 2D vector\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(2);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n }\n\n return out;\n}\n/**\r\n * Creates a new vec2 initialized with values from an existing vector\r\n *\r\n * @param {ReadonlyVec2} a vector to clone\r\n * @returns {vec2} a new 2D vector\r\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(2);\n out[0] = a[0];\n out[1] = a[1];\n return out;\n}\n/**\r\n * Creates a new vec2 initialized with the given values\r\n *\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @returns {vec2} a new 2D vector\r\n */\n\nexport function fromValues(x, y) {\n var out = new glMatrix.ARRAY_TYPE(2);\n out[0] = x;\n out[1] = y;\n return out;\n}\n/**\r\n * Copy the values from one vec2 to another\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the source vector\r\n * @returns {vec2} out\r\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n return out;\n}\n/**\r\n * Set the components of a vec2 to the given values\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @returns {vec2} out\r\n */\n\nexport function set(out, x, y) {\n out[0] = x;\n out[1] = y;\n return out;\n}\n/**\r\n * Adds two vec2's\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {vec2} out\r\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n return out;\n}\n/**\r\n * Subtracts vector b from vector a\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {vec2} out\r\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n return out;\n}\n/**\r\n * Multiplies two vec2's\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {vec2} out\r\n */\n\nexport function multiply(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n return out;\n}\n/**\r\n * Divides two vec2's\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {vec2} out\r\n */\n\nexport function divide(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n return out;\n}\n/**\r\n * Math.ceil the components of a vec2\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a vector to ceil\r\n * @returns {vec2} out\r\n */\n\nexport function ceil(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n return out;\n}\n/**\r\n * Math.floor the components of a vec2\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a vector to floor\r\n * @returns {vec2} out\r\n */\n\nexport function floor(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n return out;\n}\n/**\r\n * Returns the minimum of two vec2's\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {vec2} out\r\n */\n\nexport function min(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n return out;\n}\n/**\r\n * Returns the maximum of two vec2's\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {vec2} out\r\n */\n\nexport function max(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n return out;\n}\n/**\r\n * Math.round the components of a vec2\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a vector to round\r\n * @returns {vec2} out\r\n */\n\nexport function round(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n return out;\n}\n/**\r\n * Scales a vec2 by a scalar number\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the vector to scale\r\n * @param {Number} b amount to scale the vector by\r\n * @returns {vec2} out\r\n */\n\nexport function scale(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n return out;\n}\n/**\r\n * Adds two vec2's after scaling the second operand by a scalar value\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @param {Number} scale the amount to scale b by before adding\r\n * @returns {vec2} out\r\n */\n\nexport function scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n return out;\n}\n/**\r\n * Calculates the euclidian distance between two vec2's\r\n *\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {Number} distance between a and b\r\n */\n\nexport function distance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1];\n return Math.hypot(x, y);\n}\n/**\r\n * Calculates the squared euclidian distance between two vec2's\r\n *\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {Number} squared distance between a and b\r\n */\n\nexport function squaredDistance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1];\n return x * x + y * y;\n}\n/**\r\n * Calculates the length of a vec2\r\n *\r\n * @param {ReadonlyVec2} a vector to calculate length of\r\n * @returns {Number} length of a\r\n */\n\nexport function length(a) {\n var x = a[0],\n y = a[1];\n return Math.hypot(x, y);\n}\n/**\r\n * Calculates the squared length of a vec2\r\n *\r\n * @param {ReadonlyVec2} a vector to calculate squared length of\r\n * @returns {Number} squared length of a\r\n */\n\nexport function squaredLength(a) {\n var x = a[0],\n y = a[1];\n return x * x + y * y;\n}\n/**\r\n * Negates the components of a vec2\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a vector to negate\r\n * @returns {vec2} out\r\n */\n\nexport function negate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n return out;\n}\n/**\r\n * Returns the inverse of the components of a vec2\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a vector to invert\r\n * @returns {vec2} out\r\n */\n\nexport function inverse(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n return out;\n}\n/**\r\n * Normalize a vec2\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a vector to normalize\r\n * @returns {vec2} out\r\n */\n\nexport function normalize(out, a) {\n var x = a[0],\n y = a[1];\n var len = x * x + y * y;\n\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = a[0] * len;\n out[1] = a[1] * len;\n return out;\n}\n/**\r\n * Calculates the dot product of two vec2's\r\n *\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {Number} dot product of a and b\r\n */\n\nexport function dot(a, b) {\n return a[0] * b[0] + a[1] * b[1];\n}\n/**\r\n * Computes the cross product of two vec2's\r\n * Note that the cross product must by definition produce a 3D vector\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function cross(out, a, b) {\n var z = a[0] * b[1] - a[1] * b[0];\n out[0] = out[1] = 0;\n out[2] = z;\n return out;\n}\n/**\r\n * Performs a linear interpolation between two vec2's\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the first operand\r\n * @param {ReadonlyVec2} b the second operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {vec2} out\r\n */\n\nexport function lerp(out, a, b, t) {\n var ax = a[0],\n ay = a[1];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n return out;\n}\n/**\r\n * Generates a random vector with the given scale\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\r\n * @returns {vec2} out\r\n */\n\nexport function random(out, scale) {\n scale = scale || 1.0;\n var r = glMatrix.RANDOM() * 2.0 * Math.PI;\n out[0] = Math.cos(r) * scale;\n out[1] = Math.sin(r) * scale;\n return out;\n}\n/**\r\n * Transforms the vec2 with a mat2\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the vector to transform\r\n * @param {ReadonlyMat2} m matrix to transform with\r\n * @returns {vec2} out\r\n */\n\nexport function transformMat2(out, a, m) {\n var x = a[0],\n y = a[1];\n out[0] = m[0] * x + m[2] * y;\n out[1] = m[1] * x + m[3] * y;\n return out;\n}\n/**\r\n * Transforms the vec2 with a mat2d\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the vector to transform\r\n * @param {ReadonlyMat2d} m matrix to transform with\r\n * @returns {vec2} out\r\n */\n\nexport function transformMat2d(out, a, m) {\n var x = a[0],\n y = a[1];\n out[0] = m[0] * x + m[2] * y + m[4];\n out[1] = m[1] * x + m[3] * y + m[5];\n return out;\n}\n/**\r\n * Transforms the vec2 with a mat3\r\n * 3rd vector component is implicitly '1'\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the vector to transform\r\n * @param {ReadonlyMat3} m matrix to transform with\r\n * @returns {vec2} out\r\n */\n\nexport function transformMat3(out, a, m) {\n var x = a[0],\n y = a[1];\n out[0] = m[0] * x + m[3] * y + m[6];\n out[1] = m[1] * x + m[4] * y + m[7];\n return out;\n}\n/**\r\n * Transforms the vec2 with a mat4\r\n * 3rd vector component is implicitly '0'\r\n * 4th vector component is implicitly '1'\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @param {ReadonlyVec2} a the vector to transform\r\n * @param {ReadonlyMat4} m matrix to transform with\r\n * @returns {vec2} out\r\n */\n\nexport function transformMat4(out, a, m) {\n var x = a[0];\n var y = a[1];\n out[0] = m[0] * x + m[4] * y + m[12];\n out[1] = m[1] * x + m[5] * y + m[13];\n return out;\n}\n/**\r\n * Rotate a 2D vector\r\n * @param {vec2} out The receiving vec2\r\n * @param {ReadonlyVec2} a The vec2 point to rotate\r\n * @param {ReadonlyVec2} b The origin of the rotation\r\n * @param {Number} rad The angle of rotation in radians\r\n * @returns {vec2} out\r\n */\n\nexport function rotate(out, a, b, rad) {\n //Translate point to the origin\n var p0 = a[0] - b[0],\n p1 = a[1] - b[1],\n sinC = Math.sin(rad),\n cosC = Math.cos(rad); //perform rotation and translate to correct position\n\n out[0] = p0 * cosC - p1 * sinC + b[0];\n out[1] = p0 * sinC + p1 * cosC + b[1];\n return out;\n}\n/**\r\n * Get the angle between two 2D vectors\r\n * @param {ReadonlyVec2} a The first operand\r\n * @param {ReadonlyVec2} b The second operand\r\n * @returns {Number} The angle in radians\r\n */\n\nexport function angle(a, b) {\n var x1 = a[0],\n y1 = a[1],\n x2 = b[0],\n y2 = b[1],\n // mag is the product of the magnitudes of a and b\n mag = Math.sqrt(x1 * x1 + y1 * y1) * Math.sqrt(x2 * x2 + y2 * y2),\n // mag &&.. short circuits if mag == 0\n cosine = mag && (x1 * x2 + y1 * y2) / mag; // Math.min(Math.max(cosine, -1), 1) clamps the cosine between -1 and 1\n\n return Math.acos(Math.min(Math.max(cosine, -1), 1));\n}\n/**\r\n * Set the components of a vec2 to zero\r\n *\r\n * @param {vec2} out the receiving vector\r\n * @returns {vec2} out\r\n */\n\nexport function zero(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n return out;\n}\n/**\r\n * Returns a string representation of a vector\r\n *\r\n * @param {ReadonlyVec2} a vector to represent as a string\r\n * @returns {String} string representation of the vector\r\n */\n\nexport function str(a) {\n return \"vec2(\" + a[0] + \", \" + a[1] + \")\";\n}\n/**\r\n * Returns whether or not the vectors exactly have the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyVec2} a The first vector.\r\n * @param {ReadonlyVec2} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1];\n}\n/**\r\n * Returns whether or not the vectors have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyVec2} a The first vector.\r\n * @param {ReadonlyVec2} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1];\n var b0 = b[0],\n b1 = b[1];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1));\n}\n/**\r\n * Alias for {@link vec2.length}\r\n * @function\r\n */\n\nexport var len = length;\n/**\r\n * Alias for {@link vec2.subtract}\r\n * @function\r\n */\n\nexport var sub = subtract;\n/**\r\n * Alias for {@link vec2.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Alias for {@link vec2.divide}\r\n * @function\r\n */\n\nexport var div = divide;\n/**\r\n * Alias for {@link vec2.distance}\r\n * @function\r\n */\n\nexport var dist = distance;\n/**\r\n * Alias for {@link vec2.squaredDistance}\r\n * @function\r\n */\n\nexport var sqrDist = squaredDistance;\n/**\r\n * Alias for {@link vec2.squaredLength}\r\n * @function\r\n */\n\nexport var sqrLen = squaredLength;\n/**\r\n * Perform some operation over an array of vec2s.\r\n *\r\n * @param {Array} a the array of vectors to iterate over\r\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\r\n * @param {Number} offset Number of elements to skip at the beginning of the array\r\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\r\n * @param {Function} fn Function to call for each vector in the array\r\n * @param {Object} [arg] additional argument to pass to fn\r\n * @returns {Array} a\r\n * @function\r\n */\n\nexport var forEach = function () {\n var vec = create();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 2;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n }\n\n return a;\n };\n}();","var containers = []; // will store container HTMLElement references\nvar styleElements = []; // will store {prepend: HTMLElement, append: HTMLElement}\n\nvar usage = 'insert-css: You need to provide a CSS string. Usage: insertCss(cssString[, options]).';\n\nfunction insertCss(css, options) {\n options = options || {};\n\n if (css === undefined) {\n throw new Error(usage);\n }\n\n var position = options.prepend === true ? 'prepend' : 'append';\n var container = options.container !== undefined ? options.container : document.querySelector('head');\n var containerId = containers.indexOf(container);\n\n // first time we see this container, create the necessary entries\n if (containerId === -1) {\n containerId = containers.push(container) - 1;\n styleElements[containerId] = {};\n }\n\n // try to get the correponding container + position styleElement, create it otherwise\n var styleElement;\n\n if (styleElements[containerId] !== undefined && styleElements[containerId][position] !== undefined) {\n styleElement = styleElements[containerId][position];\n } else {\n styleElement = styleElements[containerId][position] = createStyleElement();\n\n if (position === 'prepend') {\n container.insertBefore(styleElement, container.childNodes[0]);\n } else {\n container.appendChild(styleElement);\n }\n }\n\n // strip potential UTF-8 BOM if css was read from a file\n if (css.charCodeAt(0) === 0xFEFF) { css = css.substr(1, css.length); }\n\n // actually add the stylesheet\n if (styleElement.styleSheet) {\n styleElement.styleSheet.cssText += css\n } else {\n styleElement.textContent += css;\n }\n\n return styleElement;\n};\n\nfunction createStyleElement() {\n var styleElement = document.createElement('style');\n styleElement.setAttribute('type', 'text/css');\n return styleElement;\n}\n\nmodule.exports = insertCss;\nmodule.exports.insertCss = insertCss;\n","import { inject, injectable } from 'inversify';\nimport { IDENTIFIER } from '../../../identifier';\nimport copyFrag from '../../../services/shader-module/shaders/webgl.copy.frag.glsl';\nimport copyVert from '../../../services/shader-module/shaders/webgl.copy.vert.glsl';\nimport copyFragWebGPU from '../../../services/shader-module/shaders/webgpu.copy.frag.glsl';\nimport copyVertWebGPU from '../../../services/shader-module/shaders/webgpu.copy.vert.glsl';\nimport { FrameGraphHandle } from '../../framegraph/FrameGraphHandle';\nimport { FrameGraphPass } from '../../framegraph/FrameGraphPass';\nimport { PassNode } from '../../framegraph/PassNode';\nimport { ResourcePool } from '../../framegraph/ResourcePool';\nimport { FrameGraphSystem } from '../../framegraph/System';\nimport { gl } from '../gl';\nimport { IModel } from '../IModel';\nimport { IRendererService } from '../IRendererService';\nimport { IRenderPass } from './IRenderPass';\nimport { RenderPass, RenderPassData } from './RenderPass';\n\nexport interface CopyPassData {\n input: FrameGraphHandle;\n output: FrameGraphHandle;\n}\n\n@injectable()\nexport class CopyPass implements IRenderPass<CopyPassData> {\n public static IDENTIFIER = 'Copy Pass';\n\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n @inject(IDENTIFIER.ResourcePool)\n private readonly resourcePool: ResourcePool;\n\n private model: IModel | undefined;\n\n public setup = (\n fg: FrameGraphSystem,\n passNode: PassNode,\n pass: FrameGraphPass<CopyPassData>,\n ): void => {\n const renderPass = fg.getPass<RenderPassData>(RenderPass.IDENTIFIER);\n if (renderPass) {\n const output = fg.createRenderTarget(passNode, 'render to screen', {\n width: 1,\n height: 1,\n });\n\n pass.data = {\n input: passNode.read(renderPass.data.output),\n output: passNode.write(fg, output),\n };\n }\n };\n\n public execute = async (\n fg: FrameGraphSystem,\n pass: FrameGraphPass<CopyPassData>,\n ): Promise<void> => {\n const { createModel, createAttribute, createBuffer } = this.engine;\n\n if (!this.model) {\n const model = await createModel({\n vs: this.engine.supportWebGPU ? copyVertWebGPU : copyVert,\n fs: this.engine.supportWebGPU ? copyFragWebGPU : copyFrag,\n attributes: {\n // rendering a fullscreen triangle instead of quad\n // @see https://www.saschawillems.de/blog/2016/08/13/vulkan-tutorial-on-rendering-a-fullscreen-quad-without-buffers/\n a_Position: createAttribute({\n buffer: createBuffer({\n data: [-4, -4, 4, -4, 0, 4],\n type: gl.FLOAT,\n }),\n size: 2,\n arrayStride: 2 * 4,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 0,\n offset: 0,\n format: 'float2',\n },\n ],\n }),\n },\n uniforms: {\n // @ts-ignore\n u_Texture: null,\n },\n depth: {\n enable: false,\n },\n count: 3,\n blend: {\n // copy pass 需要混合\n // enable: this.getName() === 'copy',\n enable: true,\n },\n });\n this.model = model;\n }\n\n // 实例化资源\n const resourceNode = fg.getResourceNode(pass.data.input);\n const framebuffer = this.resourcePool.getOrCreateResource(\n resourceNode.resource,\n );\n\n this.engine.useFramebuffer(null, () => {\n this.engine.clear({\n framebuffer: null,\n color: [0, 0, 0, 0],\n depth: 1,\n stencil: 0,\n });\n this.model!.draw({\n uniforms: {\n u_Texture: framebuffer,\n // u_ViewportSize: [width, height],\n },\n });\n });\n };\n\n public tearDown = () => {\n this.model = undefined;\n };\n}\n","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Hierarchy\"] = factory();\n\telse\n\t\troot[\"Hierarchy\"] = factory();\n})(typeof self !== 'undefined' ? self : this, function() {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 31);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 4fd512329b599d5b36c3","import isType from './is-type';\nexport default (function (value) {\n return Array.isArray ? Array.isArray(value) : isType(value, 'Array');\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-array.js\n// module id = 0\n// module chunks = 0","var isArrayLike = function (value) {\n /**\n * isArrayLike([1, 2, 3]) => true\n * isArrayLike(document.body.children) => true\n * isArrayLike('abc') => true\n * isArrayLike(Function) => false\n */\n return value !== null && typeof value !== 'function' && isFinite(value.length);\n};\n\nexport default isArrayLike;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-array-like.js\n// module id = 1\n// module chunks = 0","import isArray from './is-array';\nimport isObject from './is-object';\n\nfunction each(elements, func) {\n if (!elements) {\n return;\n }\n\n var rst;\n\n if (isArray(elements)) {\n for (var i = 0, len = elements.length; i < len; i++) {\n rst = func(elements[i], i);\n\n if (rst === false) {\n break;\n }\n }\n } else if (isObject(elements)) {\n for (var k in elements) {\n if (elements.hasOwnProperty(k)) {\n rst = func(elements[k], k);\n\n if (rst === false) {\n break;\n }\n }\n }\n }\n}\n\nexport default each;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/each.js\n// module id = 2\n// module chunks = 0","/**\n * 是否为函数\n * @param {*} fn 对象\n * @return {Boolean} 是否函数\n */\nimport isType from './is-type';\nexport default (function (value) {\n return isType(value, 'Function');\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-function.js\n// module id = 3\n// module chunks = 0","var toString = {}.toString;\n\nvar isType = function (value, type) {\n return toString.call(value) === '[object ' + type + ']';\n};\n\nexport default isType;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-type.js\n// module id = 4\n// module chunks = 0","/**\n * 判断是否数字\n * @return {Boolean} 是否数字\n */\nimport isType from './is-type';\n\nvar isNumber = function (value) {\n return isType(value, 'Number');\n};\n\nexport default isNumber;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-number.js\n// module id = 5\n// module chunks = 0","// isFinite,\nvar isNil = function (value) {\n /**\n * isNil(null) => true\n * isNil() => true\n */\n return value === null || value === undefined;\n};\n\nexport default isNil;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-nil.js\n// module id = 6\n// module chunks = 0","var _require = require('@antv/util'),\n mix = _require.mix;\n\nmodule.exports = {\n assign: mix\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/util.js\n// module id = 7\n// module chunks = 0","import isType from './is-type';\nexport default (function (str) {\n return isType(str, 'String');\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-string.js\n// module id = 8\n// module chunks = 0","import isObjectLike from './is-object-like';\nimport isType from './is-type';\n\nvar isPlainObject = function (value) {\n /**\n * isObjectLike(new Foo) => false\n * isObjectLike([1, 2, 3]) => false\n * isObjectLike({ x: 0, y: 0 }) => true\n * isObjectLike(Object.create(null)) => true\n */\n if (!isObjectLike(value) || !isType(value, 'Object')) {\n return false;\n }\n\n if (Object.getPrototypeOf(value) === null) {\n return true;\n }\n\n var proto = value;\n\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n\n return Object.getPrototypeOf(value) === proto;\n};\n\nexport default isPlainObject;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-plain-object.js\n// module id = 9\n// module chunks = 0","import isNil from './is-nil';\nexport default (function (value) {\n if (isNil(value)) return '';\n return value.toString();\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/to-string.js\n// module id = 10\n// module chunks = 0","var hierarchy = require('./hierarchy');\n\nvar Layout = /*#__PURE__*/function () {\n function Layout(root, options) {\n if (options === void 0) {\n options = {};\n }\n\n var me = this;\n me.options = options;\n me.rootNode = hierarchy(root, options);\n }\n\n var _proto = Layout.prototype;\n\n _proto.execute = function execute() {\n throw new Error('please override this method');\n };\n\n return Layout;\n}();\n\nmodule.exports = Layout;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/layout/base.js\n// module id = 11\n// module chunks = 0","import isArrayLike from './is-array-like';\n\nvar contains = function (arr, value) {\n if (!isArrayLike(arr)) {\n return false;\n }\n\n return arr.indexOf(value) > -1;\n};\n\nexport default contains;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/contains.js\n// module id = 12\n// module chunks = 0","export default (function (value) {\n /**\n * isObject({}) => true\n * isObject([1, 2, 3]) => true\n * isObject(Function) => true\n * isObject(null) => false\n */\n var type = typeof value;\n return value !== null && type === 'object' || type === 'function';\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-object.js\n// module id = 13\n// module chunks = 0","import each from './each';\nimport isArrayLike from './is-array-like';\n\nvar filter = function (arr, func) {\n if (!isArrayLike(arr)) {\n return arr;\n }\n\n var result = [];\n each(arr, function (value, index) {\n if (func(value, index)) {\n result.push(value);\n }\n });\n return result;\n};\n\nexport default filter;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/filter.js\n// module id = 14\n// module chunks = 0","var isObjectLike = function (value) {\n /**\n * isObjectLike({}) => true\n * isObjectLike([1, 2, 3]) => true\n * isObjectLike(Function) => false\n * isObjectLike(null) => false\n */\n return typeof value === 'object' && value !== null;\n};\n\nexport default isObjectLike;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-object-like.js\n// module id = 15\n// module chunks = 0","// FIXME: Mutable param should be forbidden in static lang.\nfunction _mix(dist, obj) {\n for (var key in obj) {\n if (obj.hasOwnProperty(key) && key !== 'constructor' && obj[key] !== undefined) {\n dist[key] = obj[key];\n }\n }\n}\n\nexport default function mix(dist, src1, src2, src3) {\n if (src1) _mix(dist, src1);\n if (src2) _mix(dist, src2);\n if (src3) _mix(dist, src3);\n return dist;\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/mix.js\n// module id = 16\n// module chunks = 0","var separateTree = require('./separate-root');\n\nvar VALID_DIRECTIONS = ['LR', // left to right\n'RL', // right to left\n'TB', // top to bottom\n'BT', // bottom to top\n'H', // horizontal\n'V' // vertical\n];\nvar HORIZONTAL_DIRECTIONS = ['LR', 'RL', 'H'];\n\nvar isHorizontal = function isHorizontal(direction) {\n return HORIZONTAL_DIRECTIONS.indexOf(direction) > -1;\n};\n\nvar DEFAULT_DIRECTION = VALID_DIRECTIONS[0];\n\nmodule.exports = function (root, options, layoutAlgrithm) {\n var direction = options.direction || DEFAULT_DIRECTION;\n options.isHorizontal = isHorizontal(direction);\n\n if (direction && VALID_DIRECTIONS.indexOf(direction) === -1) {\n throw new TypeError(\"Invalid direction: \" + direction);\n }\n\n if (direction === VALID_DIRECTIONS[0]) {\n // LR\n layoutAlgrithm(root, options);\n } else if (direction === VALID_DIRECTIONS[1]) {\n // RL\n layoutAlgrithm(root, options);\n root.right2left();\n } else if (direction === VALID_DIRECTIONS[2]) {\n // TB\n layoutAlgrithm(root, options);\n } else if (direction === VALID_DIRECTIONS[3]) {\n // BT\n layoutAlgrithm(root, options);\n root.bottom2top();\n } else if (direction === VALID_DIRECTIONS[4] || direction === VALID_DIRECTIONS[5]) {\n // H or V\n // separate into left and right trees\n var _separateTree = separateTree(root, options),\n left = _separateTree.left,\n right = _separateTree.right; // do layout for left and right trees\n\n\n layoutAlgrithm(left, options);\n layoutAlgrithm(right, options);\n options.isHorizontal ? left.right2left() : left.bottom2top(); // combine left and right trees\n\n right.translate(left.x - right.x, left.y - right.y); // translate root\n\n root.x = left.x;\n root.y = right.y;\n var bb = root.getBoundingBox();\n\n if (options.isHorizontal) {\n if (bb.top < 0) {\n root.translate(0, -bb.top);\n }\n } else {\n if (bb.left < 0) {\n root.translate(-bb.left, 0);\n }\n }\n } // fixed root position, default value is true\n\n\n var fixedRoot = options.fixedRoot;\n if (fixedRoot === undefined) fixedRoot = true;\n\n if (fixedRoot) {\n root.translate(-(root.x + root.width / 2 + root.hgap), -(root.y + root.height / 2 + root.vgap));\n }\n\n return root;\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/layout/do-layout.js\n// module id = 17\n// module chunks = 0","/* eslint-disable no-cond-assign */\nvar util = require('../util');\n\nvar PEM = 18;\nvar DEFAULT_HEIGHT = PEM * 2;\nvar DEFAULT_GAP = PEM;\nvar DEFAULT_OPTIONS = {\n getId: function getId(d) {\n return d.id || d.name;\n },\n getPreH: function getPreH(d) {\n return d.preH || 0;\n },\n getPreV: function getPreV(d) {\n return d.preV || 0;\n },\n getHGap: function getHGap(d) {\n return d.hgap || DEFAULT_GAP;\n },\n getVGap: function getVGap(d) {\n return d.vgap || DEFAULT_GAP;\n },\n getChildren: function getChildren(d) {\n return d.children;\n },\n getHeight: function getHeight(d) {\n return d.height || DEFAULT_HEIGHT;\n },\n getWidth: function getWidth(d) {\n var label = d.label || ' ';\n return d.width || label.split('').length * PEM; // FIXME DO NOT get width like this\n }\n};\n\nfunction Node(data, options) {\n var me = this;\n me.vgap = me.hgap = 0;\n if (data instanceof Node) return data;\n me.data = data;\n /*\n * Gaps: filling space between nodes\n * (x, y) ----------------------\n * | vgap |\n * | -------------------- h\n * | h | | e\n * | g | | i\n * | a | | g\n * | p | | h\n * | --------------------- t\n * | |\n * -----------width------------\n */\n\n var hgap = options.getHGap(data);\n var vgap = options.getVGap(data);\n me.preH = options.getPreH(data);\n me.preV = options.getPreV(data);\n me.width = options.getWidth(data);\n me.height = options.getHeight(data);\n me.width += me.preH;\n me.height += me.preV;\n me.id = options.getId(data);\n me.x = me.y = 0;\n me.depth = 0;\n\n if (!me.children) {\n me.children = [];\n }\n\n me.addGap(hgap, vgap);\n return me;\n}\n\nutil.assign(Node.prototype, {\n isRoot: function isRoot() {\n return this.depth === 0;\n },\n isLeaf: function isLeaf() {\n return this.children.length === 0;\n },\n addGap: function addGap(hgap, vgap) {\n var me = this;\n me.hgap += hgap;\n me.vgap += vgap;\n me.width += 2 * hgap;\n me.height += 2 * vgap;\n },\n eachNode: function eachNode(callback) {\n // Depth First traverse\n var me = this;\n var nodes = [me];\n var current;\n\n while (current = nodes.shift()) {\n callback(current);\n nodes = current.children.concat(nodes);\n }\n },\n DFTraverse: function DFTraverse(callback) {\n // Depth First traverse\n this.eachNode(callback);\n },\n BFTraverse: function BFTraverse(callback) {\n // Breadth First traverse\n var me = this;\n var nodes = [me];\n var current;\n\n while (current = nodes.shift()) {\n callback(current);\n nodes = nodes.concat(current.children);\n }\n },\n getBoundingBox: function getBoundingBox() {\n // BBox for just one tree node\n var bb = {\n left: Number.MAX_VALUE,\n top: Number.MAX_VALUE,\n width: 0,\n height: 0\n };\n this.eachNode(function (node) {\n bb.left = Math.min(bb.left, node.x);\n bb.top = Math.min(bb.top, node.y);\n bb.width = Math.max(bb.width, node.x + node.width);\n bb.height = Math.max(bb.height, node.y + node.height);\n });\n return bb;\n },\n // translate\n translate: function translate(tx, ty) {\n if (tx === void 0) {\n tx = 0;\n }\n\n if (ty === void 0) {\n ty = 0;\n }\n\n this.eachNode(function (node) {\n node.x += tx;\n node.y += ty;\n node.x += node.preH;\n node.y += node.preV;\n });\n },\n right2left: function right2left() {\n var me = this;\n var bb = me.getBoundingBox();\n me.eachNode(function (node) {\n node.x = node.x - (node.x - bb.left) * 2 - node.width; // node.x = - node.x;\n });\n me.translate(bb.width, 0);\n },\n bottom2top: function bottom2top() {\n var me = this;\n var bb = me.getBoundingBox();\n me.eachNode(function (node) {\n node.y = node.y - (node.y - bb.top) * 2 - node.height; // node.y = - node.y;\n });\n me.translate(0, bb.height);\n }\n});\n\nfunction hierarchy(data, options, isolated) {\n if (options === void 0) {\n options = {};\n }\n\n options = util.assign({}, DEFAULT_OPTIONS, options);\n var root = new Node(data, options);\n var nodes = [root];\n var node;\n\n if (!isolated && !data.collapsed) {\n while (node = nodes.shift()) {\n if (!node.data.collapsed) {\n var children = options.getChildren(node.data);\n var length = children ? children.length : 0;\n node.children = new Array(length);\n\n if (children && length) {\n for (var i = 0; i < length; i++) {\n var child = new Node(children[i], options);\n node.children[i] = child;\n nodes.push(child);\n child.parent = node;\n child.depth = node.depth + 1;\n }\n }\n }\n }\n }\n\n return root;\n}\n\nmodule.exports = hierarchy;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/layout/hierarchy.js\n// module id = 18\n// module chunks = 0","import isNil from './is-nil';\nimport keys from './keys';\n\nfunction isMatch(obj, attrs) {\n var _keys = keys(attrs);\n\n var length = _keys.length;\n if (isNil(obj)) return !length;\n\n for (var i = 0; i < length; i += 1) {\n var key = _keys[i];\n\n if (attrs[key] !== obj[key] || !(key in obj)) {\n return false;\n }\n }\n\n return true;\n}\n\nexport default isMatch;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-match.js\n// module id = 19\n// module chunks = 0","import each from './each';\nimport isFunction from './is-function';\nvar keys = Object.keys ? function (obj) {\n return Object.keys(obj);\n} : function (obj) {\n var result = [];\n each(obj, function (value, key) {\n if (!(isFunction(obj) && key === 'prototype')) {\n result.push(key);\n }\n });\n return result;\n};\nexport default keys;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/keys.js\n// module id = 20\n// module chunks = 0","import isArrayLike from './is-array-like';\nvar splice = Array.prototype.splice;\n\nvar pullAt = function pullAt(arr, indexes) {\n if (!isArrayLike(arr)) {\n return [];\n }\n\n var length = arr ? indexes.length : 0;\n var last = length - 1;\n\n while (length--) {\n var previous = void 0;\n var index = indexes[length];\n\n if (length === last || index !== previous) {\n previous = index;\n splice.call(arr, index, 1);\n }\n }\n\n return arr;\n};\n\nexport default pullAt;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/pull-at.js\n// module id = 21\n// module chunks = 0","import contains from './contains';\nimport each from './each';\n\nvar uniq = function (arr) {\n var resultArr = [];\n each(arr, function (item) {\n if (!contains(resultArr, item)) {\n resultArr.push(item);\n }\n });\n return resultArr;\n};\n\nexport default uniq;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/uniq.js\n// module id = 22\n// module chunks = 0","import isArray from './is-array';\nimport isFunction from './is-function';\nimport groupBy from './group-by';\n\nvar groupToMap = function (data, condition) {\n if (!condition) {\n return {\n 0: data\n };\n }\n\n if (!isFunction(condition)) {\n var paramsCondition_1 = isArray(condition) ? condition : condition.replace(/\\s+/g, '').split('*');\n\n condition = function (row) {\n var unique = '_'; // 避免出现数字作为Key的情况,会进行按照数字的排序\n\n for (var i = 0, l = paramsCondition_1.length; i < l; i++) {\n unique += row[paramsCondition_1[i]] && row[paramsCondition_1[i]].toString();\n }\n\n return unique;\n };\n }\n\n var groups = groupBy(data, condition);\n return groups;\n};\n\nexport default groupToMap;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/group-to-map.js\n// module id = 23\n// module chunks = 0","import each from './each';\nimport isArray from './is-array';\nimport isFunction from './is-function';\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction groupBy(data, condition) {\n if (!condition || !isArray(data)) {\n return {};\n }\n\n var result = {}; // 兼容方法和 字符串的写法\n\n var predicate = isFunction(condition) ? condition : function (item) {\n return item[condition];\n };\n var key;\n each(data, function (item) {\n key = predicate(item);\n\n if (hasOwnProperty.call(result, key)) {\n result[key].push(item);\n } else {\n result[key] = [item];\n }\n });\n return result;\n}\n\nexport default groupBy;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/group-by.js\n// module id = 24\n// module chunks = 0","export default (function (obj, key) {\n return obj.hasOwnProperty(key);\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/has.js\n// module id = 25\n// module chunks = 0","import each from './each';\nimport isFunction from './is-function'; // @ts-ignore\n\nvar values = Object.values ? function (obj) {\n return Object.values(obj);\n} : function (obj) {\n var result = [];\n each(obj, function (value, key) {\n if (!(isFunction(obj) && key === 'prototype')) {\n result.push(value);\n }\n });\n return result;\n};\nexport default values;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/values.js\n// module id = 26\n// module chunks = 0","var toString = {}.toString;\n\nvar getType = function (value) {\n return toString.call(value).replace(/^\\[object /, '').replace(/]$/, '');\n};\n\nexport default getType;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/get-type.js\n// module id = 27\n// module chunks = 0","var objectProto = Object.prototype;\n\nvar isPrototype = function (value) {\n var Ctor = value && value.constructor;\n var proto = typeof Ctor === 'function' && Ctor.prototype || objectProto;\n return value === proto;\n};\n\nexport default isPrototype;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-prototype.js\n// module id = 28\n// module chunks = 0","import isObjectLike from './is-object-like';\nimport isArrayLike from './is-array-like';\nimport isString from './is-string';\n\nvar isEqual = function (value, other) {\n if (value === other) {\n return true;\n }\n\n if (!value || !other) {\n return false;\n }\n\n if (isString(value) || isString(other)) {\n return false;\n }\n\n if (isArrayLike(value) || isArrayLike(other)) {\n if (value.length !== other.length) {\n return false;\n }\n\n var rst = true;\n\n for (var i = 0; i < value.length; i++) {\n rst = isEqual(value[i], other[i]);\n\n if (!rst) {\n break;\n }\n }\n\n return rst;\n }\n\n if (isObjectLike(value) || isObjectLike(other)) {\n var valueKeys = Object.keys(value);\n var otherKeys = Object.keys(other);\n\n if (valueKeys.length !== otherKeys.length) {\n return false;\n }\n\n var rst = true;\n\n for (var i = 0; i < valueKeys.length; i++) {\n rst = isEqual(value[valueKeys[i]], other[valueKeys[i]]);\n\n if (!rst) {\n break;\n }\n }\n\n return rst;\n }\n\n return false;\n};\n\nexport default isEqual;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-equal.js\n// module id = 29\n// module chunks = 0","var hierarchy = require('./hierarchy');\n\nmodule.exports = function (root, options) {\n // separate into left and right trees\n var left = hierarchy(root.data, options, true); // root only\n\n var right = hierarchy(root.data, options, true); // root only\n // automatically\n\n var treeSize = root.children.length;\n var rightTreeSize = Math.round(treeSize / 2); // separate left and right tree by meta data\n\n var getSide = options.getSide || function (child, index) {\n if (index < rightTreeSize) {\n return 'right';\n }\n\n return 'left';\n };\n\n for (var i = 0; i < treeSize; i++) {\n var child = root.children[i];\n var side = getSide(child, i);\n\n if (side === 'right') {\n right.children.push(child);\n } else {\n left.children.push(child);\n }\n }\n\n left.eachNode(function (node) {\n if (!node.isRoot()) {\n node.side = 'left';\n }\n });\n right.eachNode(function (node) {\n if (!node.isRoot()) {\n node.side = 'right';\n }\n });\n return {\n left: left,\n right: right\n };\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/layout/separate-root.js\n// module id = 30\n// module chunks = 0","var hierarchy = {\n compactBox: require('./compact-box'),\n dendrogram: require('./dendrogram'),\n indented: require('./indented'),\n mindmap: require('./mindmap')\n};\nmodule.exports = hierarchy;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/index.js\n// module id = 31\n// module chunks = 0","function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar TreeLayout = require('./layout/base');\n\nvar nonLayeredTidyTree = require('./layout/non-layered-tidy');\n\nvar doTreeLayout = require('./layout/do-layout');\n\nvar util = require('./util');\n\nvar CompactBoxTreeLayout = /*#__PURE__*/function (_TreeLayout) {\n _inheritsLoose(CompactBoxTreeLayout, _TreeLayout);\n\n function CompactBoxTreeLayout() {\n return _TreeLayout.apply(this, arguments) || this;\n }\n\n var _proto = CompactBoxTreeLayout.prototype;\n\n _proto.execute = function execute() {\n var me = this;\n return doTreeLayout(me.rootNode, me.options, nonLayeredTidyTree);\n };\n\n return CompactBoxTreeLayout;\n}(TreeLayout);\n\nvar DEFAULT_OPTIONS = {};\n\nfunction compactBoxLayout(root, options) {\n options = util.assign({}, DEFAULT_OPTIONS, options);\n return new CompactBoxTreeLayout(root, options).execute();\n}\n\nmodule.exports = compactBoxLayout;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/compact-box.js\n// module id = 32\n// module chunks = 0","// array\nexport { default as contains, default as includes } from './contains';\nexport { default as difference } from './difference';\nexport { default as find } from './find';\nexport { default as findIndex } from './find-index';\nexport { default as firstValue } from './first-value';\nexport { default as flatten } from './flatten';\nexport { default as flattenDeep } from './flatten-deep';\nexport { default as getRange } from './get-range';\nexport { default as pull } from './pull';\nexport { default as pullAt } from './pull-at';\nexport { default as reduce } from './reduce';\nexport { default as remove } from './remove';\nexport { default as sortBy } from './sort-by';\nexport { default as union } from './union';\nexport { default as uniq } from './uniq';\nexport { default as valuesOfKey } from './values-of-key';\nexport { default as head } from './head';\nexport { default as last } from './last';\nexport { default as startsWith } from './starts-with';\nexport { default as endsWith } from './ends-with';\nexport { default as filter } from './filter';\nexport { default as every } from './every';\nexport { default as some } from './some';\nexport { default as group } from './group';\nexport { default as groupBy } from './group-by';\nexport { default as groupToMap } from './group-to-map'; // event\n\nexport { default as getWrapBehavior } from './get-wrap-behavior';\nexport { default as wrapBehavior } from './wrap-behavior'; // format\n\nexport { default as number2color } from './number2color';\nexport { default as parseRadius } from './parse-radius'; // math\n\nexport { default as clamp } from './clamp';\nexport { default as fixedBase } from './fixed-base';\nexport { default as isDecimal } from './is-decimal';\nexport { default as isEven } from './is-even';\nexport { default as isInteger } from './is-integer';\nexport { default as isNegative } from './is-negative';\nexport { default as isNumberEqual } from './is-number-equal';\nexport { default as isOdd } from './is-odd';\nexport { default as isPositive } from './is-positive';\nexport { default as maxBy } from './max-by';\nexport { default as minBy } from './min-by';\nexport { default as mod } from './mod';\nexport { default as toDegree } from './to-degree';\nexport { default as toInteger } from './to-integer';\nexport { default as toRadian } from './to-radian'; // object\n\nexport { default as forIn } from './for-in';\nexport { default as has } from './has';\nexport { default as hasKey } from './has-key';\nexport { default as hasValue } from './has-value';\nexport { default as keys } from './keys';\nexport { default as isMatch } from './is-match';\nexport { default as values } from './values'; // string\n\nexport { default as lowerCase } from './lower-case';\nexport { default as lowerFirst } from './lower-first';\nexport { default as substitute } from './substitute';\nexport { default as upperCase } from './upper-case';\nexport { default as upperFirst } from './upper-first'; // type\n\nexport { default as getType } from './get-type';\nexport { default as isArguments } from './is-arguments';\nexport { default as isArray } from './is-array';\nexport { default as isArrayLike } from './is-array-like';\nexport { default as isBoolean } from './is-boolean';\nexport { default as isDate } from './is-date';\nexport { default as isError } from './is-error';\nexport { default as isFunction } from './is-function';\nexport { default as isFinite } from './is-finite';\nexport { default as isNil } from './is-nil';\nexport { default as isNull } from './is-null';\nexport { default as isNumber } from './is-number';\nexport { default as isObject } from './is-object';\nexport { default as isObjectLike } from './is-object-like';\nexport { default as isPlainObject } from './is-plain-object';\nexport { default as isPrototype } from './is-prototype';\nexport { default as isRegExp } from './is-reg-exp';\nexport { default as isString } from './is-string';\nexport { default as isType } from './is-type';\nexport { default as isUndefined } from './is-undefined';\nexport { default as isElement } from './is-element';\nexport { default as requestAnimationFrame } from './request-animation-frame';\nexport { default as clearAnimationFrame } from './clear-animation-frame'; // other\n\nexport { default as augment } from './augment';\nexport { default as clone } from './clone';\nexport { default as debounce } from './debounce';\nexport { default as memoize } from './memoize';\nexport { default as deepMix } from './deep-mix';\nexport { default as each } from './each';\nexport { default as extend } from './extend';\nexport { default as indexOf } from './index-of';\nexport { default as isEmpty } from './is-empty';\nexport { default as isEqual } from './is-equal';\nexport { default as isEqualWith } from './is-equal-with';\nexport { default as map } from './map';\nexport { default as mapValues } from './map-values';\nexport { default as mix, default as assign } from './mix';\nexport { default as get } from './get';\nexport { default as set } from './set';\nexport { default as pick } from './pick';\nexport { default as throttle } from './throttle';\nexport { default as toArray } from './to-array';\nexport { default as toString } from './to-string';\nexport { default as uniqueId } from './unique-id';\nexport { default as noop } from './noop';\nexport { default as identity } from './identity';\nexport { default as size } from './size'; // 不知道为什么,需要把这个 export,不然 ts 会报类型错误\n\nexport { default as Cache } from './cache';\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/index.js\n// module id = 33\n// module chunks = 0","import filter from './filter';\nimport contains from './contains';\n/**\n * Flattens `array` a single level deep.\n *\n * @param {Array} arr The array to inspect.\n * @param {Array} values The values to exclude.\n * @return {Array} Returns the new array of filtered values.\n * @example\n * difference([2, 1], [2, 3]); // => [1]\n */\n\nvar difference = function (arr, values) {\n if (values === void 0) {\n values = [];\n }\n\n return filter(arr, function (value) {\n return !contains(values, value);\n });\n};\n\nexport default difference;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/difference.js\n// module id = 34\n// module chunks = 0","import isFunction from './is-function';\nimport isMatch from './is-match';\nimport isArray from './is-array';\nimport isPlainObject from './is-plain-object';\n\nfunction find(arr, predicate) {\n if (!isArray(arr)) return null;\n\n var _predicate;\n\n if (isFunction(predicate)) {\n _predicate = predicate;\n }\n\n if (isPlainObject(predicate)) {\n _predicate = function (a) {\n return isMatch(a, predicate);\n };\n }\n\n if (_predicate) {\n for (var i = 0; i < arr.length; i += 1) {\n if (_predicate(arr[i])) {\n return arr[i];\n }\n }\n }\n\n return null;\n}\n\nexport default find;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/find.js\n// module id = 35\n// module chunks = 0","function findIndex(arr, predicate, fromIndex) {\n if (fromIndex === void 0) {\n fromIndex = 0;\n }\n\n for (var i = fromIndex; i < arr.length; i++) {\n if (predicate(arr[i], i)) {\n // 找到终止循环\n return i;\n }\n }\n\n return -1;\n}\n\nexport default findIndex;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/find-index.js\n// module id = 36\n// module chunks = 0","import isNil from './is-nil';\nimport isArray from './is-array';\n\nvar firstValue = function (data, name) {\n var rst = null;\n\n for (var i = 0; i < data.length; i++) {\n var obj = data[i];\n var value = obj[name];\n\n if (!isNil(value)) {\n if (isArray(value)) {\n rst = value[0]; // todo 这里是否应该使用递归,调用 firstValue @绝云\n } else {\n rst = value;\n }\n\n break;\n }\n }\n\n return rst;\n};\n\nexport default firstValue;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/first-value.js\n// module id = 37\n// module chunks = 0","import isArray from './is-array';\n/**\n * Flattens `array` a single level deep.\n *\n * @param {Array} arr The array to flatten.\n * @return {Array} Returns the new flattened array.\n * @example\n *\n * flatten([1, [2, [3, [4]], 5]]); // => [1, 2, [3, [4]], 5]\n */\n\nvar flatten = function (arr) {\n if (!isArray(arr)) {\n return [];\n }\n\n var rst = [];\n\n for (var i = 0; i < arr.length; i++) {\n rst = rst.concat(arr[i]);\n }\n\n return rst;\n};\n\nexport default flatten;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/flatten.js\n// module id = 38\n// module chunks = 0","import isArray from './is-array';\n/**\n * Flattens `array` a single level deep.\n *\n * @param {Array} arr The array to flatten.\n * @param {Array} result The array to return.\n * @return {Array} Returns the new flattened array.\n * @example\n *\n * flattenDeep([1, [2, [3, [4]], 5]]); // => [1, 2, 3, 4, 5]\n */\n\nvar flattenDeep = function (arr, result) {\n if (result === void 0) {\n result = [];\n }\n\n if (!isArray(arr)) {\n result.push(arr);\n } else {\n for (var i = 0; i < arr.length; i += 1) {\n flattenDeep(arr[i], result);\n }\n }\n\n return result;\n};\n\nexport default flattenDeep;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/flatten-deep.js\n// module id = 39\n// module chunks = 0","import isArray from './is-array';\nimport filter from './filter';\n\nvar getRange = function (values) {\n // 存在 NaN 时,min,max 判定会出问题\n values = filter(values, function (v) {\n return !isNaN(v);\n });\n\n if (!values.length) {\n // 如果没有数值则直接返回0\n return {\n min: 0,\n max: 0\n };\n }\n\n if (isArray(values[0])) {\n var tmp = [];\n\n for (var i = 0; i < values.length; i++) {\n tmp = tmp.concat(values[i]);\n }\n\n values = tmp;\n }\n\n var max = Math.max.apply(null, values);\n var min = Math.min.apply(null, values);\n return {\n min: min,\n max: max\n };\n};\n\nexport default getRange;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/get-range.js\n// module id = 40\n// module chunks = 0","var arrPrototype = Array.prototype;\nvar splice = arrPrototype.splice;\nvar indexOf = arrPrototype.indexOf;\n\nvar pull = function (arr) {\n var values = [];\n\n for (var _i = 1; _i < arguments.length; _i++) {\n values[_i - 1] = arguments[_i];\n }\n\n for (var i = 0; i < values.length; i++) {\n var value = values[i];\n var fromIndex = -1;\n\n while ((fromIndex = indexOf.call(arr, value)) > -1) {\n splice.call(arr, fromIndex, 1);\n }\n }\n\n return arr;\n};\n\nexport default pull;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/pull.js\n// module id = 41\n// module chunks = 0","import each from './each';\nimport isArray from './is-array';\nimport isPlainObject from './is-plain-object';\n\nvar reduce = function (arr, fn, init) {\n if (!isArray(arr) && !isPlainObject(arr)) {\n return arr;\n }\n\n var result = init;\n each(arr, function (data, i) {\n result = fn(result, data, i);\n });\n return result;\n};\n\nexport default reduce;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/reduce.js\n// module id = 42\n// module chunks = 0","import isArrayLike from './is-array-like';\nimport pullAt from './pull-at';\n\nvar remove = function (arr, predicate) {\n /**\n * const arr = [1, 2, 3, 4]\n * const evens = remove(arr, n => n % 2 == 0)\n * console.log(arr) // => [1, 3]\n * console.log(evens) // => [2, 4]\n */\n var result = [];\n\n if (!isArrayLike(arr)) {\n return result;\n }\n\n var i = -1;\n var indexes = [];\n var length = arr.length;\n\n while (++i < length) {\n var value = arr[i];\n\n if (predicate(value, i, arr)) {\n result.push(value);\n indexes.push(i);\n }\n }\n\n pullAt(arr, indexes);\n return result;\n};\n\nexport default remove;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/remove.js\n// module id = 43\n// module chunks = 0","import isArray from './is-array';\nimport isString from './is-string';\nimport isFunction from './is-function';\n\nfunction sortBy(arr, key) {\n var comparer;\n\n if (isFunction(key)) {\n comparer = function (a, b) {\n return key(a) - key(b);\n };\n } else {\n var keys_1 = [];\n\n if (isString(key)) {\n keys_1.push(key);\n } else if (isArray(key)) {\n keys_1 = key;\n }\n\n comparer = function (a, b) {\n for (var i = 0; i < keys_1.length; i += 1) {\n var prop = keys_1[i];\n\n if (a[prop] > b[prop]) {\n return 1;\n }\n\n if (a[prop] < b[prop]) {\n return -1;\n }\n }\n\n return 0;\n };\n }\n\n arr.sort(comparer);\n return arr;\n}\n\nexport default sortBy;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/sort-by.js\n// module id = 44\n// module chunks = 0","import uniq from './uniq';\n\nvar union = function () {\n var sources = [];\n\n for (var _i = 0; _i < arguments.length; _i++) {\n sources[_i] = arguments[_i];\n }\n\n return uniq([].concat.apply([], sources));\n};\n\nexport default union;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/union.js\n// module id = 45\n// module chunks = 0","import each from './each';\nimport isArray from './is-array';\nimport isNil from './is-nil';\nexport default (function (data, name) {\n var rst = [];\n var tmpMap = {};\n data.forEach(function (obj) {\n var value = obj[name];\n\n if (!isNil(value)) {\n // flatten\n if (!isArray(value)) {\n value = [value];\n }\n\n each(value, function (val) {\n // unique\n if (!tmpMap[val]) {\n rst.push(val);\n tmpMap[val] = true;\n }\n });\n }\n });\n return rst;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/values-of-key.js\n// module id = 46\n// module chunks = 0","import isArrayLike from './is-array-like';\nexport default function head(o) {\n if (isArrayLike(o)) {\n return o[0];\n }\n\n return undefined;\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/head.js\n// module id = 47\n// module chunks = 0","import isArrayLike from './is-array-like';\nexport default function last(o) {\n if (isArrayLike(o)) {\n var arr = o;\n return arr[arr.length - 1];\n }\n\n return undefined;\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/last.js\n// module id = 48\n// module chunks = 0","import isArray from './is-array';\nimport isString from './is-string';\n\nfunction startsWith(arr, e) {\n return isArray(arr) || isString(arr) ? arr[0] === e : false;\n}\n\nexport default startsWith;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/starts-with.js\n// module id = 49\n// module chunks = 0","import isArray from './is-array';\nimport isString from './is-string';\n\nfunction endsWith(arr, e) {\n return isArray(arr) || isString(arr) ? arr[arr.length - 1] === e : false;\n}\n\nexport default endsWith;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/ends-with.js\n// module id = 50\n// module chunks = 0","/**\n * 只要有一个不满足条件就返回 false\n * @param arr\n * @param func\n */\nvar every = function (arr, func) {\n for (var i = 0; i < arr.length; i++) {\n if (!func(arr[i], i)) return false;\n }\n\n return true;\n};\n\nexport default every;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/every.js\n// module id = 51\n// module chunks = 0","/**\n * 只要有一个满足条件就返回 true\n * @param arr\n * @param func\n */\nvar some = function (arr, func) {\n for (var i = 0; i < arr.length; i++) {\n if (func(arr[i], i)) return true;\n }\n\n return false;\n};\n\nexport default some;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/some.js\n// module id = 52\n// module chunks = 0","import groupToMap from './group-to-map';\nexport default (function (data, condition) {\n if (!condition) {\n // 没有条件,则自身改成数组\n return [data];\n }\n\n var groups = groupToMap(data, condition);\n var array = [];\n\n for (var i in groups) {\n array.push(groups[i]);\n }\n\n return array;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/group.js\n// module id = 53\n// module chunks = 0","/**\n * 获取封装的事件\n * @protected\n * @param {Object} obj 对象\n * @param {String} action 事件名称\n * @return {Function} 返回事件处理函数\n */\nfunction getWrapBehavior(obj, action) {\n return obj['_wrap_' + action];\n}\n\nexport default getWrapBehavior;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/get-wrap-behavior.js\n// module id = 54\n// module chunks = 0","/**\n * 封装事件,便于使用上下文this,和便于解除事件时使用\n * @protected\n * @param {Object} obj 对象\n * @param {String} action 事件名称\n * @return {Function} 返回事件处理函数\n */\nfunction wrapBehavior(obj, action) {\n if (obj['_wrap_' + action]) {\n return obj['_wrap_' + action];\n }\n\n var method = function (e) {\n obj[action](e);\n };\n\n obj['_wrap_' + action] = method;\n return method;\n}\n\nexport default wrapBehavior;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/wrap-behavior.js\n// module id = 55\n// module chunks = 0","var numColorCache = {};\n\nfunction numberToColor(num) {\n // 增加缓存\n var color = numColorCache[num];\n\n if (!color) {\n var str = num.toString(16);\n\n for (var i = str.length; i < 6; i++) {\n str = '0' + str;\n }\n\n color = '#' + str;\n numColorCache[num] = color;\n }\n\n return color;\n}\n\nexport default numberToColor;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/number2color.js\n// module id = 56\n// module chunks = 0","import isArray from './is-array';\n\nfunction parseRadius(radius) {\n var r1 = 0,\n r2 = 0,\n r3 = 0,\n r4 = 0;\n\n if (isArray(radius)) {\n if (radius.length === 1) {\n r1 = r2 = r3 = r4 = radius[0];\n } else if (radius.length === 2) {\n r1 = r3 = radius[0];\n r2 = r4 = radius[1];\n } else if (radius.length === 3) {\n r1 = radius[0];\n r2 = r4 = radius[1];\n r3 = radius[2];\n } else {\n r1 = radius[0];\n r2 = radius[1];\n r3 = radius[2];\n r4 = radius[3];\n }\n } else {\n r1 = r2 = r3 = r4 = radius;\n }\n\n return {\n r1: r1,\n r2: r2,\n r3: r3,\n r4: r4\n };\n}\n\nexport default parseRadius;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/parse-radius.js\n// module id = 57\n// module chunks = 0","var clamp = function (a, min, max) {\n if (a < min) {\n return min;\n } else if (a > max) {\n return max;\n }\n\n return a;\n};\n\nexport default clamp;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/clamp.js\n// module id = 58\n// module chunks = 0","var fixedBase = function (v, base) {\n var str = base.toString();\n var index = str.indexOf('.');\n\n if (index === -1) {\n return Math.round(v);\n }\n\n var length = str.substr(index + 1).length;\n\n if (length > 20) {\n length = 20;\n }\n\n return parseFloat(v.toFixed(length));\n};\n\nexport default fixedBase;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/fixed-base.js\n// module id = 59\n// module chunks = 0","import isNumber from './is-number';\n\nvar isDecimal = function (num) {\n return isNumber(num) && num % 1 !== 0;\n};\n\nexport default isDecimal;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-decimal.js\n// module id = 60\n// module chunks = 0","import isNumber from './is-number';\n\nvar isEven = function (num) {\n return isNumber(num) && num % 2 === 0;\n};\n\nexport default isEven;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-even.js\n// module id = 61\n// module chunks = 0","import isNumber from './is-number';\nvar isInteger = Number.isInteger ? Number.isInteger : function (num) {\n return isNumber(num) && num % 1 === 0;\n};\nexport default isInteger;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-integer.js\n// module id = 62\n// module chunks = 0","import isNumber from './is-number';\n\nvar isNegative = function (num) {\n return isNumber(num) && num < 0;\n};\n\nexport default isNegative;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-negative.js\n// module id = 63\n// module chunks = 0","var PRECISION = 0.00001; // numbers less than this is considered as 0\n\nexport default function isNumberEqual(a, b, precision) {\n if (precision === void 0) {\n precision = PRECISION;\n }\n\n return Math.abs(a - b) < precision;\n}\n;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-number-equal.js\n// module id = 64\n// module chunks = 0","import isNumber from './is-number';\n\nvar isOdd = function (num) {\n return isNumber(num) && num % 2 !== 0;\n};\n\nexport default isOdd;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-odd.js\n// module id = 65\n// module chunks = 0","import isNumber from './is-number';\n\nvar isPositive = function (num) {\n return isNumber(num) && num > 0;\n};\n\nexport default isPositive;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-positive.js\n// module id = 66\n// module chunks = 0","import each from './each';\nimport isArray from './is-array';\nimport isFunction from './is-function';\n/**\n * @param {Array} arr The array to iterate over.\n * @param {Function} [fn] The iteratee invoked per element.\n * @return {*} Returns the maximum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * maxBy(objects, function(o) { return o.n; });\n * // => { 'n': 2 }\n *\n * maxBy(objects, 'n');\n * // => { 'n': 2 }\n */\n\nexport default (function (arr, fn) {\n if (!isArray(arr)) {\n return undefined;\n }\n\n var max = arr[0];\n var maxData;\n\n if (isFunction(fn)) {\n maxData = fn(arr[0]);\n } else {\n maxData = arr[0][fn];\n }\n\n var data;\n each(arr, function (val) {\n if (isFunction(fn)) {\n data = fn(val);\n } else {\n data = val[fn];\n }\n\n if (data > maxData) {\n max = val;\n maxData = data;\n }\n });\n return max;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/max-by.js\n// module id = 67\n// module chunks = 0","import each from './each';\nimport isArray from './is-array';\nimport isFunction from './is-function';\n/**\n * @param {Array} arr The array to iterate over.\n * @param {Function} [fn] The iteratee invoked per element.\n * @return {*} Returns the minimum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * minBy(objects, function(o) { return o.n; });\n * // => { 'n': 1 }\n *\n * minBy(objects, 'n');\n * // => { 'n': 1 }\n */\n\nexport default (function (arr, fn) {\n if (!isArray(arr)) {\n return undefined;\n }\n\n var min = arr[0];\n var minData;\n\n if (isFunction(fn)) {\n minData = fn(arr[0]);\n } else {\n minData = arr[0][fn];\n }\n\n var data;\n each(arr, function (val) {\n if (isFunction(fn)) {\n data = fn(val);\n } else {\n data = val[fn];\n }\n\n if (data < minData) {\n min = val;\n minData = data;\n }\n });\n return min;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/min-by.js\n// module id = 68\n// module chunks = 0","var mod = function (n, m) {\n return (n % m + m) % m;\n};\n\nexport default mod;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/mod.js\n// module id = 69\n// module chunks = 0","var DEGREE = 180 / Math.PI;\n\nvar toDegree = function (radian) {\n return DEGREE * radian;\n};\n\nexport default toDegree;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/to-degree.js\n// module id = 70\n// module chunks = 0","export default parseInt;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/to-integer.js\n// module id = 71\n// module chunks = 0","var RADIAN = Math.PI / 180;\n\nvar toRadian = function (degree) {\n return RADIAN * degree;\n};\n\nexport default toRadian;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/to-radian.js\n// module id = 72\n// module chunks = 0","import each from './each';\nexport default each;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/for-in.js\n// module id = 73\n// module chunks = 0","import has from './has';\nexport default has;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/has-key.js\n// module id = 74\n// module chunks = 0","import contains from './contains';\nimport values from './values';\nexport default (function (obj, value) {\n return contains(values(obj), value);\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/has-value.js\n// module id = 75\n// module chunks = 0","import toString from './to-string';\n\nvar lowerCase = function (str) {\n return toString(str).toLowerCase();\n};\n\nexport default lowerCase;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/lower-case.js\n// module id = 76\n// module chunks = 0","import toString from './to-string';\n\nvar lowerFirst = function (value) {\n var str = toString(value);\n return str.charAt(0).toLowerCase() + str.substring(1);\n};\n\nexport default lowerFirst;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/lower-first.js\n// module id = 77\n// module chunks = 0","function substitute(str, o) {\n if (!str || !o) {\n return str;\n }\n\n return str.replace(/\\\\?\\{([^{}]+)\\}/g, function (match, name) {\n if (match.charAt(0) === '\\\\') {\n return match.slice(1);\n }\n\n return o[name] === undefined ? '' : o[name];\n });\n}\n\nexport default substitute;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/substitute.js\n// module id = 78\n// module chunks = 0","import toString from './to-string';\n\nvar upperCase = function (str) {\n return toString(str).toUpperCase();\n};\n\nexport default upperCase;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/upper-case.js\n// module id = 79\n// module chunks = 0","import toString from './to-string';\n\nvar upperFirst = function (value) {\n var str = toString(value);\n return str.charAt(0).toUpperCase() + str.substring(1);\n};\n\nexport default upperFirst;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/upper-first.js\n// module id = 80\n// module chunks = 0","/**\n * 是否是参数类型\n *\n * @param {Object} value 测试的值\n * @return {Boolean}\n */\nimport isType from './is-type';\n\nvar isArguments = function (value) {\n return isType(value, 'Arguments');\n};\n\nexport default isArguments;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-arguments.js\n// module id = 81\n// module chunks = 0","/**\n * 是否是布尔类型\n *\n * @param {Object} value 测试的值\n * @return {Boolean}\n */\nimport isType from './is-type';\n\nvar isBoolean = function (value) {\n return isType(value, 'Boolean');\n};\n\nexport default isBoolean;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-boolean.js\n// module id = 82\n// module chunks = 0","import isType from './is-type';\n\nvar isDate = function (value) {\n return isType(value, 'Date');\n};\n\nexport default isDate;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-date.js\n// module id = 83\n// module chunks = 0","/**\n * 是否是参数类型\n *\n * @param {Object} value 测试的值\n * @return {Boolean}\n */\nimport isType from './is-type';\n\nvar isError = function (value) {\n return isType(value, 'Error');\n};\n\nexport default isError;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-error.js\n// module id = 84\n// module chunks = 0","/**\n * 判断是否为有限数\n * @return {Boolean}\n */\nimport isNumber from './is-number';\nexport default function (value) {\n return isNumber(value) && isFinite(value);\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-finite.js\n// module id = 85\n// module chunks = 0","var isNull = function (value) {\n return value === null;\n};\n\nexport default isNull;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-null.js\n// module id = 86\n// module chunks = 0","import isType from './is-type';\n\nvar isRegExp = function (str) {\n return isType(str, 'RegExp');\n};\n\nexport default isRegExp;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-reg-exp.js\n// module id = 87\n// module chunks = 0","var isUndefined = function (value) {\n return value === undefined;\n};\n\nexport default isUndefined;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-undefined.js\n// module id = 88\n// module chunks = 0","/**\n * 判断是否HTML元素\n * @return {Boolean} 是否HTML元素\n */\nvar isElement = function (o) {\n return o instanceof Element || o instanceof HTMLDocument;\n};\n\nexport default isElement;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-element.js\n// module id = 89\n// module chunks = 0","export default function requestAnimationFrame(fn) {\n var method = window.requestAnimationFrame || window.webkitRequestAnimationFrame || // @ts-ignore\n window.mozRequestAnimationFrame || // @ts-ignore\n window.msRequestAnimationFrame || function (f) {\n return setTimeout(f, 16);\n };\n\n return method(fn);\n}\n;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/request-animation-frame.js\n// module id = 90\n// module chunks = 0","export default function cancelAnimationFrame(handler) {\n var method = window.cancelAnimationFrame || window.webkitCancelAnimationFrame || // @ts-ignore\n window.mozCancelAnimationFrame || // @ts-ignore\n window.msCancelAnimationFrame || clearTimeout;\n method(handler);\n}\n;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/clear-animation-frame.js\n// module id = 91\n// module chunks = 0","import mix from './mix';\nimport isFunction from './is-function';\n\nvar augment = function () {\n var args = [];\n\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n\n var c = args[0];\n\n for (var i = 1; i < args.length; i++) {\n var obj = args[i];\n\n if (isFunction(obj)) {\n obj = obj.prototype;\n }\n\n mix(c.prototype, obj);\n }\n};\n\nexport default augment;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/augment.js\n// module id = 92\n// module chunks = 0","import isArray from './is-array';\n\nvar clone = function (obj) {\n if (typeof obj !== 'object' || obj === null) {\n return obj;\n }\n\n var rst;\n\n if (isArray(obj)) {\n rst = [];\n\n for (var i = 0, l = obj.length; i < l; i++) {\n if (typeof obj[i] === 'object' && obj[i] != null) {\n rst[i] = clone(obj[i]);\n } else {\n rst[i] = obj[i];\n }\n }\n } else {\n rst = {};\n\n for (var k in obj) {\n if (typeof obj[k] === 'object' && obj[k] != null) {\n rst[k] = clone(obj[k]);\n } else {\n rst[k] = obj[k];\n }\n }\n }\n\n return rst;\n};\n\nexport default clone;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/clone.js\n// module id = 93\n// module chunks = 0","function debounce(func, wait, immediate) {\n var timeout;\n return function () {\n var context = this,\n args = arguments;\n\n var later = function () {\n timeout = null;\n\n if (!immediate) {\n func.apply(context, args);\n }\n };\n\n var callNow = immediate && !timeout;\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n\n if (callNow) {\n func.apply(context, args);\n }\n };\n}\n\nexport default debounce;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/debounce.js\n// module id = 94\n// module chunks = 0","import isFunction from './is-function';\n/**\n * _.memoize(calColor);\n * _.memoize(calColor, (...args) => args[0]);\n * @param f\n * @param resolver\n */\n\nexport default (function (f, resolver) {\n if (!isFunction(f)) {\n throw new TypeError('Expected a function');\n }\n\n var memoized = function () {\n var args = [];\n\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n } // 使用方法构造 key,如果不存在 resolver,则直接取第一个参数作为 key\n\n\n var key = resolver ? resolver.apply(this, args) : args[0];\n var cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n\n var result = f.apply(this, args); // 缓存起来\n\n cache.set(key, result);\n return result;\n };\n\n memoized.cache = new Map();\n return memoized;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/memoize.js\n// module id = 95\n// module chunks = 0","import isArray from './is-array';\nimport isPlainObject from './is-plain-object';\nvar MAX_MIX_LEVEL = 5;\n\nfunction _deepMix(dist, src, level, maxLevel) {\n level = level || 0;\n maxLevel = maxLevel || MAX_MIX_LEVEL;\n\n for (var key in src) {\n if (src.hasOwnProperty(key)) {\n var value = src[key];\n\n if (value !== null && isPlainObject(value)) {\n if (!isPlainObject(dist[key])) {\n dist[key] = {};\n }\n\n if (level < maxLevel) {\n _deepMix(dist[key], value, level + 1, maxLevel);\n } else {\n dist[key] = src[key];\n }\n } else if (isArray(value)) {\n dist[key] = [];\n dist[key] = dist[key].concat(value);\n } else if (value !== undefined) {\n dist[key] = value;\n }\n }\n }\n} // todo 重写\n\n\nvar deepMix = function (rst) {\n var args = [];\n\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n\n for (var i = 0; i < args.length; i += 1) {\n _deepMix(rst, args[i]);\n }\n\n return rst;\n};\n\nexport default deepMix;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/deep-mix.js\n// module id = 96\n// module chunks = 0","import mix from './mix';\nimport isFunction from './is-function';\n\nvar extend = function (subclass, superclass, overrides, staticOverrides) {\n // 如果只提供父类构造函数,则自动生成子类构造函数\n if (!isFunction(superclass)) {\n overrides = superclass;\n superclass = subclass;\n\n subclass = function () {};\n }\n\n var create = Object.create ? function (proto, c) {\n return Object.create(proto, {\n constructor: {\n value: c\n }\n });\n } : function (proto, c) {\n function Tmp() {}\n\n Tmp.prototype = proto;\n var o = new Tmp();\n o.constructor = c;\n return o;\n };\n var superObj = create(superclass.prototype, subclass); // new superclass(),//实例化父类作为子类的prototype\n\n subclass.prototype = mix(superObj, subclass.prototype); // 指定子类的prototype\n\n subclass.superclass = create(superclass.prototype, superclass);\n mix(superObj, overrides);\n mix(subclass, staticOverrides);\n return subclass;\n};\n\nexport default extend;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/extend.js\n// module id = 97\n// module chunks = 0","import isArrayLike from './is-array-like';\n\nvar indexOf = function (arr, obj) {\n if (!isArrayLike(arr)) {\n return -1;\n }\n\n var m = Array.prototype.indexOf;\n\n if (m) {\n return m.call(arr, obj);\n }\n\n var index = -1;\n\n for (var i = 0; i < arr.length; i++) {\n if (arr[i] === obj) {\n index = i;\n break;\n }\n }\n\n return index;\n};\n\nexport default indexOf;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/index-of.js\n// module id = 98\n// module chunks = 0","import isNil from './is-nil';\nimport isArrayLike from './is-array-like';\nimport getType from './get-type';\nimport isPrototype from './is-prototype';\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction isEmpty(value) {\n /**\n * isEmpty(null) => true\n * isEmpty() => true\n * isEmpty(true) => true\n * isEmpty(1) => true\n * isEmpty([1, 2, 3]) => false\n * isEmpty('abc') => false\n * isEmpty({ a: 1 }) => false\n */\n if (isNil(value)) {\n return true;\n }\n\n if (isArrayLike(value)) {\n return !value.length;\n }\n\n var type = getType(value);\n\n if (type === 'Map' || type === 'Set') {\n return !value.size;\n }\n\n if (isPrototype(value)) {\n return !Object.keys(value).length;\n }\n\n for (var key in value) {\n if (hasOwnProperty.call(value, key)) {\n return false;\n }\n }\n\n return true;\n}\n\nexport default isEmpty;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-empty.js\n// module id = 99\n// module chunks = 0","import isFunction from './is-function';\nimport isEqual from './is-equal';\n/**\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {Function} [fn] The function to customize comparisons.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, othValue) {\n * if (isGreeting(objValue) && isGreeting(othValue)) {\n * return true;\n * }\n * }\n *\n * var array = ['hello', 'goodbye'];\n * var other = ['hi', 'goodbye'];\n *\n * isEqualWith(array, other, customizer); // => true\n */\n\nexport default (function (value, other, fn) {\n if (!isFunction(fn)) {\n return isEqual(value, other);\n }\n\n return !!fn(value, other);\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/is-equal-with.js\n// module id = 100\n// module chunks = 0","import each from './each';\nimport isArrayLike from './is-array-like';\n\nvar map = function (arr, func) {\n if (!isArrayLike(arr)) {\n // @ts-ignore\n return arr;\n }\n\n var result = [];\n each(arr, function (value, index) {\n result.push(func(value, index));\n });\n return result;\n};\n\nexport default map;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/map.js\n// module id = 101\n// module chunks = 0","import isNil from './is-nil';\nimport isObject from './is-object';\n\nvar identity = function (v) {\n return v;\n};\n\nexport default (function (object, func) {\n if (func === void 0) {\n func = identity;\n }\n\n var r = {};\n\n if (isObject(object) && !isNil(object)) {\n Object.keys(object).forEach(function (key) {\n // @ts-ignore\n r[key] = func(object[key], key);\n });\n }\n\n return r;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/map-values.js\n// module id = 102\n// module chunks = 0","import isString from './is-string';\n/**\n * https://github.com/developit/dlv/blob/master/index.js\n * @param obj\n * @param key\n * @param defaultValue\n */\n\nexport default (function (obj, key, defaultValue) {\n var p = 0;\n var keyArr = isString(key) ? key.split('.') : key;\n\n while (obj && p < keyArr.length) {\n obj = obj[keyArr[p++]];\n }\n\n return obj === undefined || p < keyArr.length ? defaultValue : obj;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/get.js\n// module id = 103\n// module chunks = 0","import isObject from './is-object';\nimport isString from './is-string';\nimport isNumber from './is-number';\n/**\n * https://github.com/developit/dlv/blob/master/index.js\n * @param obj\n * @param path\n * @param value\n */\n\nexport default (function (obj, path, value) {\n var o = obj;\n var keyArr = isString(path) ? path.split('.') : path;\n keyArr.forEach(function (key, idx) {\n // 不是最后一个\n if (idx < keyArr.length - 1) {\n if (!isObject(o[key])) {\n o[key] = isNumber(keyArr[idx + 1]) ? [] : {};\n }\n\n o = o[key];\n } else {\n o[key] = value;\n }\n });\n return obj;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/set.js\n// module id = 104\n// module chunks = 0","import each from './each';\nimport isPlainObject from './is-plain-object';\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nexport default (function (object, keys) {\n if (object === null || !isPlainObject(object)) {\n return {};\n }\n\n var result = {};\n each(keys, function (key) {\n if (hasOwnProperty.call(object, key)) {\n result[key] = object[key];\n }\n });\n return result;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/pick.js\n// module id = 105\n// module chunks = 0","export default (function (func, wait, options) {\n var timeout, context, args, result;\n var previous = 0;\n if (!options) options = {};\n\n var later = function () {\n previous = options.leading === false ? 0 : Date.now();\n timeout = null;\n result = func.apply(context, args);\n if (!timeout) context = args = null;\n };\n\n var throttled = function () {\n var now = Date.now();\n if (!previous && options.leading === false) previous = now;\n var remaining = wait - (now - previous);\n context = this;\n args = arguments;\n\n if (remaining <= 0 || remaining > wait) {\n if (timeout) {\n clearTimeout(timeout);\n timeout = null;\n }\n\n previous = now;\n result = func.apply(context, args);\n if (!timeout) context = args = null;\n } else if (!timeout && options.trailing !== false) {\n timeout = setTimeout(later, remaining);\n }\n\n return result;\n };\n\n throttled.cancel = function () {\n clearTimeout(timeout);\n previous = 0;\n timeout = context = args = null;\n };\n\n return throttled;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/throttle.js\n// module id = 106\n// module chunks = 0","import isArrayLike from './is-array-like';\nexport default (function (value) {\n return isArrayLike(value) ? Array.prototype.slice.call(value) : [];\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/to-array.js\n// module id = 107\n// module chunks = 0","var map = {};\nexport default (function (prefix) {\n prefix = prefix || 'g';\n\n if (!map[prefix]) {\n map[prefix] = 1;\n } else {\n map[prefix] += 1;\n }\n\n return prefix + map[prefix];\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/unique-id.js\n// module id = 108\n// module chunks = 0","export default (function () {});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/noop.js\n// module id = 109\n// module chunks = 0","export default (function (v) {\n return v;\n});\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/identity.js\n// module id = 110\n// module chunks = 0","import isNil from './is-nil';\nimport isArraylike from './is-array-like';\nexport default function size(o) {\n if (isNil(o)) {\n return 0;\n }\n\n if (isArraylike(o)) {\n return o.length;\n }\n\n return Object.keys(o).length;\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/size.js\n// module id = 111\n// module chunks = 0","/**\n * k-v 存储\n */\nvar default_1 =\n/** @class */\nfunction () {\n function default_1() {\n this.map = {};\n }\n\n default_1.prototype.has = function (key) {\n return this.map[key] !== undefined;\n };\n\n default_1.prototype.get = function (key, def) {\n var v = this.map[key];\n return v === undefined ? def : v;\n };\n\n default_1.prototype.set = function (key, value) {\n this.map[key] = value;\n };\n\n default_1.prototype.clear = function () {\n this.map = {};\n };\n\n default_1.prototype.delete = function (key) {\n delete this.map[key];\n };\n\n default_1.prototype.size = function () {\n return Object.keys(this.map).length;\n };\n\n return default_1;\n}();\n\nexport default default_1;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/_@antv_util@2.0.7@@antv/util/esm/cache.js\n// module id = 112\n// module chunks = 0","// wrap tree node\nfunction WrappedTree(w, h, y, c) {\n if (c === void 0) {\n c = [];\n }\n\n var me = this; // size\n\n me.w = w || 0;\n me.h = h || 0; // position\n\n me.y = y || 0;\n me.x = 0; // children\n\n me.c = c || [];\n me.cs = c.length; // modified\n\n me.prelim = 0;\n me.mod = 0;\n me.shift = 0;\n me.change = 0; // left/right tree\n\n me.tl = null;\n me.tr = null; // extreme left/right tree\n\n me.el = null;\n me.er = null; // modified left/right tree\n\n me.msel = 0;\n me.mser = 0;\n}\n\nWrappedTree.fromNode = function (root, isHorizontal) {\n if (!root) return null;\n var children = [];\n root.children.forEach(function (child) {\n children.push(WrappedTree.fromNode(child, isHorizontal));\n });\n if (isHorizontal) return new WrappedTree(root.height, root.width, root.x, children);\n return new WrappedTree(root.width, root.height, root.y, children);\n}; // node utils\n\n\nfunction moveRight(node, move, isHorizontal) {\n if (isHorizontal) {\n node.y += move;\n } else {\n node.x += move;\n }\n\n node.children.forEach(function (child) {\n moveRight(child, move, isHorizontal);\n });\n}\n\nfunction getMin(node, isHorizontal) {\n var res = isHorizontal ? node.y : node.x;\n node.children.forEach(function (child) {\n res = Math.min(getMin(child, isHorizontal), res);\n });\n return res;\n}\n\nfunction normalize(node, isHorizontal) {\n var min = getMin(node, isHorizontal);\n moveRight(node, -min, isHorizontal);\n}\n\nfunction convertBack(converted\n/* WrappedTree */\n, root\n/* TreeNode */\n, isHorizontal) {\n if (isHorizontal) {\n root.y = converted.x;\n } else {\n root.x = converted.x;\n }\n\n converted.c.forEach(function (child, i) {\n convertBack(child, root.children[i], isHorizontal);\n });\n}\n\nfunction layer(node, isHorizontal, d) {\n if (d === void 0) {\n d = 0;\n }\n\n if (isHorizontal) {\n node.x = d;\n d += node.width;\n } else {\n node.y = d;\n d += node.height;\n }\n\n node.children.forEach(function (child) {\n layer(child, isHorizontal, d);\n });\n}\n\nmodule.exports = function (root, options) {\n if (options === void 0) {\n options = {};\n }\n\n var isHorizontal = options.isHorizontal;\n\n function firstWalk(t) {\n if (t.cs === 0) {\n setExtremes(t);\n return;\n }\n\n firstWalk(t.c[0]);\n var ih = updateIYL(bottom(t.c[0].el), 0, null);\n\n for (var i = 1; i < t.cs; ++i) {\n firstWalk(t.c[i]);\n var min = bottom(t.c[i].er);\n separate(t, i, ih);\n ih = updateIYL(min, i, ih);\n }\n\n positionRoot(t);\n setExtremes(t);\n }\n\n function setExtremes(t) {\n if (t.cs === 0) {\n t.el = t;\n t.er = t;\n t.msel = t.mser = 0;\n } else {\n t.el = t.c[0].el;\n t.msel = t.c[0].msel;\n t.er = t.c[t.cs - 1].er;\n t.mser = t.c[t.cs - 1].mser;\n }\n }\n\n function separate(t, i, ih) {\n var sr = t.c[i - 1];\n var mssr = sr.mod;\n var cl = t.c[i];\n var mscl = cl.mod;\n\n while (sr !== null && cl !== null) {\n if (bottom(sr) > ih.low) ih = ih.nxt;\n var dist = mssr + sr.prelim + sr.w - (mscl + cl.prelim);\n\n if (dist > 0) {\n mscl += dist;\n moveSubtree(t, i, ih.index, dist);\n }\n\n var sy = bottom(sr);\n var cy = bottom(cl);\n\n if (sy <= cy) {\n sr = nextRightContour(sr);\n if (sr !== null) mssr += sr.mod;\n }\n\n if (sy >= cy) {\n cl = nextLeftContour(cl);\n if (cl !== null) mscl += cl.mod;\n }\n }\n\n if (!sr && !!cl) {\n setLeftThread(t, i, cl, mscl);\n } else if (!!sr && !cl) {\n setRightThread(t, i, sr, mssr);\n }\n }\n\n function moveSubtree(t, i, si, dist) {\n t.c[i].mod += dist;\n t.c[i].msel += dist;\n t.c[i].mser += dist;\n distributeExtra(t, i, si, dist);\n }\n\n function nextLeftContour(t) {\n return t.cs === 0 ? t.tl : t.c[0];\n }\n\n function nextRightContour(t) {\n return t.cs === 0 ? t.tr : t.c[t.cs - 1];\n }\n\n function bottom(t) {\n return t.y + t.h;\n }\n\n function setLeftThread(t, i, cl, modsumcl) {\n var li = t.c[0].el;\n li.tl = cl;\n var diff = modsumcl - cl.mod - t.c[0].msel;\n li.mod += diff;\n li.prelim -= diff;\n t.c[0].el = t.c[i].el;\n t.c[0].msel = t.c[i].msel;\n }\n\n function setRightThread(t, i, sr, modsumsr) {\n var ri = t.c[i].er;\n ri.tr = sr;\n var diff = modsumsr - sr.mod - t.c[i].mser;\n ri.mod += diff;\n ri.prelim -= diff;\n t.c[i].er = t.c[i - 1].er;\n t.c[i].mser = t.c[i - 1].mser;\n }\n\n function positionRoot(t) {\n t.prelim = (t.c[0].prelim + t.c[0].mod + t.c[t.cs - 1].mod + t.c[t.cs - 1].prelim + t.c[t.cs - 1].w) / 2 - t.w / 2;\n }\n\n function secondWalk(t, modsum) {\n modsum += t.mod;\n t.x = t.prelim + modsum;\n addChildSpacing(t);\n\n for (var i = 0; i < t.cs; i++) {\n secondWalk(t.c[i], modsum);\n }\n }\n\n function distributeExtra(t, i, si, dist) {\n if (si !== i - 1) {\n var nr = i - si;\n t.c[si + 1].shift += dist / nr;\n t.c[i].shift -= dist / nr;\n t.c[i].change -= dist - dist / nr;\n }\n }\n\n function addChildSpacing(t) {\n var d = 0;\n var modsumdelta = 0;\n\n for (var i = 0; i < t.cs; i++) {\n d += t.c[i].shift;\n modsumdelta += d + t.c[i].change;\n t.c[i].mod += modsumdelta;\n }\n }\n\n function updateIYL(low, index, ih) {\n while (ih !== null && low >= ih.low) {\n ih = ih.nxt;\n }\n\n return {\n low: low,\n index: index,\n nxt: ih\n };\n } // do layout\n\n\n layer(root, isHorizontal);\n var wt = WrappedTree.fromNode(root, isHorizontal);\n firstWalk(wt);\n secondWalk(wt, 0);\n convertBack(wt, root, isHorizontal);\n normalize(root, isHorizontal);\n return root;\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/layout/non-layered-tidy.js\n// module id = 113\n// module chunks = 0","function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar TreeLayout = require('./layout/base');\n\nvar dendrogram = require('./layout/dendrogram');\n\nvar doTreeLayout = require('./layout/do-layout');\n\nvar util = require('./util');\n\nvar DendrogramLayout = /*#__PURE__*/function (_TreeLayout) {\n _inheritsLoose(DendrogramLayout, _TreeLayout);\n\n function DendrogramLayout() {\n return _TreeLayout.apply(this, arguments) || this;\n }\n\n var _proto = DendrogramLayout.prototype;\n\n _proto.execute = function execute() {\n var me = this;\n me.rootNode.width = 0;\n return doTreeLayout(me.rootNode, me.options, dendrogram);\n };\n\n return DendrogramLayout;\n}(TreeLayout);\n\nvar DEFAULT_OPTIONS = {};\n\nfunction dendrogramLayout(root, options) {\n options = util.assign({}, DEFAULT_OPTIONS, options);\n return new DendrogramLayout(root, options).execute();\n}\n\nmodule.exports = dendrogramLayout;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/dendrogram.js\n// module id = 114\n// module chunks = 0","// wrap tree node\n// TODO considering size\nvar util = require('../util');\n\nfunction WrappedTree(height, children) {\n if (height === void 0) {\n height = 0;\n }\n\n if (children === void 0) {\n children = [];\n }\n\n var me = this;\n me.x = me.y = 0;\n me.leftChild = me.rightChild = null;\n me.height = 0;\n me.children = children;\n}\n\nvar DEFAULT_OPTIONS = {\n isHorizontal: true,\n nodeSep: 20,\n nodeSize: 20,\n rankSep: 200,\n subTreeSep: 10\n};\n\nfunction convertBack(converted\n/* WrappedTree */\n, root\n/* TreeNode */\n, isHorizontal) {\n if (isHorizontal) {\n root.x = converted.x;\n root.y = converted.y;\n } else {\n root.x = converted.y;\n root.y = converted.x;\n }\n\n converted.children.forEach(function (child, i) {\n convertBack(child, root.children[i], isHorizontal);\n });\n}\n\nmodule.exports = function (root, options) {\n if (options === void 0) {\n options = {};\n }\n\n options = util.assign({}, DEFAULT_OPTIONS, options);\n var maxDepth = 0;\n\n function wrappedTreeFromNode(n) {\n if (!n) return null;\n n.width = 0;\n\n if (n.depth && n.depth > maxDepth) {\n maxDepth = n.depth; // get the max depth\n }\n\n var children = n.children;\n var childrenCount = children.length;\n var t = new WrappedTree(n.height, []);\n children.forEach(function (child, i) {\n var childWT = wrappedTreeFromNode(child);\n t.children.push(childWT);\n\n if (i === 0) {\n // t.leftChild = childWT.leftChild ? childWT.leftChild : childWT\n t.leftChild = childWT;\n }\n\n if (i === childrenCount - 1) {\n // t.rightChild = childWT.rightChild ? childWT.rightChild : childWT\n t.rightChild = childWT;\n }\n });\n t.originNode = n;\n t.isLeaf = n.isLeaf();\n return t;\n }\n\n function getDrawingDepth(t) {\n if (t.isLeaf || t.children.length === 0) {\n t.drawingDepth = maxDepth;\n } else {\n var depths = t.children.map(function (child) {\n return getDrawingDepth(child);\n });\n var minChildDepth = Math.min.apply(null, depths);\n t.drawingDepth = minChildDepth - 1;\n }\n\n return t.drawingDepth;\n }\n\n var prevLeaf;\n\n function position(t) {\n t.x = t.drawingDepth * options.rankSep;\n\n if (t.isLeaf) {\n t.y = 0;\n\n if (prevLeaf) {\n t.y = prevLeaf.y + prevLeaf.height + options.nodeSep;\n\n if (t.originNode.parent !== prevLeaf.originNode.parent) {\n t.y += options.subTreeSep;\n }\n }\n\n prevLeaf = t;\n } else {\n t.children.forEach(function (child) {\n position(child);\n });\n t.y = (t.leftChild.y + t.rightChild.y) / 2;\n }\n } // wrap node\n\n\n var wt = wrappedTreeFromNode(root); // get depth for drawing\n\n getDrawingDepth(wt); // get position\n\n position(wt); // get x, y\n\n convertBack(wt, root, options.isHorizontal);\n return root;\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/layout/dendrogram.js\n// module id = 115\n// module chunks = 0","function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar TreeLayout = require('./layout/base');\n\nvar indentedTree = require('./layout/indented');\n\nvar separateTree = require('./layout/separate-root');\n\nvar util = require('./util');\n\nvar VALID_DIRECTIONS = ['LR', // left to right\n'RL', // right to left\n'H' // horizontal\n];\nvar DEFAULT_DIRECTION = VALID_DIRECTIONS[0];\n\nvar IndentedLayout = /*#__PURE__*/function (_TreeLayout) {\n _inheritsLoose(IndentedLayout, _TreeLayout);\n\n function IndentedLayout() {\n return _TreeLayout.apply(this, arguments) || this;\n }\n\n var _proto = IndentedLayout.prototype;\n\n _proto.execute = function execute() {\n var me = this;\n var options = me.options;\n var root = me.rootNode;\n options.isHorizontal = true; // default indent 20 and sink first children;\n\n var _options$indent = options.indent,\n indent = _options$indent === void 0 ? 20 : _options$indent,\n _options$dropCap = options.dropCap,\n dropCap = _options$dropCap === void 0 ? true : _options$dropCap;\n var direction = options.direction || DEFAULT_DIRECTION;\n\n if (direction && VALID_DIRECTIONS.indexOf(direction) === -1) {\n throw new TypeError(\"Invalid direction: \" + direction);\n }\n\n if (direction === VALID_DIRECTIONS[0]) {\n // LR\n indentedTree(root, indent, dropCap);\n } else if (direction === VALID_DIRECTIONS[1]) {\n // RL\n indentedTree(root, indent, dropCap);\n root.right2left();\n } else if (direction === VALID_DIRECTIONS[2]) {\n // H\n // separate into left and right trees\n var _separateTree = separateTree(root, options),\n left = _separateTree.left,\n right = _separateTree.right;\n\n indentedTree(left, indent, dropCap);\n left.right2left();\n indentedTree(right, indent, dropCap);\n var bbox = left.getBoundingBox();\n right.translate(bbox.width, 0);\n root.x = right.x - root.width / 2;\n }\n\n return root;\n };\n\n return IndentedLayout;\n}(TreeLayout);\n\nvar DEFAULT_OPTIONS = {};\n\nfunction indentedLayout(root, options) {\n options = util.assign({}, DEFAULT_OPTIONS, options);\n return new IndentedLayout(root, options).execute();\n}\n\nmodule.exports = indentedLayout;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/indented.js\n// module id = 116\n// module chunks = 0","function positionNode(node, previousNode, indent, dropCap) {\n // caculate the node's horizontal offset DX, dx's type might be number or function\n var displacementX = typeof indent === 'function' ? indent(node) : indent * node.depth;\n\n if (!dropCap) {\n try {\n if (node.id === node.parent.children[0].id) {\n node.x += displacementX;\n node.y = previousNode ? previousNode.y : 0;\n return;\n }\n } catch (e) {// skip to normal when a node has no parent\n }\n }\n\n node.x += displacementX;\n node.y = previousNode ? previousNode.y + previousNode.height : 0;\n return;\n}\n\nmodule.exports = function (root, indent, dropCap) {\n var previousNode = null;\n root.eachNode(function (node) {\n positionNode(node, previousNode, indent, dropCap);\n previousNode = node;\n });\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/layout/indented.js\n// module id = 117\n// module chunks = 0","function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar TreeLayout = require('./layout/base');\n\nvar mindmap = require('./layout/mindmap');\n\nvar doTreeLayout = require('./layout/do-layout');\n\nvar util = require('./util');\n\nvar MindmapLayout = /*#__PURE__*/function (_TreeLayout) {\n _inheritsLoose(MindmapLayout, _TreeLayout);\n\n function MindmapLayout() {\n return _TreeLayout.apply(this, arguments) || this;\n }\n\n var _proto = MindmapLayout.prototype;\n\n _proto.execute = function execute() {\n var me = this;\n return doTreeLayout(me.rootNode, me.options, mindmap);\n };\n\n return MindmapLayout;\n}(TreeLayout);\n\nvar DEFAULT_OPTIONS = {};\n\nfunction mindmapLayout(root, options) {\n options = util.assign({}, DEFAULT_OPTIONS, options);\n return new MindmapLayout(root, options).execute();\n}\n\nmodule.exports = mindmapLayout;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/mindmap.js\n// module id = 118\n// module chunks = 0","var util = require('../util');\n\nfunction secondWalk(node, options) {\n var totalHeight = 0;\n\n if (!node.children.length) {\n totalHeight = node.height;\n } else {\n node.children.forEach(function (c) {\n totalHeight += secondWalk(c, options);\n });\n }\n\n node._subTreeSep = options.getSubTreeSep(node.data);\n node.totalHeight = Math.max(node.height, totalHeight) + 2 * node._subTreeSep;\n return node.totalHeight;\n}\n\nfunction thirdWalk(node) {\n var children = node.children;\n var len = children.length;\n\n if (len) {\n children.forEach(function (c) {\n thirdWalk(c);\n });\n var first = children[0];\n var last = children[len - 1];\n var childrenHeight = last.y - first.y + last.height;\n var childrenTotalHeight = 0;\n children.forEach(function (child) {\n childrenTotalHeight += child.totalHeight;\n });\n\n if (childrenHeight > node.height) {\n // 当子节点总高度大于父节点高度\n node.y = first.y + childrenHeight / 2 - node.height / 2;\n } else if (children.length !== 1 || node.height > childrenTotalHeight) {\n // 多于一个子节点或者父节点大于所有子节点的总高度\n var offset = node.y + (node.height - childrenHeight) / 2 - first.y;\n children.forEach(function (c) {\n c.translate(0, offset);\n });\n } else {\n // 只有一个子节点\n node.y = (first.y + first.height / 2 + last.y + last.height / 2) / 2 - node.height / 2;\n }\n }\n}\n\nvar DEFAULT_OPTIONS = {\n getSubTreeSep: function getSubTreeSep() {\n return 0;\n }\n};\n\nmodule.exports = function (root, options) {\n if (options === void 0) {\n options = {};\n }\n\n options = util.assign({}, DEFAULT_OPTIONS, options);\n root.parent = {\n x: 0,\n width: 0,\n height: 0,\n y: 0\n }; // first walk\n\n root.BFTraverse(function (node) {\n node.x = node.parent.x + node.parent.width; // simply get x\n });\n root.parent = null; // second walk\n\n secondWalk(root, options); // assign sub tree totalHeight\n // adjusting\n // separating nodes\n\n root.startY = 0;\n root.y = root.totalHeight / 2 - root.height / 2;\n root.eachNode(function (node) {\n var children = node.children;\n var len = children.length;\n\n if (len) {\n var first = children[0];\n first.startY = node.startY + node._subTreeSep;\n\n if (len === 1) {\n first.y = node.y + node.height / 2 - first.height / 2;\n } else {\n first.y = first.startY + first.totalHeight / 2 - first.height / 2;\n\n for (var i = 1; i < len; i++) {\n var c = children[i];\n c.startY = children[i - 1].startY + children[i - 1].totalHeight;\n c.y = c.startY + c.totalHeight / 2 - c.height / 2;\n }\n }\n }\n }); // third walk\n\n thirdWalk(root);\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/layout/mindmap.js\n// module id = 119\n// module chunks = 0","'use strict';\n\nvar colorString = require('color-string');\nvar convert = require('color-convert');\n\nvar _slice = [].slice;\n\nvar skippedModels = [\n\t// to be honest, I don't really feel like keyword belongs in color convert, but eh.\n\t'keyword',\n\n\t// gray conflicts with some method names, and has its own method defined.\n\t'gray',\n\n\t// shouldn't really be in color-convert either...\n\t'hex'\n];\n\nvar hashedModelKeys = {};\nObject.keys(convert).forEach(function (model) {\n\thashedModelKeys[_slice.call(convert[model].labels).sort().join('')] = model;\n});\n\nvar limiters = {};\n\nfunction Color(obj, model) {\n\tif (!(this instanceof Color)) {\n\t\treturn new Color(obj, model);\n\t}\n\n\tif (model && model in skippedModels) {\n\t\tmodel = null;\n\t}\n\n\tif (model && !(model in convert)) {\n\t\tthrow new Error('Unknown model: ' + model);\n\t}\n\n\tvar i;\n\tvar channels;\n\n\tif (obj == null) { // eslint-disable-line no-eq-null,eqeqeq\n\t\tthis.model = 'rgb';\n\t\tthis.color = [0, 0, 0];\n\t\tthis.valpha = 1;\n\t} else if (obj instanceof Color) {\n\t\tthis.model = obj.model;\n\t\tthis.color = obj.color.slice();\n\t\tthis.valpha = obj.valpha;\n\t} else if (typeof obj === 'string') {\n\t\tvar result = colorString.get(obj);\n\t\tif (result === null) {\n\t\t\tthrow new Error('Unable to parse color from string: ' + obj);\n\t\t}\n\n\t\tthis.model = result.model;\n\t\tchannels = convert[this.model].channels;\n\t\tthis.color = result.value.slice(0, channels);\n\t\tthis.valpha = typeof result.value[channels] === 'number' ? result.value[channels] : 1;\n\t} else if (obj.length) {\n\t\tthis.model = model || 'rgb';\n\t\tchannels = convert[this.model].channels;\n\t\tvar newArr = _slice.call(obj, 0, channels);\n\t\tthis.color = zeroArray(newArr, channels);\n\t\tthis.valpha = typeof obj[channels] === 'number' ? obj[channels] : 1;\n\t} else if (typeof obj === 'number') {\n\t\t// this is always RGB - can be converted later on.\n\t\tobj &= 0xFFFFFF;\n\t\tthis.model = 'rgb';\n\t\tthis.color = [\n\t\t\t(obj >> 16) & 0xFF,\n\t\t\t(obj >> 8) & 0xFF,\n\t\t\tobj & 0xFF\n\t\t];\n\t\tthis.valpha = 1;\n\t} else {\n\t\tthis.valpha = 1;\n\n\t\tvar keys = Object.keys(obj);\n\t\tif ('alpha' in obj) {\n\t\t\tkeys.splice(keys.indexOf('alpha'), 1);\n\t\t\tthis.valpha = typeof obj.alpha === 'number' ? obj.alpha : 0;\n\t\t}\n\n\t\tvar hashedKeys = keys.sort().join('');\n\t\tif (!(hashedKeys in hashedModelKeys)) {\n\t\t\tthrow new Error('Unable to parse color from object: ' + JSON.stringify(obj));\n\t\t}\n\n\t\tthis.model = hashedModelKeys[hashedKeys];\n\n\t\tvar labels = convert[this.model].labels;\n\t\tvar color = [];\n\t\tfor (i = 0; i < labels.length; i++) {\n\t\t\tcolor.push(obj[labels[i]]);\n\t\t}\n\n\t\tthis.color = zeroArray(color);\n\t}\n\n\t// perform limitations (clamping, etc.)\n\tif (limiters[this.model]) {\n\t\tchannels = convert[this.model].channels;\n\t\tfor (i = 0; i < channels; i++) {\n\t\t\tvar limit = limiters[this.model][i];\n\t\t\tif (limit) {\n\t\t\t\tthis.color[i] = limit(this.color[i]);\n\t\t\t}\n\t\t}\n\t}\n\n\tthis.valpha = Math.max(0, Math.min(1, this.valpha));\n\n\tif (Object.freeze) {\n\t\tObject.freeze(this);\n\t}\n}\n\nColor.prototype = {\n\ttoString: function () {\n\t\treturn this.string();\n\t},\n\n\ttoJSON: function () {\n\t\treturn this[this.model]();\n\t},\n\n\tstring: function (places) {\n\t\tvar self = this.model in colorString.to ? this : this.rgb();\n\t\tself = self.round(typeof places === 'number' ? places : 1);\n\t\tvar args = self.valpha === 1 ? self.color : self.color.concat(this.valpha);\n\t\treturn colorString.to[self.model](args);\n\t},\n\n\tpercentString: function (places) {\n\t\tvar self = this.rgb().round(typeof places === 'number' ? places : 1);\n\t\tvar args = self.valpha === 1 ? self.color : self.color.concat(this.valpha);\n\t\treturn colorString.to.rgb.percent(args);\n\t},\n\n\tarray: function () {\n\t\treturn this.valpha === 1 ? this.color.slice() : this.color.concat(this.valpha);\n\t},\n\n\tobject: function () {\n\t\tvar result = {};\n\t\tvar channels = convert[this.model].channels;\n\t\tvar labels = convert[this.model].labels;\n\n\t\tfor (var i = 0; i < channels; i++) {\n\t\t\tresult[labels[i]] = this.color[i];\n\t\t}\n\n\t\tif (this.valpha !== 1) {\n\t\t\tresult.alpha = this.valpha;\n\t\t}\n\n\t\treturn result;\n\t},\n\n\tunitArray: function () {\n\t\tvar rgb = this.rgb().color;\n\t\trgb[0] /= 255;\n\t\trgb[1] /= 255;\n\t\trgb[2] /= 255;\n\n\t\tif (this.valpha !== 1) {\n\t\t\trgb.push(this.valpha);\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tunitObject: function () {\n\t\tvar rgb = this.rgb().object();\n\t\trgb.r /= 255;\n\t\trgb.g /= 255;\n\t\trgb.b /= 255;\n\n\t\tif (this.valpha !== 1) {\n\t\t\trgb.alpha = this.valpha;\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tround: function (places) {\n\t\tplaces = Math.max(places || 0, 0);\n\t\treturn new Color(this.color.map(roundToPlace(places)).concat(this.valpha), this.model);\n\t},\n\n\talpha: function (val) {\n\t\tif (arguments.length) {\n\t\t\treturn new Color(this.color.concat(Math.max(0, Math.min(1, val))), this.model);\n\t\t}\n\n\t\treturn this.valpha;\n\t},\n\n\t// rgb\n\tred: getset('rgb', 0, maxfn(255)),\n\tgreen: getset('rgb', 1, maxfn(255)),\n\tblue: getset('rgb', 2, maxfn(255)),\n\n\thue: getset(['hsl', 'hsv', 'hsl', 'hwb', 'hcg'], 0, function (val) { return ((val % 360) + 360) % 360; }), // eslint-disable-line brace-style\n\n\tsaturationl: getset('hsl', 1, maxfn(100)),\n\tlightness: getset('hsl', 2, maxfn(100)),\n\n\tsaturationv: getset('hsv', 1, maxfn(100)),\n\tvalue: getset('hsv', 2, maxfn(100)),\n\n\tchroma: getset('hcg', 1, maxfn(100)),\n\tgray: getset('hcg', 2, maxfn(100)),\n\n\twhite: getset('hwb', 1, maxfn(100)),\n\twblack: getset('hwb', 2, maxfn(100)),\n\n\tcyan: getset('cmyk', 0, maxfn(100)),\n\tmagenta: getset('cmyk', 1, maxfn(100)),\n\tyellow: getset('cmyk', 2, maxfn(100)),\n\tblack: getset('cmyk', 3, maxfn(100)),\n\n\tx: getset('xyz', 0, maxfn(100)),\n\ty: getset('xyz', 1, maxfn(100)),\n\tz: getset('xyz', 2, maxfn(100)),\n\n\tl: getset('lab', 0, maxfn(100)),\n\ta: getset('lab', 1),\n\tb: getset('lab', 2),\n\n\tkeyword: function (val) {\n\t\tif (arguments.length) {\n\t\t\treturn new Color(val);\n\t\t}\n\n\t\treturn convert[this.model].keyword(this.color);\n\t},\n\n\thex: function (val) {\n\t\tif (arguments.length) {\n\t\t\treturn new Color(val);\n\t\t}\n\n\t\treturn colorString.to.hex(this.rgb().round().color);\n\t},\n\n\trgbNumber: function () {\n\t\tvar rgb = this.rgb().color;\n\t\treturn ((rgb[0] & 0xFF) << 16) | ((rgb[1] & 0xFF) << 8) | (rgb[2] & 0xFF);\n\t},\n\n\tluminosity: function () {\n\t\t// http://www.w3.org/TR/WCAG20/#relativeluminancedef\n\t\tvar rgb = this.rgb().color;\n\n\t\tvar lum = [];\n\t\tfor (var i = 0; i < rgb.length; i++) {\n\t\t\tvar chan = rgb[i] / 255;\n\t\t\tlum[i] = (chan <= 0.03928) ? chan / 12.92 : Math.pow(((chan + 0.055) / 1.055), 2.4);\n\t\t}\n\n\t\treturn 0.2126 * lum[0] + 0.7152 * lum[1] + 0.0722 * lum[2];\n\t},\n\n\tcontrast: function (color2) {\n\t\t// http://www.w3.org/TR/WCAG20/#contrast-ratiodef\n\t\tvar lum1 = this.luminosity();\n\t\tvar lum2 = color2.luminosity();\n\n\t\tif (lum1 > lum2) {\n\t\t\treturn (lum1 + 0.05) / (lum2 + 0.05);\n\t\t}\n\n\t\treturn (lum2 + 0.05) / (lum1 + 0.05);\n\t},\n\n\tlevel: function (color2) {\n\t\tvar contrastRatio = this.contrast(color2);\n\t\tif (contrastRatio >= 7.1) {\n\t\t\treturn 'AAA';\n\t\t}\n\n\t\treturn (contrastRatio >= 4.5) ? 'AA' : '';\n\t},\n\n\tisDark: function () {\n\t\t// YIQ equation from http://24ways.org/2010/calculating-color-contrast\n\t\tvar rgb = this.rgb().color;\n\t\tvar yiq = (rgb[0] * 299 + rgb[1] * 587 + rgb[2] * 114) / 1000;\n\t\treturn yiq < 128;\n\t},\n\n\tisLight: function () {\n\t\treturn !this.isDark();\n\t},\n\n\tnegate: function () {\n\t\tvar rgb = this.rgb();\n\t\tfor (var i = 0; i < 3; i++) {\n\t\t\trgb.color[i] = 255 - rgb.color[i];\n\t\t}\n\t\treturn rgb;\n\t},\n\n\tlighten: function (ratio) {\n\t\tvar hsl = this.hsl();\n\t\thsl.color[2] += hsl.color[2] * ratio;\n\t\treturn hsl;\n\t},\n\n\tdarken: function (ratio) {\n\t\tvar hsl = this.hsl();\n\t\thsl.color[2] -= hsl.color[2] * ratio;\n\t\treturn hsl;\n\t},\n\n\tsaturate: function (ratio) {\n\t\tvar hsl = this.hsl();\n\t\thsl.color[1] += hsl.color[1] * ratio;\n\t\treturn hsl;\n\t},\n\n\tdesaturate: function (ratio) {\n\t\tvar hsl = this.hsl();\n\t\thsl.color[1] -= hsl.color[1] * ratio;\n\t\treturn hsl;\n\t},\n\n\twhiten: function (ratio) {\n\t\tvar hwb = this.hwb();\n\t\thwb.color[1] += hwb.color[1] * ratio;\n\t\treturn hwb;\n\t},\n\n\tblacken: function (ratio) {\n\t\tvar hwb = this.hwb();\n\t\thwb.color[2] += hwb.color[2] * ratio;\n\t\treturn hwb;\n\t},\n\n\tgrayscale: function () {\n\t\t// http://en.wikipedia.org/wiki/Grayscale#Converting_color_to_grayscale\n\t\tvar rgb = this.rgb().color;\n\t\tvar val = rgb[0] * 0.3 + rgb[1] * 0.59 + rgb[2] * 0.11;\n\t\treturn Color.rgb(val, val, val);\n\t},\n\n\tfade: function (ratio) {\n\t\treturn this.alpha(this.valpha - (this.valpha * ratio));\n\t},\n\n\topaquer: function (ratio) {\n\t\treturn this.alpha(this.valpha + (this.valpha * ratio));\n\t},\n\n\trotate: function (degrees) {\n\t\tvar hsl = this.hsl();\n\t\tvar hue = hsl.color[0];\n\t\thue = (hue + degrees) % 360;\n\t\thue = hue < 0 ? 360 + hue : hue;\n\t\thsl.color[0] = hue;\n\t\treturn hsl;\n\t},\n\n\tmix: function (mixinColor, weight) {\n\t\t// ported from sass implementation in C\n\t\t// https://github.com/sass/libsass/blob/0e6b4a2850092356aa3ece07c6b249f0221caced/functions.cpp#L209\n\t\tif (!mixinColor || !mixinColor.rgb) {\n\t\t\tthrow new Error('Argument to \"mix\" was not a Color instance, but rather an instance of ' + typeof mixinColor);\n\t\t}\n\t\tvar color1 = mixinColor.rgb();\n\t\tvar color2 = this.rgb();\n\t\tvar p = weight === undefined ? 0.5 : weight;\n\n\t\tvar w = 2 * p - 1;\n\t\tvar a = color1.alpha() - color2.alpha();\n\n\t\tvar w1 = (((w * a === -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n\t\tvar w2 = 1 - w1;\n\n\t\treturn Color.rgb(\n\t\t\t\tw1 * color1.red() + w2 * color2.red(),\n\t\t\t\tw1 * color1.green() + w2 * color2.green(),\n\t\t\t\tw1 * color1.blue() + w2 * color2.blue(),\n\t\t\t\tcolor1.alpha() * p + color2.alpha() * (1 - p));\n\t}\n};\n\n// model conversion methods and static constructors\nObject.keys(convert).forEach(function (model) {\n\tif (skippedModels.indexOf(model) !== -1) {\n\t\treturn;\n\t}\n\n\tvar channels = convert[model].channels;\n\n\t// conversion methods\n\tColor.prototype[model] = function () {\n\t\tif (this.model === model) {\n\t\t\treturn new Color(this);\n\t\t}\n\n\t\tif (arguments.length) {\n\t\t\treturn new Color(arguments, model);\n\t\t}\n\n\t\tvar newAlpha = typeof arguments[channels] === 'number' ? channels : this.valpha;\n\t\treturn new Color(assertArray(convert[this.model][model].raw(this.color)).concat(newAlpha), model);\n\t};\n\n\t// 'static' construction methods\n\tColor[model] = function (color) {\n\t\tif (typeof color === 'number') {\n\t\t\tcolor = zeroArray(_slice.call(arguments), channels);\n\t\t}\n\t\treturn new Color(color, model);\n\t};\n});\n\nfunction roundTo(num, places) {\n\treturn Number(num.toFixed(places));\n}\n\nfunction roundToPlace(places) {\n\treturn function (num) {\n\t\treturn roundTo(num, places);\n\t};\n}\n\nfunction getset(model, channel, modifier) {\n\tmodel = Array.isArray(model) ? model : [model];\n\n\tmodel.forEach(function (m) {\n\t\t(limiters[m] || (limiters[m] = []))[channel] = modifier;\n\t});\n\n\tmodel = model[0];\n\n\treturn function (val) {\n\t\tvar result;\n\n\t\tif (arguments.length) {\n\t\t\tif (modifier) {\n\t\t\t\tval = modifier(val);\n\t\t\t}\n\n\t\t\tresult = this[model]();\n\t\t\tresult.color[channel] = val;\n\t\t\treturn result;\n\t\t}\n\n\t\tresult = this[model]().color[channel];\n\t\tif (modifier) {\n\t\t\tresult = modifier(result);\n\t\t}\n\n\t\treturn result;\n\t};\n}\n\nfunction maxfn(max) {\n\treturn function (v) {\n\t\treturn Math.max(0, Math.min(max, v));\n\t};\n}\n\nfunction assertArray(val) {\n\treturn Array.isArray(val) ? val : [val];\n}\n\nfunction zeroArray(arr, length) {\n\tfor (var i = 0; i < length; i++) {\n\t\tif (typeof arr[i] !== 'number') {\n\t\t\tarr[i] = 0;\n\t\t}\n\t}\n\n\treturn arr;\n}\n\nmodule.exports = Color;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n","var assignValue = require('./_assignValue'),\n baseAssignValue = require('./_baseAssignValue');\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n var isNew = !object;\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n if (newValue === undefined) {\n newValue = source[key];\n }\n if (isNew) {\n baseAssignValue(object, key, newValue);\n } else {\n assignValue(object, key, newValue);\n }\n }\n return object;\n}\n\nmodule.exports = copyObject;\n","var baseIsArguments = require('./_baseIsArguments'),\n isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\n","module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\tmodule.deprecate = function() {};\n\t\tmodule.paths = [];\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n","var isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.circularDependencyToException = exports.listMetadataForTarget = exports.listRegisteredBindingsForServiceIdentifier = exports.getServiceIdentifierAsString = exports.getFunctionName = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nfunction getServiceIdentifierAsString(serviceIdentifier) {\n if (typeof serviceIdentifier === \"function\") {\n var _serviceIdentifier = serviceIdentifier;\n return _serviceIdentifier.name;\n }\n else if (typeof serviceIdentifier === \"symbol\") {\n return serviceIdentifier.toString();\n }\n else {\n var _serviceIdentifier = serviceIdentifier;\n return _serviceIdentifier;\n }\n}\nexports.getServiceIdentifierAsString = getServiceIdentifierAsString;\nfunction listRegisteredBindingsForServiceIdentifier(container, serviceIdentifier, getBindings) {\n var registeredBindingsList = \"\";\n var registeredBindings = getBindings(container, serviceIdentifier);\n if (registeredBindings.length !== 0) {\n registeredBindingsList = \"\\nRegistered bindings:\";\n registeredBindings.forEach(function (binding) {\n var name = \"Object\";\n if (binding.implementationType !== null) {\n name = getFunctionName(binding.implementationType);\n }\n registeredBindingsList = registeredBindingsList + \"\\n \" + name;\n if (binding.constraint.metaData) {\n registeredBindingsList = registeredBindingsList + \" - \" + binding.constraint.metaData;\n }\n });\n }\n return registeredBindingsList;\n}\nexports.listRegisteredBindingsForServiceIdentifier = listRegisteredBindingsForServiceIdentifier;\nfunction alreadyDependencyChain(request, serviceIdentifier) {\n if (request.parentRequest === null) {\n return false;\n }\n else if (request.parentRequest.serviceIdentifier === serviceIdentifier) {\n return true;\n }\n else {\n return alreadyDependencyChain(request.parentRequest, serviceIdentifier);\n }\n}\nfunction dependencyChainToString(request) {\n function _createStringArr(req, result) {\n if (result === void 0) { result = []; }\n var serviceIdentifier = getServiceIdentifierAsString(req.serviceIdentifier);\n result.push(serviceIdentifier);\n if (req.parentRequest !== null) {\n return _createStringArr(req.parentRequest, result);\n }\n return result;\n }\n var stringArr = _createStringArr(request);\n return stringArr.reverse().join(\" --> \");\n}\nfunction circularDependencyToException(request) {\n request.childRequests.forEach(function (childRequest) {\n if (alreadyDependencyChain(childRequest, childRequest.serviceIdentifier)) {\n var services = dependencyChainToString(childRequest);\n throw new Error(ERROR_MSGS.CIRCULAR_DEPENDENCY + \" \" + services);\n }\n else {\n circularDependencyToException(childRequest);\n }\n });\n}\nexports.circularDependencyToException = circularDependencyToException;\nfunction listMetadataForTarget(serviceIdentifierString, target) {\n if (target.isTagged() || target.isNamed()) {\n var m_1 = \"\";\n var namedTag = target.getNamedTag();\n var otherTags = target.getCustomTags();\n if (namedTag !== null) {\n m_1 += namedTag.toString() + \"\\n\";\n }\n if (otherTags !== null) {\n otherTags.forEach(function (tag) {\n m_1 += tag.toString() + \"\\n\";\n });\n }\n return \" \" + serviceIdentifierString + \"\\n \" + serviceIdentifierString + \" - \" + m_1;\n }\n else {\n return \" \" + serviceIdentifierString;\n }\n}\nexports.listMetadataForTarget = listMetadataForTarget;\nfunction getFunctionName(v) {\n if (v.name) {\n return v.name;\n }\n else {\n var name_1 = v.toString();\n var match = name_1.match(/^function\\s*([^\\s(]+)/);\n return match ? match[1] : \"Anonymous function: \" + name_1;\n }\n}\nexports.getFunctionName = getFunctionName;\n//# sourceMappingURL=serialization.js.map","import { inject, injectable } from 'inversify';\nimport { IFramebuffer } from '../..';\nimport { IDENTIFIER } from '../../identifier';\nimport { gl } from '../renderer/gl';\nimport { IRendererService } from '../renderer/IRendererService';\nimport { ResourceEntry } from './ResourceEntry';\n\n@injectable()\nexport class ResourcePool {\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n // 资源池\n private resourcePool: Record<string, IFramebuffer> = {};\n\n /**\n * 负责实例化虚拟资源,通过引擎服务\n * @param resource 虚拟资源\n */\n public getOrCreateResource(resource: ResourceEntry): IFramebuffer {\n if (!this.resourcePool[resource.name]) {\n const { width, height, usage } = resource.descriptor;\n this.resourcePool[resource.name] = this.engine.createFramebuffer({\n color: this.engine.createTexture2D({\n width,\n height,\n wrapS: gl.CLAMP_TO_EDGE,\n wrapT: gl.CLAMP_TO_EDGE,\n usage,\n }),\n });\n }\n\n return this.resourcePool[resource.name];\n }\n\n public clean() {\n this.resourcePool = {};\n }\n}\n","import { Component } from '../../ComponentManager';\nimport { NonFunctionProperties } from '../../ComponentManager';\n\nexport class NameComponent extends Component<NameComponent> {\n public name: string;\n\n constructor(data: Partial<NonFunctionProperties<NameComponent>>) {\n super(data);\n this.name = data.name || '';\n }\n}\n","/**\n * Root Container\n * @see /dev-docs/IoC 容器、依赖注入与服务说明.md\n */\nimport 'reflect-metadata';\n\nimport { EventEmitter } from 'eventemitter3';\nimport {\n Container,\n ContainerModule,\n decorate,\n injectable,\n interfaces,\n} from 'inversify';\nimport getDecorators from 'inversify-inject-decorators';\nimport { ISystem } from '.';\nimport { ComponentManager } from './ComponentManager';\nimport { ResourcePool } from './components/framegraph/ResourcePool';\nimport { FrameGraphSystem } from './components/framegraph/System';\nimport { GeometryComponent } from './components/geometry/GeometryComponent';\nimport { GeometrySystem } from './components/geometry/System';\n// import { InteractionSystem } from './components/interaction/System';\nimport { MaterialComponent } from './components/material/MaterialComponent';\nimport { MaterialSystem } from './components/material/System';\nimport { CullableComponent } from './components/mesh/CullableComponent';\nimport { MeshComponent } from './components/mesh/MeshComponent';\nimport { MeshSystem } from './components/mesh/System';\nimport { CopyPass } from './components/renderer/passes/CopyPass';\nimport { IRenderPass } from './components/renderer/passes/IRenderPass';\nimport { PixelPickingPass } from './components/renderer/passes/PixelPickingPass';\nimport { RenderPass } from './components/renderer/passes/RenderPass';\nimport { RendererSystem } from './components/renderer/System';\nimport { HierarchyComponent } from './components/scenegraph/HierarchyComponent';\nimport { NameComponent } from './components/scenegraph/NameComponent';\nimport { SceneGraphSystem } from './components/scenegraph/System';\nimport { TransformComponent } from './components/scenegraph/TransformComponent';\nimport { IDENTIFIER } from './identifier';\nimport { ConfigService } from './services/config/ConfigService';\nimport { InteractorService } from './services/interactor/IteractorService';\nimport ShaderModuleService from './services/shader-module/ShaderModuleService';\n\n// @see https://github.com/inversify/InversifyJS/blob/master/wiki/container_api.md#defaultscope\nexport const container = new Container();\n\n// @see https://github.com/inversify/InversifyJS/blob/master/wiki/inheritance.md#what-can-i-do-when-my-base-class-is-provided-by-a-third-party-module\n// decorate(injectable(), EventEmitter);\n// container.bind(IDENTIFIER.IEventEmitter).to(EventEmitter);\n// 支持使用 new 而非容器实例化的场景,同时禁止 lazyInject cache\n// @see https://github.com/inversify/inversify-inject-decorators#caching-vs-non-caching-behaviour\nconst DECORATORS = getDecorators(container, false);\n\ninterface IBabelPropertyDescriptor extends PropertyDescriptor {\n initializer(): any;\n}\n// Add babel legacy decorators support\n// @see https://github.com/inversify/InversifyJS/issues/1050\n// @see https://github.com/inversify/InversifyJS/issues/1026#issuecomment-504936034\nexport const lazyInject = (\n serviceIdentifier: interfaces.ServiceIdentifier<any>,\n) => {\n const original = DECORATORS.lazyInject(serviceIdentifier);\n // the 'descriptor' parameter is actually always defined for class fields for Babel, but is considered undefined for TSC\n // so we just hack it with ?/! combination to avoid \"TS1240: Unable to resolve signature of property decorator when called as an expression\"\n return function(\n this: any,\n proto: any,\n key: string,\n descriptor?: IBabelPropertyDescriptor,\n ): void {\n // make it work as usual\n original.call(this, proto, key);\n // return link to proto, so own value wont be 'undefined' after component's creation\n if (descriptor) {\n descriptor.initializer = () => {\n return proto[key];\n };\n }\n };\n};\n\nexport const lazyMultiInject = (\n serviceIdentifier: interfaces.ServiceIdentifier<any>,\n) => {\n const original = DECORATORS.lazyMultiInject(serviceIdentifier);\n // the 'descriptor' parameter is actually always defined for class fields for Babel, but is considered undefined for TSC\n // so we just hack it with ?/! combination to avoid \"TS1240: Unable to resolve signature of property decorator when called as an expression\"\n return function(\n this: any,\n proto: any,\n key: string,\n descriptor?: IBabelPropertyDescriptor,\n ): void {\n // make it work as usual\n original.call(this, proto, key);\n if (descriptor) {\n // return link to proto, so own value wont be 'undefined' after component's creation\n descriptor!.initializer = () => {\n return proto[key];\n };\n }\n };\n};\n\n/** global services */\ncontainer\n .bind(IDENTIFIER.ShaderModuleService)\n .to(ShaderModuleService)\n .inSingletonScope();\n\n/**\n * bind global component managers in root container\n */\ncontainer\n .bind<ComponentManager<NameComponent>>(IDENTIFIER.NameComponentManager)\n .toConstantValue(new ComponentManager(NameComponent));\ncontainer\n .bind<ComponentManager<HierarchyComponent>>(\n IDENTIFIER.HierarchyComponentManager,\n )\n .toConstantValue(new ComponentManager(HierarchyComponent));\ncontainer\n .bind<ComponentManager<TransformComponent>>(\n IDENTIFIER.TransformComponentManager,\n )\n .toConstantValue(new ComponentManager(TransformComponent));\ncontainer\n .bind<ComponentManager<MeshComponent>>(IDENTIFIER.MeshComponentManager)\n .toConstantValue(new ComponentManager(MeshComponent));\ncontainer\n .bind<ComponentManager<CullableComponent>>(\n IDENTIFIER.CullableComponentManager,\n )\n .toConstantValue(new ComponentManager(CullableComponent));\ncontainer\n .bind<ComponentManager<GeometryComponent>>(\n IDENTIFIER.GeometryComponentManager,\n )\n .toConstantValue(new ComponentManager(GeometryComponent));\ncontainer\n .bind<ComponentManager<MaterialComponent>>(\n IDENTIFIER.MaterialComponentManager,\n )\n .toConstantValue(new ComponentManager(MaterialComponent));\n\n// https://github.com/inversify/InversifyJS/blob/master/wiki/hierarchical_di.md#support-for-hierarchical-di-systems\nexport function createWorldContainer() {\n const worldContainer = new Container();\n worldContainer.parent = container;\n\n /**\n * bind systems\n */\n worldContainer\n .bind<ISystem>(IDENTIFIER.Systems)\n .to(SceneGraphSystem)\n .inSingletonScope()\n .whenTargetNamed(IDENTIFIER.SceneGraphSystem);\n\n worldContainer\n .bind<ISystem>(IDENTIFIER.Systems)\n .to(FrameGraphSystem)\n .inSingletonScope()\n .whenTargetNamed(IDENTIFIER.FrameGraphSystem);\n\n worldContainer\n .bind<ISystem>(IDENTIFIER.Systems)\n .to(MeshSystem)\n .inSingletonScope()\n .whenTargetNamed(IDENTIFIER.MeshSystem);\n\n worldContainer\n .bind<ISystem>(IDENTIFIER.Systems)\n .to(GeometrySystem)\n .inSingletonScope()\n .whenTargetNamed(IDENTIFIER.GeometrySystem);\n\n worldContainer\n .bind<ISystem>(IDENTIFIER.Systems)\n .to(MaterialSystem)\n .inSingletonScope()\n .whenTargetNamed(IDENTIFIER.MaterialSystem);\n\n worldContainer\n .bind<ISystem>(IDENTIFIER.Systems)\n .to(RendererSystem)\n .inSingletonScope()\n .whenTargetNamed(IDENTIFIER.RendererSystem);\n\n // 资源池\n worldContainer\n .bind(IDENTIFIER.ResourcePool)\n .to(ResourcePool)\n .inSingletonScope();\n worldContainer\n .bind(IDENTIFIER.ConfigService)\n .to(ConfigService)\n .inSingletonScope();\n worldContainer\n .bind(IDENTIFIER.InteractorService)\n .to(InteractorService)\n .inSingletonScope();\n\n /**\n * bind render passes\n */\n worldContainer\n .bind<IRenderPass<any>>(IDENTIFIER.RenderPass)\n .to(RenderPass)\n .inSingletonScope()\n .whenTargetNamed(RenderPass.IDENTIFIER);\n worldContainer\n .bind<IRenderPass<any>>(IDENTIFIER.RenderPass)\n .to(CopyPass)\n .inSingletonScope()\n .whenTargetNamed(CopyPass.IDENTIFIER);\n worldContainer\n .bind<IRenderPass<any>>(IDENTIFIER.RenderPass)\n .to(PixelPickingPass)\n .inSingletonScope()\n .whenTargetNamed(PixelPickingPass.IDENTIFIER);\n\n worldContainer\n .bind<interfaces.Factory<IRenderPass<any>>>(IDENTIFIER.RenderPassFactory)\n .toFactory<IRenderPass<any>>((context: interfaces.Context) => {\n return (name: string) => {\n return context.container.getNamed(IDENTIFIER.RenderPass, name);\n };\n });\n\n return worldContainer;\n}\n","import { mod, toRadian, isSamePoint } from './util';\n// 向量长度\nfunction vMag(v) {\n return Math.sqrt(v[0] * v[0] + v[1] * v[1]);\n}\n// u.v/|u||v|,计算夹角的余弦值\nfunction vRatio(u, v) {\n // 当存在一个向量的长度为 0 时,夹角也为 0,即夹角的余弦值为 1\n return vMag(u) * vMag(v) ? (u[0] * v[0] + u[1] * v[1]) / (vMag(u) * vMag(v)) : 1;\n}\n// 向量角度\nfunction vAngle(u, v) {\n return (u[0] * v[1] < u[1] * v[0] ? -1 : 1) * Math.acos(vRatio(u, v));\n}\n// A 0:rx 1:ry 2:x-axis-rotation 3:large-arc-flag 4:sweep-flag 5: x 6: y\nexport default function getArcParams(startPoint, params) {\n var rx = params[1];\n var ry = params[2];\n var xRotation = mod(toRadian(params[3]), Math.PI * 2);\n var arcFlag = params[4];\n var sweepFlag = params[5];\n // 弧形起点坐标\n var x1 = startPoint[0];\n var y1 = startPoint[1];\n // 弧形终点坐标\n var x2 = params[6];\n var y2 = params[7];\n var xp = (Math.cos(xRotation) * (x1 - x2)) / 2.0 + (Math.sin(xRotation) * (y1 - y2)) / 2.0;\n var yp = (-1 * Math.sin(xRotation) * (x1 - x2)) / 2.0 + (Math.cos(xRotation) * (y1 - y2)) / 2.0;\n var lambda = (xp * xp) / (rx * rx) + (yp * yp) / (ry * ry);\n if (lambda > 1) {\n rx *= Math.sqrt(lambda);\n ry *= Math.sqrt(lambda);\n }\n var diff = rx * rx * (yp * yp) + ry * ry * (xp * xp);\n var f = diff ? Math.sqrt((rx * rx * (ry * ry) - diff) / diff) : 1;\n if (arcFlag === sweepFlag) {\n f *= -1;\n }\n if (isNaN(f)) {\n f = 0;\n }\n // 旋转前的起点坐标,且当长半轴和短半轴的长度为 0 时,坐标按 (0, 0) 处理\n var cxp = ry ? (f * rx * yp) / ry : 0;\n var cyp = rx ? (f * -ry * xp) / rx : 0;\n // 椭圆圆心坐标\n var cx = (x1 + x2) / 2.0 + Math.cos(xRotation) * cxp - Math.sin(xRotation) * cyp;\n var cy = (y1 + y2) / 2.0 + Math.sin(xRotation) * cxp + Math.cos(xRotation) * cyp;\n // 起始点的单位向量\n var u = [(xp - cxp) / rx, (yp - cyp) / ry];\n // 终止点的单位向量\n var v = [(-1 * xp - cxp) / rx, (-1 * yp - cyp) / ry];\n // 计算起始点和圆心的连线,与 x 轴正方向的夹角\n var theta = vAngle([1, 0], u);\n // 计算圆弧起始点和终止点与椭圆圆心连线的夹角\n var dTheta = vAngle(u, v);\n if (vRatio(u, v) <= -1) {\n dTheta = Math.PI;\n }\n if (vRatio(u, v) >= 1) {\n dTheta = 0;\n }\n if (sweepFlag === 0 && dTheta > 0) {\n dTheta = dTheta - 2 * Math.PI;\n }\n if (sweepFlag === 1 && dTheta < 0) {\n dTheta = dTheta + 2 * Math.PI;\n }\n return {\n cx: cx,\n cy: cy,\n // 弧形的起点和终点相同时,长轴和短轴的长度按 0 处理\n rx: isSamePoint(startPoint, [x2, y2]) ? 0 : rx,\n ry: isSamePoint(startPoint, [x2, y2]) ? 0 : ry,\n startAngle: theta,\n endAngle: theta + dTheta,\n xRotation: xRotation,\n arcFlag: arcFlag,\n sweepFlag: sweepFlag,\n };\n}\n//# sourceMappingURL=arc-params.js.map","// TinyColor v1.4.2\n// https://github.com/bgrins/TinyColor\n// Brian Grinstead, MIT License\n\n(function(Math) {\n\nvar trimLeft = /^\\s+/,\n trimRight = /\\s+$/,\n tinyCounter = 0,\n mathRound = Math.round,\n mathMin = Math.min,\n mathMax = Math.max,\n mathRandom = Math.random;\n\nfunction tinycolor (color, opts) {\n\n color = (color) ? color : '';\n opts = opts || { };\n\n // If input is already a tinycolor, return itself\n if (color instanceof tinycolor) {\n return color;\n }\n // If we are called as a function, call using new instead\n if (!(this instanceof tinycolor)) {\n return new tinycolor(color, opts);\n }\n\n var rgb = inputToRGB(color);\n this._originalInput = color,\n this._r = rgb.r,\n this._g = rgb.g,\n this._b = rgb.b,\n this._a = rgb.a,\n this._roundA = mathRound(100*this._a) / 100,\n this._format = opts.format || rgb.format;\n this._gradientType = opts.gradientType;\n\n // Don't let the range of [0,255] come back in [0,1].\n // Potentially lose a little bit of precision here, but will fix issues where\n // .5 gets interpreted as half of the total, instead of half of 1\n // If it was supposed to be 128, this was already taken care of by `inputToRgb`\n if (this._r < 1) { this._r = mathRound(this._r); }\n if (this._g < 1) { this._g = mathRound(this._g); }\n if (this._b < 1) { this._b = mathRound(this._b); }\n\n this._ok = rgb.ok;\n this._tc_id = tinyCounter++;\n}\n\ntinycolor.prototype = {\n isDark: function() {\n return this.getBrightness() < 128;\n },\n isLight: function() {\n return !this.isDark();\n },\n isValid: function() {\n return this._ok;\n },\n getOriginalInput: function() {\n return this._originalInput;\n },\n getFormat: function() {\n return this._format;\n },\n getAlpha: function() {\n return this._a;\n },\n getBrightness: function() {\n //http://www.w3.org/TR/AERT#color-contrast\n var rgb = this.toRgb();\n return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000;\n },\n getLuminance: function() {\n //http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n var rgb = this.toRgb();\n var RsRGB, GsRGB, BsRGB, R, G, B;\n RsRGB = rgb.r/255;\n GsRGB = rgb.g/255;\n BsRGB = rgb.b/255;\n\n if (RsRGB <= 0.03928) {R = RsRGB / 12.92;} else {R = Math.pow(((RsRGB + 0.055) / 1.055), 2.4);}\n if (GsRGB <= 0.03928) {G = GsRGB / 12.92;} else {G = Math.pow(((GsRGB + 0.055) / 1.055), 2.4);}\n if (BsRGB <= 0.03928) {B = BsRGB / 12.92;} else {B = Math.pow(((BsRGB + 0.055) / 1.055), 2.4);}\n return (0.2126 * R) + (0.7152 * G) + (0.0722 * B);\n },\n setAlpha: function(value) {\n this._a = boundAlpha(value);\n this._roundA = mathRound(100*this._a) / 100;\n return this;\n },\n toHsv: function() {\n var hsv = rgbToHsv(this._r, this._g, this._b);\n return { h: hsv.h * 360, s: hsv.s, v: hsv.v, a: this._a };\n },\n toHsvString: function() {\n var hsv = rgbToHsv(this._r, this._g, this._b);\n var h = mathRound(hsv.h * 360), s = mathRound(hsv.s * 100), v = mathRound(hsv.v * 100);\n return (this._a == 1) ?\n \"hsv(\" + h + \", \" + s + \"%, \" + v + \"%)\" :\n \"hsva(\" + h + \", \" + s + \"%, \" + v + \"%, \"+ this._roundA + \")\";\n },\n toHsl: function() {\n var hsl = rgbToHsl(this._r, this._g, this._b);\n return { h: hsl.h * 360, s: hsl.s, l: hsl.l, a: this._a };\n },\n toHslString: function() {\n var hsl = rgbToHsl(this._r, this._g, this._b);\n var h = mathRound(hsl.h * 360), s = mathRound(hsl.s * 100), l = mathRound(hsl.l * 100);\n return (this._a == 1) ?\n \"hsl(\" + h + \", \" + s + \"%, \" + l + \"%)\" :\n \"hsla(\" + h + \", \" + s + \"%, \" + l + \"%, \"+ this._roundA + \")\";\n },\n toHex: function(allow3Char) {\n return rgbToHex(this._r, this._g, this._b, allow3Char);\n },\n toHexString: function(allow3Char) {\n return '#' + this.toHex(allow3Char);\n },\n toHex8: function(allow4Char) {\n return rgbaToHex(this._r, this._g, this._b, this._a, allow4Char);\n },\n toHex8String: function(allow4Char) {\n return '#' + this.toHex8(allow4Char);\n },\n toRgb: function() {\n return { r: mathRound(this._r), g: mathRound(this._g), b: mathRound(this._b), a: this._a };\n },\n toRgbString: function() {\n return (this._a == 1) ?\n \"rgb(\" + mathRound(this._r) + \", \" + mathRound(this._g) + \", \" + mathRound(this._b) + \")\" :\n \"rgba(\" + mathRound(this._r) + \", \" + mathRound(this._g) + \", \" + mathRound(this._b) + \", \" + this._roundA + \")\";\n },\n toPercentageRgb: function() {\n return { r: mathRound(bound01(this._r, 255) * 100) + \"%\", g: mathRound(bound01(this._g, 255) * 100) + \"%\", b: mathRound(bound01(this._b, 255) * 100) + \"%\", a: this._a };\n },\n toPercentageRgbString: function() {\n return (this._a == 1) ?\n \"rgb(\" + mathRound(bound01(this._r, 255) * 100) + \"%, \" + mathRound(bound01(this._g, 255) * 100) + \"%, \" + mathRound(bound01(this._b, 255) * 100) + \"%)\" :\n \"rgba(\" + mathRound(bound01(this._r, 255) * 100) + \"%, \" + mathRound(bound01(this._g, 255) * 100) + \"%, \" + mathRound(bound01(this._b, 255) * 100) + \"%, \" + this._roundA + \")\";\n },\n toName: function() {\n if (this._a === 0) {\n return \"transparent\";\n }\n\n if (this._a < 1) {\n return false;\n }\n\n return hexNames[rgbToHex(this._r, this._g, this._b, true)] || false;\n },\n toFilter: function(secondColor) {\n var hex8String = '#' + rgbaToArgbHex(this._r, this._g, this._b, this._a);\n var secondHex8String = hex8String;\n var gradientType = this._gradientType ? \"GradientType = 1, \" : \"\";\n\n if (secondColor) {\n var s = tinycolor(secondColor);\n secondHex8String = '#' + rgbaToArgbHex(s._r, s._g, s._b, s._a);\n }\n\n return \"progid:DXImageTransform.Microsoft.gradient(\"+gradientType+\"startColorstr=\"+hex8String+\",endColorstr=\"+secondHex8String+\")\";\n },\n toString: function(format) {\n var formatSet = !!format;\n format = format || this._format;\n\n var formattedString = false;\n var hasAlpha = this._a < 1 && this._a >= 0;\n var needsAlphaFormat = !formatSet && hasAlpha && (format === \"hex\" || format === \"hex6\" || format === \"hex3\" || format === \"hex4\" || format === \"hex8\" || format === \"name\");\n\n if (needsAlphaFormat) {\n // Special case for \"transparent\", all other non-alpha formats\n // will return rgba when there is transparency.\n if (format === \"name\" && this._a === 0) {\n return this.toName();\n }\n return this.toRgbString();\n }\n if (format === \"rgb\") {\n formattedString = this.toRgbString();\n }\n if (format === \"prgb\") {\n formattedString = this.toPercentageRgbString();\n }\n if (format === \"hex\" || format === \"hex6\") {\n formattedString = this.toHexString();\n }\n if (format === \"hex3\") {\n formattedString = this.toHexString(true);\n }\n if (format === \"hex4\") {\n formattedString = this.toHex8String(true);\n }\n if (format === \"hex8\") {\n formattedString = this.toHex8String();\n }\n if (format === \"name\") {\n formattedString = this.toName();\n }\n if (format === \"hsl\") {\n formattedString = this.toHslString();\n }\n if (format === \"hsv\") {\n formattedString = this.toHsvString();\n }\n\n return formattedString || this.toHexString();\n },\n clone: function() {\n return tinycolor(this.toString());\n },\n\n _applyModification: function(fn, args) {\n var color = fn.apply(null, [this].concat([].slice.call(args)));\n this._r = color._r;\n this._g = color._g;\n this._b = color._b;\n this.setAlpha(color._a);\n return this;\n },\n lighten: function() {\n return this._applyModification(lighten, arguments);\n },\n brighten: function() {\n return this._applyModification(brighten, arguments);\n },\n darken: function() {\n return this._applyModification(darken, arguments);\n },\n desaturate: function() {\n return this._applyModification(desaturate, arguments);\n },\n saturate: function() {\n return this._applyModification(saturate, arguments);\n },\n greyscale: function() {\n return this._applyModification(greyscale, arguments);\n },\n spin: function() {\n return this._applyModification(spin, arguments);\n },\n\n _applyCombination: function(fn, args) {\n return fn.apply(null, [this].concat([].slice.call(args)));\n },\n analogous: function() {\n return this._applyCombination(analogous, arguments);\n },\n complement: function() {\n return this._applyCombination(complement, arguments);\n },\n monochromatic: function() {\n return this._applyCombination(monochromatic, arguments);\n },\n splitcomplement: function() {\n return this._applyCombination(splitcomplement, arguments);\n },\n triad: function() {\n return this._applyCombination(triad, arguments);\n },\n tetrad: function() {\n return this._applyCombination(tetrad, arguments);\n }\n};\n\n// If input is an object, force 1 into \"1.0\" to handle ratios properly\n// String input requires \"1.0\" as input, so 1 will be treated as 1\ntinycolor.fromRatio = function(color, opts) {\n if (typeof color == \"object\") {\n var newColor = {};\n for (var i in color) {\n if (color.hasOwnProperty(i)) {\n if (i === \"a\") {\n newColor[i] = color[i];\n }\n else {\n newColor[i] = convertToPercentage(color[i]);\n }\n }\n }\n color = newColor;\n }\n\n return tinycolor(color, opts);\n};\n\n// Given a string or object, convert that input to RGB\n// Possible string inputs:\n//\n// \"red\"\n// \"#f00\" or \"f00\"\n// \"#ff0000\" or \"ff0000\"\n// \"#ff000000\" or \"ff000000\"\n// \"rgb 255 0 0\" or \"rgb (255, 0, 0)\"\n// \"rgb 1.0 0 0\" or \"rgb (1, 0, 0)\"\n// \"rgba (255, 0, 0, 1)\" or \"rgba 255, 0, 0, 1\"\n// \"rgba (1.0, 0, 0, 1)\" or \"rgba 1.0, 0, 0, 1\"\n// \"hsl(0, 100%, 50%)\" or \"hsl 0 100% 50%\"\n// \"hsla(0, 100%, 50%, 1)\" or \"hsla 0 100% 50%, 1\"\n// \"hsv(0, 100%, 100%)\" or \"hsv 0 100% 100%\"\n//\nfunction inputToRGB(color) {\n\n var rgb = { r: 0, g: 0, b: 0 };\n var a = 1;\n var s = null;\n var v = null;\n var l = null;\n var ok = false;\n var format = false;\n\n if (typeof color == \"string\") {\n color = stringInputToObject(color);\n }\n\n if (typeof color == \"object\") {\n if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) {\n rgb = rgbToRgb(color.r, color.g, color.b);\n ok = true;\n format = String(color.r).substr(-1) === \"%\" ? \"prgb\" : \"rgb\";\n }\n else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) {\n s = convertToPercentage(color.s);\n v = convertToPercentage(color.v);\n rgb = hsvToRgb(color.h, s, v);\n ok = true;\n format = \"hsv\";\n }\n else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) {\n s = convertToPercentage(color.s);\n l = convertToPercentage(color.l);\n rgb = hslToRgb(color.h, s, l);\n ok = true;\n format = \"hsl\";\n }\n\n if (color.hasOwnProperty(\"a\")) {\n a = color.a;\n }\n }\n\n a = boundAlpha(a);\n\n return {\n ok: ok,\n format: color.format || format,\n r: mathMin(255, mathMax(rgb.r, 0)),\n g: mathMin(255, mathMax(rgb.g, 0)),\n b: mathMin(255, mathMax(rgb.b, 0)),\n a: a\n };\n}\n\n\n// Conversion Functions\n// --------------------\n\n// `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from:\n// <http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript>\n\n// `rgbToRgb`\n// Handle bounds / percentage checking to conform to CSS color spec\n// <http://www.w3.org/TR/css3-color/>\n// *Assumes:* r, g, b in [0, 255] or [0, 1]\n// *Returns:* { r, g, b } in [0, 255]\nfunction rgbToRgb(r, g, b){\n return {\n r: bound01(r, 255) * 255,\n g: bound01(g, 255) * 255,\n b: bound01(b, 255) * 255\n };\n}\n\n// `rgbToHsl`\n// Converts an RGB color value to HSL.\n// *Assumes:* r, g, and b are contained in [0, 255] or [0, 1]\n// *Returns:* { h, s, l } in [0,1]\nfunction rgbToHsl(r, g, b) {\n\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n\n var max = mathMax(r, g, b), min = mathMin(r, g, b);\n var h, s, l = (max + min) / 2;\n\n if(max == min) {\n h = s = 0; // achromatic\n }\n else {\n var d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n switch(max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n\n h /= 6;\n }\n\n return { h: h, s: s, l: l };\n}\n\n// `hslToRgb`\n// Converts an HSL color value to RGB.\n// *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100]\n// *Returns:* { r, g, b } in the set [0, 255]\nfunction hslToRgb(h, s, l) {\n var r, g, b;\n\n h = bound01(h, 360);\n s = bound01(s, 100);\n l = bound01(l, 100);\n\n function hue2rgb(p, q, t) {\n if(t < 0) t += 1;\n if(t > 1) t -= 1;\n if(t < 1/6) return p + (q - p) * 6 * t;\n if(t < 1/2) return q;\n if(t < 2/3) return p + (q - p) * (2/3 - t) * 6;\n return p;\n }\n\n if(s === 0) {\n r = g = b = l; // achromatic\n }\n else {\n var q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n var p = 2 * l - q;\n r = hue2rgb(p, q, h + 1/3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1/3);\n }\n\n return { r: r * 255, g: g * 255, b: b * 255 };\n}\n\n// `rgbToHsv`\n// Converts an RGB color value to HSV\n// *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1]\n// *Returns:* { h, s, v } in [0,1]\nfunction rgbToHsv(r, g, b) {\n\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n\n var max = mathMax(r, g, b), min = mathMin(r, g, b);\n var h, s, v = max;\n\n var d = max - min;\n s = max === 0 ? 0 : d / max;\n\n if(max == min) {\n h = 0; // achromatic\n }\n else {\n switch(max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n return { h: h, s: s, v: v };\n}\n\n// `hsvToRgb`\n// Converts an HSV color value to RGB.\n// *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100]\n// *Returns:* { r, g, b } in the set [0, 255]\n function hsvToRgb(h, s, v) {\n\n h = bound01(h, 360) * 6;\n s = bound01(s, 100);\n v = bound01(v, 100);\n\n var i = Math.floor(h),\n f = h - i,\n p = v * (1 - s),\n q = v * (1 - f * s),\n t = v * (1 - (1 - f) * s),\n mod = i % 6,\n r = [v, q, p, p, t, v][mod],\n g = [t, v, v, q, p, p][mod],\n b = [p, p, t, v, v, q][mod];\n\n return { r: r * 255, g: g * 255, b: b * 255 };\n}\n\n// `rgbToHex`\n// Converts an RGB color to hex\n// Assumes r, g, and b are contained in the set [0, 255]\n// Returns a 3 or 6 character hex\nfunction rgbToHex(r, g, b, allow3Char) {\n\n var hex = [\n pad2(mathRound(r).toString(16)),\n pad2(mathRound(g).toString(16)),\n pad2(mathRound(b).toString(16))\n ];\n\n // Return a 3 character hex if possible\n if (allow3Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1)) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);\n }\n\n return hex.join(\"\");\n}\n\n// `rgbaToHex`\n// Converts an RGBA color plus alpha transparency to hex\n// Assumes r, g, b are contained in the set [0, 255] and\n// a in [0, 1]. Returns a 4 or 8 character rgba hex\nfunction rgbaToHex(r, g, b, a, allow4Char) {\n\n var hex = [\n pad2(mathRound(r).toString(16)),\n pad2(mathRound(g).toString(16)),\n pad2(mathRound(b).toString(16)),\n pad2(convertDecimalToHex(a))\n ];\n\n // Return a 4 character hex if possible\n if (allow4Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1) && hex[3].charAt(0) == hex[3].charAt(1)) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);\n }\n\n return hex.join(\"\");\n}\n\n// `rgbaToArgbHex`\n// Converts an RGBA color to an ARGB Hex8 string\n// Rarely used, but required for \"toFilter()\"\nfunction rgbaToArgbHex(r, g, b, a) {\n\n var hex = [\n pad2(convertDecimalToHex(a)),\n pad2(mathRound(r).toString(16)),\n pad2(mathRound(g).toString(16)),\n pad2(mathRound(b).toString(16))\n ];\n\n return hex.join(\"\");\n}\n\n// `equals`\n// Can be called with any tinycolor input\ntinycolor.equals = function (color1, color2) {\n if (!color1 || !color2) { return false; }\n return tinycolor(color1).toRgbString() == tinycolor(color2).toRgbString();\n};\n\ntinycolor.random = function() {\n return tinycolor.fromRatio({\n r: mathRandom(),\n g: mathRandom(),\n b: mathRandom()\n });\n};\n\n\n// Modification Functions\n// ----------------------\n// Thanks to less.js for some of the basics here\n// <https://github.com/cloudhead/less.js/blob/master/lib/less/functions.js>\n\nfunction desaturate(color, amount) {\n amount = (amount === 0) ? 0 : (amount || 10);\n var hsl = tinycolor(color).toHsl();\n hsl.s -= amount / 100;\n hsl.s = clamp01(hsl.s);\n return tinycolor(hsl);\n}\n\nfunction saturate(color, amount) {\n amount = (amount === 0) ? 0 : (amount || 10);\n var hsl = tinycolor(color).toHsl();\n hsl.s += amount / 100;\n hsl.s = clamp01(hsl.s);\n return tinycolor(hsl);\n}\n\nfunction greyscale(color) {\n return tinycolor(color).desaturate(100);\n}\n\nfunction lighten (color, amount) {\n amount = (amount === 0) ? 0 : (amount || 10);\n var hsl = tinycolor(color).toHsl();\n hsl.l += amount / 100;\n hsl.l = clamp01(hsl.l);\n return tinycolor(hsl);\n}\n\nfunction brighten(color, amount) {\n amount = (amount === 0) ? 0 : (amount || 10);\n var rgb = tinycolor(color).toRgb();\n rgb.r = mathMax(0, mathMin(255, rgb.r - mathRound(255 * - (amount / 100))));\n rgb.g = mathMax(0, mathMin(255, rgb.g - mathRound(255 * - (amount / 100))));\n rgb.b = mathMax(0, mathMin(255, rgb.b - mathRound(255 * - (amount / 100))));\n return tinycolor(rgb);\n}\n\nfunction darken (color, amount) {\n amount = (amount === 0) ? 0 : (amount || 10);\n var hsl = tinycolor(color).toHsl();\n hsl.l -= amount / 100;\n hsl.l = clamp01(hsl.l);\n return tinycolor(hsl);\n}\n\n// Spin takes a positive or negative amount within [-360, 360] indicating the change of hue.\n// Values outside of this range will be wrapped into this range.\nfunction spin(color, amount) {\n var hsl = tinycolor(color).toHsl();\n var hue = (hsl.h + amount) % 360;\n hsl.h = hue < 0 ? 360 + hue : hue;\n return tinycolor(hsl);\n}\n\n// Combination Functions\n// ---------------------\n// Thanks to jQuery xColor for some of the ideas behind these\n// <https://github.com/infusion/jQuery-xcolor/blob/master/jquery.xcolor.js>\n\nfunction complement(color) {\n var hsl = tinycolor(color).toHsl();\n hsl.h = (hsl.h + 180) % 360;\n return tinycolor(hsl);\n}\n\nfunction triad(color) {\n var hsl = tinycolor(color).toHsl();\n var h = hsl.h;\n return [\n tinycolor(color),\n tinycolor({ h: (h + 120) % 360, s: hsl.s, l: hsl.l }),\n tinycolor({ h: (h + 240) % 360, s: hsl.s, l: hsl.l })\n ];\n}\n\nfunction tetrad(color) {\n var hsl = tinycolor(color).toHsl();\n var h = hsl.h;\n return [\n tinycolor(color),\n tinycolor({ h: (h + 90) % 360, s: hsl.s, l: hsl.l }),\n tinycolor({ h: (h + 180) % 360, s: hsl.s, l: hsl.l }),\n tinycolor({ h: (h + 270) % 360, s: hsl.s, l: hsl.l })\n ];\n}\n\nfunction splitcomplement(color) {\n var hsl = tinycolor(color).toHsl();\n var h = hsl.h;\n return [\n tinycolor(color),\n tinycolor({ h: (h + 72) % 360, s: hsl.s, l: hsl.l}),\n tinycolor({ h: (h + 216) % 360, s: hsl.s, l: hsl.l})\n ];\n}\n\nfunction analogous(color, results, slices) {\n results = results || 6;\n slices = slices || 30;\n\n var hsl = tinycolor(color).toHsl();\n var part = 360 / slices;\n var ret = [tinycolor(color)];\n\n for (hsl.h = ((hsl.h - (part * results >> 1)) + 720) % 360; --results; ) {\n hsl.h = (hsl.h + part) % 360;\n ret.push(tinycolor(hsl));\n }\n return ret;\n}\n\nfunction monochromatic(color, results) {\n results = results || 6;\n var hsv = tinycolor(color).toHsv();\n var h = hsv.h, s = hsv.s, v = hsv.v;\n var ret = [];\n var modification = 1 / results;\n\n while (results--) {\n ret.push(tinycolor({ h: h, s: s, v: v}));\n v = (v + modification) % 1;\n }\n\n return ret;\n}\n\n// Utility Functions\n// ---------------------\n\ntinycolor.mix = function(color1, color2, amount) {\n amount = (amount === 0) ? 0 : (amount || 50);\n\n var rgb1 = tinycolor(color1).toRgb();\n var rgb2 = tinycolor(color2).toRgb();\n\n var p = amount / 100;\n\n var rgba = {\n r: ((rgb2.r - rgb1.r) * p) + rgb1.r,\n g: ((rgb2.g - rgb1.g) * p) + rgb1.g,\n b: ((rgb2.b - rgb1.b) * p) + rgb1.b,\n a: ((rgb2.a - rgb1.a) * p) + rgb1.a\n };\n\n return tinycolor(rgba);\n};\n\n\n// Readability Functions\n// ---------------------\n// <http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef (WCAG Version 2)\n\n// `contrast`\n// Analyze the 2 colors and returns the color contrast defined by (WCAG Version 2)\ntinycolor.readability = function(color1, color2) {\n var c1 = tinycolor(color1);\n var c2 = tinycolor(color2);\n return (Math.max(c1.getLuminance(),c2.getLuminance())+0.05) / (Math.min(c1.getLuminance(),c2.getLuminance())+0.05);\n};\n\n// `isReadable`\n// Ensure that foreground and background color combinations meet WCAG2 guidelines.\n// The third argument is an optional Object.\n// the 'level' property states 'AA' or 'AAA' - if missing or invalid, it defaults to 'AA';\n// the 'size' property states 'large' or 'small' - if missing or invalid, it defaults to 'small'.\n// If the entire object is absent, isReadable defaults to {level:\"AA\",size:\"small\"}.\n\n// *Example*\n// tinycolor.isReadable(\"#000\", \"#111\") => false\n// tinycolor.isReadable(\"#000\", \"#111\",{level:\"AA\",size:\"large\"}) => false\ntinycolor.isReadable = function(color1, color2, wcag2) {\n var readability = tinycolor.readability(color1, color2);\n var wcag2Parms, out;\n\n out = false;\n\n wcag2Parms = validateWCAG2Parms(wcag2);\n switch (wcag2Parms.level + wcag2Parms.size) {\n case \"AAsmall\":\n case \"AAAlarge\":\n out = readability >= 4.5;\n break;\n case \"AAlarge\":\n out = readability >= 3;\n break;\n case \"AAAsmall\":\n out = readability >= 7;\n break;\n }\n return out;\n\n};\n\n// `mostReadable`\n// Given a base color and a list of possible foreground or background\n// colors for that base, returns the most readable color.\n// Optionally returns Black or White if the most readable color is unreadable.\n// *Example*\n// tinycolor.mostReadable(tinycolor.mostReadable(\"#123\", [\"#124\", \"#125\"],{includeFallbackColors:false}).toHexString(); // \"#112255\"\n// tinycolor.mostReadable(tinycolor.mostReadable(\"#123\", [\"#124\", \"#125\"],{includeFallbackColors:true}).toHexString(); // \"#ffffff\"\n// tinycolor.mostReadable(\"#a8015a\", [\"#faf3f3\"],{includeFallbackColors:true,level:\"AAA\",size:\"large\"}).toHexString(); // \"#faf3f3\"\n// tinycolor.mostReadable(\"#a8015a\", [\"#faf3f3\"],{includeFallbackColors:true,level:\"AAA\",size:\"small\"}).toHexString(); // \"#ffffff\"\ntinycolor.mostReadable = function(baseColor, colorList, args) {\n var bestColor = null;\n var bestScore = 0;\n var readability;\n var includeFallbackColors, level, size ;\n args = args || {};\n includeFallbackColors = args.includeFallbackColors ;\n level = args.level;\n size = args.size;\n\n for (var i= 0; i < colorList.length ; i++) {\n readability = tinycolor.readability(baseColor, colorList[i]);\n if (readability > bestScore) {\n bestScore = readability;\n bestColor = tinycolor(colorList[i]);\n }\n }\n\n if (tinycolor.isReadable(baseColor, bestColor, {\"level\":level,\"size\":size}) || !includeFallbackColors) {\n return bestColor;\n }\n else {\n args.includeFallbackColors=false;\n return tinycolor.mostReadable(baseColor,[\"#fff\", \"#000\"],args);\n }\n};\n\n\n// Big List of Colors\n// ------------------\n// <http://www.w3.org/TR/css3-color/#svg-color>\nvar names = tinycolor.names = {\n aliceblue: \"f0f8ff\",\n antiquewhite: \"faebd7\",\n aqua: \"0ff\",\n aquamarine: \"7fffd4\",\n azure: \"f0ffff\",\n beige: \"f5f5dc\",\n bisque: \"ffe4c4\",\n black: \"000\",\n blanchedalmond: \"ffebcd\",\n blue: \"00f\",\n blueviolet: \"8a2be2\",\n brown: \"a52a2a\",\n burlywood: \"deb887\",\n burntsienna: \"ea7e5d\",\n cadetblue: \"5f9ea0\",\n chartreuse: \"7fff00\",\n chocolate: \"d2691e\",\n coral: \"ff7f50\",\n cornflowerblue: \"6495ed\",\n cornsilk: \"fff8dc\",\n crimson: \"dc143c\",\n cyan: \"0ff\",\n darkblue: \"00008b\",\n darkcyan: \"008b8b\",\n darkgoldenrod: \"b8860b\",\n darkgray: \"a9a9a9\",\n darkgreen: \"006400\",\n darkgrey: \"a9a9a9\",\n darkkhaki: \"bdb76b\",\n darkmagenta: \"8b008b\",\n darkolivegreen: \"556b2f\",\n darkorange: \"ff8c00\",\n darkorchid: \"9932cc\",\n darkred: \"8b0000\",\n darksalmon: \"e9967a\",\n darkseagreen: \"8fbc8f\",\n darkslateblue: \"483d8b\",\n darkslategray: \"2f4f4f\",\n darkslategrey: \"2f4f4f\",\n darkturquoise: \"00ced1\",\n darkviolet: \"9400d3\",\n deeppink: \"ff1493\",\n deepskyblue: \"00bfff\",\n dimgray: \"696969\",\n dimgrey: \"696969\",\n dodgerblue: \"1e90ff\",\n firebrick: \"b22222\",\n floralwhite: \"fffaf0\",\n forestgreen: \"228b22\",\n fuchsia: \"f0f\",\n gainsboro: \"dcdcdc\",\n ghostwhite: \"f8f8ff\",\n gold: \"ffd700\",\n goldenrod: \"daa520\",\n gray: \"808080\",\n green: \"008000\",\n greenyellow: \"adff2f\",\n grey: \"808080\",\n honeydew: \"f0fff0\",\n hotpink: \"ff69b4\",\n indianred: \"cd5c5c\",\n indigo: \"4b0082\",\n ivory: \"fffff0\",\n khaki: \"f0e68c\",\n lavender: \"e6e6fa\",\n lavenderblush: \"fff0f5\",\n lawngreen: \"7cfc00\",\n lemonchiffon: \"fffacd\",\n lightblue: \"add8e6\",\n lightcoral: \"f08080\",\n lightcyan: \"e0ffff\",\n lightgoldenrodyellow: \"fafad2\",\n lightgray: \"d3d3d3\",\n lightgreen: \"90ee90\",\n lightgrey: \"d3d3d3\",\n lightpink: \"ffb6c1\",\n lightsalmon: \"ffa07a\",\n lightseagreen: \"20b2aa\",\n lightskyblue: \"87cefa\",\n lightslategray: \"789\",\n lightslategrey: \"789\",\n lightsteelblue: \"b0c4de\",\n lightyellow: \"ffffe0\",\n lime: \"0f0\",\n limegreen: \"32cd32\",\n linen: \"faf0e6\",\n magenta: \"f0f\",\n maroon: \"800000\",\n mediumaquamarine: \"66cdaa\",\n mediumblue: \"0000cd\",\n mediumorchid: \"ba55d3\",\n mediumpurple: \"9370db\",\n mediumseagreen: \"3cb371\",\n mediumslateblue: \"7b68ee\",\n mediumspringgreen: \"00fa9a\",\n mediumturquoise: \"48d1cc\",\n mediumvioletred: \"c71585\",\n midnightblue: \"191970\",\n mintcream: \"f5fffa\",\n mistyrose: \"ffe4e1\",\n moccasin: \"ffe4b5\",\n navajowhite: \"ffdead\",\n navy: \"000080\",\n oldlace: \"fdf5e6\",\n olive: \"808000\",\n olivedrab: \"6b8e23\",\n orange: \"ffa500\",\n orangered: \"ff4500\",\n orchid: \"da70d6\",\n palegoldenrod: \"eee8aa\",\n palegreen: \"98fb98\",\n paleturquoise: \"afeeee\",\n palevioletred: \"db7093\",\n papayawhip: \"ffefd5\",\n peachpuff: \"ffdab9\",\n peru: \"cd853f\",\n pink: \"ffc0cb\",\n plum: \"dda0dd\",\n powderblue: \"b0e0e6\",\n purple: \"800080\",\n rebeccapurple: \"663399\",\n red: \"f00\",\n rosybrown: \"bc8f8f\",\n royalblue: \"4169e1\",\n saddlebrown: \"8b4513\",\n salmon: \"fa8072\",\n sandybrown: \"f4a460\",\n seagreen: \"2e8b57\",\n seashell: \"fff5ee\",\n sienna: \"a0522d\",\n silver: \"c0c0c0\",\n skyblue: \"87ceeb\",\n slateblue: \"6a5acd\",\n slategray: \"708090\",\n slategrey: \"708090\",\n snow: \"fffafa\",\n springgreen: \"00ff7f\",\n steelblue: \"4682b4\",\n tan: \"d2b48c\",\n teal: \"008080\",\n thistle: \"d8bfd8\",\n tomato: \"ff6347\",\n turquoise: \"40e0d0\",\n violet: \"ee82ee\",\n wheat: \"f5deb3\",\n white: \"fff\",\n whitesmoke: \"f5f5f5\",\n yellow: \"ff0\",\n yellowgreen: \"9acd32\"\n};\n\n// Make it easy to access colors via `hexNames[hex]`\nvar hexNames = tinycolor.hexNames = flip(names);\n\n\n// Utilities\n// ---------\n\n// `{ 'name1': 'val1' }` becomes `{ 'val1': 'name1' }`\nfunction flip(o) {\n var flipped = { };\n for (var i in o) {\n if (o.hasOwnProperty(i)) {\n flipped[o[i]] = i;\n }\n }\n return flipped;\n}\n\n// Return a valid alpha value [0,1] with all invalid values being set to 1\nfunction boundAlpha(a) {\n a = parseFloat(a);\n\n if (isNaN(a) || a < 0 || a > 1) {\n a = 1;\n }\n\n return a;\n}\n\n// Take input from [0, n] and return it as [0, 1]\nfunction bound01(n, max) {\n if (isOnePointZero(n)) { n = \"100%\"; }\n\n var processPercent = isPercentage(n);\n n = mathMin(max, mathMax(0, parseFloat(n)));\n\n // Automatically convert percentage into number\n if (processPercent) {\n n = parseInt(n * max, 10) / 100;\n }\n\n // Handle floating point rounding errors\n if ((Math.abs(n - max) < 0.000001)) {\n return 1;\n }\n\n // Convert into [0, 1] range if it isn't already\n return (n % max) / parseFloat(max);\n}\n\n// Force a number between 0 and 1\nfunction clamp01(val) {\n return mathMin(1, mathMax(0, val));\n}\n\n// Parse a base-16 hex value into a base-10 integer\nfunction parseIntFromHex(val) {\n return parseInt(val, 16);\n}\n\n// Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1\n// <http://stackoverflow.com/questions/7422072/javascript-how-to-detect-number-as-a-decimal-including-1-0>\nfunction isOnePointZero(n) {\n return typeof n == \"string\" && n.indexOf('.') != -1 && parseFloat(n) === 1;\n}\n\n// Check to see if string passed in is a percentage\nfunction isPercentage(n) {\n return typeof n === \"string\" && n.indexOf('%') != -1;\n}\n\n// Force a hex value to have 2 characters\nfunction pad2(c) {\n return c.length == 1 ? '0' + c : '' + c;\n}\n\n// Replace a decimal with it's percentage value\nfunction convertToPercentage(n) {\n if (n <= 1) {\n n = (n * 100) + \"%\";\n }\n\n return n;\n}\n\n// Converts a decimal to a hex value\nfunction convertDecimalToHex(d) {\n return Math.round(parseFloat(d) * 255).toString(16);\n}\n// Converts a hex value to a decimal\nfunction convertHexToDecimal(h) {\n return (parseIntFromHex(h) / 255);\n}\n\nvar matchers = (function() {\n\n // <http://www.w3.org/TR/css3-values/#integers>\n var CSS_INTEGER = \"[-\\\\+]?\\\\d+%?\";\n\n // <http://www.w3.org/TR/css3-values/#number-value>\n var CSS_NUMBER = \"[-\\\\+]?\\\\d*\\\\.\\\\d+%?\";\n\n // Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome.\n var CSS_UNIT = \"(?:\" + CSS_NUMBER + \")|(?:\" + CSS_INTEGER + \")\";\n\n // Actual matching.\n // Parentheses and commas are optional, but not required.\n // Whitespace can take the place of commas or opening paren\n var PERMISSIVE_MATCH3 = \"[\\\\s|\\\\(]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")\\\\s*\\\\)?\";\n var PERMISSIVE_MATCH4 = \"[\\\\s|\\\\(]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")[,|\\\\s]+(\" + CSS_UNIT + \")\\\\s*\\\\)?\";\n\n return {\n CSS_UNIT: new RegExp(CSS_UNIT),\n rgb: new RegExp(\"rgb\" + PERMISSIVE_MATCH3),\n rgba: new RegExp(\"rgba\" + PERMISSIVE_MATCH4),\n hsl: new RegExp(\"hsl\" + PERMISSIVE_MATCH3),\n hsla: new RegExp(\"hsla\" + PERMISSIVE_MATCH4),\n hsv: new RegExp(\"hsv\" + PERMISSIVE_MATCH3),\n hsva: new RegExp(\"hsva\" + PERMISSIVE_MATCH4),\n hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/\n };\n})();\n\n// `isValidCSSUnit`\n// Take in a single string / number and check to see if it looks like a CSS unit\n// (see `matchers` above for definition).\nfunction isValidCSSUnit(color) {\n return !!matchers.CSS_UNIT.exec(color);\n}\n\n// `stringInputToObject`\n// Permissive string parsing. Take in a number of formats, and output an object\n// based on detected format. Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}`\nfunction stringInputToObject(color) {\n\n color = color.replace(trimLeft,'').replace(trimRight, '').toLowerCase();\n var named = false;\n if (names[color]) {\n color = names[color];\n named = true;\n }\n else if (color == 'transparent') {\n return { r: 0, g: 0, b: 0, a: 0, format: \"name\" };\n }\n\n // Try to match string input using regular expressions.\n // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360]\n // Just return an object and let the conversion functions handle that.\n // This way the result will be the same whether the tinycolor is initialized with string or object.\n var match;\n if ((match = matchers.rgb.exec(color))) {\n return { r: match[1], g: match[2], b: match[3] };\n }\n if ((match = matchers.rgba.exec(color))) {\n return { r: match[1], g: match[2], b: match[3], a: match[4] };\n }\n if ((match = matchers.hsl.exec(color))) {\n return { h: match[1], s: match[2], l: match[3] };\n }\n if ((match = matchers.hsla.exec(color))) {\n return { h: match[1], s: match[2], l: match[3], a: match[4] };\n }\n if ((match = matchers.hsv.exec(color))) {\n return { h: match[1], s: match[2], v: match[3] };\n }\n if ((match = matchers.hsva.exec(color))) {\n return { h: match[1], s: match[2], v: match[3], a: match[4] };\n }\n if ((match = matchers.hex8.exec(color))) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n a: convertHexToDecimal(match[4]),\n format: named ? \"name\" : \"hex8\"\n };\n }\n if ((match = matchers.hex6.exec(color))) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n format: named ? \"name\" : \"hex\"\n };\n }\n if ((match = matchers.hex4.exec(color))) {\n return {\n r: parseIntFromHex(match[1] + '' + match[1]),\n g: parseIntFromHex(match[2] + '' + match[2]),\n b: parseIntFromHex(match[3] + '' + match[3]),\n a: convertHexToDecimal(match[4] + '' + match[4]),\n format: named ? \"name\" : \"hex8\"\n };\n }\n if ((match = matchers.hex3.exec(color))) {\n return {\n r: parseIntFromHex(match[1] + '' + match[1]),\n g: parseIntFromHex(match[2] + '' + match[2]),\n b: parseIntFromHex(match[3] + '' + match[3]),\n format: named ? \"name\" : \"hex\"\n };\n }\n\n return false;\n}\n\nfunction validateWCAG2Parms(parms) {\n // return valid WCAG2 parms for isReadable.\n // If input parms are invalid, return {\"level\":\"AA\", \"size\":\"small\"}\n var level, size;\n parms = parms || {\"level\":\"AA\", \"size\":\"small\"};\n level = (parms.level || \"AA\").toUpperCase();\n size = (parms.size || \"small\").toLowerCase();\n if (level !== \"AA\" && level !== \"AAA\") {\n level = \"AA\";\n }\n if (size !== \"small\" && size !== \"large\") {\n size = \"small\";\n }\n return {\"level\":level, \"size\":size};\n}\n\n// Node: Export function\nif (typeof module !== \"undefined\" && module.exports) {\n module.exports = tinycolor;\n}\n// AMD/requirejs: Define the module\nelse if (typeof define === 'function' && define.amd) {\n define(function () {return tinycolor;});\n}\n// Browser: Expose to window\nelse {\n window.tinycolor = tinycolor;\n}\n\n})(Math);\n","module.exports = {\n EPSILON: require('./epsilon')\n , create: require('./create')\n , clone: require('./clone')\n , fromValues: require('./fromValues')\n , copy: require('./copy')\n , set: require('./set')\n , equals: require('./equals')\n , exactEquals: require('./exactEquals')\n , add: require('./add')\n , subtract: require('./subtract')\n , sub: require('./sub')\n , multiply: require('./multiply')\n , mul: require('./mul')\n , divide: require('./divide')\n , div: require('./div')\n , inverse: require('./inverse')\n , min: require('./min')\n , max: require('./max')\n , rotate: require('./rotate')\n , floor: require('./floor')\n , ceil: require('./ceil')\n , round: require('./round')\n , scale: require('./scale')\n , scaleAndAdd: require('./scaleAndAdd')\n , distance: require('./distance')\n , dist: require('./dist')\n , squaredDistance: require('./squaredDistance')\n , sqrDist: require('./sqrDist')\n , length: require('./length')\n , len: require('./len')\n , squaredLength: require('./squaredLength')\n , sqrLen: require('./sqrLen')\n , negate: require('./negate')\n , normalize: require('./normalize')\n , dot: require('./dot')\n , cross: require('./cross')\n , lerp: require('./lerp')\n , random: require('./random')\n , transformMat2: require('./transformMat2')\n , transformMat2d: require('./transformMat2d')\n , transformMat3: require('./transformMat3')\n , transformMat4: require('./transformMat4')\n , forEach: require('./forEach')\n , limit: require('./limit')\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar adjMatrix = function adjMatrix(graphData, directed) {\n var nodes = graphData.nodes,\n edges = graphData.edges;\n var matrix = []; // map node with index in data.nodes\n\n var nodeMap = {};\n\n if (!nodes) {\n throw new Error(\"invalid nodes data!\");\n }\n\n if (nodes) {\n nodes.forEach(function (node, i) {\n nodeMap[node.id] = i;\n var row = [];\n matrix.push(row);\n });\n }\n\n if (edges) {\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var sIndex = nodeMap[source];\n var tIndex = nodeMap[target];\n if (!sIndex && sIndex !== 0 || !tIndex && tIndex !== 0) return;\n matrix[sIndex][tIndex] = 1;\n\n if (!directed) {\n matrix[tIndex][sIndex] = 1;\n }\n });\n }\n\n return matrix;\n};\n\nvar _default = adjMatrix;\nexports.default = _default;","var ListCache = require('./_ListCache'),\n stackClear = require('./_stackClear'),\n stackDelete = require('./_stackDelete'),\n stackGet = require('./_stackGet'),\n stackHas = require('./_stackHas'),\n stackSet = require('./_stackSet');\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n","var listCacheClear = require('./_listCacheClear'),\n listCacheDelete = require('./_listCacheDelete'),\n listCacheGet = require('./_listCacheGet'),\n listCacheHas = require('./_listCacheHas'),\n listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n","var eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nmodule.exports = assocIndexOf;\n","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","var isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nmodule.exports = getMapData;\n","var baseAssignValue = require('./_baseAssignValue'),\n eq = require('./eq');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nmodule.exports = assignValue;\n","var defineProperty = require('./_defineProperty');\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nmodule.exports = baseAssignValue;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nmodule.exports = baseUnary;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nmodule.exports = isPrototype;\n","var overArg = require('./_overArg');\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nmodule.exports = getPrototype;\n","var baseForOwn = require('./_baseForOwn'),\n createBaseEach = require('./_createBaseEach');\n\n/**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\nvar baseEach = createBaseEach(baseForOwn);\n\nmodule.exports = baseEach;\n","var castPath = require('./_castPath'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n","var isArray = require('./isArray'),\n isKey = require('./_isKey'),\n stringToPath = require('./_stringToPath'),\n toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\nmodule.exports = arrayMap;\n","var identity = require('./identity'),\n overRest = require('./_overRest'),\n setToString = require('./_setToString');\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n return setToString(overRest(func, start, identity), func + '');\n}\n\nmodule.exports = baseRest;\n","var eq = require('./eq'),\n isArrayLike = require('./isArrayLike'),\n isIndex = require('./_isIndex'),\n isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n * else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n if (!isObject(object)) {\n return false;\n }\n var type = typeof index;\n if (type == 'number'\n ? (isArrayLike(object) && isIndex(index, object.length))\n : (type == 'string' && index in object)\n ) {\n return eq(object[index], value);\n }\n return false;\n}\n\nmodule.exports = isIterateeCall;\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\n\nmodule.exports = {\n longestPath: longestPath,\n slack: slack\n};\n\n/*\n * Initializes ranks for the input graph using the longest path algorithm. This\n * algorithm scales well and is fast in practice, it yields rather poor\n * solutions. Nodes are pushed to the lowest layer possible, leaving the bottom\n * ranks wide and leaving edges longer than necessary. However, due to its\n * speed, this algorithm is good for getting an initial ranking that can be fed\n * into other algorithms.\n *\n * This algorithm does not normalize layers because it will be used by other\n * algorithms in most cases. If using this algorithm directly, be sure to\n * run normalize at the end.\n *\n * Pre-conditions:\n *\n * 1. Input graph is a DAG.\n * 2. Input graph node labels can be assigned properties.\n *\n * Post-conditions:\n *\n * 1. Each node will be assign an (unnormalized) \"rank\" property.\n */\nfunction longestPath(g) {\n var visited = {};\n\n function dfs(v) {\n var label = g.node(v);\n if (_.has(visited, v)) {\n return label.rank;\n }\n visited[v] = true;\n\n var rank = _.min(_.map(g.outEdges(v), function(e) {\n return dfs(e.w) - g.edge(e).minlen;\n }));\n\n if (rank === Number.POSITIVE_INFINITY || // return value of _.map([]) for Lodash 3\n rank === undefined || // return value of _.map([]) for Lodash 4\n rank === null) { // return value of _.map([null])\n rank = 0;\n }\n\n return (label.rank = rank);\n }\n\n _.forEach(g.sources(), dfs);\n}\n\n/*\n * Returns the amount of slack for the given edge. The slack is defined as the\n * difference between the length of the edge and its minimum length.\n */\nfunction slack(g, e) {\n return g.node(e.w).rank - g.node(e.v).rank - g.edge(e).minlen;\n}\n","export * from './gl';\nexport * from './IAttribute';\nexport * from './IBuffer';\nexport * from './IComputeModel';\nexport * from './IElements';\nexport * from './IFramebuffer';\nexport * from './IModel';\nexport * from './IMultiPassRenderer';\nexport * from './IRenderbuffer';\nexport * from './IRendererService';\nexport * from './ITexture2D';\nexport * from './IUniform';\n","var GraphEvent = /** @class */ (function () {\n function GraphEvent(type, event) {\n /**\n * 是否允许冒泡\n * @type {boolean}\n */\n this.bubbles = true;\n /**\n * 触发对象\n * @type {object}\n */\n this.target = null;\n /**\n * 监听对象\n * @type {object}\n */\n this.currentTarget = null;\n /**\n * 委托对象\n * @type {object}\n */\n this.delegateTarget = null;\n /**\n * 委托事件监听对象的代理对象,即 ev.delegateObject = ev.currentTarget.get('delegateObject')\n * @type {object}\n */\n this.delegateObject = null;\n /**\n * 是否阻止了原生事件\n * @type {boolean}\n */\n this.defaultPrevented = false;\n /**\n * 是否阻止传播(向上冒泡)\n * @type {boolean}\n */\n this.propagationStopped = false;\n /**\n * 触发事件的图形\n * @type {IShape}\n */\n this.shape = null;\n /**\n * 开始触发事件的图形\n * @type {IShape}\n */\n this.fromShape = null;\n /**\n * 事件结束时的触发图形\n * @type {IShape}\n */\n this.toShape = null;\n // 触发事件的路径\n this.propagationPath = [];\n this.type = type;\n this.name = type;\n this.originalEvent = event;\n this.timeStamp = event.timeStamp;\n }\n /**\n * 阻止浏览器默认的行为\n */\n GraphEvent.prototype.preventDefault = function () {\n this.defaultPrevented = true;\n if (this.originalEvent.preventDefault) {\n this.originalEvent.preventDefault();\n }\n };\n /**\n * 阻止冒泡\n */\n GraphEvent.prototype.stopPropagation = function () {\n this.propagationStopped = true;\n };\n GraphEvent.prototype.toString = function () {\n var type = this.type;\n return \"[Event (type=\" + type + \")]\";\n };\n GraphEvent.prototype.save = function () { };\n GraphEvent.prototype.restore = function () { };\n return GraphEvent;\n}());\nexport default GraphEvent;\n//# sourceMappingURL=graph-event.js.map","import { __extends } from \"tslib\";\nimport EE from '@antv/event-emitter';\nimport { mix } from '../util/util';\nvar Base = /** @class */ (function (_super) {\n __extends(Base, _super);\n function Base(cfg) {\n var _this = _super.call(this) || this;\n /**\n * 是否被销毁\n * @type {boolean}\n */\n _this.destroyed = false;\n var defaultCfg = _this.getDefaultCfg();\n _this.cfg = mix(defaultCfg, cfg);\n return _this;\n }\n /**\n * @protected\n * 默认的配置项\n * @returns {object} 默认的配置项\n */\n Base.prototype.getDefaultCfg = function () {\n return {};\n };\n // 实现接口的方法\n Base.prototype.get = function (name) {\n return this.cfg[name];\n };\n // 实现接口的方法\n Base.prototype.set = function (name, value) {\n this.cfg[name] = value;\n };\n // 实现接口的方法\n Base.prototype.destroy = function () {\n this.cfg = {\n destroyed: true,\n };\n this.off();\n this.destroyed = true;\n };\n return Base;\n}(EE));\nexport default Base;\n//# sourceMappingURL=base.js.map","// 全局设置一个唯一离屏的 ctx,用于计算 isPointInPath\nvar offScreenCtx = null;\nexport function getOffScreenContext() {\n if (!offScreenCtx) {\n var canvas = document.createElement('canvas');\n canvas.width = 1;\n canvas.height = 1;\n offScreenCtx = canvas.getContext('2d');\n }\n return offScreenCtx;\n}\n//# sourceMappingURL=offscreen.js.map","export const EMPTY = -1;\n\nlet entitySequence = 1;\n\n/**\n * 类似关系型数据库的主键\n * TODO: 自动生成,考虑序列化\n */\nexport function createEntity() {\n return entitySequence++;\n}\n","import { vec3 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { createEntity, ISystem } from '../..';\nimport { ComponentManager } from '../../ComponentManager';\nimport { IDENTIFIER } from '../../identifier';\nimport { generateAABBFromVertices } from '../../utils/aabb';\nimport { gl } from '../renderer/gl';\nimport { IBuffer } from '../renderer/IBuffer';\nimport { BufferData, IRendererService } from '../renderer/IRendererService';\nimport { GeometryComponent } from './GeometryComponent';\n\n@injectable()\nexport class GeometrySystem implements ISystem {\n @inject(IDENTIFIER.GeometryComponentManager)\n private readonly geometry: ComponentManager<GeometryComponent>;\n\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n public async execute() {\n this.geometry.forEach((entity, component) => {\n // build buffers for each geometry\n if (component.dirty) {\n component.attributes.forEach((attribute) => {\n if (attribute.dirty && attribute.data) {\n if (!attribute.buffer) {\n attribute.buffer = this.engine.createBuffer({\n data: attribute.data,\n type: gl.FLOAT,\n });\n } else {\n attribute.buffer?.subData({\n data: attribute.data,\n // TODO: support offset in subdata\n offset: 0,\n });\n }\n attribute.dirty = false;\n }\n });\n\n // create index buffer if needed\n if (component.indices) {\n if (!component.indicesBuffer) {\n component.indicesBuffer = this.engine.createElements({\n data: component.indices,\n count: component.indices.length,\n type: gl.UNSIGNED_INT,\n usage: gl.STATIC_DRAW,\n });\n } else {\n component.indicesBuffer.subData({\n data: component.indices,\n offset: 0,\n });\n }\n }\n component.dirty = false;\n }\n });\n }\n\n public tearDown() {\n this.geometry.forEach((_, geometry) => {\n if (geometry.indicesBuffer) {\n geometry.indicesBuffer.destroy();\n }\n\n geometry.attributes.forEach((attribute) => {\n if (attribute.buffer) {\n attribute.buffer.destroy();\n }\n });\n });\n this.geometry.clear();\n }\n\n /**\n * @see https://threejs.org/docs/#api/en/core/BufferGeometry\n */\n public createBufferGeometry(\n { vertexCount }: { vertexCount: number } = { vertexCount: 3 },\n ) {\n const entity = createEntity();\n return this.geometry.create(entity, {\n vertexCount,\n });\n }\n\n /**\n * @see https://threejs.org/docs/#api/en/core/InstancedBufferGeometry\n */\n public createInstancedBufferGeometry({\n maxInstancedCount,\n vertexCount,\n }: {\n maxInstancedCount: number;\n vertexCount: number;\n }) {\n const entity = createEntity();\n return this.geometry.create(entity, {\n maxInstancedCount,\n vertexCount,\n });\n }\n}\n","import { Entity, gl } from '../..';\nimport { Component } from '../../ComponentManager';\nimport { NonFunctionProperties } from '../../ComponentManager';\nimport { IModelInitializationOptions } from '../renderer/IModel';\nimport { BufferData } from '../renderer/IRendererService';\nimport { IUniformBinding } from './interface';\n\nexport class MaterialComponent extends Component<MaterialComponent> {\n public vertexShaderGLSL: string;\n\n public fragmentShaderGLSL: string;\n\n // control flow in shaders, eg. USE_UV, USE_MAP...\n public defines: Record<string, boolean | number> = {};\n\n public dirty = true;\n\n public uniforms: IUniformBinding[] = [];\n\n public cull: IModelInitializationOptions['cull'] = {\n enable: true,\n face: gl.BACK,\n };\n\n public depth: IModelInitializationOptions['depth'] = {\n enable: true,\n };\n\n public blend: IModelInitializationOptions['blend'];\n\n public entity: Entity;\n\n public type: string;\n\n constructor(data: Partial<NonFunctionProperties<MaterialComponent>>) {\n super(data);\n\n Object.assign(this, data);\n }\n\n public setDefines(defines: Record<string, boolean | number>) {\n this.defines = { ...this.defines, ...defines };\n return this;\n }\n\n public setCull(cull: IModelInitializationOptions['cull']) {\n this.cull = cull;\n return this;\n }\n\n public setDepth(depth: IModelInitializationOptions['depth']) {\n this.depth = depth;\n return this;\n }\n\n public setBlend(blend: IModelInitializationOptions['blend']) {\n this.blend = blend;\n return this;\n }\n\n public setUniform(\n name: string | Record<string, BufferData>,\n data?: BufferData,\n ) {\n if (typeof name !== 'string') {\n Object.keys(name).forEach((key) => this.setUniform(key, name[key]));\n return this;\n }\n\n const existedUniform = this.uniforms.find((u) => u.name === name);\n if (!existedUniform) {\n this.uniforms.push({\n name,\n dirty: true,\n data: data!,\n });\n } else {\n existedUniform.dirty = true;\n existedUniform.data = data!;\n }\n\n this.dirty = true;\n return this;\n }\n}\n","import { mat4 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { createEntity, Entity, ISystem, IUniformBinding } from '../..';\nimport { ComponentManager } from '../../ComponentManager';\nimport { IDENTIFIER } from '../../identifier';\nimport { IShaderModuleService } from '../../services';\nimport { getLengthFromFormat } from '../../utils/shader';\nimport { IModelInitializationOptions } from '../renderer/IModel';\nimport { BufferData, IRendererService } from '../renderer/IRendererService';\nimport { MaterialComponent } from './MaterialComponent';\n\n@injectable()\nexport class MaterialSystem implements ISystem {\n @inject(IDENTIFIER.MaterialComponentManager)\n private readonly material: ComponentManager<MaterialComponent>;\n\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n @inject(IDENTIFIER.ShaderModuleService)\n private readonly shaderModule: IShaderModuleService;\n\n public async execute() {\n // await Promise.all(\n // this.material.map(async (entity, component) => {\n // // if (component.dirty) {\n // // TODO: 使用 cache 避免同类材质的重复编译\n // // component.stageDescriptor = await this.engine.compilePipelineStageDescriptor(\n // // component.vertexShaderGLSL,\n // // component.fragmentShaderGLSL,\n // // null,\n // // );\n // // this.generateUniforms(component);\n // // component.dirty = false;\n // // }\n // }),\n // );\n }\n\n public tearDown() {\n this.material.clear();\n }\n\n /**\n * @see https://threejs.org/docs/#api/en/materials/ShaderMaterial\n */\n public createShaderMaterial(params: {\n vertexShader: string;\n fragmentShader: string;\n cull?: IModelInitializationOptions['cull'];\n depth?: IModelInitializationOptions['depth'];\n blend?: IModelInitializationOptions['blend'];\n }) {\n const entity = createEntity();\n\n let vertexShaderGLSL = params.vertexShader;\n let fragmentShaderGLSL = params.fragmentShader;\n let uniforms: IUniformBinding[] = [];\n\n if (!this.engine.supportWebGPU) {\n const moduleName = `material-${entity}`;\n this.shaderModule.registerModule(moduleName, {\n vs: params.vertexShader,\n fs: params.fragmentShader,\n });\n\n const materialModule = this.shaderModule.getModule(moduleName);\n vertexShaderGLSL = materialModule.vs!;\n fragmentShaderGLSL = materialModule.fs!;\n if (materialModule.uniforms) {\n // @ts-ignore\n uniforms = Object.keys(materialModule.uniforms).map((uniformName) => ({\n dirty: true,\n name: uniformName,\n // @ts-ignore\n data: materialModule.uniforms[uniformName],\n }));\n }\n }\n\n return this.material.create(entity, {\n vertexShaderGLSL,\n fragmentShaderGLSL,\n ...params,\n uniforms,\n });\n }\n}\n","import { Component } from '../../ComponentManager';\nimport { NonFunctionProperties } from '../../ComponentManager';\n\n/**\n * @see https://doc.babylonjs.com/how_to/optimizing_your_scene#changing-mesh-culling-strategy\n */\nexport enum Strategy {\n Standard,\n}\n\nexport class CullableComponent extends Component<CullableComponent> {\n public strategy: Strategy = Strategy.Standard;\n\n public visibilityPlaneMask = 0;\n\n public visible = false;\n\n constructor(data: Partial<NonFunctionProperties<CullableComponent>>) {\n super(data);\n\n Object.assign(this, data);\n }\n}\n","import { Entity, MaterialComponent } from '../..';\nimport { Component } from '../../ComponentManager';\nimport { NonFunctionProperties } from '../../ComponentManager';\nimport { AABB } from '../../shape/AABB';\nimport { GeometryComponent } from '../geometry/GeometryComponent';\nimport { IModel } from '../renderer/IModel';\n\nexport class MeshComponent extends Component<MeshComponent> {\n public material: MaterialComponent;\n\n public geometry: GeometryComponent;\n\n /**\n * aabb 应该存在 Mesh 而非 Geometry 中,原因包括:\n * 1. 包围盒会受 transform 影响。例如每次 transform 之后应该重新计算包围盒(center 发生偏移)。\n * 2. 多个 Mesh 可以共享一个 Geometry,但可以各自拥有不同的 aabb\n */\n public aabb: AABB = new AABB();\n\n /**\n * transform 之后需要重新计算包围盒\n */\n public aabbDirty = true;\n\n /**\n * 实际渲染 Model\n */\n public model: IModel | undefined;\n\n public visible = true;\n\n public children: Entity[] = [];\n\n constructor(data: Partial<NonFunctionProperties<MeshComponent>>) {\n super(data);\n\n Object.assign(this, data);\n }\n}\n","import { mat3, mat4, vec3 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { ISystem } from '../..';\nimport { ComponentManager } from '../../ComponentManager';\nimport { IDENTIFIER } from '../../identifier';\nimport { AABB } from '../../shape/AABB';\nimport { Mask } from '../../shape/Frustum';\nimport { Plane } from '../../shape/Plane';\nimport { getRotationScale } from '../../utils/math';\nimport { GeometryComponent } from '../geometry/GeometryComponent';\nimport { MaterialComponent } from '../material/MaterialComponent';\nimport { IView } from '../renderer/IRendererService';\nimport { HierarchyComponent } from '../scenegraph/HierarchyComponent';\nimport { TransformComponent } from '../scenegraph/TransformComponent';\nimport { CullableComponent } from './CullableComponent';\nimport { IMeshParams } from './interface';\nimport { MeshComponent } from './MeshComponent';\n\n@injectable()\nexport class MeshSystem implements ISystem {\n @inject(IDENTIFIER.MeshComponentManager)\n private readonly mesh: ComponentManager<MeshComponent>;\n\n @inject(IDENTIFIER.CullableComponentManager)\n private readonly cullable: ComponentManager<CullableComponent>;\n\n @inject(IDENTIFIER.GeometryComponentManager)\n private readonly geometry: ComponentManager<GeometryComponent>;\n\n @inject(IDENTIFIER.HierarchyComponentManager)\n private readonly hierarchy: ComponentManager<HierarchyComponent>;\n\n @inject(IDENTIFIER.TransformComponentManager)\n private readonly transform: ComponentManager<TransformComponent>;\n\n private planes: Plane[];\n\n public setFrustumPlanes(planes: Plane[]) {\n this.planes = planes;\n }\n\n public async execute(views: IView[]) {\n for (const view of views) {\n const scene = view.getScene();\n const camera = view.getCamera();\n\n // get VP matrix from camera\n for (const entity of scene.getEntities()) {\n const component = this.mesh.getComponentByEntity(entity);\n\n if (component) {\n const hierarchyComponent = this.hierarchy.getComponentByEntity(entity);\n const cullableComponent = this.cullable.getComponentByEntity(entity);\n const geometryComponent = component.geometry;\n const meshTransform = this.transform.getComponentByEntity(entity);\n\n // update mesh.aabb\n if (\n geometryComponent &&\n geometryComponent.aabb &&\n meshTransform &&\n component.aabbDirty\n ) {\n const { worldTransform } = meshTransform;\n\n // apply transform to geometry.aabb\n const { center, halfExtents } = geometryComponent.aabb;\n const transformedCenter = vec3.transformMat4(\n vec3.create(),\n center,\n worldTransform,\n );\n\n const rotationScale = getRotationScale(worldTransform, mat3.create());\n const transformedHalfExtents = vec3.transformMat3(\n vec3.create(),\n halfExtents,\n rotationScale,\n );\n\n component.aabb.update(transformedCenter, transformedHalfExtents);\n component.aabbDirty = false;\n }\n\n // culling\n if (cullableComponent && geometryComponent) {\n const parentCullableComponent = this.cullable.getComponentByEntity(\n hierarchyComponent?.parentID || -1,\n );\n cullableComponent.visibilityPlaneMask = this.computeVisibilityWithPlaneMask(\n component.aabb,\n parentCullableComponent?.visibilityPlaneMask || Mask.INDETERMINATE,\n this.planes || camera.getFrustum().planes,\n );\n cullableComponent.visible =\n cullableComponent.visibilityPlaneMask !== Mask.OUTSIDE;\n }\n }\n }\n }\n }\n\n public tearDown() {\n this.cullable.clear();\n this.mesh.clear();\n }\n\n /**\n *\n * @see「Optimized View Frustum Culling Algorithms for Bounding Boxes」\n * @see https://github.com/antvis/GWebGPUEngine/issues/3\n *\n * * 基础相交测试 the basic intersection test\n * * 标记 masking @see https://cesium.com/blog/2015/08/04/fast-hierarchical-culling/\n * * TODO: 平面一致性测试 the plane-coherency test\n * * TODO: 支持 mesh 指定自身的剔除策略,参考 Babylon.js @see https://doc.babylonjs.com/how_to/optimizing_your_scene#changing-mesh-culling-strategy\n *\n * @param aabb aabb\n * @param parentPlaneMask mask of parent\n * @param planes planes of frustum\n */\n public computeVisibilityWithPlaneMask(\n aabb: AABB,\n parentPlaneMask: Mask,\n planes: Plane[],\n ) {\n if (parentPlaneMask === Mask.OUTSIDE || parentPlaneMask === Mask.INSIDE) {\n // 父节点完全位于视锥内或者外部,直接返回\n return parentPlaneMask;\n }\n\n // Start with MASK_INSIDE (all zeros) so that after the loop, the return value can be compared with MASK_INSIDE.\n // (Because if there are fewer than 31 planes, the upper bits wont be changed.)\n let mask = Mask.INSIDE;\n\n for (let k = 0, len = planes.length; k < len; ++k) {\n // For k greater than 31 (since 31 is the maximum number of INSIDE/INTERSECTING bits we can store), skip the optimization.\n const flag = k < 31 ? 1 << k : 0;\n if (k < 31 && (parentPlaneMask & flag) === 0) {\n // 父节点处于当前面内部,可以跳过\n continue;\n }\n\n // 使用 p-vertex 和 n-vertex 加速,避免进行平面和 aabb 全部顶点的相交检测\n const { normal, distance } = planes[k];\n if (\n vec3.dot(normal, aabb.getNegativeFarPoint(planes[k])) + distance >\n 0\n ) {\n return Mask.OUTSIDE;\n }\n if (\n vec3.dot(normal, aabb.getPositiveFarPoint(planes[k])) + distance >\n 0\n ) {\n // 和当前面相交,对应位置为1,继续检测下一个面\n mask |= flag;\n }\n }\n\n return mask;\n }\n}\n","import { vec3 } from 'gl-matrix';\n\nexport class Plane {\n public distance: number;\n public normal: vec3;\n\n /**\n * lookup table for p-vertex & n-vertex when doing frustum culling\n */\n public pnVertexFlag: number;\n\n constructor(distance?: number, normal?: vec3) {\n this.distance = distance || 0;\n this.normal = normal || vec3.fromValues(0, 1, 0);\n this.updatePNVertexFlag();\n }\n\n public updatePNVertexFlag() {\n this.pnVertexFlag =\n (Number(this.normal[0] >= 0) << 8) +\n (Number(this.normal[1] >= 0) << 4) +\n Number(this.normal[2] >= 0);\n }\n\n public distanceToPoint(point: vec3) {\n return vec3.dot(point, this.normal) - this.distance;\n }\n\n public normalize() {\n const invLen = 1 / vec3.len(this.normal);\n vec3.scale(this.normal, this.normal, invLen);\n this.distance *= invLen;\n }\n\n public intersectsLine(start: vec3, end: vec3, point?: vec3) {\n const d0 = this.distanceToPoint(start);\n const d1 = this.distanceToPoint(end);\n const t = d0 / (d0 - d1);\n const intersects = t >= 0 && t <= 1;\n if (intersects && point) {\n vec3.lerp(point, start, end, t);\n }\n return intersects;\n }\n}\n","import { inject, injectable, named } from 'inversify';\nimport { IConfigService, ISystem } from '../..';\nimport { IDENTIFIER } from '../../identifier';\nimport { ResourcePool } from '../framegraph/ResourcePool';\nimport { FrameGraphSystem } from '../framegraph/System';\nimport { IView } from './IRendererService';\nimport { CopyPass, CopyPassData } from './passes/CopyPass';\nimport { IRenderPass } from './passes/IRenderPass';\nimport {\n PixelPickingPass,\n PixelPickingPassData,\n} from './passes/PixelPickingPass';\nimport { RenderPass, RenderPassData } from './passes/RenderPass';\n\n@injectable()\nexport class RendererSystem implements ISystem {\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.FrameGraphSystem)\n private readonly frameGraphSystem: FrameGraphSystem;\n\n @inject(IDENTIFIER.RenderPassFactory)\n private readonly renderPassFactory: <T>(name: string) => IRenderPass<T>;\n\n @inject(IDENTIFIER.ConfigService)\n private readonly configService: IConfigService;\n\n @inject(IDENTIFIER.ResourcePool)\n private readonly resourcePool: ResourcePool;\n\n public async execute(views: IView[]) {\n // const pixelPickingPass = this.renderPassFactory<PixelPickingPassData>(\n // PixelPickingPass.IDENTIFIER,\n // );\n // const {\n // setup: setupPixelPickingPass,\n // execute: executePixelPickingPass,\n // tearDown: tearDownPickingPass,\n // } = pixelPickingPass;\n // this.frameGraphSystem.addPass<PixelPickingPassData>(\n // PixelPickingPass.IDENTIFIER,\n // setupPixelPickingPass,\n // executePixelPickingPass,\n // tearDownPickingPass,\n // );\n\n const {\n setup: setupRenderPass,\n execute: executeRenderPass,\n } = this.renderPassFactory<RenderPassData>(RenderPass.IDENTIFIER);\n const renderPass = this.frameGraphSystem.addPass<RenderPassData>(\n RenderPass.IDENTIFIER,\n setupRenderPass,\n executeRenderPass,\n );\n\n const {\n setup: setupCopyPass,\n execute: executeCopyPass,\n tearDown: tearDownCopyPass,\n } = this.renderPassFactory<CopyPassData>(CopyPass.IDENTIFIER);\n const copyPass = this.frameGraphSystem.addPass<CopyPassData>(\n CopyPass.IDENTIFIER,\n setupCopyPass,\n executeCopyPass,\n tearDownCopyPass,\n );\n\n this.frameGraphSystem.present(copyPass.data.output);\n // this.frameGraphSystem.present(renderPass.data.output);\n }\n\n public tearDown() {\n this.resourcePool.clean();\n }\n\n public pick(position: { x: number; y: number }, view: IView) {\n const pickingPass = this.renderPassFactory<PixelPickingPassData>(\n PixelPickingPass.IDENTIFIER,\n ) as PixelPickingPass;\n\n return pickingPass.pick(position, view);\n }\n}\n","import { Entity } from '../..';\nimport { Component, NonFunctionProperties } from '../../ComponentManager';\n\nexport class HierarchyComponent extends Component<HierarchyComponent> {\n public parentID: Entity;\n\n constructor(data: Partial<NonFunctionProperties<HierarchyComponent>>) {\n super(data);\n Object.assign(this, data);\n }\n}\n","import { mat4 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { Entity, ISystem } from '../..';\nimport { Component } from '../../ComponentManager';\nimport { ComponentManager } from '../../ComponentManager';\nimport { IDENTIFIER } from '../../identifier';\nimport { MeshComponent } from '../mesh/MeshComponent';\nimport { HierarchyComponent } from './HierarchyComponent';\nimport { TransformComponent } from './TransformComponent';\n\n@injectable()\nexport class SceneGraphSystem implements ISystem {\n @inject(IDENTIFIER.HierarchyComponentManager)\n private readonly hierarchy: ComponentManager<HierarchyComponent>;\n\n @inject(IDENTIFIER.TransformComponentManager)\n private readonly transform: ComponentManager<TransformComponent>;\n\n @inject(IDENTIFIER.MeshComponentManager)\n private readonly mesh: ComponentManager<MeshComponent>;\n\n public async execute() {\n this.runTransformUpdateSystem();\n this.runHierarchyUpdateSystem();\n }\n\n public tearDown() {\n this.hierarchy.clear();\n this.transform.clear();\n }\n\n public getHierarchyComponentManager() {\n return this.hierarchy;\n }\n\n public getTransformComponentManager() {\n return this.transform;\n }\n\n public runTransformUpdateSystem() {\n // 原版基于 JobSystem 实现\n this.transform.forEach((entity, transform) => {\n if (transform.isDirty() || transform.isLocalDirty()) {\n this.setMeshAABBDirty(this.mesh.getComponentByEntity(entity));\n transform.updateTransform();\n }\n });\n }\n\n public runHierarchyUpdateSystem() {\n this.hierarchy.forEach((entity, parentComponent) => {\n const transformChild = this.transform.getComponentByEntity(entity);\n const transformParent = this.transform.getComponentByEntity(\n parentComponent.parentID,\n );\n if (transformChild !== null && transformParent !== null) {\n transformChild.updateTransformWithParent(transformParent);\n }\n });\n }\n\n public attach(\n entity: Entity,\n parent: Entity,\n isChildAlreadyInLocalSpace?: boolean,\n ) {\n if (this.hierarchy.contains(entity)) {\n this.detach(entity);\n }\n\n this.hierarchy.create(entity, {\n parentID: parent,\n });\n const mesh = this.mesh.getComponentByEntity(parent);\n // inform parent mesh to update its aabb\n this.setMeshAABBDirty(mesh);\n if (mesh && mesh.children.indexOf(entity) === -1) {\n mesh.children.push(entity);\n }\n\n if (this.hierarchy.getCount() > 1) {\n for (let i = this.hierarchy.getCount() - 1; i > 0; --i) {\n const parentCandidateEntity = this.hierarchy.getEntity(i);\n // const parentCandidateComponent = this.hierarchy.getComponent(i);\n for (let j = 0; j < i; ++j) {\n const childCandidateEntity = this.hierarchy.getComponent(j);\n\n if (childCandidateEntity.parentID === parentCandidateEntity) {\n this.hierarchy.moveItem(i, j);\n ++i; // next outer iteration will check the same index again as parent candidate, however things were moved upwards, so it will be a different entity!\n break;\n }\n }\n }\n }\n\n // Re-query parent after potential MoveItem(), because it invalidates references:\n const parentcomponent = this.hierarchy.getComponentByEntity(entity);\n\n let transformParent = this.transform.getComponentByEntity(parent);\n if (transformParent === null) {\n transformParent = this.transform.create(parent);\n }\n\n let transformChild = this.transform.getComponentByEntity(entity);\n if (transformChild === null) {\n transformChild = this.transform.create(entity);\n // after transforms.Create(), transform_parent pointer could have become invalidated!\n transformParent = this.transform.getComponentByEntity(parent);\n }\n\n transformChild.parent = transformParent;\n\n if (!isChildAlreadyInLocalSpace && transformParent) {\n transformChild.matrixTransform(\n mat4.invert(mat4.create(), transformParent.worldTransform),\n );\n transformChild.updateTransform();\n }\n if (transformParent) {\n transformChild.updateTransformWithParent(transformParent);\n }\n }\n\n public detach(entity: Entity) {\n const self = this.hierarchy.getComponentByEntity(entity);\n if (self !== null) {\n const transform = this.transform.getComponentByEntity(entity);\n if (transform !== null) {\n transform.parent = null;\n transform.applyTransform();\n }\n\n this.hierarchy.removeKeepSorted(entity);\n\n // inform parent mesh to update its aabb\n const mesh = this.mesh.getComponentByEntity(self.parentID);\n if (mesh) {\n const index = mesh.children.indexOf(entity);\n mesh.children.splice(index, 1);\n }\n this.setMeshAABBDirty(mesh);\n }\n }\n\n public detachChildren(parent: Entity) {\n const mesh = this.mesh.getComponentByEntity(parent);\n if (mesh) {\n mesh.children = [];\n }\n for (let i = 0; i < this.hierarchy.getCount(); ) {\n if (this.hierarchy.getComponent(i)?.parentID === parent) {\n const entity = this.hierarchy.getEntity(i);\n this.detach(entity);\n } else {\n ++i;\n }\n }\n }\n\n private setMeshAABBDirty(\n mesh: (Component<MeshComponent> & MeshComponent) | null,\n ) {\n if (mesh) {\n mesh.aabbDirty = true;\n }\n }\n}\n","import { mat4, quat, vec3, vec4 } from 'gl-matrix';\nimport { Component, NonFunctionProperties } from '../../ComponentManager';\n\nexport class TransformComponent extends Component<TransformComponent> {\n public static DIRTY = 1 << 0;\n\n public dirtyFlag: number;\n\n public localDirtyFlag: number;\n\n public parent: TransformComponent | null = null;\n\n /**\n * local space RTS\n */\n\n /**\n * XMFLOAT4X4._41\n * @see https://docs.microsoft.com/en-us/windows/win32/api/directxmath/nf-directxmath-xmfloat4x4-xmfloat4x4(constfloat)#remarks\n */\n public localPosition = vec3.fromValues(0, 0, 0);\n public localRotation = quat.fromValues(0, 0, 0, 1);\n public localScale = vec3.fromValues(1, 1, 1);\n public localTransform = mat4.create();\n\n /**\n * world space RTS\n */\n\n public position = vec3.fromValues(0, 0, 0);\n public rotation = quat.fromValues(0, 0, 0, 1);\n public scaling = vec3.fromValues(1, 1, 1);\n public worldTransform = mat4.create();\n\n // 高阶函数,利用闭包重复利用临时变量\n // @see playcanvas graph node\n public matrixTransform = (() => {\n const transformed = mat4.create();\n return (mat: mat4) => {\n mat4.multiply(transformed, this.getLocalTransform(), mat);\n mat4.getScaling(this.localScale, transformed);\n mat4.getTranslation(this.localPosition, transformed);\n mat4.getRotation(this.localRotation, transformed);\n };\n })();\n\n /**\n * @see https://docs.microsoft.com/en-us/windows/win32/api/directxmath/nf-directxmath-xmquaternionrotationrollpitchyaw\n */\n public rotateRollPitchYaw = (() => {\n const quatX = quat.create();\n const quatY = quat.create();\n const quatZ = quat.create();\n return (x: number, y: number, z: number) => {\n this.setDirty();\n\n quat.fromEuler(quatX, x, 0, 0);\n quat.fromEuler(quatY, 0, y, 0);\n quat.fromEuler(quatZ, 0, 0, z);\n\n quat.multiply(this.localRotation, quatX, this.localRotation);\n quat.multiply(this.localRotation, this.localRotation, quatY);\n quat.multiply(this.localRotation, quatZ, this.localRotation);\n quat.normalize(this.localRotation, this.localRotation);\n };\n })();\n\n /**\n * @see https://xiaoiver.github.io/coding/2018/12/28/Camera-%E8%AE%BE%E8%AE%A1-%E4%B8%80.html\n */\n public lerp = (() => {\n const aS = vec3.create();\n const aR = quat.create();\n const aT = vec3.create();\n const bS = vec3.create();\n const bR = quat.create();\n const bT = vec3.create();\n return (a: TransformComponent, b: TransformComponent, t: number) => {\n this.setDirty();\n\n mat4.getScaling(aS, a.worldTransform);\n mat4.getTranslation(aT, a.worldTransform);\n mat4.getRotation(aR, a.worldTransform);\n mat4.getScaling(bS, b.worldTransform);\n mat4.getTranslation(bT, b.worldTransform);\n mat4.getRotation(bR, b.worldTransform);\n\n vec3.lerp(this.localScale, aS, bS, t);\n quat.slerp(this.localRotation, aR, bR, t);\n vec3.lerp(this.localPosition, aT, bT, t);\n };\n })();\n\n /**\n * TODO: 支持以下两种:\n * * translate(x, y, z)\n * * translate(vec3(x, y, z))\n */\n public translate = (() => {\n const tr = vec3.create();\n\n return (translation: vec3) => {\n vec3.add(tr, this.getPosition(), translation);\n this.setPosition(tr);\n\n this.setDirty(true);\n\n return this;\n };\n })();\n\n public translateLocal = (() => {\n return (translation: vec3) => {\n vec3.transformQuat(translation, translation, this.localRotation);\n vec3.add(this.localPosition, this.localPosition, translation);\n\n this.setLocalDirty(true);\n\n return this;\n };\n })();\n\n public setPosition = (() => {\n const parentInvertMatrix = mat4.create();\n\n return (position: vec3) => {\n this.position = position;\n\n this.setLocalDirty(true);\n\n if (this.parent === null) {\n vec3.copy(this.localPosition, position);\n } else {\n mat4.copy(parentInvertMatrix, this.parent.worldTransform);\n mat4.invert(parentInvertMatrix, parentInvertMatrix);\n vec3.transformMat4(this.localPosition, position, parentInvertMatrix);\n }\n return this;\n };\n })();\n\n public rotate = (() => {\n const parentInvertRotation = quat.create();\n return (quaternion: quat) => {\n if (this.parent === null) {\n quat.multiply(this.localRotation, this.localRotation, quaternion);\n quat.normalize(this.localRotation, this.localRotation);\n } else {\n const rot = this.getRotation();\n const parentRot = this.parent.getRotation();\n\n quat.copy(parentInvertRotation, parentRot);\n quat.invert(parentInvertRotation, parentInvertRotation);\n quat.multiply(parentInvertRotation, parentInvertRotation, quaternion);\n quat.multiply(this.localRotation, quaternion, rot);\n quat.normalize(this.localRotation, this.localRotation);\n }\n this.setLocalDirty();\n return this;\n };\n })();\n\n public rotateLocal = (() => {\n return (quaternion: quat) => {\n quat.multiply(this.localRotation, this.localRotation, quaternion);\n quat.normalize(this.localRotation, this.localRotation);\n this.setLocalDirty(true);\n return this;\n };\n })();\n\n public setRotation = (() => {\n const invParentRot = quat.create();\n\n return (rotation: quat) => {\n if (this.parent === null) {\n quat.copy(this.localRotation, rotation);\n } else {\n quat.copy(invParentRot, this.parent.getRotation());\n quat.invert(invParentRot, invParentRot);\n quat.copy(this.localRotation, invParentRot);\n quat.mul(this.localRotation, this.localRotation, rotation);\n }\n\n this.setLocalDirty(true);\n return this;\n };\n })();\n\n /**\n * @see https://en.wikipedia.org/wiki/Centripetal_Catmull%E2%80%93Rom_spline\n */\n // public catmullRom = (() => {\n // const aS = vec3.create();\n // const aR = quat.create();\n // const aT = vec3.create();\n // const bS = vec3.create();\n // const bR = quat.create();\n // const bT = vec3.create();\n // const cS = vec3.create();\n // const cR = quat.create();\n // const cT = vec3.create();\n // const dS = vec3.create();\n // const dR = quat.create();\n // const dT = vec3.create();\n // const R = quat.create();\n // return (\n // a: TransformComponent,\n // b: TransformComponent,\n // c: TransformComponent,\n // d: TransformComponent,\n // t: number,\n // ) => {\n // this.setDirty();\n // mat4.getScaling(aS, a.worldTransform);\n // mat4.getTranslation(aT, a.worldTransform);\n // mat4.getRotation(aR, a.worldTransform);\n // mat4.getScaling(bS, b.worldTransform);\n // mat4.getTranslation(bT, b.worldTransform);\n // mat4.getRotation(bR, b.worldTransform);\n // mat4.getScaling(cS, c.worldTransform);\n // mat4.getTranslation(cT, c.worldTransform);\n // mat4.getRotation(cR, c.worldTransform);\n // mat4.getScaling(dS, d.worldTransform);\n // mat4.getTranslation(dT, d.worldTransform);\n // mat4.getRotation(dR, d.worldTransform);\n\n // vec3.catmullRom(this.localPosition, aT, bT, cT, dT, t);\n // vec3.catmullRom(R, aR, bR, cR, dR, t);\n // quat.normalize(this.localRotation, R);\n // vec3.catmullRom(this.localScale, aS, bS, cS, dS, t);\n // };\n // })();\n\n constructor(data?: Partial<NonFunctionProperties<TransformComponent>>) {\n super(data);\n }\n\n public setLocalPosition(position: vec3) {\n vec3.copy(this.localPosition, position);\n this.setLocalDirty(true);\n }\n\n public setLocalScale(scale: vec3) {\n vec3.copy(this.localScale, scale);\n this.setLocalDirty(true);\n }\n\n public setLocalRotation(rotation: quat) {\n quat.copy(this.localRotation, rotation);\n\n this.setLocalDirty(true);\n return this;\n }\n\n public isDirty() {\n return this.dirtyFlag;\n }\n\n public setDirty(value = true) {\n if (value) {\n this.dirtyFlag |= TransformComponent.DIRTY;\n } else {\n this.dirtyFlag &= ~TransformComponent.DIRTY;\n }\n }\n\n public isLocalDirty() {\n return this.localDirtyFlag;\n }\n\n public setLocalDirty(value = true) {\n if (value) {\n this.localDirtyFlag |= TransformComponent.DIRTY;\n this.setDirty(true);\n } else {\n this.localDirtyFlag &= ~TransformComponent.DIRTY;\n }\n }\n\n public updateTransform() {\n if (this.isLocalDirty()) {\n this.getLocalTransform();\n }\n if (this.isDirty()) {\n if (this.parent === null) {\n mat4.copy(this.worldTransform, this.getLocalTransform());\n this.setDirty(false);\n }\n }\n }\n\n public updateTransformWithParent(parent: TransformComponent) {\n mat4.multiply(\n this.worldTransform,\n parent.worldTransform,\n this.getLocalTransform(),\n );\n }\n\n public applyTransform() {\n this.setDirty();\n\n mat4.getScaling(this.localScale, this.worldTransform);\n mat4.getTranslation(this.localPosition, this.worldTransform);\n mat4.getRotation(this.localRotation, this.worldTransform);\n }\n\n public clearTransform() {\n this.setDirty();\n this.localPosition = vec3.fromValues(0, 0, 0);\n this.localRotation = quat.fromValues(0, 0, 0, 1);\n this.localScale = vec3.fromValues(1, 1, 1);\n }\n\n public scaleLocal(scaling: vec3) {\n this.setLocalDirty();\n vec3.multiply(this.localScale, this.localScale, scaling);\n return this;\n }\n\n public getLocalPosition() {\n return this.localPosition;\n }\n\n public getLocalRotation() {\n return this.localRotation;\n }\n\n public getLocalScale() {\n return this.localScale;\n }\n\n public getLocalTransform() {\n if (this.localDirtyFlag) {\n mat4.fromRotationTranslationScale(\n this.localTransform,\n this.localRotation,\n this.localPosition,\n this.localScale,\n );\n this.setLocalDirty(false);\n }\n return this.localTransform;\n }\n\n public getWorldTransform() {\n if (!this.isLocalDirty() && !this.isDirty()) {\n return this.worldTransform;\n }\n\n if (this.parent) {\n this.parent.getWorldTransform();\n }\n\n this.updateTransform();\n\n return this.worldTransform;\n }\n\n public getPosition() {\n mat4.getTranslation(this.position, this.worldTransform);\n return this.position;\n }\n\n public getRotation() {\n mat4.getRotation(this.rotation, this.worldTransform);\n return this.rotation;\n }\n\n public getScale() {\n mat4.getScaling(this.scaling, this.worldTransform);\n return this.scaling;\n }\n}\n","import { injectable } from 'inversify';\nimport {\n IRendererConfig,\n IRendererService,\n} from '../../components/renderer/IRendererService';\n\nexport interface IConfig {\n canvas: HTMLCanvasElement;\n useRenderBundle: boolean;\n engineOptions: IRendererConfig;\n onInit: (engine: IRendererService) => void;\n onUpdate: (engine: IRendererService) => void;\n}\n\nexport interface IConfigService {\n get(): Partial<IConfig>;\n set(config: Partial<IConfig>): void;\n}\n\n@injectable()\nexport class ConfigService implements IConfigService {\n private config: Partial<IConfig>;\n\n public get() {\n return this.config;\n }\n\n public set(config: Partial<IConfig>) {\n this.config = config;\n }\n}\n","import { injectable } from 'inversify';\n\nexport interface IInteractorService {\n listen(canvas: HTMLCanvasElement): void;\n disconnect(): void;\n connect(): void;\n destroy(): void;\n on(event: IInteractorEvent, args?: unknown): void;\n}\n\nexport enum IInteractorEvent {\n PANSTART = 'PANSTART',\n PANEND = 'PANEND',\n PANMOVE = 'PANMOVE',\n PINCH = 'PINCH',\n KEYDOWN = 'KEYDOWN',\n KEYUP = 'KEYUP',\n HOVER = 'HOVER',\n}\n\n@injectable()\nexport class InteractorService implements IInteractorService {\n public listen(canvas: HTMLCanvasElement): void {}\n public on(event: IInteractorEvent, args?: unknown): void {}\n public connect() {}\n public disconnect() {}\n public destroy() {}\n}\n","export class FrameGraphHandle {\n // 保存 fg 中 resourceNodes 索引\n public index: number;\n}\n\nexport interface TextureDescriptor {\n width: number;\n height: number;\n usage?: number;\n}\n","import { IView } from '../..';\nimport { FrameGraphSystem } from './System';\n\nexport class FrameGraphPass<PassData> {\n public name: string;\n\n public data: PassData;\n\n public execute: (\n fg: FrameGraphSystem,\n pass: FrameGraphPass<PassData>,\n views: IView[],\n ) => Promise<void>;\n\n public tearDown: () => void;\n}\n","import { FrameGraphHandle } from './FrameGraphHandle';\nimport { FrameGraphSystem } from './System';\nimport { VirtualResource } from './VirtualResource';\n\nexport class PassNode {\n public name: string;\n /**\n * count resources that have a reference to this pass node\n */\n public refCount = 0;\n\n /**\n * set by FG system\n */\n public hasSideEffect = false;\n\n /**\n * during FG's compile, create before executing\n */\n public devirtualize: VirtualResource[] = [];\n\n /**\n * during FG's compile, destroy after executing\n */\n public destroy: VirtualResource[] = [];\n\n public reads: FrameGraphHandle[] = [];\n\n public writes: FrameGraphHandle[] = [];\n\n public read(handle: FrameGraphHandle): FrameGraphHandle {\n if (!this.reads.find((h) => h.index === handle.index)) {\n this.reads.push(handle);\n }\n return handle;\n }\n\n public sample(handle: FrameGraphHandle) {\n this.read(handle);\n // TODO: 记录在 this.samples 中\n return handle;\n }\n\n public write(\n fg: FrameGraphSystem,\n handle: FrameGraphHandle,\n ): FrameGraphHandle {\n const existed = this.writes.find((h) => h.index === handle.index);\n if (existed) {\n return handle;\n }\n\n const node = fg.getResourceNode(handle);\n\n node.resource.version++;\n\n if (node.resource.imported) {\n this.hasSideEffect = true;\n }\n\n const r = fg.createResourceNode(node.resource);\n const newNode = fg.getResourceNode(r);\n\n newNode.writer = this;\n\n this.writes.push(r);\n return r;\n }\n}\n","import { IFramebuffer, ITexture2D } from '../..';\nimport { TextureDescriptor } from './FrameGraphHandle';\nimport { VirtualResource } from './VirtualResource';\n\nexport class ResourceEntry extends VirtualResource {\n public version: number = 0;\n\n public refs: number = 0;\n\n public name: string;\n\n public imported: boolean;\n\n public priority: number;\n\n public discardStart = true;\n\n public discardEnd = false;\n\n public descriptor: TextureDescriptor;\n\n public resource: IFramebuffer;\n\n /**\n * Lifecycles in FG's execute\n */\n public preExecuteDestroy(): void {\n this.discardEnd = true;\n }\n\n public postExecuteDestroy(): void {\n if (!this.imported) {\n // TODO: 不需要每一帧结束后都销毁资源,可以增加临时资源标志\n // this.resource.destroy();\n }\n }\n\n public postExecuteDevirtualize(): void {\n this.discardStart = false;\n }\n\n public preExecuteDevirtualize() {\n if (!this.imported) {\n //\n }\n }\n}\n","import { IRendererService } from '../renderer/IRendererService';\nimport { PassNode } from './PassNode';\n\n/**\n * ported from filament\n */\nexport abstract class VirtualResource {\n public first: PassNode;\n public last: PassNode;\n\n public abstract preExecuteDevirtualize(engine: IRendererService): void;\n public abstract preExecuteDestroy(engine: IRendererService): void;\n public abstract postExecuteDestroy(engine: IRendererService): void;\n public abstract postExecuteDevirtualize(engine: IRendererService): void;\n}\n","import { PassNode } from './PassNode';\nimport { ResourceEntry } from './ResourceEntry';\n\nexport class ResourceNode {\n public resource: ResourceEntry;\n\n public writer: PassNode;\n\n public readerCount: number = 0;\n\n public version: number;\n}\n","import { inject, injectable } from 'inversify';\nimport { ISystem, IView } from '../..';\nimport { IDENTIFIER } from '../../identifier';\nimport { IRendererService } from '../renderer/IRendererService';\nimport { FrameGraphHandle, TextureDescriptor } from './FrameGraphHandle';\nimport { FrameGraphPass } from './FrameGraphPass';\nimport { PassNode } from './PassNode';\nimport { ResourceEntry } from './ResourceEntry';\nimport { ResourceNode } from './ResourceNode';\n\n/**\n * ported from FrameGraph implemented by SakuraRender\n * @see https://zhuanlan.zhihu.com/p/98572442\n * @see https://github.com/SaeruHikari/Sakura/blob/RenderGraph/SakuraCore/Source/Framework/GraphicTypes/FrameGraph/SakuraFrameGraph.cpp\n */\n@injectable()\nexport class FrameGraphSystem implements ISystem {\n public passNodes: PassNode[] = [];\n\n public resourceNodes: ResourceNode[] = [];\n\n public frameGraphPasses: Array<FrameGraphPass<any>> = [];\n\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n public async execute(views: IView[]) {\n // this.engine.beginFrame();\n this.compile();\n await this.executePassNodes(views);\n // this.engine.endFrame();\n }\n\n public tearDown() {\n this.frameGraphPasses.forEach((pass) => {\n if (pass.tearDown) {\n pass.tearDown();\n }\n });\n this.reset();\n }\n\n public addPass<PassData>(\n name: string,\n setup: (\n fg: FrameGraphSystem,\n passNode: PassNode,\n pass: FrameGraphPass<PassData>,\n ) => void,\n execute: (\n fg: FrameGraphSystem,\n pass: FrameGraphPass<PassData>,\n views: IView[],\n ) => Promise<void>,\n tearDown?: () => void,\n ) {\n const frameGraphPass = new FrameGraphPass<PassData>();\n frameGraphPass.execute = execute;\n if (tearDown) {\n frameGraphPass.tearDown = tearDown;\n }\n frameGraphPass.name = name;\n\n const passNode = new PassNode();\n passNode.name = name;\n this.passNodes.push(passNode);\n\n this.frameGraphPasses.push(frameGraphPass);\n\n setup(this, passNode, frameGraphPass);\n\n return frameGraphPass;\n }\n\n public getPass<T>(name: string): FrameGraphPass<T> | undefined {\n return this.frameGraphPasses.find((p) => p.name === name);\n }\n\n public compile() {\n for (const pass of this.passNodes) {\n pass.refCount = pass.writes.length + (pass.hasSideEffect ? 1 : 0);\n\n pass.reads.forEach((handle) => {\n this.resourceNodes[handle.index].readerCount++;\n });\n }\n\n const stack: ResourceNode[] = [];\n for (const node of this.resourceNodes) {\n if (node.readerCount === 0) {\n stack.push(node);\n }\n }\n while (stack.length) {\n const pNode = stack.pop();\n const writer = pNode && pNode.writer;\n if (writer) {\n if (--writer.refCount === 0) {\n // this pass is culled\n // assert(!writer->hasSideEffect);\n for (const resource of writer.reads) {\n const r = this.resourceNodes[resource.index];\n if (--r.readerCount === 0) {\n stack.push(r);\n }\n }\n }\n }\n }\n\n // update the final reference counts\n this.resourceNodes.forEach((node) => {\n node.resource.refs += node.readerCount;\n });\n\n for (const pass of this.passNodes) {\n if (!pass.refCount) {\n continue;\n }\n for (const resource of pass.reads) {\n const pResource = this.resourceNodes[resource.index].resource;\n pResource.first = pResource.first ? pResource.first : pass;\n pResource.last = pass;\n }\n for (const resource of pass.writes) {\n const pResource = this.resourceNodes[resource.index].resource;\n pResource.first = pResource.first ? pResource.first : pass;\n pResource.last = pass;\n }\n }\n\n for (let priority = 0; priority < 2; priority++) {\n for (const resoureNode of this.resourceNodes) {\n const resource = resoureNode.resource;\n if (resource.priority === priority && resource.refs) {\n const pFirst = resource.first;\n const pLast = resource.last;\n if (pFirst && pLast) {\n pFirst.devirtualize.push(resource);\n pLast.destroy.push(resource);\n }\n }\n }\n }\n }\n\n public async executePassNodes(views: IView[]) {\n for (const [index, node] of this.passNodes.entries()) {\n if (node.refCount) {\n for (const resource of node.devirtualize) {\n resource.preExecuteDevirtualize(this.engine);\n }\n\n for (const resource of node.destroy) {\n resource.preExecuteDestroy(this.engine);\n }\n\n await this.frameGraphPasses[index].execute(\n this,\n this.frameGraphPasses[index],\n views,\n );\n\n for (const resource of node.devirtualize) {\n resource.postExecuteDevirtualize(this.engine);\n }\n\n for (const resource of node.destroy) {\n resource.postExecuteDestroy(this.engine);\n }\n }\n }\n this.reset();\n }\n\n public reset() {\n this.passNodes = [];\n this.resourceNodes = [];\n this.frameGraphPasses = [];\n }\n\n public getResourceNode(r: FrameGraphHandle) {\n return this.resourceNodes[r.index];\n }\n\n public createResourceNode(resourceEntry: ResourceEntry) {\n const resourceNode = new ResourceNode();\n resourceNode.resource = resourceEntry;\n resourceNode.version = resourceEntry.version;\n\n this.resourceNodes.push(resourceNode);\n\n const fgh = new FrameGraphHandle();\n fgh.index = this.resourceNodes.length - 1;\n\n return fgh;\n }\n\n public createTexture(\n passNode: PassNode,\n name: string,\n descriptor: TextureDescriptor,\n ) {\n const resource = new ResourceEntry();\n resource.name = name;\n resource.descriptor = descriptor;\n return this.createResourceNode(resource);\n }\n\n public createRenderTarget(\n passNode: PassNode,\n name: string,\n descriptor: TextureDescriptor,\n ) {\n const resource = new ResourceEntry();\n resource.name = name;\n resource.descriptor = descriptor;\n return this.createResourceNode(resource);\n }\n\n public present(input: FrameGraphHandle) {\n this.addPass<{}>(\n 'Present',\n (fg, passNode) => {\n passNode.read(input);\n passNode.hasSideEffect = true;\n },\n async () => {\n // 不需要执行\n },\n );\n }\n}\n","export function getUniformLengthByType(type: string): number {\n let arrayLength = 0;\n switch (type) {\n case 'vec2':\n case 'ivec2':\n arrayLength = 2;\n break;\n case 'vec3':\n case 'ivec3':\n arrayLength = 3;\n break;\n case 'vec4':\n case 'ivec4':\n case 'mat2':\n arrayLength = 4;\n break;\n case 'mat3':\n arrayLength = 9;\n break;\n case 'mat4':\n arrayLength = 16;\n break;\n default:\n }\n return arrayLength;\n}\n\nconst uniformRegExp = /uniform\\s+(bool|float|int|vec2|vec3|vec4|ivec2|ivec3|ivec4|mat2|mat3|mat4|sampler2D|samplerCube)\\s+([\\s\\S]*?);/g;\nexport function extractUniforms(\n content: string,\n): {\n content: string;\n uniforms: {\n [key: string]: any;\n };\n} {\n const uniforms = {};\n content = content.replace(uniformRegExp, (_, type, c) => {\n const defaultValues = c.split(':');\n const uniformName = defaultValues[0].trim();\n let defaultValue: any = '';\n if (defaultValues.length > 1) {\n defaultValue = defaultValues[1].trim();\n }\n\n // set default value for uniform according to its type\n // eg. vec2 u -> [0.0, 0.0]\n switch (type) {\n case 'bool':\n defaultValue = defaultValue === 'true';\n break;\n case 'float':\n case 'int':\n defaultValue = Number(defaultValue);\n break;\n case 'vec2':\n case 'vec3':\n case 'vec4':\n case 'ivec2':\n case 'ivec3':\n case 'ivec4':\n case 'mat2':\n case 'mat3':\n case 'mat4':\n if (defaultValue) {\n defaultValue = defaultValue\n .replace('[', '')\n .replace(']', '')\n .split(',')\n .reduce((prev: number[], cur: string) => {\n prev.push(Number(cur.trim()));\n return prev;\n }, []);\n } else {\n defaultValue = new Array(getUniformLengthByType(type)).fill(0);\n }\n break;\n default:\n }\n\n // @ts-ignore\n uniforms[uniformName] = defaultValue;\n return `uniform ${type} ${uniformName};\\n`;\n });\n return {\n content,\n uniforms,\n };\n}\n","import { injectable } from 'inversify';\nimport { extractUniforms } from '../../utils/shader-module';\nimport { uniq } from '../../utils/uniq';\nimport pickingFrag from './shaders/webgl.picking.frag.glsl';\nimport pickingVert from './shaders/webgl.picking.vert.glsl';\nimport sdf2dFrag from './shaders/webgl.sdf2d.frag.glsl';\n\nconst precisionRegExp = /precision\\s+(high|low|medium)p\\s+float/;\nconst globalDefaultprecision =\n '#ifdef GL_FRAGMENT_PRECISION_HIGH\\n precision highp float;\\n #else\\n precision mediump float;\\n#endif\\n';\nconst includeRegExp = /#pragma include ([\"^+\"]?[\"\\ \"[a-zA-Z_0-9](.*)\"]*?)/g;\n\nimport { IUniform } from '../../components/renderer/IUniform';\n\n/**\n * 提供 ShaderModule 管理服务\n */\n\nexport interface IModuleParams {\n vs?: string;\n fs?: string;\n uniforms?: {\n [key: string]: IUniform;\n };\n}\n\nexport interface IShaderModuleService {\n registerModule(moduleName: string, moduleParams: IModuleParams): void;\n getModule(moduleName: string): IModuleParams;\n\n /**\n * 注册内置 shader module\n */\n registerBuiltinModules(): void;\n destroy(): void;\n}\n\n@injectable()\nexport default class ShaderModuleService implements IShaderModuleService {\n private moduleCache: { [key: string]: IModuleParams } = {};\n private rawContentCache: { [key: string]: IModuleParams } = {};\n\n public registerBuiltinModules() {\n this.destroy();\n this.registerModule('picking', { vs: pickingVert, fs: pickingFrag });\n this.registerModule('sdf2d', { vs: '', fs: sdf2dFrag });\n }\n\n public registerModule(moduleName: string, moduleParams: IModuleParams) {\n // prevent registering the same module multiple times\n if (this.rawContentCache[moduleName]) {\n return;\n }\n\n const { vs = '', fs = '', uniforms: declaredUniforms } = moduleParams;\n const { content: extractedVS, uniforms: vsUniforms } = extractUniforms(vs);\n const { content: extractedFS, uniforms: fsUniforms } = extractUniforms(fs);\n\n this.rawContentCache[moduleName] = {\n fs: extractedFS,\n uniforms: {\n ...vsUniforms,\n ...fsUniforms,\n ...declaredUniforms,\n },\n vs: extractedVS,\n };\n }\n public destroy() {\n this.moduleCache = {};\n this.rawContentCache = {};\n }\n public getModule(moduleName: string): IModuleParams {\n if (this.moduleCache[moduleName]) {\n return this.moduleCache[moduleName];\n }\n\n const rawVS = this.rawContentCache[moduleName].vs || '';\n const rawFS = this.rawContentCache[moduleName].fs || '';\n\n const { content: vs, includeList: vsIncludeList } = this.processModule(\n rawVS,\n [],\n 'vs',\n );\n const { content: fs, includeList: fsIncludeList } = this.processModule(\n rawFS,\n [],\n 'fs',\n );\n let compiledFs = fs;\n // TODO: extract uniforms and their default values from GLSL\n const uniforms: {\n [key: string]: any;\n } = uniq(vsIncludeList.concat(fsIncludeList).concat(moduleName)).reduce(\n (prev, cur: string) => {\n return {\n ...prev,\n ...this.rawContentCache[cur].uniforms,\n };\n },\n {},\n );\n\n /**\n * set default precision for fragment shader\n * https://stackoverflow.com/questions/28540290/why-it-is-necessary-to-set-precision-for-the-fragment-shader\n */\n if (!precisionRegExp.test(fs)) {\n compiledFs = globalDefaultprecision + fs;\n }\n\n this.moduleCache[moduleName] = {\n fs: compiledFs.trim(),\n uniforms,\n vs: vs.trim(),\n };\n return this.moduleCache[moduleName];\n }\n\n private processModule(\n rawContent: string,\n includeList: string[],\n type: 'vs' | 'fs',\n ): {\n content: string;\n includeList: string[];\n } {\n const compiled = rawContent.replace(includeRegExp, (_, strMatch) => {\n const includeOpt = strMatch.split(' ');\n const includeName = includeOpt[0].replace(/\"/g, '');\n\n if (includeList.indexOf(includeName) > -1) {\n return '';\n }\n\n const txt = this.rawContentCache[includeName][type];\n includeList.push(includeName);\n\n const { content } = this.processModule(txt || '', includeList, type);\n return content;\n });\n\n return {\n content: compiled,\n includeList,\n };\n }\n}\n","export function uniq<T>(array: T[]): T[] {\n return array.filter((v, i, a) => a.indexOf(v) === i);\n}","/** Used as references for various `Number` constants. */\nconst MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nconst argsTag = '[object Arguments]';\nconst arrayTag = '[object Array]';\nconst boolTag = '[object Boolean]';\nconst dateTag = '[object Date]';\nconst errorTag = '[object Error]';\nconst funcTag = '[object Function]';\nconst mapTag = '[object Map]';\nconst numberTag = '[object Number]';\nconst objectTag = '[object Object]';\nconst regexpTag = '[object RegExp]';\nconst setTag = '[object Set]';\nconst stringTag = '[object String]';\nconst weakMapTag = '[object WeakMap]';\n\nconst arrayBufferTag = '[object ArrayBuffer]';\nconst dataViewTag = '[object DataView]';\nconst float32Tag = '[object Float32Array]';\nconst float64Tag = '[object Float64Array]';\nconst int8Tag = '[object Int8Array]';\nconst int16Tag = '[object Int16Array]';\nconst int32Tag = '[object Int32Array]';\nconst uint8Tag = '[object Uint8Array]';\nconst uint8ClampedTag = '[object Uint8ClampedArray]';\nconst uint16Tag = '[object Uint16Array]';\nconst uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nconst typedArrayTags: Record<string, boolean> = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] = typedArrayTags[\n int8Tag\n] = typedArrayTags[int16Tag] = typedArrayTags[int32Tag] = typedArrayTags[\n uint8Tag\n] = typedArrayTags[uint8ClampedTag] = typedArrayTags[\n uint16Tag\n] = typedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] = typedArrayTags[\n arrayBufferTag\n] = typedArrayTags[boolTag] = typedArrayTags[dataViewTag] = typedArrayTags[\n dateTag\n] = typedArrayTags[errorTag] = typedArrayTags[funcTag] = typedArrayTags[\n mapTag\n] = typedArrayTags[numberTag] = typedArrayTags[objectTag] = typedArrayTags[\n regexpTag\n] = typedArrayTags[setTag] = typedArrayTags[stringTag] = typedArrayTags[\n weakMapTag\n] = false;\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func: any) {\n return function(value: any) {\n return func(value);\n };\n}\n\n/** Used for built-in method references. */\nconst objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nconst objectToString = objectProto.toString;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value: any) {\n return (\n isObjectLike(value) &&\n isLength(value.length) &&\n !!typedArrayTags[objectToString.call(value)]\n );\n}\n\nfunction isLength(value: any) {\n return (\n typeof value === 'number' &&\n value > -1 &&\n value % 1 === 0 &&\n value <= MAX_SAFE_INTEGER\n );\n}\n\nfunction isObjectLike(value: any) {\n return !!value && typeof value === 'object';\n}\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nexport const isTypedArray = baseIsTypedArray;\n","import { mat3, mat4, vec3, vec4 } from 'gl-matrix';\nimport { Entity } from '../..';\nimport { Component } from '../../ComponentManager';\nimport { NonFunctionProperties } from '../../ComponentManager';\nimport { AABB } from '../../shape/AABB';\nimport { isTypedArray } from '../../utils/is-typedarray';\nimport { IBuffer } from '../renderer/IBuffer';\nimport { IElements } from '../renderer/IElements';\nimport { BufferData } from '../renderer/IRendererService';\n\nexport class GeometryComponent extends Component<GeometryComponent> {\n public dirty: boolean = true;\n\n public attributes: Array<\n {\n dirty: boolean;\n name: string;\n data?: BufferData;\n buffer?: IBuffer;\n // 结合 Compute Pipeline 时,需要在运行时获取 PingPong buffer\n bufferGetter?: () => IBuffer;\n } & GPUVertexBufferLayoutDescriptor\n > = [];\n\n public indices: Uint32Array | null;\n public indicesBuffer: IElements | null;\n\n public vertexCount: number = 0;\n\n // instanced count\n public maxInstancedCount: number;\n\n public aabb: AABB;\n\n public entity: Entity;\n\n constructor(data: Partial<NonFunctionProperties<GeometryComponent>>) {\n super(data);\n\n Object.assign(this, data);\n }\n\n /**\n * @see https://threejs.org/docs/#api/en/core/BufferAttribute\n */\n public setAttribute(\n name: string,\n data: BufferData,\n descriptor: GPUVertexBufferLayoutDescriptor,\n bufferGetter?: () => IBuffer,\n ) {\n const existed = this.attributes.find((a) => a.name === name);\n if (!existed) {\n this.attributes.push({\n dirty: true,\n name,\n data,\n ...descriptor,\n bufferGetter,\n });\n } else {\n existed.data = data;\n existed.dirty = true;\n }\n this.dirty = true;\n return this;\n }\n\n public setIndex(data: number[] | Uint8Array | Uint16Array | Uint32Array) {\n this.indices = new Uint32Array(\n // @ts-ignore\n data.buffer ? data.buffer : (data as number[]),\n );\n this.dirty = true;\n return this;\n }\n\n /**\n * when merge all the geometries into one, we need to transform every vertex's position\n * and every face's normal\n */\n public applyMatrix(matrix: mat4) {\n const positionAttribute = this.attributes.find(\n ({ name }) => name === 'position',\n );\n const normalAttribute = this.attributes.find(\n ({ name }) => name === 'normal',\n );\n\n if (positionAttribute) {\n positionAttribute.dirty = true;\n\n // @ts-ignore\n if (positionAttribute.data && positionAttribute.data.length) {\n // @ts-ignore\n for (let i = 0; i < positionAttribute.data.length; i += 3) {\n const position = vec4.fromValues(\n // @ts-ignore\n positionAttribute.data[i] as number,\n // @ts-ignore\n positionAttribute.data[i + 1] as number,\n // @ts-ignore\n positionAttribute.data[i + 2] as number,\n 1,\n );\n vec4.transformMat4(position, position, matrix);\n if (isTypedArray(positionAttribute.data)) {\n // @ts-ignore\n positionAttribute.data.set(\n [position[0], position[1], position[2]],\n i,\n );\n } else {\n // @ts-ignore\n positionAttribute.data[i] = position[0];\n // @ts-ignore\n positionAttribute.data[i + 1] = position[1];\n // @ts-ignore\n positionAttribute.data[i + 2] = position[2];\n }\n }\n }\n }\n\n if (normalAttribute) {\n const normalMatrix = mat3.normalFromMat4(mat3.create(), matrix);\n // @ts-ignore\n if (normalAttribute.data && normalAttribute.data.length) {\n // @ts-ignore\n for (let i = 0; i < normalAttribute.data.length; i += 3) {\n const normal = vec3.fromValues(\n // @ts-ignore\n normalAttribute.data[i] as number,\n // @ts-ignore\n normalAttribute.data[i + 1] as number,\n // @ts-ignore\n normalAttribute.data[i + 2] as number,\n );\n vec3.transformMat3(normal, normal, normalMatrix);\n vec3.normalize(normal, normal);\n if (isTypedArray(normalAttribute.data)) {\n // @ts-ignore\n normalAttribute.data.set([normal[0], normal[1], normal[2]], i);\n } else {\n // @ts-ignore\n normalAttribute.data[i] = normal[0];\n // @ts-ignore\n normalAttribute.data[i + 1] = normal[1];\n // @ts-ignore\n normalAttribute.data[i + 2] = normal[2];\n }\n }\n }\n }\n }\n}\n","import { __extends } from \"tslib\";\nimport { max, min } from '@antv/util';\nimport Element from './element';\nimport { isFunction, isObject, each, removeFromArray, upperFirst, isAllowCapture } from '../util/util';\nvar SHAPE_MAP = {};\nvar INDEX = '_INDEX';\n/**\n * 设置 canvas\n * @param {IElement} element 元素\n * @param {ICanvas} canvas 画布\n */\nfunction setCanvas(element, canvas) {\n element.set('canvas', canvas);\n if (element.isGroup()) {\n var children = element.get('children');\n if (children.length) {\n children.forEach(function (child) {\n setCanvas(child, canvas);\n });\n }\n }\n}\n/**\n * 设置 timeline\n * @param {IElement} element 元素\n * @param {Timeline} timeline 时间轴\n */\nfunction setTimeline(element, timeline) {\n element.set('timeline', timeline);\n if (element.isGroup()) {\n var children = element.get('children');\n if (children.length) {\n children.forEach(function (child) {\n setTimeline(child, timeline);\n });\n }\n }\n}\nfunction contains(container, element) {\n var children = container.getChildren();\n return children.indexOf(element) >= 0;\n}\nfunction removeChild(container, element, destroy) {\n if (destroy === void 0) { destroy = true; }\n // 不再调用 element.remove() 方法,会出现循环调用\n if (destroy) {\n element.destroy();\n }\n else {\n element.set('parent', null);\n element.set('canvas', null);\n }\n removeFromArray(container.getChildren(), element);\n}\nfunction getComparer(compare) {\n return function (left, right) {\n var result = compare(left, right);\n return result === 0 ? left[INDEX] - right[INDEX] : result;\n };\n}\nvar Container = /** @class */ (function (_super) {\n __extends(Container, _super);\n function Container() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n Container.prototype.isCanvas = function () {\n return false;\n };\n // 根据子节点确定 BBox\n Container.prototype.getBBox = function () {\n // 所有的值可能在画布的可视区外\n var minX = Infinity;\n var maxX = -Infinity;\n var minY = Infinity;\n var maxY = -Infinity;\n var xArr = [];\n var yArr = [];\n // 将可见元素、图形以及不为空的图形分组筛选出来,用于包围盒合并\n var children = this.getChildren().filter(function (child) {\n return child.get('visible') && (!child.isGroup() || (child.isGroup() && child.getChildren().length > 0));\n });\n if (children.length > 0) {\n each(children, function (child) {\n var box = child.getBBox();\n xArr.push(box.minX, box.maxX);\n yArr.push(box.minY, box.maxY);\n });\n minX = min(xArr);\n maxX = max(xArr);\n minY = min(yArr);\n maxY = max(yArr);\n }\n else {\n minX = 0;\n maxX = 0;\n minY = 0;\n maxY = 0;\n }\n var box = {\n x: minX,\n y: minY,\n minX: minX,\n minY: minY,\n maxX: maxX,\n maxY: maxY,\n width: maxX - minX,\n height: maxY - minY,\n };\n return box;\n };\n // 获取画布的包围盒\n Container.prototype.getCanvasBBox = function () {\n var minX = Infinity;\n var maxX = -Infinity;\n var minY = Infinity;\n var maxY = -Infinity;\n var xArr = [];\n var yArr = [];\n // 将可见元素、图形以及不为空的图形分组筛选出来,用于包围盒合并\n var children = this.getChildren().filter(function (child) {\n return child.get('visible') && (!child.isGroup() || (child.isGroup() && child.getChildren().length > 0));\n });\n if (children.length > 0) {\n each(children, function (child) {\n var box = child.getCanvasBBox();\n xArr.push(box.minX, box.maxX);\n yArr.push(box.minY, box.maxY);\n });\n minX = min(xArr);\n maxX = max(xArr);\n minY = min(yArr);\n maxY = max(yArr);\n }\n else {\n minX = 0;\n maxX = 0;\n minY = 0;\n maxY = 0;\n }\n var box = {\n x: minX,\n y: minY,\n minX: minX,\n minY: minY,\n maxX: maxX,\n maxY: maxY,\n width: maxX - minX,\n height: maxY - minY,\n };\n return box;\n };\n Container.prototype.getDefaultCfg = function () {\n var cfg = _super.prototype.getDefaultCfg.call(this);\n cfg['children'] = [];\n return cfg;\n };\n Container.prototype.onAttrChange = function (name, value, originValue) {\n _super.prototype.onAttrChange.call(this, name, value, originValue);\n if (name === 'matrix') {\n var totalMatrix = this.getTotalMatrix();\n this._applyChildrenMarix(totalMatrix);\n }\n };\n // 不但应用到自己身上还要应用于子元素\n Container.prototype.applyMatrix = function (matrix) {\n var preTotalMatrix = this.getTotalMatrix();\n _super.prototype.applyMatrix.call(this, matrix);\n var totalMatrix = this.getTotalMatrix();\n // totalMatrix 没有发生变化时,这里仅考虑两者都为 null 时\n // 不继续向下传递矩阵\n if (totalMatrix === preTotalMatrix) {\n return;\n }\n this._applyChildrenMarix(totalMatrix);\n };\n // 在子元素上设置矩阵\n Container.prototype._applyChildrenMarix = function (totalMatrix) {\n var children = this.getChildren();\n each(children, function (child) {\n child.applyMatrix(totalMatrix);\n });\n };\n // 兼容老版本的接口\n Container.prototype.addShape = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var type = args[0];\n var cfg = args[1];\n if (isObject(type)) {\n cfg = type;\n }\n else {\n cfg['type'] = type;\n }\n var shapeType = SHAPE_MAP[cfg.type];\n if (!shapeType) {\n shapeType = upperFirst(cfg.type);\n SHAPE_MAP[cfg.type] = shapeType;\n }\n var ShapeBase = this.getShapeBase();\n var shape = new ShapeBase[shapeType](cfg);\n this.add(shape);\n return shape;\n };\n Container.prototype.addGroup = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var groupClass = args[0], cfg = args[1];\n var group;\n if (isFunction(groupClass)) {\n if (cfg) {\n group = new groupClass(cfg);\n }\n else {\n group = new groupClass({\n // canvas,\n parent: this,\n });\n }\n }\n else {\n var tmpCfg = groupClass || {};\n var TmpGroupClass = this.getGroupBase();\n group = new TmpGroupClass(tmpCfg);\n }\n this.add(group);\n return group;\n };\n Container.prototype.getCanvas = function () {\n var canvas;\n if (this.isCanvas()) {\n canvas = this;\n }\n else {\n canvas = this.get('canvas');\n }\n return canvas;\n };\n Container.prototype.getShape = function (x, y, ev) {\n // 如果不支持拾取,则直接返回\n if (!isAllowCapture(this)) {\n return null;\n }\n var children = this.getChildren();\n var shape;\n // 如果容器是 group\n if (!this.isCanvas()) {\n var v = [x, y, 1];\n // 将 x, y 转换成对应于 group 的局部坐标\n v = this.invertFromMatrix(v);\n if (!this.isClipped(v[0], v[1])) {\n shape = this._findShape(children, v[0], v[1], ev);\n }\n }\n else {\n shape = this._findShape(children, x, y, ev);\n }\n return shape;\n };\n Container.prototype._findShape = function (children, x, y, ev) {\n var shape = null;\n for (var i = children.length - 1; i >= 0; i--) {\n var child = children[i];\n if (isAllowCapture(child)) {\n if (child.isGroup()) {\n shape = child.getShape(x, y, ev);\n }\n else if (child.isHit(x, y)) {\n shape = child;\n }\n }\n if (shape) {\n break;\n }\n }\n return shape;\n };\n Container.prototype.add = function (element) {\n var canvas = this.getCanvas();\n var children = this.getChildren();\n var timeline = this.get('timeline');\n var preParent = element.getParent();\n if (preParent) {\n removeChild(preParent, element, false);\n }\n element.set('parent', this);\n if (canvas) {\n setCanvas(element, canvas);\n }\n if (timeline) {\n setTimeline(element, timeline);\n }\n children.push(element);\n element.onCanvasChange('add');\n this._applyElementMatrix(element);\n };\n // 将当前容器的矩阵应用到子元素\n Container.prototype._applyElementMatrix = function (element) {\n var totalMatrix = this.getTotalMatrix();\n // 添加图形或者分组时,需要把当前图元的矩阵设置进去\n if (totalMatrix) {\n element.applyMatrix(totalMatrix);\n }\n };\n Container.prototype.getChildren = function () {\n return this.get('children');\n };\n Container.prototype.sort = function () {\n var children = this.getChildren();\n // 稳定排序\n each(children, function (child, index) {\n child[INDEX] = index;\n return child;\n });\n children.sort(getComparer(function (obj1, obj2) {\n return obj1.get('zIndex') - obj2.get('zIndex');\n }));\n this.onCanvasChange('sort');\n };\n Container.prototype.clear = function () {\n this.set('clearing', true);\n if (this.destroyed) {\n return;\n }\n var children = this.getChildren();\n for (var i = children.length - 1; i >= 0; i--) {\n children[i].destroy(); // 销毁子元素\n }\n this.set('children', []);\n this.onCanvasChange('clear');\n this.set('clearing', false);\n };\n Container.prototype.destroy = function () {\n if (this.get('destroyed')) {\n return;\n }\n this.clear();\n _super.prototype.destroy.call(this);\n };\n /**\n * 获取第一个子元素\n * @return {IElement} 第一个元素\n */\n Container.prototype.getFirst = function () {\n return this.getChildByIndex(0);\n };\n /**\n * 获取最后一个子元素\n * @return {IElement} 元素\n */\n Container.prototype.getLast = function () {\n var children = this.getChildren();\n return this.getChildByIndex(children.length - 1);\n };\n /**\n * 根据索引获取子元素\n * @return {IElement} 第一个元素\n */\n Container.prototype.getChildByIndex = function (index) {\n var children = this.getChildren();\n return children[index];\n };\n /**\n * 子元素的数量\n * @return {number} 子元素数量\n */\n Container.prototype.getCount = function () {\n var children = this.getChildren();\n return children.length;\n };\n /**\n * 是否包含对应元素\n * @param {IElement} element 元素\n * @return {boolean}\n */\n Container.prototype.contain = function (element) {\n var children = this.getChildren();\n return children.indexOf(element) > -1;\n };\n /**\n * 移除对应子元素\n * @param {IElement} element 子元素\n * @param {boolean} destroy 是否销毁子元素,默认为 true\n */\n Container.prototype.removeChild = function (element, destroy) {\n if (destroy === void 0) { destroy = true; }\n if (this.contain(element)) {\n element.remove(destroy);\n }\n };\n /**\n * 查找所有匹配的元素\n * @param {ElementFilterFn} fn 匹配函数\n * @return {IElement[]} 元素数组\n */\n Container.prototype.findAll = function (fn) {\n var rst = [];\n var children = this.getChildren();\n each(children, function (element) {\n if (fn(element)) {\n rst.push(element);\n }\n if (element.isGroup()) {\n rst = rst.concat(element.findAll(fn));\n }\n });\n return rst;\n };\n /**\n * 查找元素,找到第一个返回\n * @param {ElementFilterFn} fn 匹配函数\n * @return {IElement|null} 元素,可以为空\n */\n Container.prototype.find = function (fn) {\n var rst = null;\n var children = this.getChildren();\n each(children, function (element) {\n if (fn(element)) {\n rst = element;\n }\n else if (element.isGroup()) {\n rst = element.find(fn);\n }\n if (rst) {\n return false;\n }\n });\n return rst;\n };\n /**\n * 根据 ID 查找元素\n * @param {string} id 元素 id\n * @return {IElement|null} 元素\n */\n Container.prototype.findById = function (id) {\n return this.find(function (element) {\n return element.get('id') === id;\n });\n };\n /**\n * 该方法即将废弃,不建议使用\n * 根据 className 查找元素\n * TODO: 该方式定义暂时只给 G6 3.3 以后的版本使用,待 G6 中的 findByClassName 方法移除后,G 也需要同步移除\n * @param {string} className 元素 className\n * @return {IElement | null} 元素\n */\n Container.prototype.findByClassName = function (className) {\n return this.find(function (element) {\n return element.get('className') === className;\n });\n };\n /**\n * 根据 name 查找元素列表\n * @param {string} name 元素名称\n * @return {IElement[]} 元素\n */\n Container.prototype.findAllByName = function (name) {\n return this.findAll(function (element) {\n return element.get('name') === name;\n });\n };\n return Container;\n}(Element));\nexport default Container;\n//# sourceMappingURL=container.js.map","import { __extends } from \"tslib\";\nimport { each, isEqual, isFunction, isNumber, isObject, isArray, noop, mix, upperFirst, uniqueId } from '@antv/util';\nimport { ext } from '@antv/matrix-util';\nimport { removeFromArray, isParent } from '../util/util';\nimport { multiplyMatrix, multiplyVec2, invert } from '../util/matrix';\nimport Base from './base';\nvar transform = ext.transform;\nvar MATRIX = 'matrix';\nvar CLONE_CFGS = ['zIndex', 'capture', 'visible', 'type'];\n// 可以在 toAttrs 中设置,但不属于绘图属性的字段\nvar RESERVED_PORPS = ['repeat'];\nvar DELEGATION_SPLIT = ':';\nvar WILDCARD = '*';\n// 需要考虑数组嵌套数组的场景\n// 数组嵌套对象的场景不考虑\nfunction _cloneArrayAttr(arr) {\n var result = [];\n for (var i = 0; i < arr.length; i++) {\n if (isArray(arr[i])) {\n result.push([].concat(arr[i]));\n }\n else {\n result.push(arr[i]);\n }\n }\n return result;\n}\nfunction getFormatFromAttrs(toAttrs, shape) {\n var fromAttrs = {};\n var attrs = shape.attrs;\n for (var k in toAttrs) {\n fromAttrs[k] = attrs[k];\n }\n return fromAttrs;\n}\nfunction getFormatToAttrs(props, shape) {\n var toAttrs = {};\n var attrs = shape.attr();\n each(props, function (v, k) {\n if (RESERVED_PORPS.indexOf(k) === -1 && !isEqual(attrs[k], v)) {\n toAttrs[k] = v;\n }\n });\n return toAttrs;\n}\nfunction checkExistedAttrs(animations, animation) {\n if (animation.onFrame) {\n return animations;\n }\n var startTime = animation.startTime, delay = animation.delay, duration = animation.duration;\n var hasOwnProperty = Object.prototype.hasOwnProperty;\n each(animations, function (item) {\n // 后一个动画开始执行的时间 < 前一个动画的结束时间 && 后一个动画的执行时间 > 前一个动画的延迟\n if (startTime + delay < item.startTime + item.delay + item.duration && duration > item.delay) {\n each(animation.toAttrs, function (v, k) {\n if (hasOwnProperty.call(item.toAttrs, k)) {\n delete item.toAttrs[k];\n delete item.fromAttrs[k];\n }\n });\n }\n });\n return animations;\n}\nvar Element = /** @class */ (function (_super) {\n __extends(Element, _super);\n function Element(cfg) {\n var _this = _super.call(this, cfg) || this;\n /**\n * @protected\n * 图形属性\n * @type {ShapeAttrs}\n */\n _this.attrs = {};\n var attrs = _this.getDefaultAttrs();\n mix(attrs, cfg.attrs);\n _this.attrs = attrs;\n _this.initAttrs(attrs);\n _this.initAnimate(); // 初始化动画\n return _this;\n }\n // override\n Element.prototype.getDefaultCfg = function () {\n return {\n visible: true,\n capture: true,\n zIndex: 0,\n };\n };\n /**\n * @protected\n * 获取默认的属相\n */\n Element.prototype.getDefaultAttrs = function () {\n return {\n matrix: this.getDefaultMatrix(),\n opacity: 1,\n };\n };\n /**\n * @protected\n * 一些方法调用会引起画布变化\n * @param {ChangeType} changeType 改变的类型\n */\n Element.prototype.onCanvasChange = function (changeType) { };\n /**\n * @protected\n * 初始化属性,有些属性需要加工\n * @param {object} attrs 属性值\n */\n Element.prototype.initAttrs = function (attrs) { };\n /**\n * @protected\n * 初始化动画\n */\n Element.prototype.initAnimate = function () {\n this.set('animable', true);\n this.set('animating', false);\n };\n Element.prototype.isGroup = function () {\n return false;\n };\n Element.prototype.getParent = function () {\n return this.get('parent');\n };\n Element.prototype.getCanvas = function () {\n return this.get('canvas');\n };\n Element.prototype.attr = function () {\n var _a;\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var name = args[0], value = args[1];\n if (!name)\n return this.attrs;\n if (isObject(name)) {\n for (var k in name) {\n this.setAttr(k, name[k]);\n }\n this.afterAttrsChange(name);\n return this;\n }\n if (args.length === 2) {\n this.setAttr(name, value);\n this.afterAttrsChange((_a = {},\n _a[name] = value,\n _a));\n return this;\n }\n return this.attrs[name];\n };\n // 是否被裁剪,被裁剪则不显示,不参与拾取\n Element.prototype.isClipped = function (refX, refY) {\n var clip = this.getClip();\n return clip && !clip.isHit(refX, refY);\n };\n /**\n * 内部设置属性值的接口\n * @param {string} name 属性名\n * @param {any} value 属性值\n */\n Element.prototype.setAttr = function (name, value) {\n var originValue = this.attrs[name];\n if (originValue !== value) {\n this.attrs[name] = value;\n this.onAttrChange(name, value, originValue);\n }\n };\n /**\n * @protected\n * 属性值发生改变\n * @param {string} name 属性名\n * @param {any} value 属性值\n * @param {any} originValue 属性值\n */\n Element.prototype.onAttrChange = function (name, value, originValue) {\n if (name === 'matrix') {\n this.set('totalMatrix', null);\n }\n };\n /**\n * 属性更改后需要做的事情\n * @protected\n */\n Element.prototype.afterAttrsChange = function (targetAttrs) {\n if (this.cfg.isClipShape) {\n var applyTo = this.cfg.applyTo;\n if (applyTo) {\n applyTo.onCanvasChange('clip');\n }\n }\n else {\n this.onCanvasChange('attr');\n }\n };\n Element.prototype.show = function () {\n // 不是高频操作直接使用 set\n this.set('visible', true);\n this.onCanvasChange('show');\n return this;\n };\n Element.prototype.hide = function () {\n // 不是高频操作直接使用 set\n this.set('visible', false);\n this.onCanvasChange('hide');\n return this;\n };\n Element.prototype.setZIndex = function (zIndex) {\n this.set('zIndex', zIndex);\n var parent = this.getParent();\n if (parent) {\n // 改变 zIndex 不应该立即触发渲染 (调用 onCanvasChange('zIndex')),需要经过 sort 再触发\n parent.sort();\n }\n return this;\n };\n Element.prototype.toFront = function () {\n var parent = this.getParent();\n if (!parent) {\n return;\n }\n var children = parent.getChildren();\n var el = this.get('el');\n var index = children.indexOf(this);\n children.splice(index, 1);\n children.push(this);\n this.onCanvasChange('zIndex');\n };\n Element.prototype.toBack = function () {\n var parent = this.getParent();\n if (!parent) {\n return;\n }\n var children = parent.getChildren();\n var el = this.get('el');\n var index = children.indexOf(this);\n children.splice(index, 1);\n children.unshift(this);\n this.onCanvasChange('zIndex');\n };\n Element.prototype.remove = function (destroy) {\n if (destroy === void 0) { destroy = true; }\n var parent = this.getParent();\n if (parent) {\n removeFromArray(parent.getChildren(), this);\n if (!parent.get('clearing')) {\n // 如果父元素正在清理,当前元素不触发 remove\n this.onCanvasChange('remove');\n }\n }\n else {\n this.onCanvasChange('remove');\n }\n if (destroy) {\n this.destroy();\n }\n };\n Element.prototype.resetMatrix = function () {\n this.attr(MATRIX, this.getDefaultMatrix());\n this.onCanvasChange('matrix');\n };\n Element.prototype.getMatrix = function () {\n return this.attr(MATRIX);\n };\n Element.prototype.setMatrix = function (m) {\n this.attr(MATRIX, m);\n this.onCanvasChange('matrix');\n };\n // 获取总的 matrix\n Element.prototype.getTotalMatrix = function () {\n var totalMatrix = this.cfg.totalMatrix;\n if (!totalMatrix) {\n var currentMatrix = this.attr('matrix');\n var parentMatrix = this.cfg.parentMatrix;\n if (parentMatrix && currentMatrix) {\n totalMatrix = multiplyMatrix(parentMatrix, currentMatrix);\n }\n else {\n totalMatrix = currentMatrix || parentMatrix;\n }\n this.set('totalMatrix', totalMatrix);\n }\n return totalMatrix;\n };\n // 上层分组设置 matrix\n Element.prototype.applyMatrix = function (matrix) {\n var currentMatrix = this.attr('matrix');\n var totalMatrix = null;\n if (matrix && currentMatrix) {\n totalMatrix = multiplyMatrix(matrix, currentMatrix);\n }\n else {\n totalMatrix = currentMatrix || matrix;\n }\n this.set('totalMatrix', totalMatrix);\n this.set('parentMatrix', matrix);\n };\n /**\n * @protected\n * 获取默认的矩阵\n * @returns {number[]|null} 默认的矩阵\n */\n Element.prototype.getDefaultMatrix = function () {\n return null;\n };\n // 将向量应用设置的矩阵\n Element.prototype.applyToMatrix = function (v) {\n var matrix = this.attr('matrix');\n if (matrix) {\n return multiplyVec2(matrix, v);\n }\n return v;\n };\n // 根据设置的矩阵,将向量转换相对于图形/分组的位置\n Element.prototype.invertFromMatrix = function (v) {\n var matrix = this.attr('matrix');\n if (matrix) {\n var invertMatrix = invert(matrix);\n if (invertMatrix) {\n return multiplyVec2(invertMatrix, v);\n }\n }\n return v;\n };\n // 设置 clip\n Element.prototype.setClip = function (clipCfg) {\n var canvas = this.getCanvas();\n // 应该只设置当前元素的 clip,不应该去修改 clip 本身,方便 clip 被复用\n // TODO: setClip 的传参既 shape 配置,也支持 shape 对象\n // const preShape = this.get('clipShape');\n // if (preShape) {\n // // 将之前的 clipShape 销毁\n // preShape.destroy();\n // }\n var clipShape = null;\n // 如果配置项为 null,则不移除 clipShape\n if (clipCfg) {\n var ShapeBase = this.getShapeBase();\n var shapeType = upperFirst(clipCfg.type);\n var Cons = ShapeBase[shapeType];\n if (Cons) {\n clipShape = new Cons({\n type: clipCfg.type,\n isClipShape: true,\n applyTo: this,\n attrs: clipCfg.attrs,\n canvas: canvas,\n });\n }\n }\n this.set('clipShape', clipShape);\n this.onCanvasChange('clip');\n return clipShape;\n };\n Element.prototype.getClip = function () {\n // 高频率调用的地方直接使用 this.cfg.xxx\n var clipShape = this.cfg.clipShape;\n // 未设置时返回 Null,保证一致性\n if (!clipShape) {\n return null;\n }\n return clipShape;\n };\n Element.prototype.clone = function () {\n var _this = this;\n var originAttrs = this.attrs;\n var attrs = {};\n each(originAttrs, function (i, k) {\n if (isArray(originAttrs[k])) {\n attrs[k] = _cloneArrayAttr(originAttrs[k]);\n }\n else {\n attrs[k] = originAttrs[k];\n }\n });\n var cons = this.constructor;\n // @ts-ignore\n var clone = new cons({ attrs: attrs });\n each(CLONE_CFGS, function (cfgName) {\n clone.set(cfgName, _this.get(cfgName));\n });\n return clone;\n };\n Element.prototype.destroy = function () {\n var destroyed = this.destroyed;\n if (destroyed) {\n return;\n }\n this.attrs = {};\n _super.prototype.destroy.call(this);\n // this.onCanvasChange('destroy');\n };\n /**\n * 是否处于动画暂停状态\n * @return {boolean} 是否处于动画暂停状态\n */\n Element.prototype.isAnimatePaused = function () {\n return this.get('_pause').isPaused;\n };\n /**\n * 执行动画,支持多种函数签名\n * 1. animate(toAttrs: ElementAttrs, duration: number, easing?: string, callback?: () => void, delay?: number)\n * 2. animate(onFrame: OnFrame, duration: number, easing?: string, callback?: () => void, delay?: number)\n * 3. animate(toAttrs: ElementAttrs, cfg: AnimateCfg)\n * 4. animate(onFrame: OnFrame, cfg: AnimateCfg)\n * 各个参数的含义为:\n * toAttrs 动画最终状态\n * onFrame 自定义帧动画函数\n * duration 动画执行时间\n * easing 动画缓动效果\n * callback 动画执行后的回调\n * delay 动画延迟时间\n */\n Element.prototype.animate = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n if (!this.get('timeline') && !this.get('canvas')) {\n return;\n }\n this.set('animating', true);\n var timeline = this.get('timeline');\n if (!timeline) {\n timeline = this.get('canvas').get('timeline');\n this.set('timeline', timeline);\n }\n var animations = this.get('animations') || [];\n // 初始化 tick\n if (!timeline.timer) {\n timeline.initTimer();\n }\n var toAttrs = args[0], duration = args[1], _a = args[2], easing = _a === void 0 ? 'easeLinear' : _a, _b = args[3], callback = _b === void 0 ? noop : _b, _c = args[4], delay = _c === void 0 ? 0 : _c;\n var onFrame;\n var repeat;\n var pauseCallback;\n var resumeCallback;\n var animateCfg;\n // 第二个参数,既可以是动画最终状态 toAttrs,也可以是自定义帧动画函数 onFrame\n if (isFunction(toAttrs)) {\n onFrame = toAttrs;\n toAttrs = {};\n }\n else if (isObject(toAttrs) && toAttrs.onFrame) {\n // 兼容 3.0 中的写法,onFrame 和 repeat 可在 toAttrs 中设置\n onFrame = toAttrs.onFrame;\n repeat = toAttrs.repeat;\n }\n // 第二个参数,既可以是执行时间 duration,也可以是动画参数 animateCfg\n if (isObject(duration)) {\n animateCfg = duration;\n duration = animateCfg.duration;\n easing = animateCfg.easing || 'easeLinear';\n delay = animateCfg.delay || 0;\n // animateCfg 中的设置优先级更高\n repeat = animateCfg.repeat || repeat || false;\n callback = animateCfg.callback || noop;\n pauseCallback = animateCfg.pauseCallback || noop;\n resumeCallback = animateCfg.resumeCallback || noop;\n }\n else {\n // 第四个参数,既可以是回调函数 callback,也可以是延迟时间 delay\n if (isNumber(callback)) {\n delay = callback;\n callback = null;\n }\n // 第三个参数,既可以是缓动参数 easing,也可以是回调函数 callback\n if (isFunction(easing)) {\n callback = easing;\n easing = 'easeLinear';\n }\n else {\n easing = easing || 'easeLinear';\n }\n }\n var formatToAttrs = getFormatToAttrs(toAttrs, this);\n var animation = {\n fromAttrs: getFormatFromAttrs(formatToAttrs, this),\n toAttrs: formatToAttrs,\n duration: duration,\n easing: easing,\n repeat: repeat,\n callback: callback,\n pauseCallback: pauseCallback,\n resumeCallback: resumeCallback,\n delay: delay,\n startTime: timeline.getTime(),\n id: uniqueId(),\n onFrame: onFrame,\n pathFormatted: false,\n };\n // 如果动画元素队列中已经有这个图形了\n if (animations.length > 0) {\n // 先检查是否需要合并属性。若有相同的动画,将该属性从前一个动画中删除,直接用后一个动画中\n animations = checkExistedAttrs(animations, animation);\n }\n else {\n // 否则将图形添加到动画元素队列\n timeline.addAnimator(this);\n }\n animations.push(animation);\n this.set('animations', animations);\n this.set('_pause', { isPaused: false });\n };\n /**\n * 停止动画\n * @param {boolean} toEnd 是否到动画的最终状态\n */\n Element.prototype.stopAnimate = function (toEnd) {\n var _this = this;\n if (toEnd === void 0) { toEnd = true; }\n var animations = this.get('animations');\n each(animations, function (animation) {\n // 将动画执行到最后一帧\n if (toEnd) {\n if (animation.onFrame) {\n _this.attr(animation.onFrame(1));\n }\n else {\n _this.attr(animation.toAttrs);\n }\n }\n if (animation.callback) {\n // 动画停止时的回调\n animation.callback();\n }\n });\n this.set('animating', false);\n this.set('animations', []);\n };\n /**\n * 暂停动画\n */\n Element.prototype.pauseAnimate = function () {\n var timeline = this.get('timeline');\n var animations = this.get('animations');\n var pauseTime = timeline.getTime();\n each(animations, function (animation) {\n animation._paused = true;\n animation._pauseTime = pauseTime;\n if (animation.pauseCallback) {\n // 动画暂停时的回调\n animation.pauseCallback();\n }\n });\n // 记录下是在什么时候暂停的\n this.set('_pause', {\n isPaused: true,\n pauseTime: pauseTime,\n });\n return this;\n };\n /**\n * 恢复动画\n */\n Element.prototype.resumeAnimate = function () {\n var timeline = this.get('timeline');\n var current = timeline.getTime();\n var animations = this.get('animations');\n var pauseTime = this.get('_pause').pauseTime;\n // 之后更新属性需要计算动画已经执行的时长,如果暂停了,就把初始时间调后\n each(animations, function (animation) {\n animation.startTime = animation.startTime + (current - pauseTime);\n animation._paused = false;\n animation._pauseTime = null;\n if (animation.resumeCallback) {\n animation.resumeCallback();\n }\n });\n this.set('_pause', {\n isPaused: false,\n });\n this.set('animations', animations);\n return this;\n };\n /**\n * 触发委托事件\n * @param {string} type 事件类型\n * @param {GraphEvent} eventObj 事件对象\n */\n Element.prototype.emitDelegation = function (type, eventObj) {\n var _this = this;\n var paths = eventObj.propagationPath;\n var events = this.getEvents();\n var relativeShape;\n if (type === 'mouseenter') {\n relativeShape = eventObj.fromShape;\n }\n else if (type === 'mouseleave') {\n relativeShape = eventObj.toShape;\n }\n var _loop_1 = function (i) {\n var element = paths[i];\n // 暂定跟 name 绑定\n var name_1 = element.get('name');\n if (name_1) {\n // 第一个 mouseenter 和 mouseleave 的停止即可,因为后面的都是前面的 Parent\n if (\n // 只有 element 是 Group 或者 Canvas 的时候,才需要判断 isParent\n (element.isGroup() || (element.isCanvas && element.isCanvas())) &&\n relativeShape &&\n isParent(element, relativeShape)) {\n return \"break\";\n }\n if (isArray(name_1)) {\n each(name_1, function (subName) {\n _this.emitDelegateEvent(element, subName, eventObj);\n });\n }\n else {\n this_1.emitDelegateEvent(element, name_1, eventObj);\n }\n }\n };\n var this_1 = this;\n // 至少有一个对象,且第一个对象为 shape\n for (var i = 0; i < paths.length; i++) {\n var state_1 = _loop_1(i);\n if (state_1 === \"break\")\n break;\n }\n };\n Element.prototype.emitDelegateEvent = function (element, name, eventObj) {\n var events = this.getEvents();\n // 事件委托的形式 name:type\n var eventName = name + DELEGATION_SPLIT + eventObj.type;\n if (events[eventName] || events[WILDCARD]) {\n // 对于通配符 *,事件名称 = 委托事件名称\n eventObj.name = eventName;\n eventObj.currentTarget = element;\n eventObj.delegateTarget = this;\n // 将委托事件的监听对象 delegateObject 挂载到事件对象上\n eventObj.delegateObject = element.get('delegateObject');\n this.emit(eventName, eventObj);\n }\n };\n /**\n * 移动元素\n * @param {number} translateX 水平移动距离\n * @param {number} translateY 垂直移动距离\n * @return {IElement} 元素\n */\n Element.prototype.translate = function (translateX, translateY) {\n if (translateX === void 0) { translateX = 0; }\n if (translateY === void 0) { translateY = 0; }\n var matrix = this.getMatrix();\n var newMatrix = transform(matrix, [['t', translateX, translateY]]);\n this.setMatrix(newMatrix);\n return this;\n };\n /**\n * 移动元素到目标位置\n * @param {number} targetX 目标位置的水平坐标\n * @param {number} targetX 目标位置的垂直坐标\n * @return {IElement} 元素\n */\n Element.prototype.move = function (targetX, targetY) {\n var x = this.attr('x') || 0;\n var y = this.attr('y') || 0;\n this.translate(targetX - x, targetY - y);\n return this;\n };\n /**\n * 移动元素到目标位置,等价于 move 方法。由于 moveTo 的语义性更强,因此在文档中推荐使用 moveTo 方法\n * @param {number} targetX 目标位置的 x 轴坐标\n * @param {number} targetY 目标位置的 y 轴坐标\n * @return {IElement} 元素\n */\n Element.prototype.moveTo = function (targetX, targetY) {\n return this.move(targetX, targetY);\n };\n /**\n * 缩放元素\n * @param {number} ratioX 水平缩放比例\n * @param {number} ratioY 垂直缩放比例\n * @return {IElement} 元素\n */\n Element.prototype.scale = function (ratioX, ratioY) {\n var matrix = this.getMatrix();\n var newMatrix = transform(matrix, [['s', ratioX, ratioY || ratioX]]);\n this.setMatrix(newMatrix);\n return this;\n };\n /**\n * 以画布左上角 (0, 0) 为中心旋转元素\n * @param {number} radian 旋转角度(弧度值)\n * @return {IElement} 元素\n */\n Element.prototype.rotate = function (radian) {\n var matrix = this.getMatrix();\n var newMatrix = transform(matrix, [['r', radian]]);\n this.setMatrix(newMatrix);\n return this;\n };\n /**\n * 以起始点为中心旋转元素\n * @param {number} radian 旋转角度(弧度值)\n * @return {IElement} 元素\n */\n Element.prototype.rotateAtStart = function (rotate) {\n var _a = this.attr(), x = _a.x, y = _a.y;\n var matrix = this.getMatrix();\n var newMatrix = transform(matrix, [\n ['t', -x, -y],\n ['r', rotate],\n ['t', x, y],\n ]);\n this.setMatrix(newMatrix);\n return this;\n };\n /**\n * 以任意点 (x, y) 为中心旋转元素\n * @param {number} radian 旋转角度(弧度值)\n * @return {IElement} 元素\n */\n Element.prototype.rotateAtPoint = function (x, y, rotate) {\n var matrix = this.getMatrix();\n var newMatrix = transform(matrix, [\n ['t', -x, -y],\n ['r', rotate],\n ['t', x, y],\n ]);\n this.setMatrix(newMatrix);\n return this;\n };\n return Element;\n}(Base));\nexport default Element;\n//# sourceMappingURL=element.js.map","var __spreadArrays = (this && this.__spreadArrays) || function () {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n};\nvar BrowserInfo = /** @class */ (function () {\n function BrowserInfo(name, version, os) {\n this.name = name;\n this.version = version;\n this.os = os;\n this.type = 'browser';\n }\n return BrowserInfo;\n}());\nexport { BrowserInfo };\nvar NodeInfo = /** @class */ (function () {\n function NodeInfo(version) {\n this.version = version;\n this.type = 'node';\n this.name = 'node';\n this.os = process.platform;\n }\n return NodeInfo;\n}());\nexport { NodeInfo };\nvar SearchBotDeviceInfo = /** @class */ (function () {\n function SearchBotDeviceInfo(name, version, os, bot) {\n this.name = name;\n this.version = version;\n this.os = os;\n this.bot = bot;\n this.type = 'bot-device';\n }\n return SearchBotDeviceInfo;\n}());\nexport { SearchBotDeviceInfo };\nvar BotInfo = /** @class */ (function () {\n function BotInfo() {\n this.type = 'bot';\n this.bot = true; // NOTE: deprecated test name instead\n this.name = 'bot';\n this.version = null;\n this.os = null;\n }\n return BotInfo;\n}());\nexport { BotInfo };\nvar ReactNativeInfo = /** @class */ (function () {\n function ReactNativeInfo() {\n this.type = 'react-native';\n this.name = 'react-native';\n this.version = null;\n this.os = null;\n }\n return ReactNativeInfo;\n}());\nexport { ReactNativeInfo };\n// tslint:disable-next-line:max-line-length\nvar SEARCHBOX_UA_REGEX = /alexa|bot|crawl(er|ing)|facebookexternalhit|feedburner|google web preview|nagios|postrank|pingdom|slurp|spider|yahoo!|yandex/;\nvar SEARCHBOT_OS_REGEX = /(nuhk|Googlebot|Yammybot|Openbot|Slurp|MSNBot|Ask\\ Jeeves\\/Teoma|ia_archiver)/;\nvar REQUIRED_VERSION_PARTS = 3;\nvar userAgentRules = [\n ['aol', /AOLShield\\/([0-9\\._]+)/],\n ['edge', /Edge\\/([0-9\\._]+)/],\n ['edge-ios', /EdgiOS\\/([0-9\\._]+)/],\n ['yandexbrowser', /YaBrowser\\/([0-9\\._]+)/],\n ['kakaotalk', /KAKAOTALK\\s([0-9\\.]+)/],\n ['samsung', /SamsungBrowser\\/([0-9\\.]+)/],\n ['silk', /\\bSilk\\/([0-9._-]+)\\b/],\n ['miui', /MiuiBrowser\\/([0-9\\.]+)$/],\n ['beaker', /BeakerBrowser\\/([0-9\\.]+)/],\n ['edge-chromium', /EdgA?\\/([0-9\\.]+)/],\n [\n 'chromium-webview',\n /(?!Chrom.*OPR)wv\\).*Chrom(?:e|ium)\\/([0-9\\.]+)(:?\\s|$)/,\n ],\n ['chrome', /(?!Chrom.*OPR)Chrom(?:e|ium)\\/([0-9\\.]+)(:?\\s|$)/],\n ['phantomjs', /PhantomJS\\/([0-9\\.]+)(:?\\s|$)/],\n ['crios', /CriOS\\/([0-9\\.]+)(:?\\s|$)/],\n ['firefox', /Firefox\\/([0-9\\.]+)(?:\\s|$)/],\n ['fxios', /FxiOS\\/([0-9\\.]+)/],\n ['opera-mini', /Opera Mini.*Version\\/([0-9\\.]+)/],\n ['opera', /Opera\\/([0-9\\.]+)(?:\\s|$)/],\n ['opera', /OPR\\/([0-9\\.]+)(:?\\s|$)/],\n ['ie', /Trident\\/7\\.0.*rv\\:([0-9\\.]+).*\\).*Gecko$/],\n ['ie', /MSIE\\s([0-9\\.]+);.*Trident\\/[4-7].0/],\n ['ie', /MSIE\\s(7\\.0)/],\n ['bb10', /BB10;\\sTouch.*Version\\/([0-9\\.]+)/],\n ['android', /Android\\s([0-9\\.]+)/],\n ['ios', /Version\\/([0-9\\._]+).*Mobile.*Safari.*/],\n ['safari', /Version\\/([0-9\\._]+).*Safari/],\n ['facebook', /FBAV\\/([0-9\\.]+)/],\n ['instagram', /Instagram\\s([0-9\\.]+)/],\n ['ios-webview', /AppleWebKit\\/([0-9\\.]+).*Mobile/],\n ['ios-webview', /AppleWebKit\\/([0-9\\.]+).*Gecko\\)$/],\n ['searchbot', SEARCHBOX_UA_REGEX],\n];\nvar operatingSystemRules = [\n ['iOS', /iP(hone|od|ad)/],\n ['Android OS', /Android/],\n ['BlackBerry OS', /BlackBerry|BB10/],\n ['Windows Mobile', /IEMobile/],\n ['Amazon OS', /Kindle/],\n ['Windows 3.11', /Win16/],\n ['Windows 95', /(Windows 95)|(Win95)|(Windows_95)/],\n ['Windows 98', /(Windows 98)|(Win98)/],\n ['Windows 2000', /(Windows NT 5.0)|(Windows 2000)/],\n ['Windows XP', /(Windows NT 5.1)|(Windows XP)/],\n ['Windows Server 2003', /(Windows NT 5.2)/],\n ['Windows Vista', /(Windows NT 6.0)/],\n ['Windows 7', /(Windows NT 6.1)/],\n ['Windows 8', /(Windows NT 6.2)/],\n ['Windows 8.1', /(Windows NT 6.3)/],\n ['Windows 10', /(Windows NT 10.0)/],\n ['Windows ME', /Windows ME/],\n ['Open BSD', /OpenBSD/],\n ['Sun OS', /SunOS/],\n ['Chrome OS', /CrOS/],\n ['Linux', /(Linux)|(X11)/],\n ['Mac OS', /(Mac_PowerPC)|(Macintosh)/],\n ['QNX', /QNX/],\n ['BeOS', /BeOS/],\n ['OS/2', /OS\\/2/],\n];\nexport function detect(userAgent) {\n if (!!userAgent) {\n return parseUserAgent(userAgent);\n }\n if (typeof document === 'undefined' &&\n typeof navigator !== 'undefined' &&\n navigator.product === 'ReactNative') {\n return new ReactNativeInfo();\n }\n if (typeof navigator !== 'undefined') {\n return parseUserAgent(navigator.userAgent);\n }\n return getNodeVersion();\n}\nfunction matchUserAgent(ua) {\n // opted for using reduce here rather than Array#first with a regex.test call\n // this is primarily because using the reduce we only perform the regex\n // execution once rather than once for the test and for the exec again below\n // probably something that needs to be benchmarked though\n return (ua !== '' &&\n userAgentRules.reduce(function (matched, _a) {\n var browser = _a[0], regex = _a[1];\n if (matched) {\n return matched;\n }\n var uaMatch = regex.exec(ua);\n return !!uaMatch && [browser, uaMatch];\n }, false));\n}\nexport function browserName(ua) {\n var data = matchUserAgent(ua);\n return data ? data[0] : null;\n}\nexport function parseUserAgent(ua) {\n var matchedRule = matchUserAgent(ua);\n if (!matchedRule) {\n return null;\n }\n var name = matchedRule[0], match = matchedRule[1];\n if (name === 'searchbot') {\n return new BotInfo();\n }\n var versionParts = match[1] && match[1].split(/[._]/).slice(0, 3);\n if (versionParts) {\n if (versionParts.length < REQUIRED_VERSION_PARTS) {\n versionParts = __spreadArrays(versionParts, createVersionParts(REQUIRED_VERSION_PARTS - versionParts.length));\n }\n }\n else {\n versionParts = [];\n }\n var version = versionParts.join('.');\n var os = detectOS(ua);\n var searchBotMatch = SEARCHBOT_OS_REGEX.exec(ua);\n if (searchBotMatch && searchBotMatch[1]) {\n return new SearchBotDeviceInfo(name, version, os, searchBotMatch[1]);\n }\n return new BrowserInfo(name, version, os);\n}\nexport function detectOS(ua) {\n for (var ii = 0, count = operatingSystemRules.length; ii < count; ii++) {\n var _a = operatingSystemRules[ii], os = _a[0], regex = _a[1];\n var match = regex.exec(ua);\n if (match) {\n return os;\n }\n }\n return null;\n}\nexport function getNodeVersion() {\n var isNode = typeof process !== 'undefined' && process.version;\n return isNode ? new NodeInfo(process.version.slice(1)) : null;\n}\nfunction createVersionParts(count) {\n var output = [];\n for (var ii = 0; ii < count; ii++) {\n output.push('0');\n }\n return output;\n}\n","import { isString, each, isArray } from './util';\nvar regexLG = /^l\\s*\\(\\s*([\\d.]+)\\s*\\)\\s*(.*)/i;\nvar regexRG = /^r\\s*\\(\\s*([\\d.]+)\\s*,\\s*([\\d.]+)\\s*,\\s*([\\d.]+)\\s*\\)\\s*(.*)/i;\nvar regexPR = /^p\\s*\\(\\s*([axyn])\\s*\\)\\s*(.*)/i;\nvar regexColorStop = /[\\d.]+:(#[^\\s]+|[^\\)]+\\))/gi;\nfunction addStop(steps, gradient) {\n var arr = steps.match(regexColorStop);\n each(arr, function (item) {\n var itemArr = item.split(':');\n gradient.addColorStop(itemArr[0], itemArr[1]);\n });\n}\n/**\n * 将边和填充设置的颜色转换成线性渐变对象\n * @param {CanvasRenderingContext2D} context canvas 上下文\n * @param {IElement} element 图形元素\n * @param {string} gradientStr 颜色\n * @returns {any} 渐变对象\n */\nexport function parseLineGradient(context, element, gradientStr) {\n var arr = regexLG.exec(gradientStr);\n var angle = (parseFloat(arr[1]) % 360) * (Math.PI / 180);\n var steps = arr[2];\n var box = element.getBBox();\n var start;\n var end;\n if (angle >= 0 && angle < (1 / 2) * Math.PI) {\n start = {\n x: box.minX,\n y: box.minY,\n };\n end = {\n x: box.maxX,\n y: box.maxY,\n };\n }\n else if ((1 / 2) * Math.PI <= angle && angle < Math.PI) {\n start = {\n x: box.maxX,\n y: box.minY,\n };\n end = {\n x: box.minX,\n y: box.maxY,\n };\n }\n else if (Math.PI <= angle && angle < (3 / 2) * Math.PI) {\n start = {\n x: box.maxX,\n y: box.maxY,\n };\n end = {\n x: box.minX,\n y: box.minY,\n };\n }\n else {\n start = {\n x: box.minX,\n y: box.maxY,\n };\n end = {\n x: box.maxX,\n y: box.minY,\n };\n }\n var tanTheta = Math.tan(angle);\n var tanTheta2 = tanTheta * tanTheta;\n var x = (end.x - start.x + tanTheta * (end.y - start.y)) / (tanTheta2 + 1) + start.x;\n var y = (tanTheta * (end.x - start.x + tanTheta * (end.y - start.y))) / (tanTheta2 + 1) + start.y;\n var gradient = context.createLinearGradient(start.x, start.y, x, y);\n addStop(steps, gradient);\n return gradient;\n}\n/**\n * 将边和填充设置的颜色转换成圆形渐变对象\n * @param {CanvasRenderingContext2D} context canvas 上下文\n * @param {IElement} element 图形元素\n * @param {string} gradientStr 颜色\n * @returns {any} 渐变对象\n */\nexport function parseRadialGradient(context, element, gradientStr) {\n var arr = regexRG.exec(gradientStr);\n var fx = parseFloat(arr[1]);\n var fy = parseFloat(arr[2]);\n var fr = parseFloat(arr[3]);\n var steps = arr[4];\n // 环半径为0时,默认无渐变,取渐变序列的最后一个颜色\n if (fr === 0) {\n var colors = steps.match(regexColorStop);\n return colors[colors.length - 1].split(':')[1];\n }\n var box = element.getBBox();\n var width = box.maxX - box.minX;\n var height = box.maxY - box.minY;\n var r = Math.sqrt(width * width + height * height) / 2;\n var gradient = context.createRadialGradient(box.minX + width * fx, box.minY + height * fy, 0, box.minX + width / 2, box.minY + height / 2, fr * r);\n addStop(steps, gradient);\n return gradient;\n}\n/**\n * 边和填充设置的颜色转换成 pattern\n * @param {CanvasRenderingContext2D} context canvas 上下文\n * @param {IElement} element 图形元素\n * @param {string} patternStr 生成 pattern 的字符串\n */\nexport function parsePattern(context, element, patternStr) {\n // 在转换过程中进行了缓存\n if (element.get('patternSource') && element.get('patternSource') === patternStr) {\n return element.get('pattern');\n }\n var pattern;\n var img;\n var arr = regexPR.exec(patternStr);\n var repeat = arr[1];\n var source = arr[2];\n // Function to be called when pattern loads\n function onload() {\n // Create pattern\n pattern = context.createPattern(img, repeat);\n element.set('pattern', pattern); // be a cache\n element.set('patternSource', patternStr);\n }\n switch (repeat) {\n case 'a':\n repeat = 'repeat';\n break;\n case 'x':\n repeat = 'repeat-x';\n break;\n case 'y':\n repeat = 'repeat-y';\n break;\n case 'n':\n repeat = 'no-repeat';\n break;\n default:\n repeat = 'no-repeat';\n }\n img = new Image();\n // If source URL is not a data URL\n if (!source.match(/^data:/i)) {\n // Set crossOrigin for this image\n img.crossOrigin = 'Anonymous';\n }\n img.src = source;\n if (img.complete) {\n onload();\n }\n else {\n img.onload = onload;\n // Fix onload() bug in IE9\n img.src = img.src;\n }\n return pattern;\n}\nexport function parseStyle(context, element, color) {\n var bbox = element.getBBox();\n if (isNaN(bbox.x) || isNaN(bbox.y) || isNaN(bbox.width) || isNaN(bbox.height)) {\n return color;\n }\n if (isString(color)) {\n if (color[1] === '(' || color[2] === '(') {\n if (color[0] === 'l') {\n // regexLG.test(color)\n return parseLineGradient(context, element, color);\n }\n if (color[0] === 'r') {\n // regexRG.test(color)\n return parseRadialGradient(context, element, color);\n }\n if (color[0] === 'p') {\n // regexPR.test(color)\n return parsePattern(context, element, color);\n }\n }\n return color;\n }\n if (color instanceof CanvasPattern) {\n return color;\n }\n}\nexport function parseRadius(radius) {\n var r1 = 0;\n var r2 = 0;\n var r3 = 0;\n var r4 = 0;\n if (isArray(radius)) {\n if (radius.length === 1) {\n r1 = r2 = r3 = r4 = radius[0];\n }\n else if (radius.length === 2) {\n r1 = r3 = radius[0];\n r2 = r4 = radius[1];\n }\n else if (radius.length === 3) {\n r1 = radius[0];\n r2 = r4 = radius[1];\n r3 = radius[2];\n }\n else {\n r1 = radius[0];\n r2 = radius[1];\n r3 = radius[2];\n r4 = radius[3];\n }\n }\n else {\n r1 = r2 = r3 = r4 = radius;\n }\n return [r1, r2, r3, r4];\n}\n//# sourceMappingURL=parse.js.map","import { vec3, vec4 } from 'gl-matrix';\nimport { isNumber } from './is-number';\n\nexport function getAngle(angle: number | undefined) {\n if (angle === undefined) {\n return 0;\n } else if (angle > 360 || angle < -360) {\n return angle % 360;\n }\n return angle;\n}\n\nexport function createVec3(x: number | vec3 | vec4, y?: number, z?: number) {\n if (isNumber(x)) {\n return vec3.fromValues(x as number, y as number, z as number);\n }\n\n if ((x as vec3).length === 3) {\n return vec3.clone(x as vec3);\n }\n\n // @ts-ignore\n return vec3.fromValues(x[0], x[1], x[2]);\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.MESSAGE = exports.ALGORITHM = void 0;\nvar ALGORITHM = {\n pageRank: 'pageRank',\n breadthFirstSearch: 'breadthFirstSearch',\n connectedComponent: 'connectedComponent',\n depthFirstSearch: 'depthFirstSearch',\n detectCycle: 'detectCycle',\n detectDirectedCycle: 'detectDirectedCycle',\n detectAllCycles: 'detectAllCycles',\n detectAllDirectedCycle: 'detectAllDirectedCycle',\n detectAllUndirectedCycle: 'detectAllUndirectedCycle',\n dijkstra: 'dijkstra',\n findAllPath: 'findAllPath',\n findShortestPath: 'findShortestPath',\n floydWarshall: 'floydWarshall',\n getAdjMatrix: 'getAdjMatrix',\n getDegree: 'getDegree',\n getInDegree: 'getInDegree',\n getNeighbors: 'getNeighbors',\n getOutDegree: 'getOutDegree',\n labelPropagation: 'labelPropagation',\n louvain: 'louvain',\n GADDI: 'GADDI',\n minimumSpanningTree: 'minimumSpanningTree',\n SUCCESS: 'SUCCESS',\n FAILURE: 'FAILURE'\n};\nexports.ALGORITHM = ALGORITHM;\nvar MESSAGE = {\n SUCCESS: 'SUCCESS',\n FAILURE: 'FAILURE'\n};\nexports.MESSAGE = MESSAGE;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _tslib = require(\"tslib\");\n\nvar _util = require(\"@antv/util\");\n\nvar _util2 = require(\"./util\");\n\nvar minVertex = function minVertex(D, nodes, marks) {\n // 找出最小的点\n var minDis = Infinity;\n var minNode;\n\n for (var i = 0; i < nodes.length; i++) {\n var nodeId = nodes[i].id;\n\n if (!marks[nodeId] && D[nodeId] <= minDis) {\n minDis = D[nodeId];\n minNode = nodes[i];\n }\n }\n\n return minNode;\n};\n\nvar dijkstra = function dijkstra(graphData, source, directed, weightPropertyName) {\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var nodeIds = [];\n var marks = {};\n var D = {};\n var prevs = {}; // key: 顶点, value: 顶点的前驱点数组(可能有多条等长的最短路径)\n\n nodes.forEach(function (node, i) {\n var id = node.id;\n nodeIds.push(id);\n D[id] = Infinity;\n if (id === source) D[id] = 0;\n });\n var nodeNum = nodes.length;\n\n var _loop_1 = function _loop_1(i) {\n // Process the vertices\n var minNode = minVertex(D, nodes, marks);\n var minNodeId = minNode.id;\n marks[minNodeId] = true;\n if (D[minNodeId] === Infinity) return \"continue\"; // Unreachable vertices cannot be the intermediate point\n\n var relatedEdges = [];\n if (directed) relatedEdges = (0, _util2.getOutEdgesNodeId)(minNodeId, edges);else relatedEdges = (0, _util2.getEdgesByNodeId)(minNodeId, edges);\n relatedEdges.forEach(function (edge) {\n var edgeTarget = edge.target;\n var edgeSource = edge.source;\n var w = edgeTarget === minNodeId ? edgeSource : edgeTarget;\n var weight = weightPropertyName && edge[weightPropertyName] ? edge[weightPropertyName] : 1;\n\n if (D[w] > D[minNode.id] + weight) {\n D[w] = D[minNode.id] + weight;\n prevs[w] = [minNode.id];\n } else if (D[w] === D[minNode.id] + weight) {\n prevs[w].push(minNode.id);\n }\n });\n };\n\n for (var i = 0; i < nodeNum; i++) {\n _loop_1(i);\n }\n\n prevs[source] = [source]; // 每个节点存可能存在多条最短路径\n\n var paths = {};\n\n for (var target in D) {\n if (D[target] !== Infinity) {\n findAllPaths(source, target, prevs, paths);\n }\n } // 兼容之前单路径\n\n\n var path = {};\n\n for (var target in paths) {\n path[target] = paths[target][0];\n }\n\n return {\n length: D,\n path: path,\n allPath: paths\n };\n};\n\nvar _default = dijkstra;\nexports.default = _default;\n\nfunction findAllPaths(source, target, prevs, foundPaths) {\n if (source === target) {\n return [source];\n }\n\n if (foundPaths[target]) {\n return foundPaths[target];\n }\n\n var paths = [];\n\n for (var _i = 0, _a = prevs[target]; _i < _a.length; _i++) {\n var prev = _a[_i];\n var prevPaths = findAllPaths(source, prev, prevs, foundPaths);\n if (!prevPaths) return;\n\n for (var _b = 0, prevPaths_1 = prevPaths; _b < prevPaths_1.length; _b++) {\n var prePath = prevPaths_1[_b];\n if ((0, _util.isArray)(prePath)) paths.push((0, _tslib.__spreadArray)((0, _tslib.__spreadArray)([], prePath), [target]));else paths.push([prePath, target]);\n }\n }\n\n foundPaths[target] = paths;\n return foundPaths[target];\n}","\"use strict\";\n\nvar _ = require(\"./lodash\");\n\nmodule.exports = Graph;\n\nvar DEFAULT_EDGE_NAME = \"\\x00\";\nvar GRAPH_NODE = \"\\x00\";\nvar EDGE_KEY_DELIM = \"\\x01\";\n\n// Implementation notes:\n//\n// * Node id query functions should return string ids for the nodes\n// * Edge id query functions should return an \"edgeObj\", edge object, that is\n// composed of enough information to uniquely identify an edge: {v, w, name}.\n// * Internally we use an \"edgeId\", a stringified form of the edgeObj, to\n// reference edges. This is because we need a performant way to look these\n// edges up and, object properties, which have string keys, are the closest\n// we're going to get to a performant hashtable in JavaScript.\n\nfunction Graph(opts) {\n this._isDirected = _.has(opts, \"directed\") ? opts.directed : true;\n this._isMultigraph = _.has(opts, \"multigraph\") ? opts.multigraph : false;\n this._isCompound = _.has(opts, \"compound\") ? opts.compound : false;\n\n // Label for the graph itself\n this._label = undefined;\n\n // Defaults to be set when creating a new node\n this._defaultNodeLabelFn = _.constant(undefined);\n\n // Defaults to be set when creating a new edge\n this._defaultEdgeLabelFn = _.constant(undefined);\n\n // v -> label\n this._nodes = {};\n\n if (this._isCompound) {\n // v -> parent\n this._parent = {};\n\n // v -> children\n this._children = {};\n this._children[GRAPH_NODE] = {};\n }\n\n // v -> edgeObj\n this._in = {};\n\n // u -> v -> Number\n this._preds = {};\n\n // v -> edgeObj\n this._out = {};\n\n // v -> w -> Number\n this._sucs = {};\n\n // e -> edgeObj\n this._edgeObjs = {};\n\n // e -> label\n this._edgeLabels = {};\n}\n\n/* Number of nodes in the graph. Should only be changed by the implementation. */\nGraph.prototype._nodeCount = 0;\n\n/* Number of edges in the graph. Should only be changed by the implementation. */\nGraph.prototype._edgeCount = 0;\n\n\n/* === Graph functions ========= */\n\nGraph.prototype.isDirected = function() {\n return this._isDirected;\n};\n\nGraph.prototype.isMultigraph = function() {\n return this._isMultigraph;\n};\n\nGraph.prototype.isCompound = function() {\n return this._isCompound;\n};\n\nGraph.prototype.setGraph = function(label) {\n this._label = label;\n return this;\n};\n\nGraph.prototype.graph = function() {\n return this._label;\n};\n\n\n/* === Node functions ========== */\n\nGraph.prototype.setDefaultNodeLabel = function(newDefault) {\n if (!_.isFunction(newDefault)) {\n newDefault = _.constant(newDefault);\n }\n this._defaultNodeLabelFn = newDefault;\n return this;\n};\n\nGraph.prototype.nodeCount = function() {\n return this._nodeCount;\n};\n\nGraph.prototype.nodes = function() {\n return _.keys(this._nodes);\n};\n\nGraph.prototype.sources = function() {\n var self = this;\n return _.filter(this.nodes(), function(v) {\n return _.isEmpty(self._in[v]);\n });\n};\n\nGraph.prototype.sinks = function() {\n var self = this;\n return _.filter(this.nodes(), function(v) {\n return _.isEmpty(self._out[v]);\n });\n};\n\nGraph.prototype.setNodes = function(vs, value) {\n var args = arguments;\n var self = this;\n _.each(vs, function(v) {\n if (args.length > 1) {\n self.setNode(v, value);\n } else {\n self.setNode(v);\n }\n });\n return this;\n};\n\nGraph.prototype.setNode = function(v, value) {\n if (_.has(this._nodes, v)) {\n if (arguments.length > 1) {\n this._nodes[v] = value;\n }\n return this;\n }\n\n this._nodes[v] = arguments.length > 1 ? value : this._defaultNodeLabelFn(v);\n if (this._isCompound) {\n this._parent[v] = GRAPH_NODE;\n this._children[v] = {};\n this._children[GRAPH_NODE][v] = true;\n }\n this._in[v] = {};\n this._preds[v] = {};\n this._out[v] = {};\n this._sucs[v] = {};\n ++this._nodeCount;\n return this;\n};\n\nGraph.prototype.node = function(v) {\n return this._nodes[v];\n};\n\nGraph.prototype.hasNode = function(v) {\n return _.has(this._nodes, v);\n};\n\nGraph.prototype.removeNode = function(v) {\n var self = this;\n if (_.has(this._nodes, v)) {\n var removeEdge = function(e) { self.removeEdge(self._edgeObjs[e]); };\n delete this._nodes[v];\n if (this._isCompound) {\n this._removeFromParentsChildList(v);\n delete this._parent[v];\n _.each(this.children(v), function(child) {\n self.setParent(child);\n });\n delete this._children[v];\n }\n _.each(_.keys(this._in[v]), removeEdge);\n delete this._in[v];\n delete this._preds[v];\n _.each(_.keys(this._out[v]), removeEdge);\n delete this._out[v];\n delete this._sucs[v];\n --this._nodeCount;\n }\n return this;\n};\n\nGraph.prototype.setParent = function(v, parent) {\n if (!this._isCompound) {\n throw new Error(\"Cannot set parent in a non-compound graph\");\n }\n\n if (_.isUndefined(parent)) {\n parent = GRAPH_NODE;\n } else {\n // Coerce parent to string\n parent += \"\";\n for (var ancestor = parent;\n !_.isUndefined(ancestor);\n ancestor = this.parent(ancestor)) {\n if (ancestor === v) {\n throw new Error(\"Setting \" + parent+ \" as parent of \" + v +\n \" would create a cycle\");\n }\n }\n\n this.setNode(parent);\n }\n\n this.setNode(v);\n this._removeFromParentsChildList(v);\n this._parent[v] = parent;\n this._children[parent][v] = true;\n return this;\n};\n\nGraph.prototype._removeFromParentsChildList = function(v) {\n delete this._children[this._parent[v]][v];\n};\n\nGraph.prototype.parent = function(v) {\n if (this._isCompound) {\n var parent = this._parent[v];\n if (parent !== GRAPH_NODE) {\n return parent;\n }\n }\n};\n\nGraph.prototype.children = function(v) {\n if (_.isUndefined(v)) {\n v = GRAPH_NODE;\n }\n\n if (this._isCompound) {\n var children = this._children[v];\n if (children) {\n return _.keys(children);\n }\n } else if (v === GRAPH_NODE) {\n return this.nodes();\n } else if (this.hasNode(v)) {\n return [];\n }\n};\n\nGraph.prototype.predecessors = function(v) {\n var predsV = this._preds[v];\n if (predsV) {\n return _.keys(predsV);\n }\n};\n\nGraph.prototype.successors = function(v) {\n var sucsV = this._sucs[v];\n if (sucsV) {\n return _.keys(sucsV);\n }\n};\n\nGraph.prototype.neighbors = function(v) {\n var preds = this.predecessors(v);\n if (preds) {\n return _.union(preds, this.successors(v));\n }\n};\n\nGraph.prototype.isLeaf = function (v) {\n var neighbors;\n if (this.isDirected()) {\n neighbors = this.successors(v);\n } else {\n neighbors = this.neighbors(v);\n }\n return neighbors.length === 0;\n};\n\nGraph.prototype.filterNodes = function(filter) {\n var copy = new this.constructor({\n directed: this._isDirected,\n multigraph: this._isMultigraph,\n compound: this._isCompound\n });\n\n copy.setGraph(this.graph());\n\n var self = this;\n _.each(this._nodes, function(value, v) {\n if (filter(v)) {\n copy.setNode(v, value);\n }\n });\n\n _.each(this._edgeObjs, function(e) {\n if (copy.hasNode(e.v) && copy.hasNode(e.w)) {\n copy.setEdge(e, self.edge(e));\n }\n });\n\n var parents = {};\n function findParent(v) {\n var parent = self.parent(v);\n if (parent === undefined || copy.hasNode(parent)) {\n parents[v] = parent;\n return parent;\n } else if (parent in parents) {\n return parents[parent];\n } else {\n return findParent(parent);\n }\n }\n\n if (this._isCompound) {\n _.each(copy.nodes(), function(v) {\n copy.setParent(v, findParent(v));\n });\n }\n\n return copy;\n};\n\n/* === Edge functions ========== */\n\nGraph.prototype.setDefaultEdgeLabel = function(newDefault) {\n if (!_.isFunction(newDefault)) {\n newDefault = _.constant(newDefault);\n }\n this._defaultEdgeLabelFn = newDefault;\n return this;\n};\n\nGraph.prototype.edgeCount = function() {\n return this._edgeCount;\n};\n\nGraph.prototype.edges = function() {\n return _.values(this._edgeObjs);\n};\n\nGraph.prototype.setPath = function(vs, value) {\n var self = this;\n var args = arguments;\n _.reduce(vs, function(v, w) {\n if (args.length > 1) {\n self.setEdge(v, w, value);\n } else {\n self.setEdge(v, w);\n }\n return w;\n });\n return this;\n};\n\n/*\n * setEdge(v, w, [value, [name]])\n * setEdge({ v, w, [name] }, [value])\n */\nGraph.prototype.setEdge = function() {\n var v, w, name, value;\n var valueSpecified = false;\n var arg0 = arguments[0];\n\n if (typeof arg0 === \"object\" && arg0 !== null && \"v\" in arg0) {\n v = arg0.v;\n w = arg0.w;\n name = arg0.name;\n if (arguments.length === 2) {\n value = arguments[1];\n valueSpecified = true;\n }\n } else {\n v = arg0;\n w = arguments[1];\n name = arguments[3];\n if (arguments.length > 2) {\n value = arguments[2];\n valueSpecified = true;\n }\n }\n\n v = \"\" + v;\n w = \"\" + w;\n if (!_.isUndefined(name)) {\n name = \"\" + name;\n }\n\n var e = edgeArgsToId(this._isDirected, v, w, name);\n if (_.has(this._edgeLabels, e)) {\n if (valueSpecified) {\n this._edgeLabels[e] = value;\n }\n return this;\n }\n\n if (!_.isUndefined(name) && !this._isMultigraph) {\n throw new Error(\"Cannot set a named edge when isMultigraph = false\");\n }\n\n // It didn't exist, so we need to create it.\n // First ensure the nodes exist.\n this.setNode(v);\n this.setNode(w);\n\n this._edgeLabels[e] = valueSpecified ? value : this._defaultEdgeLabelFn(v, w, name);\n\n var edgeObj = edgeArgsToObj(this._isDirected, v, w, name);\n // Ensure we add undirected edges in a consistent way.\n v = edgeObj.v;\n w = edgeObj.w;\n\n Object.freeze(edgeObj);\n this._edgeObjs[e] = edgeObj;\n incrementOrInitEntry(this._preds[w], v);\n incrementOrInitEntry(this._sucs[v], w);\n this._in[w][e] = edgeObj;\n this._out[v][e] = edgeObj;\n this._edgeCount++;\n return this;\n};\n\nGraph.prototype.edge = function(v, w, name) {\n var e = (arguments.length === 1\n ? edgeObjToId(this._isDirected, arguments[0])\n : edgeArgsToId(this._isDirected, v, w, name));\n return this._edgeLabels[e];\n};\n\nGraph.prototype.hasEdge = function(v, w, name) {\n var e = (arguments.length === 1\n ? edgeObjToId(this._isDirected, arguments[0])\n : edgeArgsToId(this._isDirected, v, w, name));\n return _.has(this._edgeLabels, e);\n};\n\nGraph.prototype.removeEdge = function(v, w, name) {\n var e = (arguments.length === 1\n ? edgeObjToId(this._isDirected, arguments[0])\n : edgeArgsToId(this._isDirected, v, w, name));\n var edge = this._edgeObjs[e];\n if (edge) {\n v = edge.v;\n w = edge.w;\n delete this._edgeLabels[e];\n delete this._edgeObjs[e];\n decrementOrRemoveEntry(this._preds[w], v);\n decrementOrRemoveEntry(this._sucs[v], w);\n delete this._in[w][e];\n delete this._out[v][e];\n this._edgeCount--;\n }\n return this;\n};\n\nGraph.prototype.inEdges = function(v, u) {\n var inV = this._in[v];\n if (inV) {\n var edges = _.values(inV);\n if (!u) {\n return edges;\n }\n return _.filter(edges, function(edge) { return edge.v === u; });\n }\n};\n\nGraph.prototype.outEdges = function(v, w) {\n var outV = this._out[v];\n if (outV) {\n var edges = _.values(outV);\n if (!w) {\n return edges;\n }\n return _.filter(edges, function(edge) { return edge.w === w; });\n }\n};\n\nGraph.prototype.nodeEdges = function(v, w) {\n var inEdges = this.inEdges(v, w);\n if (inEdges) {\n return inEdges.concat(this.outEdges(v, w));\n }\n};\n\nfunction incrementOrInitEntry(map, k) {\n if (map[k]) {\n map[k]++;\n } else {\n map[k] = 1;\n }\n}\n\nfunction decrementOrRemoveEntry(map, k) {\n if (!--map[k]) { delete map[k]; }\n}\n\nfunction edgeArgsToId(isDirected, v_, w_, name) {\n var v = \"\" + v_;\n var w = \"\" + w_;\n if (!isDirected && v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n return v + EDGE_KEY_DELIM + w + EDGE_KEY_DELIM +\n (_.isUndefined(name) ? DEFAULT_EDGE_NAME : name);\n}\n\nfunction edgeArgsToObj(isDirected, v_, w_, name) {\n var v = \"\" + v_;\n var w = \"\" + w_;\n if (!isDirected && v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n var edgeObj = { v: v, w: w };\n if (name) {\n edgeObj.name = name;\n }\n return edgeObj;\n}\n\nfunction edgeObjToId(isDirected, edgeObj) {\n return edgeArgsToId(isDirected, edgeObj.v, edgeObj.w, edgeObj.name);\n}\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n","var mapCacheClear = require('./_mapCacheClear'),\n mapCacheDelete = require('./_mapCacheDelete'),\n mapCacheGet = require('./_mapCacheGet'),\n mapCacheHas = require('./_mapCacheHas'),\n mapCacheSet = require('./_mapCacheSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n}\n\nmodule.exports = arrayEach;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\n","var isPrototype = require('./_isPrototype'),\n nativeKeys = require('./_nativeKeys');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeys;\n","var arrayFilter = require('./_arrayFilter'),\n stubArray = require('./stubArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nmodule.exports = getSymbols;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nmodule.exports = arrayPush;\n","var Uint8Array = require('./_Uint8Array');\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n}\n\nmodule.exports = cloneArrayBuffer;\n","/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new constant function.\n * @example\n *\n * var objects = _.times(2, _.constant({ 'a': 1 }));\n *\n * console.log(objects);\n * // => [{ 'a': 1 }, { 'a': 1 }]\n *\n * console.log(objects[0] === objects[1]);\n * // => true\n */\nfunction constant(value) {\n return function() {\n return value;\n };\n}\n\nmodule.exports = constant;\n","var baseFor = require('./_baseFor'),\n keys = require('./keys');\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n}\n\nmodule.exports = baseForOwn;\n","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n","/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\nmodule.exports = setToArray;\n","var isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\n","var arrayPush = require('./_arrayPush'),\n isFlattenable = require('./_isFlattenable');\n\n/**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, predicate, isStrict, result) {\n var index = -1,\n length = array.length;\n\n predicate || (predicate = isFlattenable);\n result || (result = []);\n\n while (++index < length) {\n var value = array[index];\n if (depth > 0 && predicate(value)) {\n if (depth > 1) {\n // Recursively flatten arrays (susceptible to call stack limits).\n baseFlatten(value, depth - 1, predicate, isStrict, result);\n } else {\n arrayPush(result, value);\n }\n } else if (!isStrict) {\n result[result.length] = value;\n }\n }\n return result;\n}\n\nmodule.exports = baseFlatten;\n","var isSymbol = require('./isSymbol');\n\n/**\n * The base implementation of methods like `_.max` and `_.min` which accepts a\n * `comparator` to determine the extremum value.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The iteratee invoked per iteration.\n * @param {Function} comparator The comparator used to compare values.\n * @returns {*} Returns the extremum value.\n */\nfunction baseExtremum(array, iteratee, comparator) {\n var index = -1,\n length = array.length;\n\n while (++index < length) {\n var value = array[index],\n current = iteratee(value);\n\n if (current != null && (computed === undefined\n ? (current === current && !isSymbol(current))\n : comparator(current, computed)\n )) {\n var computed = current,\n result = value;\n }\n }\n return result;\n}\n\nmodule.exports = baseExtremum;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingOnSyntax = void 0;\nvar binding_when_syntax_1 = require(\"./binding_when_syntax\");\nvar BindingOnSyntax = (function () {\n function BindingOnSyntax(binding) {\n this._binding = binding;\n }\n BindingOnSyntax.prototype.onActivation = function (handler) {\n this._binding.onActivation = handler;\n return new binding_when_syntax_1.BindingWhenSyntax(this._binding);\n };\n return BindingOnSyntax;\n}());\nexports.BindingOnSyntax = BindingOnSyntax;\n//# sourceMappingURL=binding_on_syntax.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingWhenSyntax = void 0;\nvar binding_on_syntax_1 = require(\"./binding_on_syntax\");\nvar constraint_helpers_1 = require(\"./constraint_helpers\");\nvar BindingWhenSyntax = (function () {\n function BindingWhenSyntax(binding) {\n this._binding = binding;\n }\n BindingWhenSyntax.prototype.when = function (constraint) {\n this._binding.constraint = constraint;\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenTargetNamed = function (name) {\n this._binding.constraint = constraint_helpers_1.namedConstraint(name);\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenTargetIsDefault = function () {\n this._binding.constraint = function (request) {\n var targetIsDefault = (request.target !== null) &&\n (!request.target.isNamed()) &&\n (!request.target.isTagged());\n return targetIsDefault;\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenTargetTagged = function (tag, value) {\n this._binding.constraint = constraint_helpers_1.taggedConstraint(tag)(value);\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenInjectedInto = function (parent) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.typeConstraint(parent)(request.parentRequest);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenParentNamed = function (name) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.namedConstraint(name)(request.parentRequest);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenParentTagged = function (tag, value) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.taggedConstraint(tag)(value)(request.parentRequest);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenAnyAncestorIs = function (ancestor) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.typeConstraint(ancestor));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenNoAncestorIs = function (ancestor) {\n this._binding.constraint = function (request) {\n return !constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.typeConstraint(ancestor));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenAnyAncestorNamed = function (name) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.namedConstraint(name));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenNoAncestorNamed = function (name) {\n this._binding.constraint = function (request) {\n return !constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.namedConstraint(name));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenAnyAncestorTagged = function (tag, value) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.taggedConstraint(tag)(value));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenNoAncestorTagged = function (tag, value) {\n this._binding.constraint = function (request) {\n return !constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.taggedConstraint(tag)(value));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenAnyAncestorMatches = function (constraint) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.traverseAncerstors(request, constraint);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenNoAncestorMatches = function (constraint) {\n this._binding.constraint = function (request) {\n return !constraint_helpers_1.traverseAncerstors(request, constraint);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n return BindingWhenSyntax;\n}());\nexports.BindingWhenSyntax = BindingWhenSyntax;\n//# sourceMappingURL=binding_when_syntax.js.map","module.exports = subtract\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction subtract(out, a, b) {\n out[0] = a[0] - b[0]\n out[1] = a[1] - b[1]\n return out\n}","/*\nCopyright (c) 2012-2014 Chris Pettitt\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n*/\n\nmodule.exports = {\n graphlib: require(\"./lib/graphlib\"),\n\n layout: require(\"./lib/layout\"),\n debug: require(\"./lib/debug\"),\n util: {\n time: require(\"./lib/util\").time,\n notime: require(\"./lib/util\").notime\n },\n version: require(\"./lib/version\")\n};\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","import { __extends } from \"tslib\";\nimport Container from './container';\nvar AbstractGroup = /** @class */ (function (_super) {\n __extends(AbstractGroup, _super);\n function AbstractGroup() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n AbstractGroup.prototype.isGroup = function () {\n return true;\n };\n AbstractGroup.prototype.isEntityGroup = function () {\n return false;\n };\n AbstractGroup.prototype.clone = function () {\n var clone = _super.prototype.clone.call(this);\n // 获取构造函数\n var children = this.getChildren();\n for (var i = 0; i < children.length; i++) {\n var child = children[i];\n clone.add(child.clone());\n }\n return clone;\n };\n return AbstractGroup;\n}(Container));\nexport default AbstractGroup;\n//# sourceMappingURL=group.js.map","import { __extends } from \"tslib\";\nimport Element from './element';\nimport { multiplyVec2 } from '../util/matrix';\nvar AbstractShape = /** @class */ (function (_super) {\n __extends(AbstractShape, _super);\n function AbstractShape(cfg) {\n return _super.call(this, cfg) || this;\n }\n // 是否在包围盒内\n AbstractShape.prototype._isInBBox = function (refX, refY) {\n var bbox = this.getBBox();\n return bbox.minX <= refX && bbox.maxX >= refX && bbox.minY <= refY && bbox.maxY >= refY;\n };\n /**\n * 属性更改后需要做的事情\n * @protected\n * @param {ShapeAttrs} targetAttrs 渲染的图像属性\n */\n AbstractShape.prototype.afterAttrsChange = function (targetAttrs) {\n _super.prototype.afterAttrsChange.call(this, targetAttrs);\n this.clearCacheBBox();\n };\n // 计算包围盒时,需要缓存,这是一个高频的操作\n AbstractShape.prototype.getBBox = function () {\n var bbox = this.cfg.bbox;\n if (!bbox) {\n bbox = this.calculateBBox();\n this.set('bbox', bbox);\n }\n return bbox;\n };\n // 计算相对于画布的包围盒\n AbstractShape.prototype.getCanvasBBox = function () {\n var canvasBBox = this.cfg.canvasBBox;\n if (!canvasBBox) {\n canvasBBox = this.calculateCanvasBBox();\n this.set('canvasBBox', canvasBBox);\n }\n return canvasBBox;\n };\n AbstractShape.prototype.applyMatrix = function (matrix) {\n _super.prototype.applyMatrix.call(this, matrix);\n // 清理掉缓存的包围盒\n this.set('canvasBBox', null);\n };\n /**\n * 计算相对于画布的包围盒,默认等同于 bbox\n * @return {BBox} 包围盒\n */\n AbstractShape.prototype.calculateCanvasBBox = function () {\n var bbox = this.getBBox();\n var totalMatrix = this.getTotalMatrix();\n var minX = bbox.minX, minY = bbox.minY, maxX = bbox.maxX, maxY = bbox.maxY;\n if (totalMatrix) {\n var topLeft = multiplyVec2(totalMatrix, [bbox.minX, bbox.minY]);\n var topRight = multiplyVec2(totalMatrix, [bbox.maxX, bbox.minY]);\n var bottomLeft = multiplyVec2(totalMatrix, [bbox.minX, bbox.maxY]);\n var bottomRight = multiplyVec2(totalMatrix, [bbox.maxX, bbox.maxY]);\n minX = Math.min(topLeft[0], topRight[0], bottomLeft[0], bottomRight[0]);\n maxX = Math.max(topLeft[0], topRight[0], bottomLeft[0], bottomRight[0]);\n minY = Math.min(topLeft[1], topRight[1], bottomLeft[1], bottomRight[1]);\n maxY = Math.max(topLeft[1], topRight[1], bottomLeft[1], bottomRight[1]);\n }\n var attrs = this.attrs;\n // 如果存在 shadow 则计算 shadow\n if (attrs.shadowColor) {\n var _a = attrs.shadowBlur, shadowBlur = _a === void 0 ? 0 : _a, _b = attrs.shadowOffsetX, shadowOffsetX = _b === void 0 ? 0 : _b, _c = attrs.shadowOffsetY, shadowOffsetY = _c === void 0 ? 0 : _c;\n var shadowLeft = minX - shadowBlur + shadowOffsetX;\n var shadowRight = maxX + shadowBlur + shadowOffsetX;\n var shadowTop = minY - shadowBlur + shadowOffsetY;\n var shadowBottom = maxY + shadowBlur + shadowOffsetY;\n minX = Math.min(minX, shadowLeft);\n maxX = Math.max(maxX, shadowRight);\n minY = Math.min(minY, shadowTop);\n maxY = Math.max(maxY, shadowBottom);\n }\n return {\n x: minX,\n y: minY,\n minX: minX,\n minY: minY,\n maxX: maxX,\n maxY: maxY,\n width: maxX - minX,\n height: maxY - minY,\n };\n };\n /**\n * @protected\n * 清理缓存的 bbox\n */\n AbstractShape.prototype.clearCacheBBox = function () {\n this.set('bbox', null);\n this.set('canvasBBox', null);\n };\n // 实现接口\n AbstractShape.prototype.isClipShape = function () {\n return this.get('isClipShape');\n };\n /**\n * @protected\n * 不同的图形自己实现是否在图形内部的逻辑,要判断边和填充区域\n * @param {number} refX 相对于图形的坐标 x\n * @param {number} refY 相对于图形的坐标 Y\n * @return {boolean} 点是否在图形内部\n */\n AbstractShape.prototype.isInShape = function (refX, refY) {\n return false;\n };\n /**\n * 是否仅仅使用 BBox 检测就可以判定拾取到图形\n * 默认是 false,但是有些图形例如 image、marker 等都可直接使用 BBox 的检测而不需要使用图形拾取\n * @return {Boolean} 仅仅使用 BBox 进行拾取\n */\n AbstractShape.prototype.isOnlyHitBox = function () {\n return false;\n };\n // 不同的 Shape 各自实现\n AbstractShape.prototype.isHit = function (x, y) {\n var startArrowShape = this.get('startArrowShape');\n var endArrowShape = this.get('endArrowShape');\n var vec = [x, y, 1];\n vec = this.invertFromMatrix(vec);\n var refX = vec[0], refY = vec[1];\n var inBBox = this._isInBBox(refX, refY);\n // 跳过图形的拾取,在某些图形中可以省略一倍的检测成本\n if (this.isOnlyHitBox()) {\n return inBBox;\n }\n // 被裁减掉的和不在包围盒内的不进行计算\n if (inBBox && !this.isClipped(refX, refY)) {\n // 对图形进行拾取判断\n if (this.isInShape(refX, refY)) {\n return true;\n }\n // 对起始箭头进行拾取判断\n if (startArrowShape && startArrowShape.isHit(refX, refY)) {\n return true;\n }\n // 对结束箭头进行拾取判断\n if (endArrowShape && endArrowShape.isHit(refX, refY)) {\n return true;\n }\n }\n return false;\n };\n return AbstractShape;\n}(Element));\nexport default AbstractShape;\n//# sourceMappingURL=shape.js.map","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = getConnectedComponents;\nexports.detectStrongConnectComponents = exports.detectConnectedComponents = void 0;\n\nvar _util = require(\"./util\");\n\n/**\n * Generate all connected components for an undirected graph\n * @param graph\n */\nvar detectConnectedComponents = function detectConnectedComponents(graphData) {\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var allComponents = [];\n var visited = {};\n var nodeStack = [];\n\n var getComponent = function getComponent(node) {\n nodeStack.push(node);\n visited[node.id] = true;\n var neighbors = (0, _util.getNeighbors)(node.id, edges);\n\n var _loop_1 = function _loop_1(i) {\n var neighbor = neighbors[i];\n\n if (!visited[neighbor]) {\n var targetNode = nodes.filter(function (node) {\n return node.id === neighbor;\n });\n\n if (targetNode.length > 0) {\n getComponent(targetNode[0]);\n }\n }\n };\n\n for (var i = 0; i < neighbors.length; ++i) {\n _loop_1(i);\n }\n };\n\n for (var i = 0; i < nodes.length; i++) {\n var node = nodes[i];\n\n if (!visited[node.id]) {\n // 对于无向图进行dfs遍历,每一次调用后都得到一个连通分量\n getComponent(node);\n var component = [];\n\n while (nodeStack.length > 0) {\n component.push(nodeStack.pop());\n }\n\n allComponents.push(component);\n }\n }\n\n return allComponents;\n};\n/**\n * Tarjan's Algorithm 复杂度 O(|V|+|E|)\n * For directed graph only\n * a directed graph is said to be strongly connected if \"every vertex is reachable from every other vertex\".\n * refer: http://en.wikipedia.org/wiki/Tarjan%27s_strongly_connected_components_algorithm\n * @param graph\n * @return a list of strongly connected components\n */\n\n\nexports.detectConnectedComponents = detectConnectedComponents;\n\nvar detectStrongConnectComponents = function detectStrongConnectComponents(graphData) {\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var nodeStack = [];\n var inStack = {}; // 辅助判断是否已经在stack中,减少查找开销\n\n var indices = {};\n var lowLink = {};\n var allComponents = [];\n var index = 0;\n\n var getComponent = function getComponent(node) {\n // Set the depth index for v to the smallest unused index\n indices[node.id] = index;\n lowLink[node.id] = index;\n index += 1;\n nodeStack.push(node);\n inStack[node.id] = true; // 考虑每个邻接点\n\n var neighbors = (0, _util.getNeighbors)(node.id, edges, 'target').filter(function (n) {\n return nodes.map(function (node) {\n return node.id;\n }).indexOf(n) > -1;\n });\n\n var _loop_2 = function _loop_2(i) {\n var targetNodeID = neighbors[i];\n\n if (!indices[targetNodeID] && indices[targetNodeID] !== 0) {\n var targetNode = nodes.filter(function (node) {\n return node.id === targetNodeID;\n });\n\n if (targetNode.length > 0) {\n getComponent(targetNode[0]);\n } // tree edge\n\n\n lowLink[node.id] = Math.min(lowLink[node.id], lowLink[targetNodeID]);\n } else if (inStack[targetNodeID]) {\n // back edge, target node is in the current SCC\n lowLink[node.id] = Math.min(lowLink[node.id], indices[targetNodeID]);\n }\n };\n\n for (var i = 0; i < neighbors.length; i++) {\n _loop_2(i);\n } // If node is a root node, generate an SCC\n\n\n if (lowLink[node.id] === indices[node.id]) {\n var component = [];\n\n while (nodeStack.length > 0) {\n var tmpNode = nodeStack.pop();\n inStack[tmpNode.id] = false;\n component.push(tmpNode);\n if (tmpNode === node) break;\n }\n\n if (component.length > 0) {\n allComponents.push(component);\n }\n }\n };\n\n for (var _i = 0, nodes_1 = nodes; _i < nodes_1.length; _i++) {\n var node = nodes_1[_i];\n\n if (!indices[node.id] && indices[node.id] !== 0) {\n getComponent(node);\n }\n }\n\n return allComponents;\n};\n\nexports.detectStrongConnectComponents = detectStrongConnectComponents;\n\nfunction getConnectedComponents(graphData, directed) {\n if (directed) return detectStrongConnectComponents(graphData);\n return detectConnectedComponents(graphData);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getOutDegree = exports.getInDegree = exports.default = void 0;\n\nvar degree = function degree(graphData) {\n var degrees = {};\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n nodes.forEach(function (node) {\n degrees[node.id] = {\n degree: 0,\n inDegree: 0,\n outDegree: 0\n };\n });\n edges.forEach(function (edge) {\n degrees[edge.source].degree++;\n degrees[edge.source].outDegree++;\n degrees[edge.target].degree++;\n degrees[edge.target].inDegree++;\n });\n return degrees;\n};\n\nvar _default = degree;\n/**\n * 获取指定节点的入度\n * @param graphData 图数据\n * @param nodeId 节点ID\n */\n\nexports.default = _default;\n\nvar getInDegree = function getInDegree(graphData, nodeId) {\n var nodeDegree = degree(graphData);\n\n if (nodeDegree[nodeId]) {\n return degree(graphData)[nodeId].inDegree;\n }\n\n return 0;\n};\n/**\n * 获取指定节点的出度\n * @param graphData 图数据\n * @param nodeId 节点ID\n */\n\n\nexports.getInDegree = getInDegree;\n\nvar getOutDegree = function getOutDegree(graphData, nodeId) {\n var nodeDegree = degree(graphData);\n\n if (nodeDegree[nodeId]) {\n return degree(graphData)[nodeId].outDegree;\n }\n\n return 0;\n};\n\nexports.getOutDegree = getOutDegree;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = depthFirstSearch;\n\nvar _util = require(\"./util\");\n\nfunction initCallbacks(callbacks) {\n if (callbacks === void 0) {\n callbacks = {};\n }\n\n var initiatedCallback = callbacks;\n\n var stubCallback = function stubCallback() {};\n\n var allowTraversalCallback = function () {\n var seen = {};\n return function (_a) {\n var next = _a.next;\n\n if (!seen[next]) {\n seen[next] = true;\n return true;\n }\n\n return false;\n };\n }();\n\n initiatedCallback.allowTraversal = callbacks.allowTraversal || allowTraversalCallback;\n initiatedCallback.enter = callbacks.enter || stubCallback;\n initiatedCallback.leave = callbacks.leave || stubCallback;\n return initiatedCallback;\n}\n/**\n * @param {Graph} graph\n * @param {GraphNode} currentNode\n * @param {GraphNode} previousNode\n * @param {Callbacks} callbacks\n */\n\n\nfunction depthFirstSearchRecursive(graphData, currentNode, previousNode, callbacks) {\n callbacks.enter({\n current: currentNode,\n previous: previousNode\n });\n var _a = graphData.edges,\n edges = _a === void 0 ? [] : _a;\n (0, _util.getNeighbors)(currentNode, edges, 'target').forEach(function (nextNode) {\n if (callbacks.allowTraversal({\n previous: previousNode,\n current: currentNode,\n next: nextNode\n })) {\n depthFirstSearchRecursive(graphData, nextNode, currentNode, callbacks);\n }\n });\n callbacks.leave({\n current: currentNode,\n previous: previousNode\n });\n}\n/**\n * 深度优先遍历图\n * @param data GraphData 图数据\n * @param startNodeId 开始遍历的节点的 ID\n * @param originalCallbacks 回调\n */\n\n\nfunction depthFirstSearch(graphData, startNodeId, callbacks) {\n depthFirstSearchRecursive(graphData, startNodeId, '', initCallbacks(callbacks));\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _adjacentMatrix = _interopRequireDefault(require(\"./adjacent-matrix\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar floydWarshall = function floydWarshall(graphData, directed) {\n var adjacentMatrix = (0, _adjacentMatrix.default)(graphData, directed);\n var dist = [];\n var size = adjacentMatrix.length;\n\n for (var i = 0; i < size; i += 1) {\n dist[i] = [];\n\n for (var j = 0; j < size; j += 1) {\n if (i === j) {\n dist[i][j] = 0;\n } else if (adjacentMatrix[i][j] === 0 || !adjacentMatrix[i][j]) {\n dist[i][j] = Infinity;\n } else {\n dist[i][j] = adjacentMatrix[i][j];\n }\n }\n } // floyd\n\n\n for (var k = 0; k < size; k += 1) {\n for (var i = 0; i < size; i += 1) {\n for (var j = 0; j < size; j += 1) {\n if (dist[i][j] > dist[i][k] + dist[k][j]) {\n dist[i][j] = dist[i][k] + dist[k][j];\n }\n }\n }\n }\n\n return dist;\n};\n\nvar _default = floydWarshall;\nexports.default = _default;","/* MIT license */\nvar cssKeywords = require('color-name');\n\n// NOTE: conversions should only return primitive values (i.e. arrays, or\n// values that give correct `typeof` results).\n// do not use box values types (i.e. Number(), String(), etc.)\n\nvar reverseKeywords = {};\nfor (var key in cssKeywords) {\n\tif (cssKeywords.hasOwnProperty(key)) {\n\t\treverseKeywords[cssKeywords[key]] = key;\n\t}\n}\n\nvar convert = module.exports = {\n\trgb: {channels: 3, labels: 'rgb'},\n\thsl: {channels: 3, labels: 'hsl'},\n\thsv: {channels: 3, labels: 'hsv'},\n\thwb: {channels: 3, labels: 'hwb'},\n\tcmyk: {channels: 4, labels: 'cmyk'},\n\txyz: {channels: 3, labels: 'xyz'},\n\tlab: {channels: 3, labels: 'lab'},\n\tlch: {channels: 3, labels: 'lch'},\n\thex: {channels: 1, labels: ['hex']},\n\tkeyword: {channels: 1, labels: ['keyword']},\n\tansi16: {channels: 1, labels: ['ansi16']},\n\tansi256: {channels: 1, labels: ['ansi256']},\n\thcg: {channels: 3, labels: ['h', 'c', 'g']},\n\tapple: {channels: 3, labels: ['r16', 'g16', 'b16']},\n\tgray: {channels: 1, labels: ['gray']}\n};\n\n// hide .channels and .labels properties\nfor (var model in convert) {\n\tif (convert.hasOwnProperty(model)) {\n\t\tif (!('channels' in convert[model])) {\n\t\t\tthrow new Error('missing channels property: ' + model);\n\t\t}\n\n\t\tif (!('labels' in convert[model])) {\n\t\t\tthrow new Error('missing channel labels property: ' + model);\n\t\t}\n\n\t\tif (convert[model].labels.length !== convert[model].channels) {\n\t\t\tthrow new Error('channel and label counts mismatch: ' + model);\n\t\t}\n\n\t\tvar channels = convert[model].channels;\n\t\tvar labels = convert[model].labels;\n\t\tdelete convert[model].channels;\n\t\tdelete convert[model].labels;\n\t\tObject.defineProperty(convert[model], 'channels', {value: channels});\n\t\tObject.defineProperty(convert[model], 'labels', {value: labels});\n\t}\n}\n\nconvert.rgb.hsl = function (rgb) {\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\tvar min = Math.min(r, g, b);\n\tvar max = Math.max(r, g, b);\n\tvar delta = max - min;\n\tvar h;\n\tvar s;\n\tvar l;\n\n\tif (max === min) {\n\t\th = 0;\n\t} else if (r === max) {\n\t\th = (g - b) / delta;\n\t} else if (g === max) {\n\t\th = 2 + (b - r) / delta;\n\t} else if (b === max) {\n\t\th = 4 + (r - g) / delta;\n\t}\n\n\th = Math.min(h * 60, 360);\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tl = (min + max) / 2;\n\n\tif (max === min) {\n\t\ts = 0;\n\t} else if (l <= 0.5) {\n\t\ts = delta / (max + min);\n\t} else {\n\t\ts = delta / (2 - max - min);\n\t}\n\n\treturn [h, s * 100, l * 100];\n};\n\nconvert.rgb.hsv = function (rgb) {\n\tvar rdif;\n\tvar gdif;\n\tvar bdif;\n\tvar h;\n\tvar s;\n\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\tvar v = Math.max(r, g, b);\n\tvar diff = v - Math.min(r, g, b);\n\tvar diffc = function (c) {\n\t\treturn (v - c) / 6 / diff + 1 / 2;\n\t};\n\n\tif (diff === 0) {\n\t\th = s = 0;\n\t} else {\n\t\ts = diff / v;\n\t\trdif = diffc(r);\n\t\tgdif = diffc(g);\n\t\tbdif = diffc(b);\n\n\t\tif (r === v) {\n\t\t\th = bdif - gdif;\n\t\t} else if (g === v) {\n\t\t\th = (1 / 3) + rdif - bdif;\n\t\t} else if (b === v) {\n\t\t\th = (2 / 3) + gdif - rdif;\n\t\t}\n\t\tif (h < 0) {\n\t\t\th += 1;\n\t\t} else if (h > 1) {\n\t\t\th -= 1;\n\t\t}\n\t}\n\n\treturn [\n\t\th * 360,\n\t\ts * 100,\n\t\tv * 100\n\t];\n};\n\nconvert.rgb.hwb = function (rgb) {\n\tvar r = rgb[0];\n\tvar g = rgb[1];\n\tvar b = rgb[2];\n\tvar h = convert.rgb.hsl(rgb)[0];\n\tvar w = 1 / 255 * Math.min(r, Math.min(g, b));\n\n\tb = 1 - 1 / 255 * Math.max(r, Math.max(g, b));\n\n\treturn [h, w * 100, b * 100];\n};\n\nconvert.rgb.cmyk = function (rgb) {\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\tvar c;\n\tvar m;\n\tvar y;\n\tvar k;\n\n\tk = Math.min(1 - r, 1 - g, 1 - b);\n\tc = (1 - r - k) / (1 - k) || 0;\n\tm = (1 - g - k) / (1 - k) || 0;\n\ty = (1 - b - k) / (1 - k) || 0;\n\n\treturn [c * 100, m * 100, y * 100, k * 100];\n};\n\n/**\n * See https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance\n * */\nfunction comparativeDistance(x, y) {\n\treturn (\n\t\tMath.pow(x[0] - y[0], 2) +\n\t\tMath.pow(x[1] - y[1], 2) +\n\t\tMath.pow(x[2] - y[2], 2)\n\t);\n}\n\nconvert.rgb.keyword = function (rgb) {\n\tvar reversed = reverseKeywords[rgb];\n\tif (reversed) {\n\t\treturn reversed;\n\t}\n\n\tvar currentClosestDistance = Infinity;\n\tvar currentClosestKeyword;\n\n\tfor (var keyword in cssKeywords) {\n\t\tif (cssKeywords.hasOwnProperty(keyword)) {\n\t\t\tvar value = cssKeywords[keyword];\n\n\t\t\t// Compute comparative distance\n\t\t\tvar distance = comparativeDistance(rgb, value);\n\n\t\t\t// Check if its less, if so set as closest\n\t\t\tif (distance < currentClosestDistance) {\n\t\t\t\tcurrentClosestDistance = distance;\n\t\t\t\tcurrentClosestKeyword = keyword;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn currentClosestKeyword;\n};\n\nconvert.keyword.rgb = function (keyword) {\n\treturn cssKeywords[keyword];\n};\n\nconvert.rgb.xyz = function (rgb) {\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\n\t// assume sRGB\n\tr = r > 0.04045 ? Math.pow(((r + 0.055) / 1.055), 2.4) : (r / 12.92);\n\tg = g > 0.04045 ? Math.pow(((g + 0.055) / 1.055), 2.4) : (g / 12.92);\n\tb = b > 0.04045 ? Math.pow(((b + 0.055) / 1.055), 2.4) : (b / 12.92);\n\n\tvar x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805);\n\tvar y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722);\n\tvar z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505);\n\n\treturn [x * 100, y * 100, z * 100];\n};\n\nconvert.rgb.lab = function (rgb) {\n\tvar xyz = convert.rgb.xyz(rgb);\n\tvar x = xyz[0];\n\tvar y = xyz[1];\n\tvar z = xyz[2];\n\tvar l;\n\tvar a;\n\tvar b;\n\n\tx /= 95.047;\n\ty /= 100;\n\tz /= 108.883;\n\n\tx = x > 0.008856 ? Math.pow(x, 1 / 3) : (7.787 * x) + (16 / 116);\n\ty = y > 0.008856 ? Math.pow(y, 1 / 3) : (7.787 * y) + (16 / 116);\n\tz = z > 0.008856 ? Math.pow(z, 1 / 3) : (7.787 * z) + (16 / 116);\n\n\tl = (116 * y) - 16;\n\ta = 500 * (x - y);\n\tb = 200 * (y - z);\n\n\treturn [l, a, b];\n};\n\nconvert.hsl.rgb = function (hsl) {\n\tvar h = hsl[0] / 360;\n\tvar s = hsl[1] / 100;\n\tvar l = hsl[2] / 100;\n\tvar t1;\n\tvar t2;\n\tvar t3;\n\tvar rgb;\n\tvar val;\n\n\tif (s === 0) {\n\t\tval = l * 255;\n\t\treturn [val, val, val];\n\t}\n\n\tif (l < 0.5) {\n\t\tt2 = l * (1 + s);\n\t} else {\n\t\tt2 = l + s - l * s;\n\t}\n\n\tt1 = 2 * l - t2;\n\n\trgb = [0, 0, 0];\n\tfor (var i = 0; i < 3; i++) {\n\t\tt3 = h + 1 / 3 * -(i - 1);\n\t\tif (t3 < 0) {\n\t\t\tt3++;\n\t\t}\n\t\tif (t3 > 1) {\n\t\t\tt3--;\n\t\t}\n\n\t\tif (6 * t3 < 1) {\n\t\t\tval = t1 + (t2 - t1) * 6 * t3;\n\t\t} else if (2 * t3 < 1) {\n\t\t\tval = t2;\n\t\t} else if (3 * t3 < 2) {\n\t\t\tval = t1 + (t2 - t1) * (2 / 3 - t3) * 6;\n\t\t} else {\n\t\t\tval = t1;\n\t\t}\n\n\t\trgb[i] = val * 255;\n\t}\n\n\treturn rgb;\n};\n\nconvert.hsl.hsv = function (hsl) {\n\tvar h = hsl[0];\n\tvar s = hsl[1] / 100;\n\tvar l = hsl[2] / 100;\n\tvar smin = s;\n\tvar lmin = Math.max(l, 0.01);\n\tvar sv;\n\tvar v;\n\n\tl *= 2;\n\ts *= (l <= 1) ? l : 2 - l;\n\tsmin *= lmin <= 1 ? lmin : 2 - lmin;\n\tv = (l + s) / 2;\n\tsv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s);\n\n\treturn [h, sv * 100, v * 100];\n};\n\nconvert.hsv.rgb = function (hsv) {\n\tvar h = hsv[0] / 60;\n\tvar s = hsv[1] / 100;\n\tvar v = hsv[2] / 100;\n\tvar hi = Math.floor(h) % 6;\n\n\tvar f = h - Math.floor(h);\n\tvar p = 255 * v * (1 - s);\n\tvar q = 255 * v * (1 - (s * f));\n\tvar t = 255 * v * (1 - (s * (1 - f)));\n\tv *= 255;\n\n\tswitch (hi) {\n\t\tcase 0:\n\t\t\treturn [v, t, p];\n\t\tcase 1:\n\t\t\treturn [q, v, p];\n\t\tcase 2:\n\t\t\treturn [p, v, t];\n\t\tcase 3:\n\t\t\treturn [p, q, v];\n\t\tcase 4:\n\t\t\treturn [t, p, v];\n\t\tcase 5:\n\t\t\treturn [v, p, q];\n\t}\n};\n\nconvert.hsv.hsl = function (hsv) {\n\tvar h = hsv[0];\n\tvar s = hsv[1] / 100;\n\tvar v = hsv[2] / 100;\n\tvar vmin = Math.max(v, 0.01);\n\tvar lmin;\n\tvar sl;\n\tvar l;\n\n\tl = (2 - s) * v;\n\tlmin = (2 - s) * vmin;\n\tsl = s * vmin;\n\tsl /= (lmin <= 1) ? lmin : 2 - lmin;\n\tsl = sl || 0;\n\tl /= 2;\n\n\treturn [h, sl * 100, l * 100];\n};\n\n// http://dev.w3.org/csswg/css-color/#hwb-to-rgb\nconvert.hwb.rgb = function (hwb) {\n\tvar h = hwb[0] / 360;\n\tvar wh = hwb[1] / 100;\n\tvar bl = hwb[2] / 100;\n\tvar ratio = wh + bl;\n\tvar i;\n\tvar v;\n\tvar f;\n\tvar n;\n\n\t// wh + bl cant be > 1\n\tif (ratio > 1) {\n\t\twh /= ratio;\n\t\tbl /= ratio;\n\t}\n\n\ti = Math.floor(6 * h);\n\tv = 1 - bl;\n\tf = 6 * h - i;\n\n\tif ((i & 0x01) !== 0) {\n\t\tf = 1 - f;\n\t}\n\n\tn = wh + f * (v - wh); // linear interpolation\n\n\tvar r;\n\tvar g;\n\tvar b;\n\tswitch (i) {\n\t\tdefault:\n\t\tcase 6:\n\t\tcase 0: r = v; g = n; b = wh; break;\n\t\tcase 1: r = n; g = v; b = wh; break;\n\t\tcase 2: r = wh; g = v; b = n; break;\n\t\tcase 3: r = wh; g = n; b = v; break;\n\t\tcase 4: r = n; g = wh; b = v; break;\n\t\tcase 5: r = v; g = wh; b = n; break;\n\t}\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.cmyk.rgb = function (cmyk) {\n\tvar c = cmyk[0] / 100;\n\tvar m = cmyk[1] / 100;\n\tvar y = cmyk[2] / 100;\n\tvar k = cmyk[3] / 100;\n\tvar r;\n\tvar g;\n\tvar b;\n\n\tr = 1 - Math.min(1, c * (1 - k) + k);\n\tg = 1 - Math.min(1, m * (1 - k) + k);\n\tb = 1 - Math.min(1, y * (1 - k) + k);\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.xyz.rgb = function (xyz) {\n\tvar x = xyz[0] / 100;\n\tvar y = xyz[1] / 100;\n\tvar z = xyz[2] / 100;\n\tvar r;\n\tvar g;\n\tvar b;\n\n\tr = (x * 3.2406) + (y * -1.5372) + (z * -0.4986);\n\tg = (x * -0.9689) + (y * 1.8758) + (z * 0.0415);\n\tb = (x * 0.0557) + (y * -0.2040) + (z * 1.0570);\n\n\t// assume sRGB\n\tr = r > 0.0031308\n\t\t? ((1.055 * Math.pow(r, 1.0 / 2.4)) - 0.055)\n\t\t: r * 12.92;\n\n\tg = g > 0.0031308\n\t\t? ((1.055 * Math.pow(g, 1.0 / 2.4)) - 0.055)\n\t\t: g * 12.92;\n\n\tb = b > 0.0031308\n\t\t? ((1.055 * Math.pow(b, 1.0 / 2.4)) - 0.055)\n\t\t: b * 12.92;\n\n\tr = Math.min(Math.max(0, r), 1);\n\tg = Math.min(Math.max(0, g), 1);\n\tb = Math.min(Math.max(0, b), 1);\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.xyz.lab = function (xyz) {\n\tvar x = xyz[0];\n\tvar y = xyz[1];\n\tvar z = xyz[2];\n\tvar l;\n\tvar a;\n\tvar b;\n\n\tx /= 95.047;\n\ty /= 100;\n\tz /= 108.883;\n\n\tx = x > 0.008856 ? Math.pow(x, 1 / 3) : (7.787 * x) + (16 / 116);\n\ty = y > 0.008856 ? Math.pow(y, 1 / 3) : (7.787 * y) + (16 / 116);\n\tz = z > 0.008856 ? Math.pow(z, 1 / 3) : (7.787 * z) + (16 / 116);\n\n\tl = (116 * y) - 16;\n\ta = 500 * (x - y);\n\tb = 200 * (y - z);\n\n\treturn [l, a, b];\n};\n\nconvert.lab.xyz = function (lab) {\n\tvar l = lab[0];\n\tvar a = lab[1];\n\tvar b = lab[2];\n\tvar x;\n\tvar y;\n\tvar z;\n\n\ty = (l + 16) / 116;\n\tx = a / 500 + y;\n\tz = y - b / 200;\n\n\tvar y2 = Math.pow(y, 3);\n\tvar x2 = Math.pow(x, 3);\n\tvar z2 = Math.pow(z, 3);\n\ty = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787;\n\tx = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787;\n\tz = z2 > 0.008856 ? z2 : (z - 16 / 116) / 7.787;\n\n\tx *= 95.047;\n\ty *= 100;\n\tz *= 108.883;\n\n\treturn [x, y, z];\n};\n\nconvert.lab.lch = function (lab) {\n\tvar l = lab[0];\n\tvar a = lab[1];\n\tvar b = lab[2];\n\tvar hr;\n\tvar h;\n\tvar c;\n\n\thr = Math.atan2(b, a);\n\th = hr * 360 / 2 / Math.PI;\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tc = Math.sqrt(a * a + b * b);\n\n\treturn [l, c, h];\n};\n\nconvert.lch.lab = function (lch) {\n\tvar l = lch[0];\n\tvar c = lch[1];\n\tvar h = lch[2];\n\tvar a;\n\tvar b;\n\tvar hr;\n\n\thr = h / 360 * 2 * Math.PI;\n\ta = c * Math.cos(hr);\n\tb = c * Math.sin(hr);\n\n\treturn [l, a, b];\n};\n\nconvert.rgb.ansi16 = function (args) {\n\tvar r = args[0];\n\tvar g = args[1];\n\tvar b = args[2];\n\tvar value = 1 in arguments ? arguments[1] : convert.rgb.hsv(args)[2]; // hsv -> ansi16 optimization\n\n\tvalue = Math.round(value / 50);\n\n\tif (value === 0) {\n\t\treturn 30;\n\t}\n\n\tvar ansi = 30\n\t\t+ ((Math.round(b / 255) << 2)\n\t\t| (Math.round(g / 255) << 1)\n\t\t| Math.round(r / 255));\n\n\tif (value === 2) {\n\t\tansi += 60;\n\t}\n\n\treturn ansi;\n};\n\nconvert.hsv.ansi16 = function (args) {\n\t// optimization here; we already know the value and don't need to get\n\t// it converted for us.\n\treturn convert.rgb.ansi16(convert.hsv.rgb(args), args[2]);\n};\n\nconvert.rgb.ansi256 = function (args) {\n\tvar r = args[0];\n\tvar g = args[1];\n\tvar b = args[2];\n\n\t// we use the extended greyscale palette here, with the exception of\n\t// black and white. normal palette only has 4 greyscale shades.\n\tif (r === g && g === b) {\n\t\tif (r < 8) {\n\t\t\treturn 16;\n\t\t}\n\n\t\tif (r > 248) {\n\t\t\treturn 231;\n\t\t}\n\n\t\treturn Math.round(((r - 8) / 247) * 24) + 232;\n\t}\n\n\tvar ansi = 16\n\t\t+ (36 * Math.round(r / 255 * 5))\n\t\t+ (6 * Math.round(g / 255 * 5))\n\t\t+ Math.round(b / 255 * 5);\n\n\treturn ansi;\n};\n\nconvert.ansi16.rgb = function (args) {\n\tvar color = args % 10;\n\n\t// handle greyscale\n\tif (color === 0 || color === 7) {\n\t\tif (args > 50) {\n\t\t\tcolor += 3.5;\n\t\t}\n\n\t\tcolor = color / 10.5 * 255;\n\n\t\treturn [color, color, color];\n\t}\n\n\tvar mult = (~~(args > 50) + 1) * 0.5;\n\tvar r = ((color & 1) * mult) * 255;\n\tvar g = (((color >> 1) & 1) * mult) * 255;\n\tvar b = (((color >> 2) & 1) * mult) * 255;\n\n\treturn [r, g, b];\n};\n\nconvert.ansi256.rgb = function (args) {\n\t// handle greyscale\n\tif (args >= 232) {\n\t\tvar c = (args - 232) * 10 + 8;\n\t\treturn [c, c, c];\n\t}\n\n\targs -= 16;\n\n\tvar rem;\n\tvar r = Math.floor(args / 36) / 5 * 255;\n\tvar g = Math.floor((rem = args % 36) / 6) / 5 * 255;\n\tvar b = (rem % 6) / 5 * 255;\n\n\treturn [r, g, b];\n};\n\nconvert.rgb.hex = function (args) {\n\tvar integer = ((Math.round(args[0]) & 0xFF) << 16)\n\t\t+ ((Math.round(args[1]) & 0xFF) << 8)\n\t\t+ (Math.round(args[2]) & 0xFF);\n\n\tvar string = integer.toString(16).toUpperCase();\n\treturn '000000'.substring(string.length) + string;\n};\n\nconvert.hex.rgb = function (args) {\n\tvar match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);\n\tif (!match) {\n\t\treturn [0, 0, 0];\n\t}\n\n\tvar colorString = match[0];\n\n\tif (match[0].length === 3) {\n\t\tcolorString = colorString.split('').map(function (char) {\n\t\t\treturn char + char;\n\t\t}).join('');\n\t}\n\n\tvar integer = parseInt(colorString, 16);\n\tvar r = (integer >> 16) & 0xFF;\n\tvar g = (integer >> 8) & 0xFF;\n\tvar b = integer & 0xFF;\n\n\treturn [r, g, b];\n};\n\nconvert.rgb.hcg = function (rgb) {\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\tvar max = Math.max(Math.max(r, g), b);\n\tvar min = Math.min(Math.min(r, g), b);\n\tvar chroma = (max - min);\n\tvar grayscale;\n\tvar hue;\n\n\tif (chroma < 1) {\n\t\tgrayscale = min / (1 - chroma);\n\t} else {\n\t\tgrayscale = 0;\n\t}\n\n\tif (chroma <= 0) {\n\t\thue = 0;\n\t} else\n\tif (max === r) {\n\t\thue = ((g - b) / chroma) % 6;\n\t} else\n\tif (max === g) {\n\t\thue = 2 + (b - r) / chroma;\n\t} else {\n\t\thue = 4 + (r - g) / chroma + 4;\n\t}\n\n\thue /= 6;\n\thue %= 1;\n\n\treturn [hue * 360, chroma * 100, grayscale * 100];\n};\n\nconvert.hsl.hcg = function (hsl) {\n\tvar s = hsl[1] / 100;\n\tvar l = hsl[2] / 100;\n\tvar c = 1;\n\tvar f = 0;\n\n\tif (l < 0.5) {\n\t\tc = 2.0 * s * l;\n\t} else {\n\t\tc = 2.0 * s * (1.0 - l);\n\t}\n\n\tif (c < 1.0) {\n\t\tf = (l - 0.5 * c) / (1.0 - c);\n\t}\n\n\treturn [hsl[0], c * 100, f * 100];\n};\n\nconvert.hsv.hcg = function (hsv) {\n\tvar s = hsv[1] / 100;\n\tvar v = hsv[2] / 100;\n\n\tvar c = s * v;\n\tvar f = 0;\n\n\tif (c < 1.0) {\n\t\tf = (v - c) / (1 - c);\n\t}\n\n\treturn [hsv[0], c * 100, f * 100];\n};\n\nconvert.hcg.rgb = function (hcg) {\n\tvar h = hcg[0] / 360;\n\tvar c = hcg[1] / 100;\n\tvar g = hcg[2] / 100;\n\n\tif (c === 0.0) {\n\t\treturn [g * 255, g * 255, g * 255];\n\t}\n\n\tvar pure = [0, 0, 0];\n\tvar hi = (h % 1) * 6;\n\tvar v = hi % 1;\n\tvar w = 1 - v;\n\tvar mg = 0;\n\n\tswitch (Math.floor(hi)) {\n\t\tcase 0:\n\t\t\tpure[0] = 1; pure[1] = v; pure[2] = 0; break;\n\t\tcase 1:\n\t\t\tpure[0] = w; pure[1] = 1; pure[2] = 0; break;\n\t\tcase 2:\n\t\t\tpure[0] = 0; pure[1] = 1; pure[2] = v; break;\n\t\tcase 3:\n\t\t\tpure[0] = 0; pure[1] = w; pure[2] = 1; break;\n\t\tcase 4:\n\t\t\tpure[0] = v; pure[1] = 0; pure[2] = 1; break;\n\t\tdefault:\n\t\t\tpure[0] = 1; pure[1] = 0; pure[2] = w;\n\t}\n\n\tmg = (1.0 - c) * g;\n\n\treturn [\n\t\t(c * pure[0] + mg) * 255,\n\t\t(c * pure[1] + mg) * 255,\n\t\t(c * pure[2] + mg) * 255\n\t];\n};\n\nconvert.hcg.hsv = function (hcg) {\n\tvar c = hcg[1] / 100;\n\tvar g = hcg[2] / 100;\n\n\tvar v = c + g * (1.0 - c);\n\tvar f = 0;\n\n\tif (v > 0.0) {\n\t\tf = c / v;\n\t}\n\n\treturn [hcg[0], f * 100, v * 100];\n};\n\nconvert.hcg.hsl = function (hcg) {\n\tvar c = hcg[1] / 100;\n\tvar g = hcg[2] / 100;\n\n\tvar l = g * (1.0 - c) + 0.5 * c;\n\tvar s = 0;\n\n\tif (l > 0.0 && l < 0.5) {\n\t\ts = c / (2 * l);\n\t} else\n\tif (l >= 0.5 && l < 1.0) {\n\t\ts = c / (2 * (1 - l));\n\t}\n\n\treturn [hcg[0], s * 100, l * 100];\n};\n\nconvert.hcg.hwb = function (hcg) {\n\tvar c = hcg[1] / 100;\n\tvar g = hcg[2] / 100;\n\tvar v = c + g * (1.0 - c);\n\treturn [hcg[0], (v - c) * 100, (1 - v) * 100];\n};\n\nconvert.hwb.hcg = function (hwb) {\n\tvar w = hwb[1] / 100;\n\tvar b = hwb[2] / 100;\n\tvar v = 1 - b;\n\tvar c = v - w;\n\tvar g = 0;\n\n\tif (c < 1) {\n\t\tg = (v - c) / (1 - c);\n\t}\n\n\treturn [hwb[0], c * 100, g * 100];\n};\n\nconvert.apple.rgb = function (apple) {\n\treturn [(apple[0] / 65535) * 255, (apple[1] / 65535) * 255, (apple[2] / 65535) * 255];\n};\n\nconvert.rgb.apple = function (rgb) {\n\treturn [(rgb[0] / 255) * 65535, (rgb[1] / 255) * 65535, (rgb[2] / 255) * 65535];\n};\n\nconvert.gray.rgb = function (args) {\n\treturn [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255];\n};\n\nconvert.gray.hsl = convert.gray.hsv = function (args) {\n\treturn [0, 0, args[0]];\n};\n\nconvert.gray.hwb = function (gray) {\n\treturn [0, 100, gray[0]];\n};\n\nconvert.gray.cmyk = function (gray) {\n\treturn [0, 0, 0, gray[0]];\n};\n\nconvert.gray.lab = function (gray) {\n\treturn [gray[0], 0, 0];\n};\n\nconvert.gray.hex = function (gray) {\n\tvar val = Math.round(gray[0] / 100 * 255) & 0xFF;\n\tvar integer = (val << 16) + (val << 8) + val;\n\n\tvar string = integer.toString(16).toUpperCase();\n\treturn '000000'.substring(string.length) + string;\n};\n\nconvert.rgb.gray = function (rgb) {\n\tvar val = (rgb[0] + rgb[1] + rgb[2]) / 3;\n\treturn [val / 255 * 100];\n};\n","var Stack = require('./_Stack'),\n arrayEach = require('./_arrayEach'),\n assignValue = require('./_assignValue'),\n baseAssign = require('./_baseAssign'),\n baseAssignIn = require('./_baseAssignIn'),\n cloneBuffer = require('./_cloneBuffer'),\n copyArray = require('./_copyArray'),\n copySymbols = require('./_copySymbols'),\n copySymbolsIn = require('./_copySymbolsIn'),\n getAllKeys = require('./_getAllKeys'),\n getAllKeysIn = require('./_getAllKeysIn'),\n getTag = require('./_getTag'),\n initCloneArray = require('./_initCloneArray'),\n initCloneByTag = require('./_initCloneByTag'),\n initCloneObject = require('./_initCloneObject'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isMap = require('./isMap'),\n isObject = require('./isObject'),\n isSet = require('./isSet'),\n keys = require('./keys'),\n keysIn = require('./keysIn');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n}\n\nmodule.exports = baseClone;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nmodule.exports = toSource;\n","var getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\n","var baseTimes = require('./_baseTimes'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isIndex = require('./_isIndex'),\n isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = arrayLikeKeys;\n","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nmodule.exports = overArg;\n","var root = require('./_root');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n}\n\nmodule.exports = cloneBuffer;\n","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n}\n\nmodule.exports = copyArray;\n","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nmodule.exports = arrayFilter;\n","/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\nmodule.exports = stubArray;\n","var arrayPush = require('./_arrayPush'),\n getPrototype = require('./_getPrototype'),\n getSymbols = require('./_getSymbols'),\n stubArray = require('./stubArray');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n};\n\nmodule.exports = getSymbolsIn;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbols = require('./_getSymbols'),\n keys = require('./keys');\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\nmodule.exports = getAllKeys;\n","var arrayPush = require('./_arrayPush'),\n isArray = require('./isArray');\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nmodule.exports = baseGetAllKeys;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nmodule.exports = cloneTypedArray;\n","var baseCreate = require('./_baseCreate'),\n getPrototype = require('./_getPrototype'),\n isPrototype = require('./_isPrototype');\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n}\n\nmodule.exports = initCloneObject;\n","var isObject = require('./isObject');\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n}());\n\nmodule.exports = baseCreate;\n","module.exports = require('./forEach');\n","var arrayEach = require('./_arrayEach'),\n baseEach = require('./_baseEach'),\n castFunction = require('./_castFunction'),\n isArray = require('./isArray');\n\n/**\n * Iterates over elements of `collection` and invokes `iteratee` for each element.\n * The iteratee is invoked with three arguments: (value, index|key, collection).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * **Note:** As with other \"Collections\" methods, objects with a \"length\"\n * property are iterated like arrays. To avoid this behavior use `_.forIn`\n * or `_.forOwn` for object iteration.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias each\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEachRight\n * @example\n *\n * _.forEach([1, 2], function(value) {\n * console.log(value);\n * });\n * // => Logs `1` then `2`.\n *\n * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\nfunction forEach(collection, iteratee) {\n var func = isArray(collection) ? arrayEach : baseEach;\n return func(collection, castFunction(iteratee));\n}\n\nmodule.exports = forEach;\n","var identity = require('./identity');\n\n/**\n * Casts `value` to `identity` if it's not a function.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Function} Returns cast function.\n */\nfunction castFunction(value) {\n return typeof value == 'function' ? value : identity;\n}\n\nmodule.exports = castFunction;\n","var arrayFilter = require('./_arrayFilter'),\n baseFilter = require('./_baseFilter'),\n baseIteratee = require('./_baseIteratee'),\n isArray = require('./isArray');\n\n/**\n * Iterates over elements of `collection`, returning an array of all elements\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * **Note:** Unlike `_.remove`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.reject\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * _.filter(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, { 'age': 36, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.filter(users, 'active');\n * // => objects for ['barney']\n *\n * // Combining several predicates using `_.overEvery` or `_.overSome`.\n * _.filter(users, _.overSome([{ 'age': 36 }, ['age', 40]]));\n * // => objects for ['fred', 'barney']\n */\nfunction filter(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, baseIteratee(predicate, 3));\n}\n\nmodule.exports = filter;\n","var baseIsEqualDeep = require('./_baseIsEqualDeep'),\n isObjectLike = require('./isObjectLike');\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\nmodule.exports = baseIsEqual;\n","var SetCache = require('./_SetCache'),\n arraySome = require('./_arraySome'),\n cacheHas = require('./_cacheHas');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Check that cyclic values are equal.\n var arrStacked = stack.get(array);\n var othStacked = stack.get(other);\n if (arrStacked && othStacked) {\n return arrStacked == other && othStacked == array;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalArrays;\n","var MapCache = require('./_MapCache'),\n setCacheAdd = require('./_setCacheAdd'),\n setCacheHas = require('./_setCacheHas');\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nmodule.exports = SetCache;\n","/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\nmodule.exports = cacheHas;\n","var isObject = require('./isObject');\n\n/**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\nfunction isStrictComparable(value) {\n return value === value && !isObject(value);\n}\n\nmodule.exports = isStrictComparable;\n","/**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n}\n\nmodule.exports = matchesStrictComparable;\n","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\n","var baseHasIn = require('./_baseHasIn'),\n hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n}\n\nmodule.exports = hasIn;\n","var castPath = require('./_castPath'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isIndex = require('./_isIndex'),\n isLength = require('./isLength'),\n toKey = require('./_toKey');\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n}\n\nmodule.exports = hasPath;\n","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n}\n\nmodule.exports = baseProperty;\n","var baseHas = require('./_baseHas'),\n hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct property of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = { 'a': { 'b': 2 } };\n * var other = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.has(object, 'a');\n * // => true\n *\n * _.has(object, 'a.b');\n * // => true\n *\n * _.has(object, ['a', 'b']);\n * // => true\n *\n * _.has(other, 'a');\n * // => false\n */\nfunction has(object, path) {\n return object != null && hasPath(object, path, baseHas);\n}\n\nmodule.exports = has;\n","/**\n * Checks if `value` is `undefined`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\n * @example\n *\n * _.isUndefined(void 0);\n * // => true\n *\n * _.isUndefined(null);\n * // => false\n */\nfunction isUndefined(value) {\n return value === undefined;\n}\n\nmodule.exports = isUndefined;\n","var arrayMap = require('./_arrayMap'),\n baseIteratee = require('./_baseIteratee'),\n baseMap = require('./_baseMap'),\n isArray = require('./isArray');\n\n/**\n * Creates an array of values by running each element in `collection` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\n *\n * The guarded methods are:\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * _.map([4, 8], square);\n * // => [16, 64]\n *\n * _.map({ 'a': 4, 'b': 8 }, square);\n * // => [16, 64] (iteration order is not guaranteed)\n *\n * var users = [\n * { 'user': 'barney' },\n * { 'user': 'fred' }\n * ];\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, 'user');\n * // => ['barney', 'fred']\n */\nfunction map(collection, iteratee) {\n var func = isArray(collection) ? arrayMap : baseMap;\n return func(collection, baseIteratee(iteratee, 3));\n}\n\nmodule.exports = map;\n","var baseEach = require('./_baseEach'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * The base implementation of `_.map` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction baseMap(collection, iteratee) {\n var index = -1,\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value, key, collection) {\n result[++index] = iteratee(value, key, collection);\n });\n return result;\n}\n\nmodule.exports = baseMap;\n","var arrayReduce = require('./_arrayReduce'),\n baseEach = require('./_baseEach'),\n baseIteratee = require('./_baseIteratee'),\n baseReduce = require('./_baseReduce'),\n isArray = require('./isArray');\n\n/**\n * Reduces `collection` to a value which is the accumulated result of running\n * each element in `collection` thru `iteratee`, where each successive\n * invocation is supplied the return value of the previous. If `accumulator`\n * is not given, the first element of `collection` is used as the initial\n * value. The iteratee is invoked with four arguments:\n * (accumulator, value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.reduce`, `_.reduceRight`, and `_.transform`.\n *\n * The guarded methods are:\n * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,\n * and `sortBy`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduceRight\n * @example\n *\n * _.reduce([1, 2], function(sum, n) {\n * return sum + n;\n * }, 0);\n * // => 3\n *\n * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * return result;\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)\n */\nfunction reduce(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduce : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, baseIteratee(iteratee, 4), accumulator, initAccum, baseEach);\n}\n\nmodule.exports = reduce;\n","var apply = require('./_apply');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\nfunction overRest(func, start, transform) {\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n return function() {\n var args = arguments,\n index = -1,\n length = nativeMax(args.length - start, 0),\n array = Array(length);\n\n while (++index < length) {\n array[index] = args[start + index];\n }\n index = -1;\n var otherArgs = Array(start + 1);\n while (++index < start) {\n otherArgs[index] = args[index];\n }\n otherArgs[start] = transform(array);\n return apply(func, this, otherArgs);\n };\n}\n\nmodule.exports = overRest;\n","var baseSetToString = require('./_baseSetToString'),\n shortOut = require('./_shortOut');\n\n/**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar setToString = shortOut(baseSetToString);\n\nmodule.exports = setToString;\n","/**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseFindIndex(array, predicate, fromIndex, fromRight) {\n var length = array.length,\n index = fromIndex + (fromRight ? 1 : -1);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (predicate(array[index], index, array)) {\n return index;\n }\n }\n return -1;\n}\n\nmodule.exports = baseFindIndex;\n","var isArrayLike = require('./isArrayLike'),\n isObjectLike = require('./isObjectLike');\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n * else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\n}\n\nmodule.exports = isArrayLikeObject;\n","var baseValues = require('./_baseValues'),\n keys = require('./keys');\n\n/**\n * Creates an array of the own enumerable string keyed property values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.values(new Foo);\n * // => [1, 2] (iteration order is not guaranteed)\n *\n * _.values('hi');\n * // => ['h', 'i']\n */\nfunction values(object) {\n return object == null ? [] : baseValues(object, keys(object));\n}\n\nmodule.exports = values;\n","var _ = require(\"../lodash\");\nvar PriorityQueue = require(\"../data/priority-queue\");\n\nmodule.exports = dijkstra;\n\nvar DEFAULT_WEIGHT_FUNC = _.constant(1);\n\nfunction dijkstra(g, source, weightFn, edgeFn) {\n return runDijkstra(g, String(source),\n weightFn || DEFAULT_WEIGHT_FUNC,\n edgeFn || function(v) { return g.outEdges(v); });\n}\n\nfunction runDijkstra(g, source, weightFn, edgeFn) {\n var results = {};\n var pq = new PriorityQueue();\n var v, vEntry;\n\n var updateNeighbors = function(edge) {\n var w = edge.v !== v ? edge.v : edge.w;\n var wEntry = results[w];\n var weight = weightFn(edge);\n var distance = vEntry.distance + weight;\n\n if (weight < 0) {\n throw new Error(\"dijkstra does not allow negative edge weights. \" +\n \"Bad edge: \" + edge + \" Weight: \" + weight);\n }\n\n if (distance < wEntry.distance) {\n wEntry.distance = distance;\n wEntry.predecessor = v;\n pq.decrease(w, distance);\n }\n };\n\n g.nodes().forEach(function(v) {\n var distance = v === source ? 0 : Number.POSITIVE_INFINITY;\n results[v] = { distance: distance };\n pq.add(v, distance);\n });\n\n while (pq.size() > 0) {\n v = pq.removeMin();\n vEntry = results[v];\n if (vEntry.distance === Number.POSITIVE_INFINITY) {\n break;\n }\n\n edgeFn(v).forEach(updateNeighbors);\n }\n\n return results;\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = PriorityQueue;\n\n/**\n * A min-priority queue data structure. This algorithm is derived from Cormen,\n * et al., \"Introduction to Algorithms\". The basic idea of a min-priority\n * queue is that you can efficiently (in O(1) time) get the smallest key in\n * the queue. Adding and removing elements takes O(log n) time. A key can\n * have its priority decreased in O(log n) time.\n */\nfunction PriorityQueue() {\n this._arr = [];\n this._keyIndices = {};\n}\n\n/**\n * Returns the number of elements in the queue. Takes `O(1)` time.\n */\nPriorityQueue.prototype.size = function() {\n return this._arr.length;\n};\n\n/**\n * Returns the keys that are in the queue. Takes `O(n)` time.\n */\nPriorityQueue.prototype.keys = function() {\n return this._arr.map(function(x) { return x.key; });\n};\n\n/**\n * Returns `true` if **key** is in the queue and `false` if not.\n */\nPriorityQueue.prototype.has = function(key) {\n return _.has(this._keyIndices, key);\n};\n\n/**\n * Returns the priority for **key**. If **key** is not present in the queue\n * then this function returns `undefined`. Takes `O(1)` time.\n *\n * @param {Object} key\n */\nPriorityQueue.prototype.priority = function(key) {\n var index = this._keyIndices[key];\n if (index !== undefined) {\n return this._arr[index].priority;\n }\n};\n\n/**\n * Returns the key for the minimum element in this queue. If the queue is\n * empty this function throws an Error. Takes `O(1)` time.\n */\nPriorityQueue.prototype.min = function() {\n if (this.size() === 0) {\n throw new Error(\"Queue underflow\");\n }\n return this._arr[0].key;\n};\n\n/**\n * Inserts a new key into the priority queue. If the key already exists in\n * the queue this function returns `false`; otherwise it will return `true`.\n * Takes `O(n)` time.\n *\n * @param {Object} key the key to add\n * @param {Number} priority the initial priority for the key\n */\nPriorityQueue.prototype.add = function(key, priority) {\n var keyIndices = this._keyIndices;\n key = String(key);\n if (!_.has(keyIndices, key)) {\n var arr = this._arr;\n var index = arr.length;\n keyIndices[key] = index;\n arr.push({key: key, priority: priority});\n this._decrease(index);\n return true;\n }\n return false;\n};\n\n/**\n * Removes and returns the smallest key in the queue. Takes `O(log n)` time.\n */\nPriorityQueue.prototype.removeMin = function() {\n this._swap(0, this._arr.length - 1);\n var min = this._arr.pop();\n delete this._keyIndices[min.key];\n this._heapify(0);\n return min.key;\n};\n\n/**\n * Decreases the priority for **key** to **priority**. If the new priority is\n * greater than the previous priority, this function will throw an Error.\n *\n * @param {Object} key the key for which to raise priority\n * @param {Number} priority the new priority for the key\n */\nPriorityQueue.prototype.decrease = function(key, priority) {\n var index = this._keyIndices[key];\n if (priority > this._arr[index].priority) {\n throw new Error(\"New priority is greater than current priority. \" +\n \"Key: \" + key + \" Old: \" + this._arr[index].priority + \" New: \" + priority);\n }\n this._arr[index].priority = priority;\n this._decrease(index);\n};\n\nPriorityQueue.prototype._heapify = function(i) {\n var arr = this._arr;\n var l = 2 * i;\n var r = l + 1;\n var largest = i;\n if (l < arr.length) {\n largest = arr[l].priority < arr[largest].priority ? l : largest;\n if (r < arr.length) {\n largest = arr[r].priority < arr[largest].priority ? r : largest;\n }\n if (largest !== i) {\n this._swap(i, largest);\n this._heapify(largest);\n }\n }\n};\n\nPriorityQueue.prototype._decrease = function(index) {\n var arr = this._arr;\n var priority = arr[index].priority;\n var parent;\n while (index !== 0) {\n parent = index >> 1;\n if (arr[parent].priority < priority) {\n break;\n }\n this._swap(index, parent);\n index = parent;\n }\n};\n\nPriorityQueue.prototype._swap = function(i, j) {\n var arr = this._arr;\n var keyIndices = this._keyIndices;\n var origArrI = arr[i];\n var origArrJ = arr[j];\n arr[i] = origArrJ;\n arr[j] = origArrI;\n keyIndices[origArrJ.key] = i;\n keyIndices[origArrI.key] = j;\n};\n","var _ = require(\"../lodash\");\n\nmodule.exports = tarjan;\n\nfunction tarjan(g) {\n var index = 0;\n var stack = [];\n var visited = {}; // node id -> { onStack, lowlink, index }\n var results = [];\n\n function dfs(v) {\n var entry = visited[v] = {\n onStack: true,\n lowlink: index,\n index: index++\n };\n stack.push(v);\n\n g.successors(v).forEach(function(w) {\n if (!_.has(visited, w)) {\n dfs(w);\n entry.lowlink = Math.min(entry.lowlink, visited[w].lowlink);\n } else if (visited[w].onStack) {\n entry.lowlink = Math.min(entry.lowlink, visited[w].index);\n }\n });\n\n if (entry.lowlink === entry.index) {\n var cmpt = [];\n var w;\n do {\n w = stack.pop();\n visited[w].onStack = false;\n cmpt.push(w);\n } while (v !== w);\n results.push(cmpt);\n }\n }\n\n g.nodes().forEach(function(v) {\n if (!_.has(visited, v)) {\n dfs(v);\n }\n });\n\n return results;\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = topsort;\ntopsort.CycleException = CycleException;\n\nfunction topsort(g) {\n var visited = {};\n var stack = {};\n var results = [];\n\n function visit(node) {\n if (_.has(stack, node)) {\n throw new CycleException();\n }\n\n if (!_.has(visited, node)) {\n stack[node] = true;\n visited[node] = true;\n _.each(g.predecessors(node), visit);\n delete stack[node];\n results.push(node);\n }\n }\n\n _.each(g.sinks(), visit);\n\n if (_.size(visited) !== g.nodeCount()) {\n throw new CycleException();\n }\n\n return results;\n}\n\nfunction CycleException() {}\nCycleException.prototype = new Error(); // must be an instance of Error to pass testing","var _ = require(\"../lodash\");\n\nmodule.exports = dfs;\n\n/*\n * A helper that preforms a pre- or post-order traversal on the input graph\n * and returns the nodes in the order they were visited. If the graph is\n * undirected then this algorithm will navigate using neighbors. If the graph\n * is directed then this algorithm will navigate using successors.\n *\n * Order must be one of \"pre\" or \"post\".\n */\nfunction dfs(g, vs, order) {\n if (!_.isArray(vs)) {\n vs = [vs];\n }\n\n var navigation = (g.isDirected() ? g.successors : g.neighbors).bind(g);\n\n var acc = [];\n var visited = {};\n _.each(vs, function(v) {\n if (!g.hasNode(v)) {\n throw new Error(\"Graph does not have node: \" + v);\n }\n\n doDfs(g, v, order === \"post\", visited, navigation, acc);\n });\n return acc;\n}\n\nfunction doDfs(g, v, postorder, visited, navigation, acc) {\n if (!_.has(visited, v)) {\n visited[v] = true;\n\n if (!postorder) { acc.push(v); }\n _.each(navigation(v), function(w) {\n doDfs(g, w, postorder, visited, navigation, acc);\n });\n if (postorder) { acc.push(v); }\n }\n}\n","var toNumber = require('./toNumber');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n}\n\nmodule.exports = toFinite;\n","var baseFlatten = require('./_baseFlatten');\n\n/**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\nfunction flatten(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, 1) : [];\n}\n\nmodule.exports = flatten;\n","var baseAssignValue = require('./_baseAssignValue'),\n eq = require('./eq');\n\n/**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignMergeValue(object, key, value) {\n if ((value !== undefined && !eq(object[key], value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nmodule.exports = assignMergeValue;\n","/**\n * Gets the value at `key`, unless `key` is \"__proto__\" or \"constructor\".\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction safeGet(object, key) {\n if (key === 'constructor' && typeof object[key] === 'function') {\n return;\n }\n\n if (key == '__proto__') {\n return;\n }\n\n return object[key];\n}\n\nmodule.exports = safeGet;\n","/**\n * The base implementation of `_.lt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n */\nfunction baseLt(value, other) {\n return value < other;\n}\n\nmodule.exports = baseLt;\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar Graph = require(\"../graphlib\").Graph;\nvar slack = require(\"./util\").slack;\n\nmodule.exports = feasibleTree;\n\n/*\n * Constructs a spanning tree with tight edges and adjusted the input node's\n * ranks to achieve this. A tight edge is one that is has a length that matches\n * its \"minlen\" attribute.\n *\n * The basic structure for this function is derived from Gansner, et al., \"A\n * Technique for Drawing Directed Graphs.\"\n *\n * Pre-conditions:\n *\n * 1. Graph must be a DAG.\n * 2. Graph must be connected.\n * 3. Graph must have at least one node.\n * 5. Graph nodes must have been previously assigned a \"rank\" property that\n * respects the \"minlen\" property of incident edges.\n * 6. Graph edges must have a \"minlen\" property.\n *\n * Post-conditions:\n *\n * - Graph nodes will have their rank adjusted to ensure that all edges are\n * tight.\n *\n * Returns a tree (undirected graph) that is constructed using only \"tight\"\n * edges.\n */\nfunction feasibleTree(g) {\n var t = new Graph({ directed: false });\n\n // Choose arbitrary node from which to start our tree\n var start = g.nodes()[0];\n var size = g.nodeCount();\n t.setNode(start, {});\n\n var edge, delta;\n while (tightTree(t, g) < size) {\n edge = findMinSlackEdge(t, g);\n delta = t.hasNode(edge.v) ? slack(g, edge) : -slack(g, edge);\n shiftRanks(t, g, delta);\n }\n\n return t;\n}\n\n/*\n * Finds a maximal tree of tight edges and returns the number of nodes in the\n * tree.\n */\nfunction tightTree(t, g) {\n function dfs(v) {\n _.forEach(g.nodeEdges(v), function(e) {\n var edgeV = e.v,\n w = (v === edgeV) ? e.w : edgeV;\n if (!t.hasNode(w) && !slack(g, e)) {\n t.setNode(w, {});\n t.setEdge(v, w, {});\n dfs(w);\n }\n });\n }\n\n _.forEach(t.nodes(), dfs);\n return t.nodeCount();\n}\n\n/*\n * Finds the edge with the smallest slack that is incident on tree and returns\n * it.\n */\nfunction findMinSlackEdge(t, g) {\n return _.minBy(g.edges(), function(e) {\n if (t.hasNode(e.v) !== t.hasNode(e.w)) {\n return slack(g, e);\n }\n });\n}\n\nfunction shiftRanks(t, g, delta) {\n _.forEach(t.nodes(), function(v) {\n g.node(v).rank += delta;\n });\n}\n","/*! *****************************************************************************\nCopyright (C) Microsoft. All rights reserved.\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\nthis file except in compliance with the License. You may obtain a copy of the\nLicense at http://www.apache.org/licenses/LICENSE-2.0\n\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\nMERCHANTABLITY OR NON-INFRINGEMENT.\n\nSee the Apache Version 2.0 License for specific language governing permissions\nand limitations under the License.\n***************************************************************************** */\nvar Reflect;\n(function (Reflect) {\n // Metadata Proposal\n // https://rbuckton.github.io/reflect-metadata/\n (function (factory) {\n var root = typeof global === \"object\" ? global :\n typeof self === \"object\" ? self :\n typeof this === \"object\" ? this :\n Function(\"return this;\")();\n var exporter = makeExporter(Reflect);\n if (typeof root.Reflect === \"undefined\") {\n root.Reflect = Reflect;\n }\n else {\n exporter = makeExporter(root.Reflect, exporter);\n }\n factory(exporter);\n function makeExporter(target, previous) {\n return function (key, value) {\n if (typeof target[key] !== \"function\") {\n Object.defineProperty(target, key, { configurable: true, writable: true, value: value });\n }\n if (previous)\n previous(key, value);\n };\n }\n })(function (exporter) {\n var hasOwn = Object.prototype.hasOwnProperty;\n // feature test for Symbol support\n var supportsSymbol = typeof Symbol === \"function\";\n var toPrimitiveSymbol = supportsSymbol && typeof Symbol.toPrimitive !== \"undefined\" ? Symbol.toPrimitive : \"@@toPrimitive\";\n var iteratorSymbol = supportsSymbol && typeof Symbol.iterator !== \"undefined\" ? Symbol.iterator : \"@@iterator\";\n var supportsCreate = typeof Object.create === \"function\"; // feature test for Object.create support\n var supportsProto = { __proto__: [] } instanceof Array; // feature test for __proto__ support\n var downLevel = !supportsCreate && !supportsProto;\n var HashMap = {\n // create an object in dictionary mode (a.k.a. \"slow\" mode in v8)\n create: supportsCreate\n ? function () { return MakeDictionary(Object.create(null)); }\n : supportsProto\n ? function () { return MakeDictionary({ __proto__: null }); }\n : function () { return MakeDictionary({}); },\n has: downLevel\n ? function (map, key) { return hasOwn.call(map, key); }\n : function (map, key) { return key in map; },\n get: downLevel\n ? function (map, key) { return hasOwn.call(map, key) ? map[key] : undefined; }\n : function (map, key) { return map[key]; },\n };\n // Load global or shim versions of Map, Set, and WeakMap\n var functionPrototype = Object.getPrototypeOf(Function);\n var usePolyfill = typeof process === \"object\" && process.env && process.env[\"REFLECT_METADATA_USE_MAP_POLYFILL\"] === \"true\";\n var _Map = !usePolyfill && typeof Map === \"function\" && typeof Map.prototype.entries === \"function\" ? Map : CreateMapPolyfill();\n var _Set = !usePolyfill && typeof Set === \"function\" && typeof Set.prototype.entries === \"function\" ? Set : CreateSetPolyfill();\n var _WeakMap = !usePolyfill && typeof WeakMap === \"function\" ? WeakMap : CreateWeakMapPolyfill();\n // [[Metadata]] internal slot\n // https://rbuckton.github.io/reflect-metadata/#ordinary-object-internal-methods-and-internal-slots\n var Metadata = new _WeakMap();\n /**\n * Applies a set of decorators to a property of a target object.\n * @param decorators An array of decorators.\n * @param target The target object.\n * @param propertyKey (Optional) The property key to decorate.\n * @param attributes (Optional) The property descriptor for the target key.\n * @remarks Decorators are applied in reverse order.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * Example = Reflect.decorate(decoratorsArray, Example);\n *\n * // property (on constructor)\n * Reflect.decorate(decoratorsArray, Example, \"staticProperty\");\n *\n * // property (on prototype)\n * Reflect.decorate(decoratorsArray, Example.prototype, \"property\");\n *\n * // method (on constructor)\n * Object.defineProperty(Example, \"staticMethod\",\n * Reflect.decorate(decoratorsArray, Example, \"staticMethod\",\n * Object.getOwnPropertyDescriptor(Example, \"staticMethod\")));\n *\n * // method (on prototype)\n * Object.defineProperty(Example.prototype, \"method\",\n * Reflect.decorate(decoratorsArray, Example.prototype, \"method\",\n * Object.getOwnPropertyDescriptor(Example.prototype, \"method\")));\n *\n */\n function decorate(decorators, target, propertyKey, attributes) {\n if (!IsUndefined(propertyKey)) {\n if (!IsArray(decorators))\n throw new TypeError();\n if (!IsObject(target))\n throw new TypeError();\n if (!IsObject(attributes) && !IsUndefined(attributes) && !IsNull(attributes))\n throw new TypeError();\n if (IsNull(attributes))\n attributes = undefined;\n propertyKey = ToPropertyKey(propertyKey);\n return DecorateProperty(decorators, target, propertyKey, attributes);\n }\n else {\n if (!IsArray(decorators))\n throw new TypeError();\n if (!IsConstructor(target))\n throw new TypeError();\n return DecorateConstructor(decorators, target);\n }\n }\n exporter(\"decorate\", decorate);\n // 4.1.2 Reflect.metadata(metadataKey, metadataValue)\n // https://rbuckton.github.io/reflect-metadata/#reflect.metadata\n /**\n * A default metadata decorator factory that can be used on a class, class member, or parameter.\n * @param metadataKey The key for the metadata entry.\n * @param metadataValue The value for the metadata entry.\n * @returns A decorator function.\n * @remarks\n * If `metadataKey` is already defined for the target and target key, the\n * metadataValue for that key will be overwritten.\n * @example\n *\n * // constructor\n * @Reflect.metadata(key, value)\n * class Example {\n * }\n *\n * // property (on constructor, TypeScript only)\n * class Example {\n * @Reflect.metadata(key, value)\n * static staticProperty;\n * }\n *\n * // property (on prototype, TypeScript only)\n * class Example {\n * @Reflect.metadata(key, value)\n * property;\n * }\n *\n * // method (on constructor)\n * class Example {\n * @Reflect.metadata(key, value)\n * static staticMethod() { }\n * }\n *\n * // method (on prototype)\n * class Example {\n * @Reflect.metadata(key, value)\n * method() { }\n * }\n *\n */\n function metadata(metadataKey, metadataValue) {\n function decorator(target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey) && !IsPropertyKey(propertyKey))\n throw new TypeError();\n OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey);\n }\n return decorator;\n }\n exporter(\"metadata\", metadata);\n /**\n * Define a unique metadata entry on the target.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param metadataValue A value that contains attached metadata.\n * @param target The target object on which to define metadata.\n * @param propertyKey (Optional) The property key for the target.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * Reflect.defineMetadata(\"custom:annotation\", options, Example);\n *\n * // property (on constructor)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example, \"staticProperty\");\n *\n * // property (on prototype)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example.prototype, \"property\");\n *\n * // method (on constructor)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example, \"staticMethod\");\n *\n * // method (on prototype)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example.prototype, \"method\");\n *\n * // decorator factory as metadata-producing annotation.\n * function MyAnnotation(options): Decorator {\n * return (target, key?) => Reflect.defineMetadata(\"custom:annotation\", options, target, key);\n * }\n *\n */\n function defineMetadata(metadataKey, metadataValue, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey);\n }\n exporter(\"defineMetadata\", defineMetadata);\n /**\n * Gets a value indicating whether the target object or its prototype chain has the provided metadata key defined.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns `true` if the metadata key was defined on the target object or its prototype chain; otherwise, `false`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.hasMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function hasMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryHasMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"hasMetadata\", hasMetadata);\n /**\n * Gets a value indicating whether the target object has the provided metadata key defined.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns `true` if the metadata key was defined on the target object; otherwise, `false`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function hasOwnMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryHasOwnMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"hasOwnMetadata\", hasOwnMetadata);\n /**\n * Gets the metadata value for the provided metadata key on the target object or its prototype chain.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns The metadata value for the metadata key if found; otherwise, `undefined`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.getMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function getMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryGetMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"getMetadata\", getMetadata);\n /**\n * Gets the metadata value for the provided metadata key on the target object.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns The metadata value for the metadata key if found; otherwise, `undefined`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function getOwnMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryGetOwnMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"getOwnMetadata\", getOwnMetadata);\n /**\n * Gets the metadata keys defined on the target object or its prototype chain.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns An array of unique metadata keys.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getMetadataKeys(Example);\n *\n * // property (on constructor)\n * result = Reflect.getMetadataKeys(Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getMetadataKeys(Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getMetadataKeys(Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getMetadataKeys(Example.prototype, \"method\");\n *\n */\n function getMetadataKeys(target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryMetadataKeys(target, propertyKey);\n }\n exporter(\"getMetadataKeys\", getMetadataKeys);\n /**\n * Gets the unique metadata keys defined on the target object.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns An array of unique metadata keys.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getOwnMetadataKeys(Example);\n *\n * // property (on constructor)\n * result = Reflect.getOwnMetadataKeys(Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getOwnMetadataKeys(Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getOwnMetadataKeys(Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getOwnMetadataKeys(Example.prototype, \"method\");\n *\n */\n function getOwnMetadataKeys(target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryOwnMetadataKeys(target, propertyKey);\n }\n exporter(\"getOwnMetadataKeys\", getOwnMetadataKeys);\n /**\n * Deletes the metadata entry from the target object with the provided key.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns `true` if the metadata entry was found and deleted; otherwise, false.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function deleteMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n var metadataMap = GetOrCreateMetadataMap(target, propertyKey, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return false;\n if (!metadataMap.delete(metadataKey))\n return false;\n if (metadataMap.size > 0)\n return true;\n var targetMetadata = Metadata.get(target);\n targetMetadata.delete(propertyKey);\n if (targetMetadata.size > 0)\n return true;\n Metadata.delete(target);\n return true;\n }\n exporter(\"deleteMetadata\", deleteMetadata);\n function DecorateConstructor(decorators, target) {\n for (var i = decorators.length - 1; i >= 0; --i) {\n var decorator = decorators[i];\n var decorated = decorator(target);\n if (!IsUndefined(decorated) && !IsNull(decorated)) {\n if (!IsConstructor(decorated))\n throw new TypeError();\n target = decorated;\n }\n }\n return target;\n }\n function DecorateProperty(decorators, target, propertyKey, descriptor) {\n for (var i = decorators.length - 1; i >= 0; --i) {\n var decorator = decorators[i];\n var decorated = decorator(target, propertyKey, descriptor);\n if (!IsUndefined(decorated) && !IsNull(decorated)) {\n if (!IsObject(decorated))\n throw new TypeError();\n descriptor = decorated;\n }\n }\n return descriptor;\n }\n function GetOrCreateMetadataMap(O, P, Create) {\n var targetMetadata = Metadata.get(O);\n if (IsUndefined(targetMetadata)) {\n if (!Create)\n return undefined;\n targetMetadata = new _Map();\n Metadata.set(O, targetMetadata);\n }\n var metadataMap = targetMetadata.get(P);\n if (IsUndefined(metadataMap)) {\n if (!Create)\n return undefined;\n metadataMap = new _Map();\n targetMetadata.set(P, metadataMap);\n }\n return metadataMap;\n }\n // 3.1.1.1 OrdinaryHasMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinaryhasmetadata\n function OrdinaryHasMetadata(MetadataKey, O, P) {\n var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P);\n if (hasOwn)\n return true;\n var parent = OrdinaryGetPrototypeOf(O);\n if (!IsNull(parent))\n return OrdinaryHasMetadata(MetadataKey, parent, P);\n return false;\n }\n // 3.1.2.1 OrdinaryHasOwnMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinaryhasownmetadata\n function OrdinaryHasOwnMetadata(MetadataKey, O, P) {\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return false;\n return ToBoolean(metadataMap.has(MetadataKey));\n }\n // 3.1.3.1 OrdinaryGetMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarygetmetadata\n function OrdinaryGetMetadata(MetadataKey, O, P) {\n var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P);\n if (hasOwn)\n return OrdinaryGetOwnMetadata(MetadataKey, O, P);\n var parent = OrdinaryGetPrototypeOf(O);\n if (!IsNull(parent))\n return OrdinaryGetMetadata(MetadataKey, parent, P);\n return undefined;\n }\n // 3.1.4.1 OrdinaryGetOwnMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarygetownmetadata\n function OrdinaryGetOwnMetadata(MetadataKey, O, P) {\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return undefined;\n return metadataMap.get(MetadataKey);\n }\n // 3.1.5.1 OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarydefineownmetadata\n function OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P) {\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ true);\n metadataMap.set(MetadataKey, MetadataValue);\n }\n // 3.1.6.1 OrdinaryMetadataKeys(O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarymetadatakeys\n function OrdinaryMetadataKeys(O, P) {\n var ownKeys = OrdinaryOwnMetadataKeys(O, P);\n var parent = OrdinaryGetPrototypeOf(O);\n if (parent === null)\n return ownKeys;\n var parentKeys = OrdinaryMetadataKeys(parent, P);\n if (parentKeys.length <= 0)\n return ownKeys;\n if (ownKeys.length <= 0)\n return parentKeys;\n var set = new _Set();\n var keys = [];\n for (var _i = 0, ownKeys_1 = ownKeys; _i < ownKeys_1.length; _i++) {\n var key = ownKeys_1[_i];\n var hasKey = set.has(key);\n if (!hasKey) {\n set.add(key);\n keys.push(key);\n }\n }\n for (var _a = 0, parentKeys_1 = parentKeys; _a < parentKeys_1.length; _a++) {\n var key = parentKeys_1[_a];\n var hasKey = set.has(key);\n if (!hasKey) {\n set.add(key);\n keys.push(key);\n }\n }\n return keys;\n }\n // 3.1.7.1 OrdinaryOwnMetadataKeys(O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinaryownmetadatakeys\n function OrdinaryOwnMetadataKeys(O, P) {\n var keys = [];\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return keys;\n var keysObj = metadataMap.keys();\n var iterator = GetIterator(keysObj);\n var k = 0;\n while (true) {\n var next = IteratorStep(iterator);\n if (!next) {\n keys.length = k;\n return keys;\n }\n var nextValue = IteratorValue(next);\n try {\n keys[k] = nextValue;\n }\n catch (e) {\n try {\n IteratorClose(iterator);\n }\n finally {\n throw e;\n }\n }\n k++;\n }\n }\n // 6 ECMAScript Data Typ0es and Values\n // https://tc39.github.io/ecma262/#sec-ecmascript-data-types-and-values\n function Type(x) {\n if (x === null)\n return 1 /* Null */;\n switch (typeof x) {\n case \"undefined\": return 0 /* Undefined */;\n case \"boolean\": return 2 /* Boolean */;\n case \"string\": return 3 /* String */;\n case \"symbol\": return 4 /* Symbol */;\n case \"number\": return 5 /* Number */;\n case \"object\": return x === null ? 1 /* Null */ : 6 /* Object */;\n default: return 6 /* Object */;\n }\n }\n // 6.1.1 The Undefined Type\n // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-undefined-type\n function IsUndefined(x) {\n return x === undefined;\n }\n // 6.1.2 The Null Type\n // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-null-type\n function IsNull(x) {\n return x === null;\n }\n // 6.1.5 The Symbol Type\n // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-symbol-type\n function IsSymbol(x) {\n return typeof x === \"symbol\";\n }\n // 6.1.7 The Object Type\n // https://tc39.github.io/ecma262/#sec-object-type\n function IsObject(x) {\n return typeof x === \"object\" ? x !== null : typeof x === \"function\";\n }\n // 7.1 Type Conversion\n // https://tc39.github.io/ecma262/#sec-type-conversion\n // 7.1.1 ToPrimitive(input [, PreferredType])\n // https://tc39.github.io/ecma262/#sec-toprimitive\n function ToPrimitive(input, PreferredType) {\n switch (Type(input)) {\n case 0 /* Undefined */: return input;\n case 1 /* Null */: return input;\n case 2 /* Boolean */: return input;\n case 3 /* String */: return input;\n case 4 /* Symbol */: return input;\n case 5 /* Number */: return input;\n }\n var hint = PreferredType === 3 /* String */ ? \"string\" : PreferredType === 5 /* Number */ ? \"number\" : \"default\";\n var exoticToPrim = GetMethod(input, toPrimitiveSymbol);\n if (exoticToPrim !== undefined) {\n var result = exoticToPrim.call(input, hint);\n if (IsObject(result))\n throw new TypeError();\n return result;\n }\n return OrdinaryToPrimitive(input, hint === \"default\" ? \"number\" : hint);\n }\n // 7.1.1.1 OrdinaryToPrimitive(O, hint)\n // https://tc39.github.io/ecma262/#sec-ordinarytoprimitive\n function OrdinaryToPrimitive(O, hint) {\n if (hint === \"string\") {\n var toString_1 = O.toString;\n if (IsCallable(toString_1)) {\n var result = toString_1.call(O);\n if (!IsObject(result))\n return result;\n }\n var valueOf = O.valueOf;\n if (IsCallable(valueOf)) {\n var result = valueOf.call(O);\n if (!IsObject(result))\n return result;\n }\n }\n else {\n var valueOf = O.valueOf;\n if (IsCallable(valueOf)) {\n var result = valueOf.call(O);\n if (!IsObject(result))\n return result;\n }\n var toString_2 = O.toString;\n if (IsCallable(toString_2)) {\n var result = toString_2.call(O);\n if (!IsObject(result))\n return result;\n }\n }\n throw new TypeError();\n }\n // 7.1.2 ToBoolean(argument)\n // https://tc39.github.io/ecma262/2016/#sec-toboolean\n function ToBoolean(argument) {\n return !!argument;\n }\n // 7.1.12 ToString(argument)\n // https://tc39.github.io/ecma262/#sec-tostring\n function ToString(argument) {\n return \"\" + argument;\n }\n // 7.1.14 ToPropertyKey(argument)\n // https://tc39.github.io/ecma262/#sec-topropertykey\n function ToPropertyKey(argument) {\n var key = ToPrimitive(argument, 3 /* String */);\n if (IsSymbol(key))\n return key;\n return ToString(key);\n }\n // 7.2 Testing and Comparison Operations\n // https://tc39.github.io/ecma262/#sec-testing-and-comparison-operations\n // 7.2.2 IsArray(argument)\n // https://tc39.github.io/ecma262/#sec-isarray\n function IsArray(argument) {\n return Array.isArray\n ? Array.isArray(argument)\n : argument instanceof Object\n ? argument instanceof Array\n : Object.prototype.toString.call(argument) === \"[object Array]\";\n }\n // 7.2.3 IsCallable(argument)\n // https://tc39.github.io/ecma262/#sec-iscallable\n function IsCallable(argument) {\n // NOTE: This is an approximation as we cannot check for [[Call]] internal method.\n return typeof argument === \"function\";\n }\n // 7.2.4 IsConstructor(argument)\n // https://tc39.github.io/ecma262/#sec-isconstructor\n function IsConstructor(argument) {\n // NOTE: This is an approximation as we cannot check for [[Construct]] internal method.\n return typeof argument === \"function\";\n }\n // 7.2.7 IsPropertyKey(argument)\n // https://tc39.github.io/ecma262/#sec-ispropertykey\n function IsPropertyKey(argument) {\n switch (Type(argument)) {\n case 3 /* String */: return true;\n case 4 /* Symbol */: return true;\n default: return false;\n }\n }\n // 7.3 Operations on Objects\n // https://tc39.github.io/ecma262/#sec-operations-on-objects\n // 7.3.9 GetMethod(V, P)\n // https://tc39.github.io/ecma262/#sec-getmethod\n function GetMethod(V, P) {\n var func = V[P];\n if (func === undefined || func === null)\n return undefined;\n if (!IsCallable(func))\n throw new TypeError();\n return func;\n }\n // 7.4 Operations on Iterator Objects\n // https://tc39.github.io/ecma262/#sec-operations-on-iterator-objects\n function GetIterator(obj) {\n var method = GetMethod(obj, iteratorSymbol);\n if (!IsCallable(method))\n throw new TypeError(); // from Call\n var iterator = method.call(obj);\n if (!IsObject(iterator))\n throw new TypeError();\n return iterator;\n }\n // 7.4.4 IteratorValue(iterResult)\n // https://tc39.github.io/ecma262/2016/#sec-iteratorvalue\n function IteratorValue(iterResult) {\n return iterResult.value;\n }\n // 7.4.5 IteratorStep(iterator)\n // https://tc39.github.io/ecma262/#sec-iteratorstep\n function IteratorStep(iterator) {\n var result = iterator.next();\n return result.done ? false : result;\n }\n // 7.4.6 IteratorClose(iterator, completion)\n // https://tc39.github.io/ecma262/#sec-iteratorclose\n function IteratorClose(iterator) {\n var f = iterator[\"return\"];\n if (f)\n f.call(iterator);\n }\n // 9.1 Ordinary Object Internal Methods and Internal Slots\n // https://tc39.github.io/ecma262/#sec-ordinary-object-internal-methods-and-internal-slots\n // 9.1.1.1 OrdinaryGetPrototypeOf(O)\n // https://tc39.github.io/ecma262/#sec-ordinarygetprototypeof\n function OrdinaryGetPrototypeOf(O) {\n var proto = Object.getPrototypeOf(O);\n if (typeof O !== \"function\" || O === functionPrototype)\n return proto;\n // TypeScript doesn't set __proto__ in ES5, as it's non-standard.\n // Try to determine the superclass constructor. Compatible implementations\n // must either set __proto__ on a subclass constructor to the superclass constructor,\n // or ensure each class has a valid `constructor` property on its prototype that\n // points back to the constructor.\n // If this is not the same as Function.[[Prototype]], then this is definately inherited.\n // This is the case when in ES6 or when using __proto__ in a compatible browser.\n if (proto !== functionPrototype)\n return proto;\n // If the super prototype is Object.prototype, null, or undefined, then we cannot determine the heritage.\n var prototype = O.prototype;\n var prototypeProto = prototype && Object.getPrototypeOf(prototype);\n if (prototypeProto == null || prototypeProto === Object.prototype)\n return proto;\n // If the constructor was not a function, then we cannot determine the heritage.\n var constructor = prototypeProto.constructor;\n if (typeof constructor !== \"function\")\n return proto;\n // If we have some kind of self-reference, then we cannot determine the heritage.\n if (constructor === O)\n return proto;\n // we have a pretty good guess at the heritage.\n return constructor;\n }\n // naive Map shim\n function CreateMapPolyfill() {\n var cacheSentinel = {};\n var arraySentinel = [];\n var MapIterator = /** @class */ (function () {\n function MapIterator(keys, values, selector) {\n this._index = 0;\n this._keys = keys;\n this._values = values;\n this._selector = selector;\n }\n MapIterator.prototype[\"@@iterator\"] = function () { return this; };\n MapIterator.prototype[iteratorSymbol] = function () { return this; };\n MapIterator.prototype.next = function () {\n var index = this._index;\n if (index >= 0 && index < this._keys.length) {\n var result = this._selector(this._keys[index], this._values[index]);\n if (index + 1 >= this._keys.length) {\n this._index = -1;\n this._keys = arraySentinel;\n this._values = arraySentinel;\n }\n else {\n this._index++;\n }\n return { value: result, done: false };\n }\n return { value: undefined, done: true };\n };\n MapIterator.prototype.throw = function (error) {\n if (this._index >= 0) {\n this._index = -1;\n this._keys = arraySentinel;\n this._values = arraySentinel;\n }\n throw error;\n };\n MapIterator.prototype.return = function (value) {\n if (this._index >= 0) {\n this._index = -1;\n this._keys = arraySentinel;\n this._values = arraySentinel;\n }\n return { value: value, done: true };\n };\n return MapIterator;\n }());\n return /** @class */ (function () {\n function Map() {\n this._keys = [];\n this._values = [];\n this._cacheKey = cacheSentinel;\n this._cacheIndex = -2;\n }\n Object.defineProperty(Map.prototype, \"size\", {\n get: function () { return this._keys.length; },\n enumerable: true,\n configurable: true\n });\n Map.prototype.has = function (key) { return this._find(key, /*insert*/ false) >= 0; };\n Map.prototype.get = function (key) {\n var index = this._find(key, /*insert*/ false);\n return index >= 0 ? this._values[index] : undefined;\n };\n Map.prototype.set = function (key, value) {\n var index = this._find(key, /*insert*/ true);\n this._values[index] = value;\n return this;\n };\n Map.prototype.delete = function (key) {\n var index = this._find(key, /*insert*/ false);\n if (index >= 0) {\n var size = this._keys.length;\n for (var i = index + 1; i < size; i++) {\n this._keys[i - 1] = this._keys[i];\n this._values[i - 1] = this._values[i];\n }\n this._keys.length--;\n this._values.length--;\n if (key === this._cacheKey) {\n this._cacheKey = cacheSentinel;\n this._cacheIndex = -2;\n }\n return true;\n }\n return false;\n };\n Map.prototype.clear = function () {\n this._keys.length = 0;\n this._values.length = 0;\n this._cacheKey = cacheSentinel;\n this._cacheIndex = -2;\n };\n Map.prototype.keys = function () { return new MapIterator(this._keys, this._values, getKey); };\n Map.prototype.values = function () { return new MapIterator(this._keys, this._values, getValue); };\n Map.prototype.entries = function () { return new MapIterator(this._keys, this._values, getEntry); };\n Map.prototype[\"@@iterator\"] = function () { return this.entries(); };\n Map.prototype[iteratorSymbol] = function () { return this.entries(); };\n Map.prototype._find = function (key, insert) {\n if (this._cacheKey !== key) {\n this._cacheIndex = this._keys.indexOf(this._cacheKey = key);\n }\n if (this._cacheIndex < 0 && insert) {\n this._cacheIndex = this._keys.length;\n this._keys.push(key);\n this._values.push(undefined);\n }\n return this._cacheIndex;\n };\n return Map;\n }());\n function getKey(key, _) {\n return key;\n }\n function getValue(_, value) {\n return value;\n }\n function getEntry(key, value) {\n return [key, value];\n }\n }\n // naive Set shim\n function CreateSetPolyfill() {\n return /** @class */ (function () {\n function Set() {\n this._map = new _Map();\n }\n Object.defineProperty(Set.prototype, \"size\", {\n get: function () { return this._map.size; },\n enumerable: true,\n configurable: true\n });\n Set.prototype.has = function (value) { return this._map.has(value); };\n Set.prototype.add = function (value) { return this._map.set(value, value), this; };\n Set.prototype.delete = function (value) { return this._map.delete(value); };\n Set.prototype.clear = function () { this._map.clear(); };\n Set.prototype.keys = function () { return this._map.keys(); };\n Set.prototype.values = function () { return this._map.values(); };\n Set.prototype.entries = function () { return this._map.entries(); };\n Set.prototype[\"@@iterator\"] = function () { return this.keys(); };\n Set.prototype[iteratorSymbol] = function () { return this.keys(); };\n return Set;\n }());\n }\n // naive WeakMap shim\n function CreateWeakMapPolyfill() {\n var UUID_SIZE = 16;\n var keys = HashMap.create();\n var rootKey = CreateUniqueKey();\n return /** @class */ (function () {\n function WeakMap() {\n this._key = CreateUniqueKey();\n }\n WeakMap.prototype.has = function (target) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ false);\n return table !== undefined ? HashMap.has(table, this._key) : false;\n };\n WeakMap.prototype.get = function (target) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ false);\n return table !== undefined ? HashMap.get(table, this._key) : undefined;\n };\n WeakMap.prototype.set = function (target, value) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ true);\n table[this._key] = value;\n return this;\n };\n WeakMap.prototype.delete = function (target) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ false);\n return table !== undefined ? delete table[this._key] : false;\n };\n WeakMap.prototype.clear = function () {\n // NOTE: not a real clear, just makes the previous data unreachable\n this._key = CreateUniqueKey();\n };\n return WeakMap;\n }());\n function CreateUniqueKey() {\n var key;\n do\n key = \"@@WeakMap@@\" + CreateUUID();\n while (HashMap.has(keys, key));\n keys[key] = true;\n return key;\n }\n function GetOrCreateWeakMapTable(target, create) {\n if (!hasOwn.call(target, rootKey)) {\n if (!create)\n return undefined;\n Object.defineProperty(target, rootKey, { value: HashMap.create() });\n }\n return target[rootKey];\n }\n function FillRandomBytes(buffer, size) {\n for (var i = 0; i < size; ++i)\n buffer[i] = Math.random() * 0xff | 0;\n return buffer;\n }\n function GenRandomBytes(size) {\n if (typeof Uint8Array === \"function\") {\n if (typeof crypto !== \"undefined\")\n return crypto.getRandomValues(new Uint8Array(size));\n if (typeof msCrypto !== \"undefined\")\n return msCrypto.getRandomValues(new Uint8Array(size));\n return FillRandomBytes(new Uint8Array(size), size);\n }\n return FillRandomBytes(new Array(size), size);\n }\n function CreateUUID() {\n var data = GenRandomBytes(UUID_SIZE);\n // mark as random - RFC 4122 § 4.4\n data[6] = data[6] & 0x4f | 0x40;\n data[8] = data[8] & 0xbf | 0x80;\n var result = \"\";\n for (var offset = 0; offset < UUID_SIZE; ++offset) {\n var byte = data[offset];\n if (offset === 4 || offset === 6 || offset === 8)\n result += \"-\";\n if (byte < 16)\n result += \"0\";\n result += byte.toString(16).toLowerCase();\n }\n return result;\n }\n }\n // uses a heuristic used by v8 and chakra to force an object into dictionary mode.\n function MakeDictionary(obj) {\n obj.__ = undefined;\n delete obj.__;\n return obj;\n }\n });\n})(Reflect || (Reflect = {}));\n","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\n\nmodule.exports = _unsupportedIterableToArray;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}\n\nmodule.exports = _arrayLikeToArray;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MetadataReader = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar MetadataReader = (function () {\n function MetadataReader() {\n }\n MetadataReader.prototype.getConstructorMetadata = function (constructorFunc) {\n var compilerGeneratedMetadata = Reflect.getMetadata(METADATA_KEY.PARAM_TYPES, constructorFunc);\n var userGeneratedMetadata = Reflect.getMetadata(METADATA_KEY.TAGGED, constructorFunc);\n return {\n compilerGeneratedMetadata: compilerGeneratedMetadata,\n userGeneratedMetadata: userGeneratedMetadata || {}\n };\n };\n MetadataReader.prototype.getPropertiesMetadata = function (constructorFunc) {\n var userGeneratedMetadata = Reflect.getMetadata(METADATA_KEY.TAGGED_PROP, constructorFunc) || [];\n return userGeneratedMetadata;\n };\n return MetadataReader;\n}());\nexports.MetadataReader = MetadataReader;\n//# sourceMappingURL=metadata_reader.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isStackOverflowExeption = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nfunction isStackOverflowExeption(error) {\n return (error instanceof RangeError ||\n error.message === ERROR_MSGS.STACK_OVERFLOW);\n}\nexports.isStackOverflowExeption = isStackOverflowExeption;\n//# sourceMappingURL=exceptions.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.inject = exports.LazyServiceIdentifer = void 0;\nvar error_msgs_1 = require(\"../constants/error_msgs\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nvar LazyServiceIdentifer = (function () {\n function LazyServiceIdentifer(cb) {\n this._cb = cb;\n }\n LazyServiceIdentifer.prototype.unwrap = function () {\n return this._cb();\n };\n return LazyServiceIdentifer;\n}());\nexports.LazyServiceIdentifer = LazyServiceIdentifer;\nfunction inject(serviceIdentifier) {\n return function (target, targetKey, index) {\n if (serviceIdentifier === undefined) {\n throw new Error(error_msgs_1.UNDEFINED_INJECT_ANNOTATION(target.name));\n }\n var metadata = new metadata_1.Metadata(METADATA_KEY.INJECT_TAG, serviceIdentifier);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.inject = inject;\n//# sourceMappingURL=inject.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Target = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar id_1 = require(\"../utils/id\");\nvar metadata_1 = require(\"./metadata\");\nvar queryable_string_1 = require(\"./queryable_string\");\nvar Target = (function () {\n function Target(type, name, serviceIdentifier, namedOrTagged) {\n this.id = id_1.id();\n this.type = type;\n this.serviceIdentifier = serviceIdentifier;\n this.name = new queryable_string_1.QueryableString(name || \"\");\n this.metadata = new Array();\n var metadataItem = null;\n if (typeof namedOrTagged === \"string\") {\n metadataItem = new metadata_1.Metadata(METADATA_KEY.NAMED_TAG, namedOrTagged);\n }\n else if (namedOrTagged instanceof metadata_1.Metadata) {\n metadataItem = namedOrTagged;\n }\n if (metadataItem !== null) {\n this.metadata.push(metadataItem);\n }\n }\n Target.prototype.hasTag = function (key) {\n for (var _i = 0, _a = this.metadata; _i < _a.length; _i++) {\n var m = _a[_i];\n if (m.key === key) {\n return true;\n }\n }\n return false;\n };\n Target.prototype.isArray = function () {\n return this.hasTag(METADATA_KEY.MULTI_INJECT_TAG);\n };\n Target.prototype.matchesArray = function (name) {\n return this.matchesTag(METADATA_KEY.MULTI_INJECT_TAG)(name);\n };\n Target.prototype.isNamed = function () {\n return this.hasTag(METADATA_KEY.NAMED_TAG);\n };\n Target.prototype.isTagged = function () {\n return this.metadata.some(function (metadata) { return METADATA_KEY.NON_CUSTOM_TAG_KEYS.every(function (key) { return metadata.key !== key; }); });\n };\n Target.prototype.isOptional = function () {\n return this.matchesTag(METADATA_KEY.OPTIONAL_TAG)(true);\n };\n Target.prototype.getNamedTag = function () {\n if (this.isNamed()) {\n return this.metadata.filter(function (m) { return m.key === METADATA_KEY.NAMED_TAG; })[0];\n }\n return null;\n };\n Target.prototype.getCustomTags = function () {\n if (this.isTagged()) {\n return this.metadata.filter(function (metadata) { return METADATA_KEY.NON_CUSTOM_TAG_KEYS.every(function (key) { return metadata.key !== key; }); });\n }\n else {\n return null;\n }\n };\n Target.prototype.matchesNamedTag = function (name) {\n return this.matchesTag(METADATA_KEY.NAMED_TAG)(name);\n };\n Target.prototype.matchesTag = function (key) {\n var _this = this;\n return function (value) {\n for (var _i = 0, _a = _this.metadata; _i < _a.length; _i++) {\n var m = _a[_i];\n if (m.key === key && m.value === value) {\n return true;\n }\n }\n return false;\n };\n };\n return Target;\n}());\nexports.Target = Target;\n//# sourceMappingURL=target.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingWhenOnSyntax = void 0;\nvar binding_on_syntax_1 = require(\"./binding_on_syntax\");\nvar binding_when_syntax_1 = require(\"./binding_when_syntax\");\nvar BindingWhenOnSyntax = (function () {\n function BindingWhenOnSyntax(binding) {\n this._binding = binding;\n this._bindingWhenSyntax = new binding_when_syntax_1.BindingWhenSyntax(this._binding);\n this._bindingOnSyntax = new binding_on_syntax_1.BindingOnSyntax(this._binding);\n }\n BindingWhenOnSyntax.prototype.when = function (constraint) {\n return this._bindingWhenSyntax.when(constraint);\n };\n BindingWhenOnSyntax.prototype.whenTargetNamed = function (name) {\n return this._bindingWhenSyntax.whenTargetNamed(name);\n };\n BindingWhenOnSyntax.prototype.whenTargetIsDefault = function () {\n return this._bindingWhenSyntax.whenTargetIsDefault();\n };\n BindingWhenOnSyntax.prototype.whenTargetTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenTargetTagged(tag, value);\n };\n BindingWhenOnSyntax.prototype.whenInjectedInto = function (parent) {\n return this._bindingWhenSyntax.whenInjectedInto(parent);\n };\n BindingWhenOnSyntax.prototype.whenParentNamed = function (name) {\n return this._bindingWhenSyntax.whenParentNamed(name);\n };\n BindingWhenOnSyntax.prototype.whenParentTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenParentTagged(tag, value);\n };\n BindingWhenOnSyntax.prototype.whenAnyAncestorIs = function (ancestor) {\n return this._bindingWhenSyntax.whenAnyAncestorIs(ancestor);\n };\n BindingWhenOnSyntax.prototype.whenNoAncestorIs = function (ancestor) {\n return this._bindingWhenSyntax.whenNoAncestorIs(ancestor);\n };\n BindingWhenOnSyntax.prototype.whenAnyAncestorNamed = function (name) {\n return this._bindingWhenSyntax.whenAnyAncestorNamed(name);\n };\n BindingWhenOnSyntax.prototype.whenAnyAncestorTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenAnyAncestorTagged(tag, value);\n };\n BindingWhenOnSyntax.prototype.whenNoAncestorNamed = function (name) {\n return this._bindingWhenSyntax.whenNoAncestorNamed(name);\n };\n BindingWhenOnSyntax.prototype.whenNoAncestorTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenNoAncestorTagged(tag, value);\n };\n BindingWhenOnSyntax.prototype.whenAnyAncestorMatches = function (constraint) {\n return this._bindingWhenSyntax.whenAnyAncestorMatches(constraint);\n };\n BindingWhenOnSyntax.prototype.whenNoAncestorMatches = function (constraint) {\n return this._bindingWhenSyntax.whenNoAncestorMatches(constraint);\n };\n BindingWhenOnSyntax.prototype.onActivation = function (handler) {\n return this._bindingOnSyntax.onActivation(handler);\n };\n return BindingWhenOnSyntax;\n}());\nexports.BindingWhenOnSyntax = BindingWhenOnSyntax;\n//# sourceMappingURL=binding_when_on_syntax.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.typeConstraint = exports.namedConstraint = exports.taggedConstraint = exports.traverseAncerstors = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar traverseAncerstors = function (request, constraint) {\n var parent = request.parentRequest;\n if (parent !== null) {\n return constraint(parent) ? true : traverseAncerstors(parent, constraint);\n }\n else {\n return false;\n }\n};\nexports.traverseAncerstors = traverseAncerstors;\nvar taggedConstraint = function (key) { return function (value) {\n var constraint = function (request) {\n return request !== null && request.target !== null && request.target.matchesTag(key)(value);\n };\n constraint.metaData = new metadata_1.Metadata(key, value);\n return constraint;\n}; };\nexports.taggedConstraint = taggedConstraint;\nvar namedConstraint = taggedConstraint(METADATA_KEY.NAMED_TAG);\nexports.namedConstraint = namedConstraint;\nvar typeConstraint = function (type) { return function (request) {\n var binding = null;\n if (request !== null) {\n binding = request.bindings[0];\n if (typeof type === \"string\") {\n var serviceIdentifier = binding.serviceIdentifier;\n return serviceIdentifier === type;\n }\n else {\n var constructor = request.bindings[0].implementationType;\n return type === constructor;\n }\n }\n return false;\n}; };\nexports.typeConstraint = typeConstraint;\n//# sourceMappingURL=constraint_helpers.js.map","import { vec3 } from 'gl-matrix';\nimport { AABB } from '../shape/AABB';\n\n/**\n * generate AABB with positions\n * @param positions [x1,y1,z1, x2,y2,z2]\n */\nexport function generateAABBFromVertices(positions: number[]): AABB {\n const aabb = new AABB();\n const min = vec3.fromValues(positions[0], positions[1], positions[2]);\n const max = vec3.fromValues(positions[0], positions[1], positions[2]);\n\n for (let i = 3; i < positions.length; ) {\n const x = positions[i++];\n const y = positions[i++];\n const z = positions[i++];\n if (x < min[0]) {\n min[0] = x;\n }\n if (y < min[1]) {\n min[1] = y;\n }\n if (z < min[2]) {\n min[2] = z;\n }\n if (x > max[0]) {\n max[0] = x;\n }\n if (y > max[1]) {\n max[1] = y;\n }\n if (z > max[2]) {\n max[2] = z;\n }\n }\n\n aabb.setMinMax(min, max);\n return aabb;\n}\n","export const isSafari =\n typeof navigator !== 'undefined' &&\n /Version\\/[\\d\\.]+.*Safari/.test(navigator.userAgent);\n","import { IFramebuffer } from './IFramebuffer';\n\nexport enum PassType {\n Normal = 'normal',\n PostProcessing = 'post-processing',\n}\n\n/**\n * Pass 分两类:\n * 1. 渲染相关 eg. ClearPass、RenderPass、PickingPass、ShadowPass\n * 2. PostProcessing eg. CopyPass、BlurPass\n * 另外考虑到 Pass 之间严格的执行顺序,render 方法必须是异步的\n */\nexport interface IPass<InitializationOptions> {\n getName(): string;\n getType(): PassType;\n init(config?: Partial<InitializationOptions>): void;\n render(): void;\n}\n\n/**\n * PostProcessing,自动切换 renderTarget\n * 例如最后一个 PostProcessingPass 自动切换 renderTarget 为屏幕\n */\nexport interface IPostProcessingPass<InitializationOptions>\n extends IPass<InitializationOptions> {\n setRenderToScreen(renderToScreen: boolean): void;\n setName(name: string): void;\n isEnabled(): boolean;\n setEnabled(enabled: boolean): void;\n updateOptions(config: Partial<InitializationOptions>): void;\n}\n\nexport interface IPostProcessor {\n getReadFBO(): IFramebuffer;\n getWriteFBO(): IFramebuffer;\n resize(viewportWidth: number, viewportHeight: number): void;\n add<InitializationOptions>(\n pass: IPostProcessingPass<InitializationOptions>,\n config?: Partial<InitializationOptions>,\n ): void;\n render(): Promise<unknown>;\n getPostProcessingPassByName(\n name: string,\n ): IPostProcessingPass<unknown> | undefined;\n}\n\nexport interface IMultiPassRenderer {\n getPostProcessor(): IPostProcessor;\n resize(viewportWidth: number, viewportHeight: number): void;\n add<InitializationOptions>(\n pass: IPass<InitializationOptions>,\n config?: Partial<InitializationOptions>,\n ): void;\n render(): void;\n getRenderFlag(): boolean;\n setRenderFlag(enabled: boolean): void;\n destroy(): void;\n}\n","module.exports = 0.000001\n","module.exports = create\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\nfunction create() {\n var out = new Float32Array(2)\n out[0] = 0\n out[1] = 0\n return out\n}","module.exports = set\n\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\nfunction set(out, x, y) {\n out[0] = x\n out[1] = y\n return out\n}","module.exports = add\n\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction add(out, a, b) {\n out[0] = a[0] + b[0]\n out[1] = a[1] + b[1]\n return out\n}","module.exports = multiply\n\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction multiply(out, a, b) {\n out[0] = a[0] * b[0]\n out[1] = a[1] * b[1]\n return out\n}","module.exports = divide\n\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction divide(out, a, b) {\n out[0] = a[0] / b[0]\n out[1] = a[1] / b[1]\n return out\n}","module.exports = distance\n\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} distance between a and b\n */\nfunction distance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1]\n return Math.sqrt(x*x + y*y)\n}","module.exports = squaredDistance\n\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\nfunction squaredDistance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1]\n return x*x + y*y\n}","module.exports = length\n\n/**\n * Calculates the length of a vec2\n *\n * @param {vec2} a vector to calculate length of\n * @returns {Number} length of a\n */\nfunction length(a) {\n var x = a[0],\n y = a[1]\n return Math.sqrt(x*x + y*y)\n}","module.exports = squaredLength\n\n/**\n * Calculates the squared length of a vec2\n *\n * @param {vec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nfunction squaredLength(a) {\n var x = a[0],\n y = a[1]\n return x*x + y*y\n}","module.exports = normalize\n\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to normalize\n * @returns {vec2} out\n */\nfunction normalize(out, a) {\n var x = a[0],\n y = a[1]\n var len = x*x + y*y\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len)\n out[0] = a[0] * len\n out[1] = a[1] * len\n }\n return out\n}","module.exports = dot\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nfunction dot(a, b) {\n return a[0] * b[0] + a[1] * b[1]\n}","var frame = 0, // is an animation frame pending?\n timeout = 0, // is a timeout pending?\n interval = 0, // are any timers active?\n pokeDelay = 1000, // how frequently we check for clock skew\n taskHead,\n taskTail,\n clockLast = 0,\n clockNow = 0,\n clockSkew = 0,\n clock = typeof performance === \"object\" && performance.now ? performance : Date,\n setFrame = typeof window === \"object\" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { setTimeout(f, 17); };\n\nexport function now() {\n return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n}\n\nfunction clearNow() {\n clockNow = 0;\n}\n\nexport function Timer() {\n this._call =\n this._time =\n this._next = null;\n}\n\nTimer.prototype = timer.prototype = {\n constructor: Timer,\n restart: function(callback, delay, time) {\n if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n if (!this._next && taskTail !== this) {\n if (taskTail) taskTail._next = this;\n else taskHead = this;\n taskTail = this;\n }\n this._call = callback;\n this._time = time;\n sleep();\n },\n stop: function() {\n if (this._call) {\n this._call = null;\n this._time = Infinity;\n sleep();\n }\n }\n};\n\nexport function timer(callback, delay, time) {\n var t = new Timer;\n t.restart(callback, delay, time);\n return t;\n}\n\nexport function timerFlush() {\n now(); // Get the current time, if not already set.\n ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n var t = taskHead, e;\n while (t) {\n if ((e = clockNow - t._time) >= 0) t._call.call(null, e);\n t = t._next;\n }\n --frame;\n}\n\nfunction wake() {\n clockNow = (clockLast = clock.now()) + clockSkew;\n frame = timeout = 0;\n try {\n timerFlush();\n } finally {\n frame = 0;\n nap();\n clockNow = 0;\n }\n}\n\nfunction poke() {\n var now = clock.now(), delay = now - clockLast;\n if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n}\n\nfunction nap() {\n var t0, t1 = taskHead, t2, time = Infinity;\n while (t1) {\n if (t1._call) {\n if (time > t1._time) time = t1._time;\n t0 = t1, t1 = t1._next;\n } else {\n t2 = t1._next, t1._next = null;\n t1 = t0 ? t0._next = t2 : taskHead = t2;\n }\n }\n taskTail = t0;\n sleep(time);\n}\n\nfunction sleep(time) {\n if (frame) return; // Soonest alarm already set, or will be.\n if (timeout) timeout = clearTimeout(timeout);\n var delay = time - clockNow; // Strictly less than if we recomputed clockNow.\n if (delay > 24) {\n if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);\n if (interval) interval = clearInterval(interval);\n } else {\n if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);\n frame = 1, setFrame(wake);\n }\n}\n","export function linear(t) {\n return +t;\n}\n","export function quadIn(t) {\n return t * t;\n}\n\nexport function quadOut(t) {\n return t * (2 - t);\n}\n\nexport function quadInOut(t) {\n return ((t *= 2) <= 1 ? t * t : --t * (2 - t) + 1) / 2;\n}\n","export function cubicIn(t) {\n return t * t * t;\n}\n\nexport function cubicOut(t) {\n return --t * t * t + 1;\n}\n\nexport function cubicInOut(t) {\n return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;\n}\n","var exponent = 3;\n\nexport var polyIn = (function custom(e) {\n e = +e;\n\n function polyIn(t) {\n return Math.pow(t, e);\n }\n\n polyIn.exponent = custom;\n\n return polyIn;\n})(exponent);\n\nexport var polyOut = (function custom(e) {\n e = +e;\n\n function polyOut(t) {\n return 1 - Math.pow(1 - t, e);\n }\n\n polyOut.exponent = custom;\n\n return polyOut;\n})(exponent);\n\nexport var polyInOut = (function custom(e) {\n e = +e;\n\n function polyInOut(t) {\n return ((t *= 2) <= 1 ? Math.pow(t, e) : 2 - Math.pow(2 - t, e)) / 2;\n }\n\n polyInOut.exponent = custom;\n\n return polyInOut;\n})(exponent);\n","var pi = Math.PI,\n halfPi = pi / 2;\n\nexport function sinIn(t) {\n return (+t === 1) ? 1 : 1 - Math.cos(t * halfPi);\n}\n\nexport function sinOut(t) {\n return Math.sin(t * halfPi);\n}\n\nexport function sinInOut(t) {\n return (1 - Math.cos(pi * t)) / 2;\n}\n","// tpmt is two power minus ten times t scaled to [0,1]\nexport function tpmt(x) {\n return (Math.pow(2, -10 * x) - 0.0009765625) * 1.0009775171065494;\n}\n","import {tpmt} from \"./math.js\";\n\nexport function expIn(t) {\n return tpmt(1 - +t);\n}\n\nexport function expOut(t) {\n return 1 - tpmt(t);\n}\n\nexport function expInOut(t) {\n return ((t *= 2) <= 1 ? tpmt(1 - t) : 2 - tpmt(t - 1)) / 2;\n}\n","export function circleIn(t) {\n return 1 - Math.sqrt(1 - t * t);\n}\n\nexport function circleOut(t) {\n return Math.sqrt(1 - --t * t);\n}\n\nexport function circleInOut(t) {\n return ((t *= 2) <= 1 ? 1 - Math.sqrt(1 - t * t) : Math.sqrt(1 - (t -= 2) * t) + 1) / 2;\n}\n","var b1 = 4 / 11,\n b2 = 6 / 11,\n b3 = 8 / 11,\n b4 = 3 / 4,\n b5 = 9 / 11,\n b6 = 10 / 11,\n b7 = 15 / 16,\n b8 = 21 / 22,\n b9 = 63 / 64,\n b0 = 1 / b1 / b1;\n\nexport function bounceIn(t) {\n return 1 - bounceOut(1 - t);\n}\n\nexport function bounceOut(t) {\n return (t = +t) < b1 ? b0 * t * t : t < b3 ? b0 * (t -= b2) * t + b4 : t < b6 ? b0 * (t -= b5) * t + b7 : b0 * (t -= b8) * t + b9;\n}\n\nexport function bounceInOut(t) {\n return ((t *= 2) <= 1 ? 1 - bounceOut(1 - t) : bounceOut(t - 1) + 1) / 2;\n}\n","var overshoot = 1.70158;\n\nexport var backIn = (function custom(s) {\n s = +s;\n\n function backIn(t) {\n return (t = +t) * t * (s * (t - 1) + t);\n }\n\n backIn.overshoot = custom;\n\n return backIn;\n})(overshoot);\n\nexport var backOut = (function custom(s) {\n s = +s;\n\n function backOut(t) {\n return --t * t * ((t + 1) * s + t) + 1;\n }\n\n backOut.overshoot = custom;\n\n return backOut;\n})(overshoot);\n\nexport var backInOut = (function custom(s) {\n s = +s;\n\n function backInOut(t) {\n return ((t *= 2) < 1 ? t * t * ((s + 1) * t - s) : (t -= 2) * t * ((s + 1) * t + s) + 2) / 2;\n }\n\n backInOut.overshoot = custom;\n\n return backInOut;\n})(overshoot);\n","import {tpmt} from \"./math.js\";\n\nvar tau = 2 * Math.PI,\n amplitude = 1,\n period = 0.3;\n\nexport var elasticIn = (function custom(a, p) {\n var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n function elasticIn(t) {\n return a * tpmt(-(--t)) * Math.sin((s - t) / p);\n }\n\n elasticIn.amplitude = function(a) { return custom(a, p * tau); };\n elasticIn.period = function(p) { return custom(a, p); };\n\n return elasticIn;\n})(amplitude, period);\n\nexport var elasticOut = (function custom(a, p) {\n var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n function elasticOut(t) {\n return 1 - a * tpmt(t = +t) * Math.sin((t + s) / p);\n }\n\n elasticOut.amplitude = function(a) { return custom(a, p * tau); };\n elasticOut.period = function(p) { return custom(a, p); };\n\n return elasticOut;\n})(amplitude, period);\n\nexport var elasticInOut = (function custom(a, p) {\n var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n function elasticInOut(t) {\n return ((t = t * 2 - 1) < 0\n ? a * tpmt(-t) * Math.sin((s - t) / p)\n : 2 - a * tpmt(t) * Math.sin((s + t) / p)) / 2;\n }\n\n elasticInOut.amplitude = function(a) { return custom(a, p * tau); };\n elasticInOut.period = function(p) { return custom(a, p); };\n\n return elasticInOut;\n})(amplitude, period);\n","export default function(constructor, factory, prototype) {\n constructor.prototype = factory.prototype = prototype;\n prototype.constructor = constructor;\n}\n\nexport function extend(parent, definition) {\n var prototype = Object.create(parent.prototype);\n for (var key in definition) prototype[key] = definition[key];\n return prototype;\n}\n","import define, {extend} from \"./define.js\";\n\nexport function Color() {}\n\nexport var darker = 0.7;\nexport var brighter = 1 / darker;\n\nvar reI = \"\\\\s*([+-]?\\\\d+)\\\\s*\",\n reN = \"\\\\s*([+-]?\\\\d*\\\\.?\\\\d+(?:[eE][+-]?\\\\d+)?)\\\\s*\",\n reP = \"\\\\s*([+-]?\\\\d*\\\\.?\\\\d+(?:[eE][+-]?\\\\d+)?)%\\\\s*\",\n reHex = /^#([0-9a-f]{3,8})$/,\n reRgbInteger = new RegExp(\"^rgb\\\\(\" + [reI, reI, reI] + \"\\\\)$\"),\n reRgbPercent = new RegExp(\"^rgb\\\\(\" + [reP, reP, reP] + \"\\\\)$\"),\n reRgbaInteger = new RegExp(\"^rgba\\\\(\" + [reI, reI, reI, reN] + \"\\\\)$\"),\n reRgbaPercent = new RegExp(\"^rgba\\\\(\" + [reP, reP, reP, reN] + \"\\\\)$\"),\n reHslPercent = new RegExp(\"^hsl\\\\(\" + [reN, reP, reP] + \"\\\\)$\"),\n reHslaPercent = new RegExp(\"^hsla\\\\(\" + [reN, reP, reP, reN] + \"\\\\)$\");\n\nvar named = {\n aliceblue: 0xf0f8ff,\n antiquewhite: 0xfaebd7,\n aqua: 0x00ffff,\n aquamarine: 0x7fffd4,\n azure: 0xf0ffff,\n beige: 0xf5f5dc,\n bisque: 0xffe4c4,\n black: 0x000000,\n blanchedalmond: 0xffebcd,\n blue: 0x0000ff,\n blueviolet: 0x8a2be2,\n brown: 0xa52a2a,\n burlywood: 0xdeb887,\n cadetblue: 0x5f9ea0,\n chartreuse: 0x7fff00,\n chocolate: 0xd2691e,\n coral: 0xff7f50,\n cornflowerblue: 0x6495ed,\n cornsilk: 0xfff8dc,\n crimson: 0xdc143c,\n cyan: 0x00ffff,\n darkblue: 0x00008b,\n darkcyan: 0x008b8b,\n darkgoldenrod: 0xb8860b,\n darkgray: 0xa9a9a9,\n darkgreen: 0x006400,\n darkgrey: 0xa9a9a9,\n darkkhaki: 0xbdb76b,\n darkmagenta: 0x8b008b,\n darkolivegreen: 0x556b2f,\n darkorange: 0xff8c00,\n darkorchid: 0x9932cc,\n darkred: 0x8b0000,\n darksalmon: 0xe9967a,\n darkseagreen: 0x8fbc8f,\n darkslateblue: 0x483d8b,\n darkslategray: 0x2f4f4f,\n darkslategrey: 0x2f4f4f,\n darkturquoise: 0x00ced1,\n darkviolet: 0x9400d3,\n deeppink: 0xff1493,\n deepskyblue: 0x00bfff,\n dimgray: 0x696969,\n dimgrey: 0x696969,\n dodgerblue: 0x1e90ff,\n firebrick: 0xb22222,\n floralwhite: 0xfffaf0,\n forestgreen: 0x228b22,\n fuchsia: 0xff00ff,\n gainsboro: 0xdcdcdc,\n ghostwhite: 0xf8f8ff,\n gold: 0xffd700,\n goldenrod: 0xdaa520,\n gray: 0x808080,\n green: 0x008000,\n greenyellow: 0xadff2f,\n grey: 0x808080,\n honeydew: 0xf0fff0,\n hotpink: 0xff69b4,\n indianred: 0xcd5c5c,\n indigo: 0x4b0082,\n ivory: 0xfffff0,\n khaki: 0xf0e68c,\n lavender: 0xe6e6fa,\n lavenderblush: 0xfff0f5,\n lawngreen: 0x7cfc00,\n lemonchiffon: 0xfffacd,\n lightblue: 0xadd8e6,\n lightcoral: 0xf08080,\n lightcyan: 0xe0ffff,\n lightgoldenrodyellow: 0xfafad2,\n lightgray: 0xd3d3d3,\n lightgreen: 0x90ee90,\n lightgrey: 0xd3d3d3,\n lightpink: 0xffb6c1,\n lightsalmon: 0xffa07a,\n lightseagreen: 0x20b2aa,\n lightskyblue: 0x87cefa,\n lightslategray: 0x778899,\n lightslategrey: 0x778899,\n lightsteelblue: 0xb0c4de,\n lightyellow: 0xffffe0,\n lime: 0x00ff00,\n limegreen: 0x32cd32,\n linen: 0xfaf0e6,\n magenta: 0xff00ff,\n maroon: 0x800000,\n mediumaquamarine: 0x66cdaa,\n mediumblue: 0x0000cd,\n mediumorchid: 0xba55d3,\n mediumpurple: 0x9370db,\n mediumseagreen: 0x3cb371,\n mediumslateblue: 0x7b68ee,\n mediumspringgreen: 0x00fa9a,\n mediumturquoise: 0x48d1cc,\n mediumvioletred: 0xc71585,\n midnightblue: 0x191970,\n mintcream: 0xf5fffa,\n mistyrose: 0xffe4e1,\n moccasin: 0xffe4b5,\n navajowhite: 0xffdead,\n navy: 0x000080,\n oldlace: 0xfdf5e6,\n olive: 0x808000,\n olivedrab: 0x6b8e23,\n orange: 0xffa500,\n orangered: 0xff4500,\n orchid: 0xda70d6,\n palegoldenrod: 0xeee8aa,\n palegreen: 0x98fb98,\n paleturquoise: 0xafeeee,\n palevioletred: 0xdb7093,\n papayawhip: 0xffefd5,\n peachpuff: 0xffdab9,\n peru: 0xcd853f,\n pink: 0xffc0cb,\n plum: 0xdda0dd,\n powderblue: 0xb0e0e6,\n purple: 0x800080,\n rebeccapurple: 0x663399,\n red: 0xff0000,\n rosybrown: 0xbc8f8f,\n royalblue: 0x4169e1,\n saddlebrown: 0x8b4513,\n salmon: 0xfa8072,\n sandybrown: 0xf4a460,\n seagreen: 0x2e8b57,\n seashell: 0xfff5ee,\n sienna: 0xa0522d,\n silver: 0xc0c0c0,\n skyblue: 0x87ceeb,\n slateblue: 0x6a5acd,\n slategray: 0x708090,\n slategrey: 0x708090,\n snow: 0xfffafa,\n springgreen: 0x00ff7f,\n steelblue: 0x4682b4,\n tan: 0xd2b48c,\n teal: 0x008080,\n thistle: 0xd8bfd8,\n tomato: 0xff6347,\n turquoise: 0x40e0d0,\n violet: 0xee82ee,\n wheat: 0xf5deb3,\n white: 0xffffff,\n whitesmoke: 0xf5f5f5,\n yellow: 0xffff00,\n yellowgreen: 0x9acd32\n};\n\ndefine(Color, color, {\n copy: function(channels) {\n return Object.assign(new this.constructor, this, channels);\n },\n displayable: function() {\n return this.rgb().displayable();\n },\n hex: color_formatHex, // Deprecated! Use color.formatHex.\n formatHex: color_formatHex,\n formatHsl: color_formatHsl,\n formatRgb: color_formatRgb,\n toString: color_formatRgb\n});\n\nfunction color_formatHex() {\n return this.rgb().formatHex();\n}\n\nfunction color_formatHsl() {\n return hslConvert(this).formatHsl();\n}\n\nfunction color_formatRgb() {\n return this.rgb().formatRgb();\n}\n\nexport default function color(format) {\n var m, l;\n format = (format + \"\").trim().toLowerCase();\n return (m = reHex.exec(format)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) // #ff0000\n : l === 3 ? new Rgb((m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1) // #f00\n : l === 8 ? rgba(m >> 24 & 0xff, m >> 16 & 0xff, m >> 8 & 0xff, (m & 0xff) / 0xff) // #ff000000\n : l === 4 ? rgba((m >> 12 & 0xf) | (m >> 8 & 0xf0), (m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), (((m & 0xf) << 4) | (m & 0xf)) / 0xff) // #f000\n : null) // invalid hex\n : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n : named.hasOwnProperty(format) ? rgbn(named[format]) // eslint-disable-line no-prototype-builtins\n : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n : null;\n}\n\nfunction rgbn(n) {\n return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n}\n\nfunction rgba(r, g, b, a) {\n if (a <= 0) r = g = b = NaN;\n return new Rgb(r, g, b, a);\n}\n\nexport function rgbConvert(o) {\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Rgb;\n o = o.rgb();\n return new Rgb(o.r, o.g, o.b, o.opacity);\n}\n\nexport function rgb(r, g, b, opacity) {\n return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n}\n\nexport function Rgb(r, g, b, opacity) {\n this.r = +r;\n this.g = +g;\n this.b = +b;\n this.opacity = +opacity;\n}\n\ndefine(Rgb, rgb, extend(Color, {\n brighter: function(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n darker: function(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n rgb: function() {\n return this;\n },\n displayable: function() {\n return (-0.5 <= this.r && this.r < 255.5)\n && (-0.5 <= this.g && this.g < 255.5)\n && (-0.5 <= this.b && this.b < 255.5)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n hex: rgb_formatHex, // Deprecated! Use color.formatHex.\n formatHex: rgb_formatHex,\n formatRgb: rgb_formatRgb,\n toString: rgb_formatRgb\n}));\n\nfunction rgb_formatHex() {\n return \"#\" + hex(this.r) + hex(this.g) + hex(this.b);\n}\n\nfunction rgb_formatRgb() {\n var a = this.opacity; a = isNaN(a) ? 1 : Math.max(0, Math.min(1, a));\n return (a === 1 ? \"rgb(\" : \"rgba(\")\n + Math.max(0, Math.min(255, Math.round(this.r) || 0)) + \", \"\n + Math.max(0, Math.min(255, Math.round(this.g) || 0)) + \", \"\n + Math.max(0, Math.min(255, Math.round(this.b) || 0))\n + (a === 1 ? \")\" : \", \" + a + \")\");\n}\n\nfunction hex(value) {\n value = Math.max(0, Math.min(255, Math.round(value) || 0));\n return (value < 16 ? \"0\" : \"\") + value.toString(16);\n}\n\nfunction hsla(h, s, l, a) {\n if (a <= 0) h = s = l = NaN;\n else if (l <= 0 || l >= 1) h = s = NaN;\n else if (s <= 0) h = NaN;\n return new Hsl(h, s, l, a);\n}\n\nexport function hslConvert(o) {\n if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Hsl;\n if (o instanceof Hsl) return o;\n o = o.rgb();\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n min = Math.min(r, g, b),\n max = Math.max(r, g, b),\n h = NaN,\n s = max - min,\n l = (max + min) / 2;\n if (s) {\n if (r === max) h = (g - b) / s + (g < b) * 6;\n else if (g === max) h = (b - r) / s + 2;\n else h = (r - g) / s + 4;\n s /= l < 0.5 ? max + min : 2 - max - min;\n h *= 60;\n } else {\n s = l > 0 && l < 1 ? 0 : h;\n }\n return new Hsl(h, s, l, o.opacity);\n}\n\nexport function hsl(h, s, l, opacity) {\n return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n}\n\nfunction Hsl(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n}\n\ndefine(Hsl, hsl, extend(Color, {\n brighter: function(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n darker: function(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n rgb: function() {\n var h = this.h % 360 + (this.h < 0) * 360,\n s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n l = this.l,\n m2 = l + (l < 0.5 ? l : 1 - l) * s,\n m1 = 2 * l - m2;\n return new Rgb(\n hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n hsl2rgb(h, m1, m2),\n hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n this.opacity\n );\n },\n displayable: function() {\n return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n && (0 <= this.l && this.l <= 1)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n formatHsl: function() {\n var a = this.opacity; a = isNaN(a) ? 1 : Math.max(0, Math.min(1, a));\n return (a === 1 ? \"hsl(\" : \"hsla(\")\n + (this.h || 0) + \", \"\n + (this.s || 0) * 100 + \"%, \"\n + (this.l || 0) * 100 + \"%\"\n + (a === 1 ? \")\" : \", \" + a + \")\");\n }\n}));\n\n/* From FvD 13.37, CSS Color Module Level 3 */\nfunction hsl2rgb(h, m1, m2) {\n return (h < 60 ? m1 + (m2 - m1) * h / 60\n : h < 180 ? m2\n : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n : m1) * 255;\n}\n","export function basis(t1, v0, v1, v2, v3) {\n var t2 = t1 * t1, t3 = t2 * t1;\n return ((1 - 3 * t1 + 3 * t2 - t3) * v0\n + (4 - 6 * t2 + 3 * t3) * v1\n + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2\n + t3 * v3) / 6;\n}\n\nexport default function(values) {\n var n = values.length - 1;\n return function(t) {\n var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),\n v1 = values[i],\n v2 = values[i + 1],\n v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,\n v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n","export default function(x) {\n return function() {\n return x;\n };\n}\n","import constant from \"./constant.js\";\n\nfunction linear(a, d) {\n return function(t) {\n return a + t * d;\n };\n}\n\nfunction exponential(a, b, y) {\n return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n return Math.pow(a + t * b, y);\n };\n}\n\nexport function hue(a, b) {\n var d = b - a;\n return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant(isNaN(a) ? b : a);\n}\n\nexport function gamma(y) {\n return (y = +y) === 1 ? nogamma : function(a, b) {\n return b - a ? exponential(a, b, y) : constant(isNaN(a) ? b : a);\n };\n}\n\nexport default function nogamma(a, b) {\n var d = b - a;\n return d ? linear(a, d) : constant(isNaN(a) ? b : a);\n}\n","import {rgb as colorRgb} from \"d3-color\";\nimport basis from \"./basis.js\";\nimport basisClosed from \"./basisClosed.js\";\nimport nogamma, {gamma} from \"./color.js\";\n\nexport default (function rgbGamma(y) {\n var color = gamma(y);\n\n function rgb(start, end) {\n var r = color((start = colorRgb(start)).r, (end = colorRgb(end)).r),\n g = color(start.g, end.g),\n b = color(start.b, end.b),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.r = r(t);\n start.g = g(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n rgb.gamma = rgbGamma;\n\n return rgb;\n})(1);\n\nfunction rgbSpline(spline) {\n return function(colors) {\n var n = colors.length,\n r = new Array(n),\n g = new Array(n),\n b = new Array(n),\n i, color;\n for (i = 0; i < n; ++i) {\n color = colorRgb(colors[i]);\n r[i] = color.r || 0;\n g[i] = color.g || 0;\n b[i] = color.b || 0;\n }\n r = spline(r);\n g = spline(g);\n b = spline(b);\n color.opacity = 1;\n return function(t) {\n color.r = r(t);\n color.g = g(t);\n color.b = b(t);\n return color + \"\";\n };\n };\n}\n\nexport var rgbBasis = rgbSpline(basis);\nexport var rgbBasisClosed = rgbSpline(basisClosed);\n","import {basis} from \"./basis.js\";\n\nexport default function(values) {\n var n = values.length;\n return function(t) {\n var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),\n v0 = values[(i + n - 1) % n],\n v1 = values[i % n],\n v2 = values[(i + 1) % n],\n v3 = values[(i + 2) % n];\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n","export default function(a, b) {\n if (!b) b = [];\n var n = a ? Math.min(b.length, a.length) : 0,\n c = b.slice(),\n i;\n return function(t) {\n for (i = 0; i < n; ++i) c[i] = a[i] * (1 - t) + b[i] * t;\n return c;\n };\n}\n\nexport function isNumberArray(x) {\n return ArrayBuffer.isView(x) && !(x instanceof DataView);\n}\n","import value from \"./value.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n return (isNumberArray(b) ? numberArray : genericArray)(a, b);\n}\n\nexport function genericArray(a, b) {\n var nb = b ? b.length : 0,\n na = a ? Math.min(nb, a.length) : 0,\n x = new Array(na),\n c = new Array(nb),\n i;\n\n for (i = 0; i < na; ++i) x[i] = value(a[i], b[i]);\n for (; i < nb; ++i) c[i] = b[i];\n\n return function(t) {\n for (i = 0; i < na; ++i) c[i] = x[i](t);\n return c;\n };\n}\n","export default function(a, b) {\n var d = new Date;\n return a = +a, b = +b, function(t) {\n return d.setTime(a * (1 - t) + b * t), d;\n };\n}\n","export default function(a, b) {\n return a = +a, b = +b, function(t) {\n return a * (1 - t) + b * t;\n };\n}\n","import value from \"./value.js\";\n\nexport default function(a, b) {\n var i = {},\n c = {},\n k;\n\n if (a === null || typeof a !== \"object\") a = {};\n if (b === null || typeof b !== \"object\") b = {};\n\n for (k in b) {\n if (k in a) {\n i[k] = value(a[k], b[k]);\n } else {\n c[k] = b[k];\n }\n }\n\n return function(t) {\n for (k in i) c[k] = i[k](t);\n return c;\n };\n}\n","import number from \"./number.js\";\n\nvar reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g,\n reB = new RegExp(reA.source, \"g\");\n\nfunction zero(b) {\n return function() {\n return b;\n };\n}\n\nfunction one(b) {\n return function(t) {\n return b(t) + \"\";\n };\n}\n\nexport default function(a, b) {\n var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n am, // current match in a\n bm, // current match in b\n bs, // string preceding current number in b, if any\n i = -1, // index in s\n s = [], // string constants and placeholders\n q = []; // number interpolators\n\n // Coerce inputs to strings.\n a = a + \"\", b = b + \"\";\n\n // Interpolate pairs of numbers in a & b.\n while ((am = reA.exec(a))\n && (bm = reB.exec(b))) {\n if ((bs = bm.index) > bi) { // a string precedes the next number in b\n bs = b.slice(bi, bs);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n if (s[i]) s[i] += bm; // coalesce with previous string\n else s[++i] = bm;\n } else { // interpolate non-matching numbers\n s[++i] = null;\n q.push({i: i, x: number(am, bm)});\n }\n bi = reB.lastIndex;\n }\n\n // Add remains of b.\n if (bi < b.length) {\n bs = b.slice(bi);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n\n // Special optimization for only a single match.\n // Otherwise, interpolate each of the numbers and rejoin the string.\n return s.length < 2 ? (q[0]\n ? one(q[0].x)\n : zero(b))\n : (b = q.length, function(t) {\n for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n });\n}\n","import {color} from \"d3-color\";\nimport rgb from \"./rgb.js\";\nimport {genericArray} from \"./array.js\";\nimport date from \"./date.js\";\nimport number from \"./number.js\";\nimport object from \"./object.js\";\nimport string from \"./string.js\";\nimport constant from \"./constant.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n var t = typeof b, c;\n return b == null || t === \"boolean\" ? constant(b)\n : (t === \"number\" ? number\n : t === \"string\" ? ((c = color(b)) ? (b = c, rgb) : string)\n : b instanceof color ? rgb\n : b instanceof Date ? date\n : isNumberArray(b) ? numberArray\n : Array.isArray(b) ? genericArray\n : typeof b.valueOf !== \"function\" && typeof b.toString !== \"function\" || isNaN(b) ? object\n : number)(a, b);\n}\n","import { isEqual, isNumber, isFunction } from '@antv/util';\nimport * as d3Timer from 'd3-timer';\nimport * as d3Ease from 'd3-ease';\nimport { interpolate, interpolateArray } from 'd3-interpolate'; // 目前整体动画只需要数值和数组的差值计算\nimport * as PathUtil from '../util/path';\nimport { isColorProp, isGradientColor } from '../util/color';\nvar IDENTITY_MATRIX = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n/**\n * 使用 ratio 进行插值计算来更新属性\n * @param {IElement} shape 元素\n * @param {Animation} animation 动画\n * @param {number} ratio 比例\n * @return {boolean} 动画是否执行完成\n */\nfunction _update(shape, animation, ratio) {\n var cProps = {}; // 此刻属性\n var fromAttrs = animation.fromAttrs, toAttrs = animation.toAttrs;\n if (shape.destroyed) {\n return;\n }\n var interf; // 差值函数\n for (var k in toAttrs) {\n if (!isEqual(fromAttrs[k], toAttrs[k])) {\n if (k === 'path') {\n var toPath = toAttrs[k];\n var fromPath = fromAttrs[k];\n if (toPath.length > fromPath.length) {\n toPath = PathUtil.parsePathString(toAttrs[k]); // 终点状态\n fromPath = PathUtil.parsePathString(fromAttrs[k]); // 起始状态\n fromPath = PathUtil.fillPathByDiff(fromPath, toPath);\n fromPath = PathUtil.formatPath(fromPath, toPath);\n animation.fromAttrs.path = fromPath;\n animation.toAttrs.path = toPath;\n }\n else if (!animation.pathFormatted) {\n toPath = PathUtil.parsePathString(toAttrs[k]);\n fromPath = PathUtil.parsePathString(fromAttrs[k]);\n fromPath = PathUtil.formatPath(fromPath, toPath);\n animation.fromAttrs.path = fromPath;\n animation.toAttrs.path = toPath;\n animation.pathFormatted = true;\n }\n cProps[k] = [];\n for (var i = 0; i < toPath.length; i++) {\n var toPathPoint = toPath[i];\n var fromPathPoint = fromPath[i];\n var cPathPoint = [];\n for (var j = 0; j < toPathPoint.length; j++) {\n if (isNumber(toPathPoint[j]) && fromPathPoint && isNumber(fromPathPoint[j])) {\n interf = interpolate(fromPathPoint[j], toPathPoint[j]);\n cPathPoint.push(interf(ratio));\n }\n else {\n cPathPoint.push(toPathPoint[j]);\n }\n }\n cProps[k].push(cPathPoint);\n }\n }\n else if (k === 'matrix') {\n /*\n 对矩阵进行插值时,需要保证矩阵不为空,为空则使用单位矩阵\n TODO: 二维和三维场景下单位矩阵不同,之后 WebGL 版需要做进一步处理\n */\n var matrixFn = interpolateArray(fromAttrs[k] || IDENTITY_MATRIX, toAttrs[k] || IDENTITY_MATRIX);\n var currentMatrix = matrixFn(ratio);\n cProps[k] = currentMatrix;\n }\n else if (isColorProp(k) && isGradientColor(toAttrs[k])) {\n cProps[k] = toAttrs[k];\n }\n else if (!isFunction(toAttrs[k])) {\n // 非函数类型的值才能做插值\n interf = interpolate(fromAttrs[k], toAttrs[k]);\n cProps[k] = interf(ratio);\n }\n }\n }\n shape.attr(cProps);\n}\n/**\n * 根据自定义帧动画函数 onFrame 来更新属性\n * @param {IElement} shape 元素\n * @param {Animation} animation 动画\n * @param {number} elapsed 动画执行时间(毫秒)\n * @return {boolean} 动画是否执行完成\n */\nfunction update(shape, animation, elapsed) {\n var startTime = animation.startTime, delay = animation.delay;\n // 如果还没有开始执行或暂停,先不更新\n if (elapsed < startTime + delay || animation._paused) {\n return false;\n }\n var ratio;\n var duration = animation.duration;\n var easing = animation.easing;\n // 已执行时间\n elapsed = elapsed - startTime - animation.delay;\n if (animation.repeat) {\n // 如果动画重复执行,则 elapsed > duration,计算 ratio 时需取模\n ratio = (elapsed % duration) / duration;\n ratio = d3Ease[easing](ratio);\n }\n else {\n ratio = elapsed / duration;\n if (ratio < 1) {\n // 动画未执行完\n ratio = d3Ease[easing](ratio);\n }\n else {\n // 动画已执行完\n if (animation.onFrame) {\n shape.attr(animation.onFrame(1));\n }\n else {\n shape.attr(animation.toAttrs);\n }\n return true;\n }\n }\n if (animation.onFrame) {\n var attrs = animation.onFrame(ratio);\n shape.attr(attrs);\n }\n else {\n _update(shape, animation, ratio);\n }\n return false;\n}\nvar Timeline = /** @class */ (function () {\n /**\n * 时间轴构造函数,依赖于画布\n * @param {}\n */\n function Timeline(canvas) {\n /**\n * 执行动画的元素列表\n * @type {IElement[]}\n */\n this.animators = [];\n /**\n * 当前时间\n * @type {number}\n */\n this.current = 0;\n /**\n * 定时器\n * @type {d3Timer.Timer}\n */\n this.timer = null;\n this.canvas = canvas;\n }\n /**\n * 初始化定时器\n */\n Timeline.prototype.initTimer = function () {\n var _this = this;\n var isFinished = false;\n var shape;\n var animations;\n var animation;\n this.timer = d3Timer.timer(function (elapsed) {\n _this.current = elapsed;\n if (_this.animators.length > 0) {\n for (var i = _this.animators.length - 1; i >= 0; i--) {\n shape = _this.animators[i];\n if (shape.destroyed) {\n // 如果已经被销毁,直接移出队列\n _this.removeAnimator(i);\n continue;\n }\n if (!shape.isAnimatePaused()) {\n animations = shape.get('animations');\n for (var j = animations.length - 1; j >= 0; j--) {\n animation = animations[j];\n isFinished = update(shape, animation, elapsed);\n if (isFinished) {\n animations.splice(j, 1);\n isFinished = false;\n if (animation.callback) {\n animation.callback();\n }\n }\n }\n }\n if (animations.length === 0) {\n _this.removeAnimator(i);\n }\n }\n var autoDraw = _this.canvas.get('autoDraw');\n // 非自动渲染模式下,手动调用 canvas.draw() 重新渲染\n if (!autoDraw) {\n _this.canvas.draw();\n }\n }\n });\n };\n /**\n * 增加动画元素\n */\n Timeline.prototype.addAnimator = function (shape) {\n this.animators.push(shape);\n };\n /**\n * 移除动画元素\n */\n Timeline.prototype.removeAnimator = function (index) {\n this.animators.splice(index, 1);\n };\n /**\n * 是否有动画在执行\n */\n Timeline.prototype.isAnimating = function () {\n return !!this.animators.length;\n };\n /**\n * 停止定时器\n */\n Timeline.prototype.stop = function () {\n if (this.timer) {\n this.timer.stop();\n }\n };\n /**\n * 停止时间轴上所有元素的动画,并置空动画元素列表\n * @param {boolean} toEnd 是否到动画的最终状态,用来透传给动画元素的 stopAnimate 方法\n */\n Timeline.prototype.stopAllAnimations = function (toEnd) {\n if (toEnd === void 0) { toEnd = true; }\n this.animators.forEach(function (animator) {\n animator.stopAnimate(toEnd);\n });\n this.animators = [];\n this.canvas.draw();\n };\n /**\n * 获取当前时间\n */\n Timeline.prototype.getTime = function () {\n return this.current;\n };\n return Timeline;\n}());\nexport default Timeline;\n//# sourceMappingURL=timeline.js.map","export var isColorProp = function (prop) { return ['fill', 'stroke', 'fillStyle', 'strokeStyle'].includes(prop); };\nexport var isGradientColor = function (val) { return /^[r,R,L,l]{1}[\\s]*\\(/.test(val); };\n//# sourceMappingURL=color.js.map","/**\n * @fileoverview 事件处理器\n * @author dxq613@gmail.com\n */\nimport GraphEvent from './graph-event';\nimport { each, isParent } from '../util/util';\nvar CLICK_OFFSET = 40;\nvar LEFT_BTN_CODE = 0;\nvar DELEGATION_SPLIT = ':';\nvar EVENTS = [\n 'mousedown',\n 'mouseup',\n 'dblclick',\n 'mouseout',\n 'mouseover',\n 'mousemove',\n 'mouseleave',\n 'mouseenter',\n 'touchstart',\n 'touchmove',\n 'touchend',\n 'dragenter',\n 'dragover',\n 'dragleave',\n 'drop',\n 'contextmenu',\n 'mousewheel',\n];\n// 是否有委托事件监听\nfunction hasDelegation(events, type) {\n for (var key in events) {\n if (events.hasOwnProperty(key) && key.indexOf(DELEGATION_SPLIT + type) >= 0) {\n return true;\n }\n }\n return false;\n}\n// 触发目标事件,目标只能是 shape 或 canvas\nfunction emitTargetEvent(target, type, eventObj) {\n eventObj.name = type;\n eventObj.target = target;\n eventObj.currentTarget = target;\n eventObj.delegateTarget = target;\n target.emit(type, eventObj);\n}\n// 事件冒泡, enter 和 leave 需要对 fromShape 和 toShape 进行判同\nfunction bubbleEvent(container, type, eventObj) {\n if (eventObj.bubbles) {\n var relativeShape = void 0;\n var isOverEvent = false;\n if (type === 'mouseenter') {\n relativeShape = eventObj.fromShape;\n isOverEvent = true;\n }\n else if (type === 'mouseleave') {\n isOverEvent = true;\n relativeShape = eventObj.toShape;\n }\n // canvas 上的 mouseenter, mouseleave 事件,仅当进入或者移出 canvas 时触发\n if (container.isCanvas() && isOverEvent) {\n return;\n }\n // 如果相关图形同当前图形在同一个容器内,不触发事件\n if (relativeShape && isParent(container, relativeShape)) {\n // 阻止继续向上冒泡\n eventObj.bubbles = false;\n return;\n }\n // 事件名称可能在委托过程中被修改,因此事件冒泡时需要重新设置事件名称\n eventObj.name = type;\n eventObj.currentTarget = container;\n eventObj.delegateTarget = container;\n container.emit(type, eventObj);\n }\n}\nvar EventController = /** @class */ (function () {\n function EventController(cfg) {\n var _this = this;\n // 正在被拖拽的图形\n this.draggingShape = null;\n this.dragging = false;\n // 当前鼠标/touch所在位置的图形\n this.currentShape = null;\n this.mousedownShape = null;\n this.mousedownPoint = null;\n // 统一处理所有的回调\n this._eventCallback = function (ev) {\n var type = ev.type;\n _this._triggerEvent(type, ev);\n };\n // 在 document 处理拖拽到画布外的事件,处理从图形上移除画布未被捕捉的问题\n this._onDocumentMove = function (ev) {\n var canvas = _this.canvas;\n var el = canvas.get('el');\n if (el !== ev.target) {\n // 不在 canvas 上移动\n if (_this.dragging || _this.currentShape) {\n var pointInfo = _this._getPointInfo(ev);\n // 还在拖拽过程中\n if (_this.dragging) {\n _this._emitEvent('drag', ev, pointInfo, _this.draggingShape);\n }\n // 说明从某个图形直接移动到了画布外面,\n // 修复了 mouseleave 的 bug 后不再出现这种情况\n // if (this.currentShape) {\n // this._emitEvent('mouseleave', ev, pointInfo, this.currentShape, this.currentShape, null);\n // this.currentShape = null;\n // }\n }\n }\n };\n // 在 document 上处理拖拽到外面,释放鼠标时触发 dragend\n this._onDocumentMouseUp = function (ev) {\n var canvas = _this.canvas;\n var el = canvas.get('el');\n if (el !== ev.target) {\n // 不在 canvas 上移动\n if (_this.dragging) {\n var pointInfo = _this._getPointInfo(ev);\n if (_this.draggingShape) {\n // 如果存在拖拽的图形,则也触发 drop 事件\n _this._emitEvent('drop', ev, pointInfo, null);\n }\n _this._emitEvent('dragend', ev, pointInfo, _this.draggingShape);\n _this._afterDrag(_this.draggingShape, pointInfo, ev);\n }\n }\n };\n this.canvas = cfg.canvas;\n }\n EventController.prototype.init = function () {\n this._bindEvents();\n };\n // 注册事件\n EventController.prototype._bindEvents = function () {\n var _this = this;\n var el = this.canvas.get('el');\n each(EVENTS, function (eventName) {\n el.addEventListener(eventName, _this._eventCallback);\n });\n if (document) {\n // 处理移动到外面没有触发 shape mouse leave 的事件\n // 处理拖拽到外部的问题\n document.addEventListener('mousemove', this._onDocumentMove);\n // 处理拖拽过程中在外部释放鼠标的问题\n document.addEventListener('mouseup', this._onDocumentMouseUp);\n }\n };\n // 清理事件\n EventController.prototype._clearEvents = function () {\n var _this = this;\n var el = this.canvas.get('el');\n each(EVENTS, function (eventName) {\n el.removeEventListener(eventName, _this._eventCallback);\n });\n if (document) {\n document.removeEventListener('mousemove', this._onDocumentMove);\n document.removeEventListener('mouseup', this._onDocumentMouseUp);\n }\n };\n EventController.prototype._getEventObj = function (type, event, point, target, fromShape, toShape) {\n var eventObj = new GraphEvent(type, event);\n eventObj.fromShape = fromShape;\n eventObj.toShape = toShape;\n eventObj.x = point.x;\n eventObj.y = point.y;\n eventObj.clientX = point.clientX;\n eventObj.clientY = point.clientY;\n eventObj.propagationPath.push(target);\n // 事件的x,y应该是基于画布左上角的,与canvas的matrix无关\n return eventObj;\n };\n // 根据点获取图形,提取成独立方法,便于后续优化\n EventController.prototype._getShape = function (point, ev) {\n return this.canvas.getShape(point.x, point.y, ev);\n };\n // 获取事件的当前点的信息\n EventController.prototype._getPointInfo = function (ev) {\n var canvas = this.canvas;\n var clientPoint = canvas.getClientByEvent(ev);\n var point = canvas.getPointByEvent(ev);\n return {\n x: point.x,\n y: point.y,\n clientX: clientPoint.x,\n clientY: clientPoint.y,\n };\n };\n // 触发事件\n EventController.prototype._triggerEvent = function (type, ev) {\n var pointInfo = this._getPointInfo(ev);\n // 每次都获取图形有一定成本,后期可以考虑进行缓存策略\n var shape = this._getShape(pointInfo, ev);\n var method = this[\"_on\" + type];\n var leaveCanvas = false;\n if (method) {\n method.call(this, pointInfo, shape, ev);\n }\n else {\n var preShape = this.currentShape;\n // 如果进入、移出画布时存在图形,则要分别触发事件\n if (type === 'mouseenter' || type === 'dragenter' || type === 'mouseover') {\n this._emitEvent(type, ev, pointInfo, null, null, shape); // 先进入画布\n if (shape) {\n this._emitEvent(type, ev, pointInfo, shape, null, shape); // 再触发图形的事件\n }\n if (type === 'mouseenter' && this.draggingShape) {\n // 如果正在拖拽图形, 则触发 dragleave\n this._emitEvent('dragenter', ev, pointInfo, null);\n }\n }\n else if (type === 'mouseleave' || type === 'dragleave' || type === 'mouseout') {\n leaveCanvas = true;\n if (preShape) {\n this._emitEvent(type, ev, pointInfo, preShape, preShape, null); // 先触发图形的事件\n }\n this._emitEvent(type, ev, pointInfo, null, preShape, null); // 再触发离开画布事件\n if (type === 'mouseleave' && this.draggingShape) {\n this._emitEvent('dragleave', ev, pointInfo, null);\n }\n }\n else {\n this._emitEvent(type, ev, pointInfo, shape, null, null); // 一般事件中不需要考虑 from, to\n }\n }\n if (!leaveCanvas) {\n this.currentShape = shape;\n }\n // 当鼠标从画布移动到 shape 或者从 preShape 移动到 shape 时,应用 shape 上的鼠标样式\n if (shape && !shape.get('destroyed')) {\n var canvas = this.canvas;\n var el = canvas.get('el');\n el.style.cursor = shape.attr('cursor') || canvas.get('cursor');\n }\n };\n // 记录下点击的位置、图形,便于拖拽事件、click 事件的判定\n EventController.prototype._onmousedown = function (pointInfo, shape, event) {\n // 只有鼠标左键的 mousedown 事件才会设置 mousedownShape 等属性,避免鼠标右键的 mousedown 事件引起其他事件发生\n if (event.button === LEFT_BTN_CODE) {\n this.mousedownShape = shape;\n this.mousedownPoint = pointInfo;\n this.mousedownTimeStamp = event.timeStamp;\n }\n this._emitEvent('mousedown', event, pointInfo, shape, null, null); // mousedown 不考虑fromShape, toShape\n };\n // mouseleave 和 mouseenter 都是成对存在的\n // mouseenter 和 mouseover 同时触发\n EventController.prototype._emitMouseoverEvents = function (event, pointInfo, fromShape, toShape) {\n var el = this.canvas.get('el');\n if (fromShape !== toShape) {\n if (fromShape) {\n this._emitEvent('mouseout', event, pointInfo, fromShape, fromShape, toShape);\n this._emitEvent('mouseleave', event, pointInfo, fromShape, fromShape, toShape);\n // 当鼠标从 fromShape 移动到画布上时,重置鼠标样式\n if (!toShape || toShape.get('destroyed')) {\n el.style.cursor = this.canvas.get('cursor');\n }\n }\n if (toShape) {\n this._emitEvent('mouseover', event, pointInfo, toShape, fromShape, toShape);\n this._emitEvent('mouseenter', event, pointInfo, toShape, fromShape, toShape);\n }\n }\n };\n // dragover 不等同于 mouseover,而等同于 mousemove\n EventController.prototype._emitDragoverEvents = function (event, pointInfo, fromShape, toShape, isCanvasEmit) {\n if (toShape) {\n if (toShape !== fromShape) {\n if (fromShape) {\n this._emitEvent('dragleave', event, pointInfo, fromShape, fromShape, toShape);\n }\n this._emitEvent('dragenter', event, pointInfo, toShape, fromShape, toShape);\n }\n if (!isCanvasEmit) {\n this._emitEvent('dragover', event, pointInfo, toShape);\n }\n }\n else if (fromShape) {\n // TODO: 此处判断有问题,当 drag 图形时,也会触发一次 dragleave 事件,因为此时 toShape 为 null,这不是所期望的\n // 经过空白区域\n this._emitEvent('dragleave', event, pointInfo, fromShape, fromShape, toShape);\n }\n if (isCanvasEmit) {\n this._emitEvent('dragover', event, pointInfo, toShape);\n }\n };\n // drag 完成后,需要做一些清理工作\n EventController.prototype._afterDrag = function (draggingShape, pointInfo, event) {\n if (draggingShape) {\n draggingShape.set('capture', true); // 恢复可以拾取\n this.draggingShape = null;\n }\n this.dragging = false;\n // drag 完成后,有可能 draggingShape 已经移动到了当前位置,所以不能直接取当前图形\n var shape = this._getShape(pointInfo, event);\n // 拖拽完成后,进行 enter,leave 的判定\n if (shape !== draggingShape) {\n this._emitMouseoverEvents(event, pointInfo, draggingShape, shape);\n }\n this.currentShape = shape; // 更新当前 shape,如果不处理当前图形的 mouseleave 事件可能会出问题\n };\n // 按键抬起时,会终止拖拽、触发点击\n EventController.prototype._onmouseup = function (pointInfo, shape, event) {\n // eevent.button === 0 表示鼠标左键事件,此处加上判断主要是为了避免右键鼠标会触发 mouseup 和 click 事件\n // ref: https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/button\n if (event.button === LEFT_BTN_CODE) {\n var draggingShape = this.draggingShape;\n if (this.dragging) {\n // 存在可以拖拽的图形,同时拖拽到其他图形上时触发 drag 事件\n if (draggingShape) {\n this._emitEvent('drop', event, pointInfo, shape);\n }\n this._emitEvent('dragend', event, pointInfo, draggingShape);\n this._afterDrag(draggingShape, pointInfo, event);\n }\n else {\n this._emitEvent('mouseup', event, pointInfo, shape); // 先触发 mouseup 再触发 click\n if (shape === this.mousedownShape) {\n this._emitEvent('click', event, pointInfo, shape);\n }\n this.mousedownShape = null;\n this.mousedownPoint = null;\n }\n }\n };\n // 当触发浏览器的 dragover 事件时,不会再触发 mousemove ,所以这时候的 dragenter, dragleave 事件需要重新处理\n EventController.prototype._ondragover = function (pointInfo, shape, event) {\n event.preventDefault(); // 如果不对 dragover 进行 preventDefault,则不会在 canvas 上触发 drop 事件\n var preShape = this.currentShape;\n this._emitDragoverEvents(event, pointInfo, preShape, shape, true);\n };\n // 大量的图形事件,都通过 mousemove 模拟\n EventController.prototype._onmousemove = function (pointInfo, shape, event) {\n var canvas = this.canvas;\n var preShape = this.currentShape;\n var draggingShape = this.draggingShape;\n // 正在拖拽时\n if (this.dragging) {\n // 正在拖拽中\n if (draggingShape) {\n // 如果拖拽了 shape 会触发 dragenter, dragleave, dragover 和 drag 事件\n this._emitDragoverEvents(event, pointInfo, preShape, shape, false);\n }\n // 如果存在 draggingShape 则会在 draggingShape 上触发 drag 事件,冒泡到 canvas 上\n // 否则在 canvas 上触发 drag 事件\n this._emitEvent('drag', event, pointInfo, draggingShape);\n }\n else {\n var mousedownPoint = this.mousedownPoint;\n if (mousedownPoint) {\n // 当鼠标点击下去,同时移动时,进行 drag 判定\n var mousedownShape = this.mousedownShape;\n var now = event.timeStamp;\n var timeWindow = now - this.mousedownTimeStamp;\n var dx = mousedownPoint.clientX - pointInfo.clientX;\n var dy = mousedownPoint.clientY - pointInfo.clientY;\n var dist = dx * dx + dy * dy;\n if (timeWindow > 120 || dist > CLICK_OFFSET) {\n if (mousedownShape && mousedownShape.get('draggable')) {\n // 设置了 draggable 的 shape 才能触发 drag 相关的事件\n draggingShape = this.mousedownShape; // 拖动鼠标点下时的 shape\n draggingShape.set('capture', false); // 禁止继续拾取,否则无法进行 dragover,dragenter,dragleave,drop的判定\n this.draggingShape = draggingShape;\n this.dragging = true;\n this._emitEvent('dragstart', event, pointInfo, draggingShape);\n // 清理按下鼠标时缓存的值\n this.mousedownShape = null;\n this.mousedownPoint = null;\n }\n else if (!mousedownShape && canvas.get('draggable')) {\n // 设置了 draggable 的 canvas 才能触发 drag 相关的事件\n this.dragging = true;\n this._emitEvent('dragstart', event, pointInfo, null);\n // 清理按下鼠标时缓存的值\n this.mousedownShape = null;\n this.mousedownPoint = null;\n }\n else {\n this._emitMouseoverEvents(event, pointInfo, preShape, shape);\n this._emitEvent('mousemove', event, pointInfo, shape);\n }\n }\n else {\n this._emitMouseoverEvents(event, pointInfo, preShape, shape);\n this._emitEvent('mousemove', event, pointInfo, shape);\n }\n }\n else {\n // 没有按键按下时,则直接触发 mouse over 相关的各种事件\n this._emitMouseoverEvents(event, pointInfo, preShape, shape);\n // 始终触发移动\n this._emitEvent('mousemove', event, pointInfo, shape);\n }\n }\n };\n // 触发事件\n EventController.prototype._emitEvent = function (type, event, pointInfo, shape, fromShape, toShape) {\n var eventObj = this._getEventObj(type, event, pointInfo, shape, fromShape, toShape);\n // 存在 shape 触发,则进行冒泡处理\n if (shape) {\n eventObj.shape = shape;\n // 触发 shape 上的事件\n emitTargetEvent(shape, type, eventObj);\n var parent_1 = shape.getParent();\n // 执行冒泡\n while (parent_1) {\n // 委托事件要先触发\n parent_1.emitDelegation(type, eventObj);\n // 事件冒泡停止,不能妨碍委托事件\n if (!eventObj.propagationStopped) {\n bubbleEvent(parent_1, type, eventObj);\n }\n eventObj.propagationPath.push(parent_1);\n parent_1 = parent_1.getParent();\n }\n }\n else {\n // 如果没有 shape 直接在 canvas 上触发\n var canvas = this.canvas;\n // 直接触发 canvas 上的事件\n emitTargetEvent(canvas, type, eventObj);\n }\n };\n EventController.prototype.destroy = function () {\n // 清理事件\n this._clearEvents();\n // 清理缓存的对象\n this.canvas = null;\n this.currentShape = null;\n this.draggingShape = null;\n this.mousedownPoint = null;\n this.mousedownShape = null;\n this.mousedownTimeStamp = null;\n };\n return EventController;\n}());\nexport default EventController;\n//# sourceMappingURL=event-contoller.js.map","import { __extends } from \"tslib\";\nimport { detect } from 'detect-browser';\nimport Container from './container';\nimport { isBrowser, isNil, isString } from '../util/util';\nimport Timeline from '../animate/timeline';\nimport EventController from '../event/event-contoller';\nvar PX_SUFFIX = 'px';\nvar browser = detect();\nvar isFirefox = browser && browser.name === 'firefox';\nvar Canvas = /** @class */ (function (_super) {\n __extends(Canvas, _super);\n function Canvas(cfg) {\n var _this = _super.call(this, cfg) || this;\n _this.initContainer();\n _this.initDom();\n _this.initEvents();\n _this.initTimeline();\n return _this;\n }\n Canvas.prototype.getDefaultCfg = function () {\n var cfg = _super.prototype.getDefaultCfg.call(this);\n // set default cursor style for canvas\n cfg['cursor'] = 'default';\n // CSS transform 目前尚未经过长时间验证,为了避免影响上层业务,默认关闭,上层按需开启\n cfg['supportCSSTransform'] = false;\n return cfg;\n };\n /**\n * @protected\n * 初始化容器\n */\n Canvas.prototype.initContainer = function () {\n var container = this.get('container');\n if (isString(container)) {\n container = document.getElementById(container);\n this.set('container', container);\n }\n };\n /**\n * @protected\n * 初始化 DOM\n */\n Canvas.prototype.initDom = function () {\n var el = this.createDom();\n this.set('el', el);\n // 附加到容器\n var container = this.get('container');\n container.appendChild(el);\n // 设置初始宽度\n this.setDOMSize(this.get('width'), this.get('height'));\n };\n /**\n * @protected\n * 初始化绑定的事件\n */\n Canvas.prototype.initEvents = function () {\n var eventController = new EventController({\n canvas: this,\n });\n eventController.init();\n this.set('eventController', eventController);\n };\n /**\n * @protected\n * 初始化时间轴\n */\n Canvas.prototype.initTimeline = function () {\n var timeline = new Timeline(this);\n this.set('timeline', timeline);\n };\n /**\n * @protected\n * 修改画布对应的 DOM 的大小\n * @param {number} width 宽度\n * @param {number} height 高度\n */\n Canvas.prototype.setDOMSize = function (width, height) {\n var el = this.get('el');\n if (isBrowser) {\n el.style.width = width + PX_SUFFIX;\n el.style.height = height + PX_SUFFIX;\n }\n };\n // 实现接口\n Canvas.prototype.changeSize = function (width, height) {\n this.setDOMSize(width, height);\n this.set('width', width);\n this.set('height', height);\n this.onCanvasChange('changeSize');\n };\n /**\n * 获取当前的渲染引擎\n * @return {Renderer} 返回当前的渲染引擎\n */\n Canvas.prototype.getRenderer = function () {\n return this.get('renderer');\n };\n /**\n * 获取画布的 cursor 样式\n * @return {Cursor}\n */\n Canvas.prototype.getCursor = function () {\n return this.get('cursor');\n };\n /**\n * 设置画布的 cursor 样式\n * @param {Cursor} cursor cursor 样式\n */\n Canvas.prototype.setCursor = function (cursor) {\n this.set('cursor', cursor);\n var el = this.get('el');\n if (isBrowser && el) {\n // 直接设置样式,不等待鼠标移动时再设置\n el.style.cursor = cursor;\n }\n };\n // 实现接口\n Canvas.prototype.getPointByEvent = function (ev) {\n var supportCSSTransform = this.get('supportCSSTransform');\n if (supportCSSTransform) {\n // For Firefox <= 38\n if (isFirefox && !isNil(ev.layerX) && ev.layerX !== ev.offsetX) {\n return {\n x: ev.layerX,\n y: ev.layerY,\n };\n }\n if (!isNil(ev.offsetX)) {\n // For IE6+, Firefox >= 39, Chrome, Safari, Opera\n return {\n x: ev.offsetX,\n y: ev.offsetY,\n };\n }\n }\n // should calculate by self for other cases, like Safari in ios\n // TODO: support CSS transform\n var _a = this.getClientByEvent(ev), clientX = _a.x, clientY = _a.y;\n return this.getPointByClient(clientX, clientY);\n };\n // 获取 touch 事件的 clientX 和 clientY 需要单独处理\n Canvas.prototype.getClientByEvent = function (ev) {\n var clientInfo = ev;\n if (ev.touches) {\n if (ev.type === 'touchend') {\n clientInfo = ev.changedTouches[0];\n }\n else {\n clientInfo = ev.touches[0];\n }\n }\n return {\n x: clientInfo.clientX,\n y: clientInfo.clientY,\n };\n };\n // 实现接口\n Canvas.prototype.getPointByClient = function (clientX, clientY) {\n var el = this.get('el');\n var bbox = el.getBoundingClientRect();\n return {\n x: clientX - bbox.left,\n y: clientY - bbox.top,\n };\n };\n // 实现接口\n Canvas.prototype.getClientByPoint = function (x, y) {\n var el = this.get('el');\n var bbox = el.getBoundingClientRect();\n return {\n x: x + bbox.left,\n y: y + bbox.top,\n };\n };\n // 实现接口\n Canvas.prototype.draw = function () { };\n /**\n * @protected\n * 销毁 DOM 容器\n */\n Canvas.prototype.removeDom = function () {\n var el = this.get('el');\n el.parentNode.removeChild(el);\n };\n /**\n * @protected\n * 清理所有的事件\n */\n Canvas.prototype.clearEvents = function () {\n var eventController = this.get('eventController');\n eventController.destroy();\n };\n Canvas.prototype.isCanvas = function () {\n return true;\n };\n Canvas.prototype.getParent = function () {\n return null;\n };\n Canvas.prototype.destroy = function () {\n var timeline = this.get('timeline');\n if (this.get('destroyed')) {\n return;\n }\n this.clear();\n // 同初始化时相反顺序调用\n if (timeline) {\n // 画布销毁时自动停止动画\n timeline.stop();\n }\n this.clearEvents();\n this.removeDom();\n _super.prototype.destroy.call(this);\n };\n return Canvas;\n}(Container));\nexport default Canvas;\n//# sourceMappingURL=canvas.js.map","var cache = new Map();\n/**\n * 注册计算包围盒的算法\n * @param type 方法名\n * @param method 方法\n */\nexport function register(type, method) {\n cache.set(type, method);\n}\n/**\n * 获取计算包围盒的算法\n * @param type 方法名\n */\nexport function getMethod(type) {\n return cache.get(type);\n}\n//# sourceMappingURL=register.js.map","export default function (shape) {\n var attrs = shape.attr();\n var x = attrs.x, y = attrs.y, width = attrs.width, height = attrs.height;\n return {\n x: x,\n y: y,\n width: width,\n height: height,\n };\n}\n//# sourceMappingURL=rect.js.map","export default function (shape) {\n var _a = shape.attr(), x = _a.x, y = _a.y, r = _a.r;\n return {\n x: x - r,\n y: y - r,\n width: r * 2,\n height: r * 2,\n };\n}\n//# sourceMappingURL=circle.js.map","// 合并包围盒\nexport function mergeBBox(bbox1, bbox2) {\n if (!bbox1 || !bbox2) {\n return bbox1 || bbox2;\n }\n return {\n minX: Math.min(bbox1.minX, bbox2.minX),\n minY: Math.min(bbox1.minY, bbox2.minY),\n maxX: Math.max(bbox1.maxX, bbox2.maxX),\n maxY: Math.max(bbox1.maxY, bbox2.maxY),\n };\n}\n// 合并箭头的包围盒\nexport function mergeArrowBBox(shape, bbox) {\n var startArrowShape = shape.get('startArrowShape');\n var endArrowShape = shape.get('endArrowShape');\n var startArrowBBox = null;\n var endArrowBBox = null;\n if (startArrowShape) {\n startArrowBBox = startArrowShape.getCanvasBBox();\n bbox = mergeBBox(bbox, startArrowBBox);\n }\n if (endArrowShape) {\n endArrowBBox = endArrowShape.getCanvasBBox();\n bbox = mergeBBox(bbox, endArrowBBox);\n }\n return bbox;\n}\n//# sourceMappingURL=util.js.map","import { Util } from '@antv/g-math';\nimport { mergeArrowBBox } from './util';\nexport default function (shape) {\n var attrs = shape.attr();\n var points = attrs.points;\n var xArr = [];\n var yArr = [];\n for (var i = 0; i < points.length; i++) {\n var point = points[i];\n xArr.push(point[0]);\n yArr.push(point[1]);\n }\n var _a = Util.getBBoxByArray(xArr, yArr), x = _a.x, y = _a.y, width = _a.width, height = _a.height;\n var bbox = {\n minX: x,\n minY: y,\n maxX: x + width,\n maxY: y + height,\n };\n bbox = mergeArrowBBox(shape, bbox);\n return {\n x: bbox.minX,\n y: bbox.minY,\n width: bbox.maxX - bbox.minX,\n height: bbox.maxY - bbox.minY,\n };\n}\n//# sourceMappingURL=polyline.js.map","import { Quad as QuadUtil, Cubic as CubicUtil, Arc as EllipseArcUtil } from '@antv/g-math';\nimport { path2Segments } from '@antv/path-util';\nimport { isNumberEqual, max, min } from '@antv/util';\nimport { mergeArrowBBox } from './util';\nfunction getPathBox(segments, lineWidth) {\n var xArr = [];\n var yArr = [];\n var segmentsWithAngle = [];\n for (var i = 0; i < segments.length; i++) {\n var segment = segments[i];\n var currentPoint = segment.currentPoint, params = segment.params, prePoint = segment.prePoint;\n var box = void 0;\n switch (segment.command) {\n case 'Q':\n box = QuadUtil.box(prePoint[0], prePoint[1], params[1], params[2], params[3], params[4]);\n break;\n case 'C':\n box = CubicUtil.box(prePoint[0], prePoint[1], params[1], params[2], params[3], params[4], params[5], params[6]);\n break;\n case 'A':\n var arcParams = segment.arcParams;\n box = EllipseArcUtil.box(arcParams.cx, arcParams.cy, arcParams.rx, arcParams.ry, arcParams.xRotation, arcParams.startAngle, arcParams.endAngle);\n break;\n default:\n xArr.push(currentPoint[0]);\n yArr.push(currentPoint[1]);\n break;\n }\n if (box) {\n segment.box = box;\n xArr.push(box.x, box.x + box.width);\n yArr.push(box.y, box.y + box.height);\n }\n if (lineWidth && (segment.command === 'L' || segment.command === 'M') && segment.prePoint && segment.nextPoint) {\n segmentsWithAngle.push(segment);\n }\n }\n // bbox calculation should ignore NaN for path attribute\n // ref: https://github.com/antvis/g/issues/210\n xArr = xArr.filter(function (item) { return !Number.isNaN(item); });\n yArr = yArr.filter(function (item) { return !Number.isNaN(item); });\n var minX = min(xArr);\n var minY = min(yArr);\n var maxX = max(xArr);\n var maxY = max(yArr);\n if (segmentsWithAngle.length === 0) {\n return {\n x: minX,\n y: minY,\n width: maxX - minX,\n height: maxY - minY,\n };\n }\n for (var i = 0; i < segmentsWithAngle.length; i++) {\n var segment = segmentsWithAngle[i];\n var currentPoint = segment.currentPoint;\n var extra = void 0;\n if (currentPoint[0] === minX) {\n extra = getExtraFromSegmentWithAngle(segment, lineWidth);\n minX = minX - extra.xExtra;\n }\n else if (currentPoint[0] === maxX) {\n extra = getExtraFromSegmentWithAngle(segment, lineWidth);\n maxX = maxX + extra.xExtra;\n }\n if (currentPoint[1] === minY) {\n extra = getExtraFromSegmentWithAngle(segment, lineWidth);\n minY = minY - extra.yExtra;\n }\n else if (currentPoint[1] === maxY) {\n extra = getExtraFromSegmentWithAngle(segment, lineWidth);\n maxY = maxY + extra.yExtra;\n }\n }\n return {\n x: minX,\n y: minY,\n width: maxX - minX,\n height: maxY - minY,\n };\n}\nfunction getExtraFromSegmentWithAngle(segment, lineWidth) {\n var prePoint = segment.prePoint, currentPoint = segment.currentPoint, nextPoint = segment.nextPoint;\n var currentAndPre = Math.pow(currentPoint[0] - prePoint[0], 2) + Math.pow(currentPoint[1] - prePoint[1], 2);\n var currentAndNext = Math.pow(currentPoint[0] - nextPoint[0], 2) + Math.pow(currentPoint[1] - nextPoint[1], 2);\n var preAndNext = Math.pow(prePoint[0] - nextPoint[0], 2) + Math.pow(prePoint[1] - nextPoint[1], 2);\n // 以 currentPoint 为顶点的夹角\n var currentAngle = Math.acos((currentAndPre + currentAndNext - preAndNext) / (2 * Math.sqrt(currentAndPre) * Math.sqrt(currentAndNext)));\n // 夹角为空、 0 或 PI 时,不需要计算夹角处的额外宽度\n // 注意: 由于计算精度问题,夹角为 0 的情况计算出来的角度可能是一个很小的值,还需要判断其与 0 是否近似相等\n if (!currentAngle || Math.sin(currentAngle) === 0 || isNumberEqual(currentAngle, 0)) {\n return {\n xExtra: 0,\n yExtra: 0,\n };\n }\n var xAngle = Math.abs(Math.atan2(nextPoint[1] - currentPoint[1], nextPoint[0] - currentPoint[0]));\n var yAngle = Math.abs(Math.atan2(nextPoint[0] - currentPoint[0], nextPoint[1] - currentPoint[1]));\n // 将夹角转为锐角\n xAngle = xAngle > Math.PI / 2 ? Math.PI - xAngle : xAngle;\n yAngle = yAngle > Math.PI / 2 ? Math.PI - yAngle : yAngle;\n // 这里不考虑在水平和垂直方向的投影,直接使用最大差值\n // 由于上层统一加减了二分之一线宽,这里需要进行弥补\n var extra = {\n // 水平方向投影\n xExtra: Math.cos(currentAngle / 2 - xAngle) * ((lineWidth / 2) * (1 / Math.sin(currentAngle / 2))) - lineWidth / 2 || 0,\n // 垂直方向投影\n yExtra: Math.cos(yAngle - currentAngle / 2) * ((lineWidth / 2) * (1 / Math.sin(currentAngle / 2))) - lineWidth / 2 || 0,\n };\n return extra;\n}\nexport default function (shape) {\n var attrs = shape.attr();\n var path = attrs.path, stroke = attrs.stroke;\n var lineWidth = stroke ? attrs.lineWidth : 0; // 只有有 stroke 时,lineWidth 才生效\n var segments = shape.get('segments') || path2Segments(path);\n var _a = getPathBox(segments, lineWidth), x = _a.x, y = _a.y, width = _a.width, height = _a.height;\n var bbox = {\n minX: x,\n minY: y,\n maxX: x + width,\n maxY: y + height,\n };\n bbox = mergeArrowBBox(shape, bbox);\n return {\n x: bbox.minX,\n y: bbox.minY,\n width: bbox.maxX - bbox.minX,\n height: bbox.maxY - bbox.minY,\n };\n}\n//# sourceMappingURL=path.js.map","import { register, getMethod } from './register';\nimport rect from './rect';\nimport circle from './circle';\nimport polyline from './polyline';\nimport polygon from './polygon';\nimport text from './text';\nimport path from './path';\nimport line from './line';\nimport ellipse from './ellipse';\nregister('rect', rect);\nregister('image', rect); // image 使用 rect 的包围盒计算\nregister('circle', circle);\nregister('marker', circle); // marker 使用 circle 的计算方案\nregister('polyline', polyline);\nregister('polygon', polygon);\nregister('text', text);\nregister('path', path);\nregister('line', line);\nregister('ellipse', ellipse);\nexport { getMethod as getBBoxMethod };\n//# sourceMappingURL=index.js.map","import { Util } from '@antv/g-math';\nexport default function (shape) {\n var attrs = shape.attr();\n var points = attrs.points;\n var xArr = [];\n var yArr = [];\n for (var i = 0; i < points.length; i++) {\n var point = points[i];\n xArr.push(point[0]);\n yArr.push(point[1]);\n }\n return Util.getBBoxByArray(xArr, yArr);\n}\n//# sourceMappingURL=polygon.js.map","import { getTextWidth, getTextHeight, assembleFont } from '../util/text';\nexport default function (shape) {\n var attrs = shape.attr();\n var x = attrs.x, y = attrs.y, text = attrs.text, fontSize = attrs.fontSize, lineHeight = attrs.lineHeight;\n var font = attrs.font;\n if (!font) {\n // 如果未组装 font\n font = assembleFont(attrs);\n }\n var width = getTextWidth(text, font);\n var bbox;\n if (!width) {\n // 如果width不存在,四点共其实点\n bbox = {\n x: x,\n y: y,\n width: 0,\n height: 0,\n };\n }\n else {\n var textAlign = attrs.textAlign, textBaseline = attrs.textBaseline;\n var height = getTextHeight(text, fontSize, lineHeight); // attrs.height\n // 默认左右对齐:left, 默认上下对齐 bottom\n var point = {\n x: x,\n y: y - height,\n };\n if (textAlign) {\n if (textAlign === 'end' || textAlign === 'right') {\n point.x -= width;\n }\n else if (textAlign === 'center') {\n point.x -= width / 2;\n }\n }\n if (textBaseline) {\n if (textBaseline === 'top') {\n point.y += height;\n }\n else if (textBaseline === 'middle') {\n point.y += height / 2;\n }\n }\n bbox = {\n x: point.x,\n y: point.y,\n width: width,\n height: height,\n };\n }\n return bbox;\n}\n//# sourceMappingURL=text.js.map","import { mergeArrowBBox } from './util';\nexport default function (shape) {\n var attrs = shape.attr();\n var x1 = attrs.x1, y1 = attrs.y1, x2 = attrs.x2, y2 = attrs.y2;\n var minX = Math.min(x1, x2);\n var maxX = Math.max(x1, x2);\n var minY = Math.min(y1, y2);\n var maxY = Math.max(y1, y2);\n var bbox = {\n minX: minX,\n maxX: maxX,\n minY: minY,\n maxY: maxY,\n };\n bbox = mergeArrowBBox(shape, bbox);\n return {\n x: bbox.minX,\n y: bbox.minY,\n width: bbox.maxX - bbox.minX,\n height: bbox.maxY - bbox.minY,\n };\n}\n//# sourceMappingURL=line.js.map","export default function (shape) {\n var attrs = shape.attr();\n var x = attrs.x, y = attrs.y, rx = attrs.rx, ry = attrs.ry;\n return {\n x: x - rx,\n y: y - ry,\n width: rx * 2,\n height: ry * 2,\n };\n}\n//# sourceMappingURL=ellipse.js.map","/**\n * @fileoverview gradient\n * @author dengfuping_develop@163.com\n */\nimport { each, mod, toRadian, uniqueId } from '@antv/util';\nimport { createSVGElement } from '../util/dom';\nvar regexLG = /^l\\s*\\(\\s*([\\d.]+)\\s*\\)\\s*(.*)/i;\nvar regexRG = /^r\\s*\\(\\s*([\\d.]+)\\s*,\\s*([\\d.]+)\\s*,\\s*([\\d.]+)\\s*\\)\\s*(.*)/i;\nvar regexColorStop = /[\\d.]+:(#[^\\s]+|[^)]+\\))/gi;\nfunction addStop(steps) {\n var arr = steps.match(regexColorStop);\n if (!arr) {\n return '';\n }\n var stops = '';\n arr.sort(function (a, b) {\n a = a.split(':');\n b = b.split(':');\n return Number(a[0]) - Number(b[0]);\n });\n each(arr, function (item) {\n item = item.split(':');\n stops += \"<stop offset=\\\"\" + item[0] + \"\\\" stop-color=\\\"\" + item[1] + \"\\\"></stop>\";\n });\n return stops;\n}\nfunction parseLineGradient(color, el) {\n var arr = regexLG.exec(color);\n var angle = mod(toRadian(parseFloat(arr[1])), Math.PI * 2);\n var steps = arr[2];\n var start;\n var end;\n if (angle >= 0 && angle < 0.5 * Math.PI) {\n start = {\n x: 0,\n y: 0,\n };\n end = {\n x: 1,\n y: 1,\n };\n }\n else if (0.5 * Math.PI <= angle && angle < Math.PI) {\n start = {\n x: 1,\n y: 0,\n };\n end = {\n x: 0,\n y: 1,\n };\n }\n else if (Math.PI <= angle && angle < 1.5 * Math.PI) {\n start = {\n x: 1,\n y: 1,\n };\n end = {\n x: 0,\n y: 0,\n };\n }\n else {\n start = {\n x: 0,\n y: 1,\n };\n end = {\n x: 1,\n y: 0,\n };\n }\n var tanTheta = Math.tan(angle);\n var tanTheta2 = tanTheta * tanTheta;\n var x = (end.x - start.x + tanTheta * (end.y - start.y)) / (tanTheta2 + 1) + start.x;\n var y = (tanTheta * (end.x - start.x + tanTheta * (end.y - start.y))) / (tanTheta2 + 1) + start.y;\n el.setAttribute('x1', start.x);\n el.setAttribute('y1', start.y);\n el.setAttribute('x2', x);\n el.setAttribute('y2', y);\n el.innerHTML = addStop(steps);\n}\nfunction parseRadialGradient(color, self) {\n var arr = regexRG.exec(color);\n var cx = parseFloat(arr[1]);\n var cy = parseFloat(arr[2]);\n var r = parseFloat(arr[3]);\n var steps = arr[4];\n self.setAttribute('cx', cx);\n self.setAttribute('cy', cy);\n self.setAttribute('r', r);\n self.innerHTML = addStop(steps);\n}\nvar Gradient = /** @class */ (function () {\n function Gradient(cfg) {\n this.cfg = {};\n var el = null;\n var id = uniqueId('gradient_');\n if (cfg.toLowerCase()[0] === 'l') {\n el = createSVGElement('linearGradient');\n parseLineGradient(cfg, el);\n }\n else {\n el = createSVGElement('radialGradient');\n parseRadialGradient(cfg, el);\n }\n el.setAttribute('id', id);\n this.el = el;\n this.id = id;\n this.cfg = cfg;\n return this;\n }\n Gradient.prototype.match = function (type, attr) {\n return this.cfg === attr;\n };\n return Gradient;\n}());\nexport default Gradient;\n//# sourceMappingURL=gradient.js.map","/**\n * @fileoverview shadow\n * @author dengfuping_develop@163.com\n */\nimport { each, uniqueId } from '@antv/util';\nimport { createSVGElement } from '../util/dom';\nvar ATTR_MAP = {\n shadowColor: 'color',\n shadowOpacity: 'opacity',\n shadowBlur: 'blur',\n shadowOffsetX: 'dx',\n shadowOffsetY: 'dy',\n};\nvar SHADOW_DIMENSION = {\n x: '-40%',\n y: '-40%',\n width: '200%',\n height: '200%',\n};\nvar Shadow = /** @class */ (function () {\n function Shadow(cfg) {\n this.type = 'filter';\n this.cfg = {};\n this.type = 'filter';\n var el = createSVGElement('filter');\n // expand the filter region to fill in shadows\n each(SHADOW_DIMENSION, function (v, k) {\n el.setAttribute(k, v);\n });\n this.el = el;\n this.id = uniqueId('filter_');\n this.el.id = this.id;\n this.cfg = cfg;\n this._parseShadow(cfg, el);\n return this;\n }\n Shadow.prototype.match = function (type, cfg) {\n if (this.type !== type) {\n return false;\n }\n var flag = true;\n var config = this.cfg;\n each(Object.keys(config), function (attr) {\n if (config[attr] !== cfg[attr]) {\n flag = false;\n return false;\n }\n });\n return flag;\n };\n Shadow.prototype.update = function (name, value) {\n var config = this.cfg;\n config[ATTR_MAP[name]] = value;\n this._parseShadow(config, this.el);\n return this;\n };\n Shadow.prototype._parseShadow = function (config, el) {\n var child = \"<feDropShadow\\n dx=\\\"\" + (config.dx || 0) + \"\\\"\\n dy=\\\"\" + (config.dy || 0) + \"\\\"\\n stdDeviation=\\\"\" + (config.blur ? config.blur / 10 : 0) + \"\\\"\\n flood-color=\\\"\" + (config.color ? config.color : '#000') + \"\\\"\\n flood-opacity=\\\"\" + (config.opacity ? config.opacity : 1) + \"\\\"\\n />\";\n el.innerHTML = child;\n };\n return Shadow;\n}());\nexport default Shadow;\n//# sourceMappingURL=shadow.js.map","/**\n * @fileoverview arrow\n * @author dengfuping_develop@163.com\n */\nimport { isArray, uniqueId } from '@antv/util';\nimport { createSVGElement } from '../util/dom';\nvar Arrow = /** @class */ (function () {\n function Arrow(attrs, type) {\n this.cfg = {};\n var el = createSVGElement('marker');\n var id = uniqueId('marker_');\n el.setAttribute('id', id);\n var shape = createSVGElement('path');\n shape.setAttribute('stroke', attrs.stroke || 'none');\n shape.setAttribute('fill', attrs.fill || 'none');\n el.appendChild(shape);\n el.setAttribute('overflow', 'visible');\n el.setAttribute('orient', 'auto-start-reverse');\n this.el = el;\n this.child = shape;\n this.id = id;\n var cfg = attrs[type === 'marker-start' ? 'startArrow' : 'endArrow'];\n this.stroke = attrs.stroke || '#000';\n if (cfg === true) {\n this._setDefaultPath(type, shape);\n }\n else {\n this.cfg = cfg; // when arrow config exists\n this._setMarker(attrs.lineWidth, shape);\n }\n return this;\n }\n Arrow.prototype.match = function () {\n return false;\n };\n Arrow.prototype._setDefaultPath = function (type, el) {\n var parent = this.el;\n // 默认箭头的边长为 10,夹角为 60 度\n el.setAttribute('d', \"M0,0 L\" + 10 * Math.cos(Math.PI / 6) + \",5 L0,10\");\n parent.setAttribute('refX', \"\" + 10 * Math.cos(Math.PI / 6));\n parent.setAttribute('refY', \"\" + 5);\n };\n Arrow.prototype._setMarker = function (r, el) {\n var parent = this.el;\n var path = this.cfg.path;\n var d = this.cfg.d;\n if (isArray(path)) {\n path = path\n .map(function (segment) {\n return segment.join(' ');\n })\n .join('');\n }\n el.setAttribute('d', path);\n parent.appendChild(el);\n if (d) {\n parent.setAttribute('refX', \"\" + d / r);\n }\n };\n Arrow.prototype.update = function (fill) {\n var child = this.child;\n if (child.attr) {\n child.attr('fill', fill);\n }\n else {\n child.setAttribute('fill', fill);\n }\n };\n return Arrow;\n}());\nexport default Arrow;\n//# sourceMappingURL=arrow.js.map","/**\n * @fileoverview clip\n * @author dengfuping_develop@163.com\n */\nimport { uniqueId } from '@antv/util';\nimport { createSVGElement } from '../util/dom';\nvar Clip = /** @class */ (function () {\n function Clip(cfg) {\n this.type = 'clip';\n this.cfg = {};\n var el = createSVGElement('clipPath');\n this.el = el;\n this.id = uniqueId('clip_');\n el.id = this.id;\n var shapeEl = cfg.cfg.el;\n el.appendChild(shapeEl);\n this.cfg = cfg;\n return this;\n }\n Clip.prototype.match = function () {\n return false;\n };\n Clip.prototype.remove = function () {\n var el = this.el;\n el.parentNode.removeChild(el);\n };\n return Clip;\n}());\nexport default Clip;\n//# sourceMappingURL=clip.js.map","/**\n * @fileoverview pattern\n * @author dengfuping_develop@163.com\n */\nimport { uniqueId } from '@antv/util';\nimport { createSVGElement } from '../util/dom';\nvar regexPR = /^p\\s*\\(\\s*([axyn])\\s*\\)\\s*(.*)/i;\nvar Pattern = /** @class */ (function () {\n function Pattern(cfg) {\n this.cfg = {};\n var el = createSVGElement('pattern');\n el.setAttribute('patternUnits', 'userSpaceOnUse');\n var child = createSVGElement('image');\n el.appendChild(child);\n var id = uniqueId('pattern_');\n el.id = id;\n this.el = el;\n this.id = id;\n this.cfg = cfg;\n var arr = regexPR.exec(cfg);\n var source = arr[2];\n child.setAttribute('href', source);\n var img = new Image();\n if (!source.match(/^data:/i)) {\n img.crossOrigin = 'Anonymous';\n }\n img.src = source;\n function onload() {\n el.setAttribute('width', \"\" + img.width);\n el.setAttribute('height', \"\" + img.height);\n }\n if (img.complete) {\n onload();\n }\n else {\n img.onload = onload;\n // Fix onload() bug in IE9\n img.src = img.src;\n }\n return this;\n }\n Pattern.prototype.match = function (type, attr) {\n return this.cfg === attr;\n };\n return Pattern;\n}());\nexport default Pattern;\n//# sourceMappingURL=pattern.js.map","/**\n * @fileoverview defs\n * @author dengfuping_develop@163.com\n */\nimport { uniqueId } from '@antv/util';\nimport Gradient from './gradient';\nimport Shadow from './shadow';\nimport Arrow from './arrow';\nimport Clip from './clip';\nimport Pattern from './pattern';\nimport { createSVGElement } from '../util/dom';\nvar Defs = /** @class */ (function () {\n function Defs(canvas) {\n var el = createSVGElement('defs');\n var id = uniqueId('defs_');\n el.id = id;\n canvas.appendChild(el);\n this.children = [];\n this.defaultArrow = {};\n this.el = el;\n this.canvas = canvas;\n }\n Defs.prototype.find = function (type, attr) {\n var children = this.children;\n var result = null;\n for (var i = 0; i < children.length; i++) {\n if (children[i].match(type, attr)) {\n result = children[i].id;\n break;\n }\n }\n return result;\n };\n Defs.prototype.findById = function (id) {\n var children = this.children;\n var flag = null;\n for (var i = 0; i < children.length; i++) {\n if (children[i].id === id) {\n flag = children[i];\n break;\n }\n }\n return flag;\n };\n Defs.prototype.add = function (item) {\n this.children.push(item);\n item.canvas = this.canvas;\n item.parent = this;\n };\n Defs.prototype.getDefaultArrow = function (attrs, name) {\n var stroke = attrs.stroke || attrs.strokeStyle;\n if (this.defaultArrow[stroke]) {\n return this.defaultArrow[stroke].id;\n }\n var arrow = new Arrow(attrs, name);\n this.defaultArrow[stroke] = arrow;\n this.el.appendChild(arrow.el);\n this.add(arrow);\n return arrow.id;\n };\n Defs.prototype.addGradient = function (cfg) {\n var gradient = new Gradient(cfg);\n this.el.appendChild(gradient.el);\n this.add(gradient);\n return gradient.id;\n };\n Defs.prototype.addArrow = function (attrs, name) {\n var arrow = new Arrow(attrs, name);\n this.el.appendChild(arrow.el);\n this.add(arrow);\n return arrow.id;\n };\n Defs.prototype.addShadow = function (cfg) {\n var shadow = new Shadow(cfg);\n this.el.appendChild(shadow.el);\n this.add(shadow);\n return shadow.id;\n };\n Defs.prototype.addPattern = function (cfg) {\n var pattern = new Pattern(cfg);\n this.el.appendChild(pattern.el);\n this.add(pattern);\n return pattern.id;\n };\n Defs.prototype.addClip = function (cfg) {\n var clip = new Clip(cfg);\n this.el.appendChild(clip.el);\n this.add(clip);\n return clip.id;\n };\n return Defs;\n}());\nexport default Defs;\n//# sourceMappingURL=index.js.map","import { __extends } from \"tslib\";\nimport { AbstractCanvas } from '@antv/g-base';\nimport { getShape } from './util/hit';\nimport * as Shape from './shape';\nimport Group from './group';\nimport { each, getPixelRatio, requestAnimationFrame, clearAnimationFrame } from './util/util';\nimport { applyAttrsToContext, drawChildren, getMergedRegion, mergeView, checkRefresh, clearChanged } from './util/draw';\nvar Canvas = /** @class */ (function (_super) {\n __extends(Canvas, _super);\n function Canvas() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n Canvas.prototype.getDefaultCfg = function () {\n var cfg = _super.prototype.getDefaultCfg.call(this);\n // 设置渲染引擎为 canvas,只读属性\n cfg['renderer'] = 'canvas';\n // 是否自动绘制,不需要用户调用 draw 方法\n cfg['autoDraw'] = true;\n // 是否允许局部刷新图表\n cfg['localRefresh'] = true;\n cfg['refreshElements'] = [];\n // 是否在视图内自动裁剪\n cfg['clipView'] = true;\n // 是否使用快速拾取的方案,默认为 false,上层可以打开\n cfg['quickHit'] = false;\n return cfg;\n };\n /**\n * 一些方法调用会引起画布变化\n * @param {ChangeType} changeType 改变的类型\n */\n Canvas.prototype.onCanvasChange = function (changeType) {\n /**\n * 触发画布更新的三种 changeType\n * 1. attr: 修改画布的绘图属性\n * 2. sort: 画布排序,图形的层次会发生变化\n * 3. changeSize: 改变画布大小\n */\n if (changeType === 'attr' || changeType === 'sort' || changeType === 'changeSize') {\n this.set('refreshElements', [this]);\n this.draw();\n }\n };\n Canvas.prototype.getShapeBase = function () {\n return Shape;\n };\n Canvas.prototype.getGroupBase = function () {\n return Group;\n };\n /**\n * 获取屏幕像素比\n */\n Canvas.prototype.getPixelRatio = function () {\n var pixelRatio = this.get('pixelRatio') || getPixelRatio();\n // 不足 1 的取 1,超出 1 的取整\n return pixelRatio >= 1 ? Math.ceil(pixelRatio) : 1;\n };\n Canvas.prototype.getViewRange = function () {\n return {\n minX: 0,\n minY: 0,\n maxX: this.cfg.width,\n maxY: this.cfg.height,\n };\n };\n // 复写基类的方法生成标签\n Canvas.prototype.createDom = function () {\n var element = document.createElement('canvas');\n var context = element.getContext('2d');\n // 缓存 context 对象\n this.set('context', context);\n return element;\n };\n Canvas.prototype.setDOMSize = function (width, height) {\n _super.prototype.setDOMSize.call(this, width, height);\n var context = this.get('context');\n var el = this.get('el');\n var pixelRatio = this.getPixelRatio();\n el.width = pixelRatio * width;\n el.height = pixelRatio * height;\n // 设置 canvas 元素的宽度和高度,会重置缩放,因此 context.scale 需要在每次设置宽、高后调用\n if (pixelRatio > 1) {\n context.scale(pixelRatio, pixelRatio);\n }\n };\n // 复写基类方法\n Canvas.prototype.clear = function () {\n _super.prototype.clear.call(this);\n this._clearFrame(); // 需要清理掉延迟绘制的帧\n var context = this.get('context');\n var element = this.get('el');\n context.clearRect(0, 0, element.width, element.height);\n };\n Canvas.prototype.getShape = function (x, y) {\n var shape;\n if (this.get('quickHit')) {\n shape = getShape(this, x, y);\n }\n else {\n shape = _super.prototype.getShape.call(this, x, y, null);\n }\n return shape;\n };\n // 对绘制区域边缘取整,避免浮点数问题\n Canvas.prototype._getRefreshRegion = function () {\n var elements = this.get('refreshElements');\n var viewRegion = this.getViewRange();\n var region;\n // 如果是当前画布整体发生了变化,则直接重绘整个画布\n if (elements.length && elements[0] === this) {\n region = viewRegion;\n }\n else {\n region = getMergedRegion(elements);\n if (region) {\n region.minX = Math.floor(region.minX);\n region.minY = Math.floor(region.minY);\n region.maxX = Math.ceil(region.maxX);\n region.maxY = Math.ceil(region.maxY);\n region.maxY += 1; // 在很多环境下字体的高低会不一致,附加一像素,避免残影\n var clipView = this.get('clipView');\n // 自动裁剪不在 view 内的区域\n if (clipView) {\n region = mergeView(region, viewRegion);\n }\n }\n }\n return region;\n };\n /**\n * 刷新图形元素,这里仅仅是放入队列,下次绘制时进行绘制\n * @param {IElement} element 图形元素\n */\n Canvas.prototype.refreshElement = function (element) {\n var refreshElements = this.get('refreshElements');\n refreshElements.push(element);\n // if (this.get('autoDraw')) {\n // this._startDraw();\n // }\n };\n // 清理还在进行的绘制\n Canvas.prototype._clearFrame = function () {\n var drawFrame = this.get('drawFrame');\n if (drawFrame) {\n // 如果全部渲染时,存在局部渲染,则抛弃掉局部渲染\n clearAnimationFrame(drawFrame);\n this.set('drawFrame', null);\n this.set('refreshElements', []);\n }\n };\n // 手工调用绘制接口\n Canvas.prototype.draw = function () {\n var drawFrame = this.get('drawFrame');\n if (this.get('autoDraw') && drawFrame) {\n return;\n }\n this._startDraw();\n };\n // 绘制所有图形\n Canvas.prototype._drawAll = function () {\n var context = this.get('context');\n var element = this.get('el');\n var children = this.getChildren();\n context.clearRect(0, 0, element.width, element.height);\n applyAttrsToContext(context, this);\n drawChildren(context, children);\n // 对于 https://github.com/antvis/g/issues/422 的场景,全局渲染的模式下也会记录更新的元素队列,因此全局渲染完后也需要置空\n this.set('refreshElements', []);\n };\n // 绘制局部\n Canvas.prototype._drawRegion = function () {\n var context = this.get('context');\n var refreshElements = this.get('refreshElements');\n var children = this.getChildren();\n var region = this._getRefreshRegion();\n // 需要注意可能没有 region 的场景\n // 一般发生在设置了 localRefresh ,在没有图形发生变化的情况下,用户调用了 draw\n if (region) {\n // 清理指定区域\n context.clearRect(region.minX, region.minY, region.maxX - region.minX, region.maxY - region.minY);\n // 保存上下文,设置 clip\n context.save();\n context.beginPath();\n context.rect(region.minX, region.minY, region.maxX - region.minX, region.maxY - region.minY);\n context.clip();\n applyAttrsToContext(context, this);\n // 确认更新的元素,这个优化可以提升 10 倍左右的性能,10W 个带有 group 的节点,局部渲染会从 90ms 下降到 5-6 ms\n checkRefresh(this, children, region);\n // 绘制子元素\n drawChildren(context, children, region);\n context.restore();\n }\n else if (refreshElements.length) {\n // 防止发生改变的 elements 没有 region 的场景,这会发生在多个情况下\n // 1. 空的 group\n // 2. 所有 elements 没有在绘图区域\n // 3. group 下面的 elements 隐藏掉\n // 如果不进行清理 hasChanged 的状态会不正确\n clearChanged(refreshElements);\n }\n each(refreshElements, function (element) {\n if (element.get('hasChanged')) {\n // 在视窗外的 Group 元素会加入到更新队列里,但实际却没有执行 draw() 逻辑,也就没有清除 hasChanged 标记\n // 即已经重绘完、但 hasChanged 标记没有清除的元素,需要统一清除掉。主要是 Group 存在问题,具体原因待排查\n element.set('hasChanged', false);\n }\n });\n this.set('refreshElements', []);\n };\n // 触发绘制\n Canvas.prototype._startDraw = function () {\n var _this = this;\n var drawFrame = this.get('drawFrame');\n if (!drawFrame) {\n drawFrame = requestAnimationFrame(function () {\n if (_this.get('localRefresh')) {\n _this._drawRegion();\n }\n else {\n _this._drawAll();\n }\n _this.set('drawFrame', null);\n });\n this.set('drawFrame', drawFrame);\n }\n };\n Canvas.prototype.skipDraw = function () { };\n Canvas.prototype.removeDom = function () {\n var el = this.get('el');\n // 需要清理 canvas 画布内容,否则ios下 创建的canvas垃圾未回收,导致Total canvas memory use exceeds问题\n // 相关问题列表\n // https://stackoverflow.com/questions/52532614/total-canvas-memory-use-exceeds-the-maximum-limit-safari-12\n // https://github.com/openlayers/openlayers/issues/9291\n el.width = 0;\n el.height = 0;\n el.parentNode.removeChild(el);\n };\n return Canvas;\n}(AbstractCanvas));\nexport default Canvas;\n//# sourceMappingURL=canvas.js.map","import { vec3 } from 'gl-matrix';\n\nconst tmpVecA = vec3.create();\n\nexport class BoundingSphere {\n public center: vec3;\n public radius: number;\n\n constructor(center?: vec3, radius?: number) {\n this.center = center || vec3.create();\n this.radius = radius || 0.5;\n }\n\n public containsPoint(point: vec3) {\n vec3.sub(tmpVecA, point, this.center);\n return vec3.length(tmpVecA) < this.radius * this.radius;\n }\n\n public intersects(sphere: BoundingSphere) {\n vec3.sub(tmpVecA, sphere.center, this.center);\n const totalRadius = sphere.radius + this.radius;\n\n if (vec3.length(tmpVecA) <= totalRadius * totalRadius) {\n return true;\n }\n\n return false;\n }\n}\n","import { vec3 } from 'gl-matrix';\nimport { AABB } from './AABB';\nimport { BoundingSphere } from './BoundingSphere';\nimport { Plane } from './Plane';\n\nconst tmpVecA = vec3.create();\nconst tmpVecB = vec3.create();\nconst tmpVecC = vec3.create();\nconst tmpVecD = vec3.create();\nconst tmpVecE = vec3.create();\n\n/**\n * 包含求交方法:\n * * intersectsShape(Shape, intersection) 返回交点和求交结果\n * @see https://github.com/playcanvas/engine/blob/master/src/shape/bounding-box.js#L161\n * @see https://github.com/mrdoob/three.js/blob/dev/src/math/Ray.js\n */\nexport class Ray {\n public origin: vec3;\n public direction: vec3;\n\n constructor(origin: vec3, direction: vec3) {\n this.origin = origin || vec3.create();\n this.direction = direction || vec3.fromValues(0, 0, -1);\n }\n\n public intersectsAABB(aabb: AABB, intersection?: vec3) {\n return intersection\n ? this.intersectAABBWithIntersection(aabb, intersection)\n : this.intersectsAABBWithoutIntersection(aabb);\n }\n\n public intersectsSphere(sphere: BoundingSphere, intersection?: vec3) {\n const m = vec3.sub(tmpVecA, this.origin, sphere.center);\n vec3.normalize(tmpVecB, vec3.copy(tmpVecB, this.direction));\n const b = vec3.dot(m, tmpVecB);\n const c = vec3.dot(m, m) - sphere.radius * sphere.radius;\n\n // exit if ray's origin outside of sphere (c > 0) and ray pointing away from s (b > 0)\n if (c > 0 && b > 0) {\n return null;\n }\n\n const discr = b * b - c;\n // a negative discriminant corresponds to ray missing sphere\n if (discr < 0) {\n return false;\n }\n\n // ray intersects sphere, compute smallest t value of intersection\n const t = Math.abs(-b - Math.sqrt(discr));\n\n // if t is negative, ray started inside sphere so clamp t to zero\n if (intersection) {\n vec3.copy(intersection, this.direction);\n vec3.scaleAndAdd(intersection, this.origin, intersection, t);\n }\n\n return true;\n }\n\n public intersectsPlane(plane: Plane, intersection?: vec3) {\n const t =\n (plane.distance - vec3.dot(plane.normal, this.origin)) /\n vec3.dot(plane.normal, this.direction);\n const intersects = t >= 0;\n if (intersects && intersection) {\n vec3.scaleAndAdd(intersection, this.origin, this.direction, t);\n }\n\n return intersects;\n }\n\n /**\n * faster than implements like Three.js\n * @see https://github.com/playcanvas/engine/blob/master/src/shape/bounding-box.js#L161\n */\n private intersectsAABBWithoutIntersection(aabb: AABB) {\n const diff = tmpVecA;\n const cross = tmpVecB;\n const prod = tmpVecC;\n const absDiff = tmpVecD;\n const absDir = tmpVecE;\n const rayDir = this.direction;\n\n vec3.sub(diff, this.origin, aabb.center);\n vec3.set(absDiff, Math.abs(diff[0]), Math.abs(diff[1]), Math.abs(diff[2]));\n vec3.mul(prod, diff, rayDir);\n\n if (\n (absDiff[0] > aabb.halfExtents[0] && prod[0] >= 0) ||\n (absDiff[1] > aabb.halfExtents[1] && prod[1] >= 0) ||\n (absDiff[2] > aabb.halfExtents[2] && prod[2] >= 0)\n ) {\n return false;\n }\n\n vec3.set(\n absDir,\n Math.abs(rayDir[0]),\n Math.abs(rayDir[1]),\n Math.abs(rayDir[2]),\n );\n vec3.cross(cross, rayDir, diff);\n vec3.set(cross, Math.abs(cross[0]), Math.abs(cross[1]), Math.abs(cross[2]));\n\n return !(\n cross[0] >\n aabb.halfExtents[1] * absDir[2] + aabb.halfExtents[2] * absDir[1] ||\n cross[1] >\n aabb.halfExtents[0] * absDir[2] + aabb.halfExtents[2] * absDir[0] ||\n cross[2] >\n aabb.halfExtents[0] * absDir[1] + aabb.halfExtents[1] * absDir[0]\n );\n }\n\n private intersectAABBWithIntersection(aabb: AABB, intersection: vec3) {\n const tMin = vec3.copy(vec3.create(), aabb.getMin());\n vec3.sub(tMin, tMin, this.origin);\n const tMax = vec3.copy(vec3.create(), aabb.getMax());\n vec3.sub(tMax, tMax, this.origin);\n const dir = this.direction;\n\n // Ensure that we are not dividing it by zero\n if (dir[0] === 0) {\n tMin[0] = tMin[0] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n tMax[0] = tMax[0] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n } else {\n tMin[0] /= dir[0];\n tMax[0] /= dir[0];\n }\n if (dir[1] === 0) {\n tMin[1] = tMin[1] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n tMax[1] = tMax[1] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n } else {\n tMin[1] /= dir[1];\n tMax[1] /= dir[1];\n }\n if (dir[2] === 0) {\n tMin[2] = tMin[2] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n tMax[2] = tMax[2] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n } else {\n tMin[2] /= dir[2];\n tMax[2] /= dir[2];\n }\n\n const realMin = vec3.set(\n tmpVecC,\n Math.min(tMin[0], tMax[0]),\n Math.min(tMin[1], tMax[1]),\n Math.min(tMin[2], tMax[2]),\n );\n const realMax = vec3.set(\n tmpVecD,\n Math.max(tMin[0], tMax[0]),\n Math.max(tMin[1], tMax[1]),\n Math.max(tMin[2], tMax[2]),\n );\n\n const minMax = Math.min(Math.min(realMax[0], realMax[1]), realMax[2]);\n const maxMin = Math.max(Math.max(realMin[0], realMin[1]), realMin[2]);\n\n const intersects = minMax >= maxMin && maxMin >= 0;\n\n if (intersects) {\n vec3.copy(intersection, this.direction);\n vec3.scaleAndAdd(intersection, this.origin, intersection, maxMin);\n }\n\n return intersects;\n }\n}\n","import { isAllowCapture, multiplyVec2, invert } from '@antv/g-base';\nfunction invertFromMatrix(v, matrix) {\n if (matrix) {\n var invertMatrix = invert(matrix);\n return multiplyVec2(invertMatrix, v);\n }\n return v;\n}\nfunction getRefXY(element, x, y) {\n // @ts-ignore\n var totalMatrix = element.getTotalMatrix();\n if (totalMatrix) {\n var _a = invertFromMatrix([x, y, 1], totalMatrix), refX = _a[0], refY = _a[1];\n return [refX, refY];\n }\n return [x, y];\n}\n// 拾取前的检测,只有通过检测才能继续拾取\nfunction preTest(element, x, y) {\n // @ts-ignore\n if (element.isCanvas && element.isCanvas()) {\n return true;\n }\n // 不允许被拾取,则返回 null\n // @ts-ignore\n if (!isAllowCapture(element) || element.cfg.isInView === false) {\n return false;\n }\n if (element.cfg.clipShape) {\n // 如果存在 clip\n var _a = getRefXY(element, x, y), refX = _a[0], refY = _a[1];\n if (element.isClipped(refX, refY)) {\n return false;\n }\n }\n // @ts-ignore ,这个地方调用过于频繁\n var bbox = element.cfg.cacheCanvasBBox || element.getCanvasBBox();\n // 如果没有缓存 bbox,则说明不可见\n // 注释掉的这段可能会加速拾取,上面的语句改写成 const bbox = element.cfg.cacheCanvasBBox;\n // 这时候的拾取假设图形/分组在上一次绘制都在视窗内,但是上面已经判定了 isInView 所以意义不大\n // 现在还调用 element.getCanvasBBox(); 一个很大的原因是便于单元测试\n // if (!bbox) {\n // return false;\n // }\n if (!(x >= bbox.minX && x <= bbox.maxX && y >= bbox.minY && y <= bbox.maxY)) {\n return false;\n }\n return true;\n}\n// 这个方法复写了 g-base 的 getShape\nexport function getShape(container, x, y) {\n // 没有通过检测,则返回 null\n if (!preTest(container, x, y)) {\n return null;\n }\n var shape = null;\n var children = container.getChildren();\n var count = children.length;\n for (var i = count - 1; i >= 0; i--) {\n var child = children[i];\n if (child.isGroup()) {\n shape = getShape(child, x, y);\n }\n else if (preTest(child, x, y)) {\n var curShape = child;\n var _a = getRefXY(child, x, y), refX = _a[0], refY = _a[1];\n // @ts-ignore\n if (curShape.isInShape(refX, refY)) {\n shape = child;\n }\n }\n if (shape) {\n break;\n }\n }\n return shape;\n}\n//# sourceMappingURL=hit.js.map","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"getAdjMatrixAsync\", {\n enumerable: true,\n get: function get() {\n return _index.getAdjMatrixAsync;\n }\n});\nObject.defineProperty(exports, \"connectedComponentAsync\", {\n enumerable: true,\n get: function get() {\n return _index.connectedComponentAsync;\n }\n});\nObject.defineProperty(exports, \"getDegreeAsync\", {\n enumerable: true,\n get: function get() {\n return _index.getDegreeAsync;\n }\n});\nObject.defineProperty(exports, \"getInDegreeAsync\", {\n enumerable: true,\n get: function get() {\n return _index.getInDegreeAsync;\n }\n});\nObject.defineProperty(exports, \"getOutDegreeAsync\", {\n enumerable: true,\n get: function get() {\n return _index.getOutDegreeAsync;\n }\n});\nObject.defineProperty(exports, \"detectCycleAsync\", {\n enumerable: true,\n get: function get() {\n return _index.detectCycleAsync;\n }\n});\nObject.defineProperty(exports, \"detectAllCyclesAsync\", {\n enumerable: true,\n get: function get() {\n return _index.detectAllCyclesAsync;\n }\n});\nObject.defineProperty(exports, \"detectAllDirectedCycleAsync\", {\n enumerable: true,\n get: function get() {\n return _index.detectAllDirectedCycleAsync;\n }\n});\nObject.defineProperty(exports, \"detectAllUndirectedCycleAsync\", {\n enumerable: true,\n get: function get() {\n return _index.detectAllUndirectedCycleAsync;\n }\n});\nObject.defineProperty(exports, \"dijkstraAsync\", {\n enumerable: true,\n get: function get() {\n return _index.dijkstraAsync;\n }\n});\nObject.defineProperty(exports, \"findAllPathAsync\", {\n enumerable: true,\n get: function get() {\n return _index.findAllPathAsync;\n }\n});\nObject.defineProperty(exports, \"findShortestPathAsync\", {\n enumerable: true,\n get: function get() {\n return _index.findShortestPathAsync;\n }\n});\nObject.defineProperty(exports, \"floydWarshallAsync\", {\n enumerable: true,\n get: function get() {\n return _index.floydWarshallAsync;\n }\n});\nObject.defineProperty(exports, \"labelPropagationAsync\", {\n enumerable: true,\n get: function get() {\n return _index.labelPropagationAsync;\n }\n});\nObject.defineProperty(exports, \"louvainAsync\", {\n enumerable: true,\n get: function get() {\n return _index.louvainAsync;\n }\n});\nObject.defineProperty(exports, \"minimumSpanningTreeAsync\", {\n enumerable: true,\n get: function get() {\n return _index.minimumSpanningTreeAsync;\n }\n});\nObject.defineProperty(exports, \"pageRankAsync\", {\n enumerable: true,\n get: function get() {\n return _index.pageRankAsync;\n }\n});\nObject.defineProperty(exports, \"getNeighborsAsync\", {\n enumerable: true,\n get: function get() {\n return _index.getNeighborsAsync;\n }\n});\nObject.defineProperty(exports, \"GADDIAsync\", {\n enumerable: true,\n get: function get() {\n return _index.GADDIAsync;\n }\n});\nexports.default = exports.detectDirectedCycleAsync = void 0;\n\nvar _index = require(\"./workers/index\");\n\nvar detectDirectedCycleAsync = _index.detectCycleAsync;\nexports.detectDirectedCycleAsync = detectDirectedCycleAsync;\nvar _default = {\n getAdjMatrixAsync: _index.getAdjMatrixAsync,\n connectedComponentAsync: _index.connectedComponentAsync,\n getDegreeAsync: _index.getDegreeAsync,\n getInDegreeAsync: _index.getInDegreeAsync,\n getOutDegreeAsync: _index.getOutDegreeAsync,\n detectCycleAsync: _index.detectCycleAsync,\n detectDirectedCycleAsync: detectDirectedCycleAsync,\n detectAllCyclesAsync: _index.detectAllCyclesAsync,\n detectAllDirectedCycleAsync: _index.detectAllDirectedCycleAsync,\n detectAllUndirectedCycleAsync: _index.detectAllUndirectedCycleAsync,\n dijkstraAsync: _index.dijkstraAsync,\n findAllPathAsync: _index.findAllPathAsync,\n findShortestPathAsync: _index.findShortestPathAsync,\n floydWarshallAsync: _index.floydWarshallAsync,\n labelPropagationAsync: _index.labelPropagationAsync,\n louvainAsync: _index.louvainAsync,\n minimumSpanningTreeAsync: _index.minimumSpanningTreeAsync,\n pageRankAsync: _index.pageRankAsync,\n getNeighborsAsync: _index.getNeighborsAsync,\n GADDIAsync: _index.GADDIAsync\n};\nexports.default = _default;","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar decorators_1 = require(\"./decorators\");\nfunction getDecorators(container, doCache) {\n if (doCache === void 0) { doCache = true; }\n var lazyInject = decorators_1.makePropertyInjectDecorator(container, doCache);\n var lazyInjectNamed = decorators_1.makePropertyInjectNamedDecorator(container, doCache);\n var lazyInjectTagged = decorators_1.makePropertyInjectTaggedDecorator(container, doCache);\n var lazyMultiInject = decorators_1.makePropertyMultiInjectDecorator(container, doCache);\n return {\n lazyInject: lazyInject,\n lazyInjectNamed: lazyInjectNamed,\n lazyInjectTagged: lazyInjectTagged,\n lazyMultiInject: lazyMultiInject\n };\n}\nexports.default = getDecorators;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.GADDIAsync = exports.getNeighborsAsync = exports.pageRankAsync = exports.minimumSpanningTreeAsync = exports.louvainAsync = exports.labelPropagationAsync = exports.floydWarshallAsync = exports.findShortestPathAsync = exports.findAllPathAsync = exports.dijkstraAsync = exports.detectAllUndirectedCycleAsync = exports.detectAllDirectedCycleAsync = exports.detectAllCyclesAsync = exports.detectCycleAsync = exports.getOutDegreeAsync = exports.getInDegreeAsync = exports.getDegreeAsync = exports.connectedComponentAsync = exports.getAdjMatrixAsync = void 0;\n\nvar _createWorker = _interopRequireDefault(require(\"./createWorker\"));\n\nvar _constant = require(\"./constant\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * @param graphData 图数据\n * @param directed 是否为有向图\n */\nvar getAdjMatrixAsync = function getAdjMatrixAsync(graphData, directed) {\n return (0, _createWorker.default)(_constant.ALGORITHM.getAdjMatrix).apply(void 0, [graphData, directed]);\n};\n/**\n * 图的连通分量\n * @param graphData 图数据\n * @param directed 是否为有向图\n */\n\n\nexports.getAdjMatrixAsync = getAdjMatrixAsync;\n\nvar connectedComponentAsync = function connectedComponentAsync(graphData, directed) {\n return (0, _createWorker.default)(_constant.ALGORITHM.connectedComponent).apply(void 0, [graphData, directed]);\n};\n/**\n * 获取节点的度\n * @param graphData 图数据\n */\n\n\nexports.connectedComponentAsync = connectedComponentAsync;\n\nvar getDegreeAsync = function getDegreeAsync(graphData) {\n return (0, _createWorker.default)(_constant.ALGORITHM.getDegree)(graphData);\n};\n/**\n * 获取节点的入度\n * @param graphData 图数据\n * @param nodeId 节点ID\n */\n\n\nexports.getDegreeAsync = getDegreeAsync;\n\nvar getInDegreeAsync = function getInDegreeAsync(graphData, nodeId) {\n return (0, _createWorker.default)(_constant.ALGORITHM.getInDegree)(graphData, nodeId);\n};\n/**\n * 获取节点的出度\n * @param graphData 图数据\n * @param nodeId 节点ID\n */\n\n\nexports.getInDegreeAsync = getInDegreeAsync;\n\nvar getOutDegreeAsync = function getOutDegreeAsync(graphData, nodeId) {\n return (0, _createWorker.default)(_constant.ALGORITHM.getOutDegree)(graphData, nodeId);\n};\n/**\n * 检测图中的(有向) Cycle\n * @param graphData 图数据\n */\n\n\nexports.getOutDegreeAsync = getOutDegreeAsync;\n\nvar detectCycleAsync = function detectCycleAsync(graphData) {\n return (0, _createWorker.default)(_constant.ALGORITHM.detectCycle)(graphData);\n};\n/**\n * 检测图中的(无向) Cycle\n * @param graphData 图数据\n */\n\n\nexports.detectCycleAsync = detectCycleAsync;\n\nvar detectAllCyclesAsync = function detectAllCyclesAsync(graphData) {\n return (0, _createWorker.default)(_constant.ALGORITHM.detectAllCycles)(graphData);\n};\n/**\n * 检测图中的所有(有向) Cycle\n * @param graphData 图数据\n */\n\n\nexports.detectAllCyclesAsync = detectAllCyclesAsync;\n\nvar detectAllDirectedCycleAsync = function detectAllDirectedCycleAsync(graphData) {\n return (0, _createWorker.default)(_constant.ALGORITHM.detectAllDirectedCycle)(graphData);\n};\n/**\n * 检测图中的所有(无向) Cycle\n * @param graphData 图数据\n */\n\n\nexports.detectAllDirectedCycleAsync = detectAllDirectedCycleAsync;\n\nvar detectAllUndirectedCycleAsync = function detectAllUndirectedCycleAsync(graphData) {\n return (0, _createWorker.default)(_constant.ALGORITHM.detectAllUndirectedCycle)(graphData);\n};\n/**\n * Dijkstra's algorithm, See {@link https://en.wikipedia.org/wiki/Dijkstra%27s_algorithm}\n * @param graphData 图数据\n */\n\n\nexports.detectAllUndirectedCycleAsync = detectAllUndirectedCycleAsync;\n\nvar dijkstraAsync = function dijkstraAsync(graphData, source, directed, weightPropertyName) {\n return (0, _createWorker.default)(_constant.ALGORITHM.dijkstra).apply(void 0, [graphData, source, directed, weightPropertyName]);\n};\n/**\n * 查找两点之间的所有路径\n * @param graphData 图数据\n * @param start 路径起始点ID\n * @param end 路径终点ID\n * @param directed 是否为有向图\n */\n\n\nexports.dijkstraAsync = dijkstraAsync;\n\nvar findAllPathAsync = function findAllPathAsync(graphData, start, end, directed) {\n return (0, _createWorker.default)(_constant.ALGORITHM.findAllPath).apply(void 0, [graphData, start, end, directed]);\n};\n/**\n * 查找两点之间的所有路径\n * @param graphData 图数据\n * @param start 路径起始点ID\n * @param end 路径终点ID\n * @param directed 是否为有向图\n * @param weightPropertyName 边权重的属名称,若数据中没有权重,则默认每条边权重为 1\n */\n\n\nexports.findAllPathAsync = findAllPathAsync;\n\nvar findShortestPathAsync = function findShortestPathAsync(graphData, start, end, directed, weightPropertyName) {\n return (0, _createWorker.default)(_constant.ALGORITHM.findShortestPath).apply(void 0, [graphData, start, end, directed, weightPropertyName]);\n};\n/**\n * Floyd–Warshall algorithm, See {@link https://en.wikipedia.org/wiki/Floyd%E2%80%93Warshall_algorithm}\n * @param graphData 图数据\n * @param directed 是否为有向图\n */\n\n\nexports.findShortestPathAsync = findShortestPathAsync;\n\nvar floydWarshallAsync = function floydWarshallAsync(graphData, directed) {\n return (0, _createWorker.default)(_constant.ALGORITHM.floydWarshall).apply(void 0, [graphData, directed]);\n};\n/**\n * 标签传播算法\n * @param graphData 图数据\n * @param directed 是否有向图,默认为 false\n * @param weightPropertyName 权重的属性字段\n * @param maxIteration 最大迭代次数\n */\n\n\nexports.floydWarshallAsync = floydWarshallAsync;\n\nvar labelPropagationAsync = function labelPropagationAsync(graphData, directed, weightPropertyName, maxIteration) {\n if (maxIteration === void 0) {\n maxIteration = 1000;\n }\n\n return (0, _createWorker.default)(_constant.ALGORITHM.labelPropagation)(graphData, directed, weightPropertyName, maxIteration);\n};\n/**\n * 社区发现 louvain 算法\n * @param graphData 图数据\n * @param directed 是否有向图,默认为 false\n * @param weightPropertyName 权重的属性字段\n * @param threshold\n */\n\n\nexports.labelPropagationAsync = labelPropagationAsync;\n\nvar louvainAsync = function louvainAsync(graphData, directed, weightPropertyName, threshold) {\n return (0, _createWorker.default)(_constant.ALGORITHM.louvain)(graphData, directed, weightPropertyName, threshold);\n};\n/**\n * 最小生成树,See {@link https://en.wikipedia.org/wiki/Kruskal%27s_algorithm}\n * @param graph\n * @param weight 指定用于作为边权重的属性,若不指定,则认为所有边权重一致\n * @param algo 'prim' | 'kruskal' 算法类型\n * @return EdgeConfig[] 返回构成MST的边的数组\n */\n\n\nexports.louvainAsync = louvainAsync;\n\nvar minimumSpanningTreeAsync = function minimumSpanningTreeAsync(graphData, weight, algo) {\n return (0, _createWorker.default)(_constant.ALGORITHM.minimumSpanningTree).apply(void 0, [graphData, weight, algo]);\n};\n/**\n * PageRank https://en.wikipedia.org/wiki/PageRank\n * refer: https://github.com/anvaka/ngraph.pagerank\n * @param graph\n * @param epsilon 判断是否收敛的精度值,默认 0.000001\n * @param linkProb 阻尼系数(dumping factor),指任意时刻,用户访问到某节点后继续访问该节点链接的下一个节点的概率,经验值 0.85\n */\n\n\nexports.minimumSpanningTreeAsync = minimumSpanningTreeAsync;\n\nvar pageRankAsync = function pageRankAsync(graphData, epsilon, linkProb) {\n return (0, _createWorker.default)(_constant.ALGORITHM.pageRank).apply(void 0, [graphData, epsilon, linkProb]);\n};\n/**\n * 获取指定节点的所有邻居\n * @param nodeId 节点 ID\n * @param edges 图中的所有边数据\n * @param type 邻居类型\n */\n\n\nexports.pageRankAsync = pageRankAsync;\n\nvar getNeighborsAsync = function getNeighborsAsync(nodeId, edges, type) {\n return (0, _createWorker.default)(_constant.ALGORITHM.getNeighbors).apply(void 0, [nodeId, edges, type]);\n};\n/**\n * GADDI 图模式匹配\n * @param graphData 原图数据\n * @param pattern 搜索图(需要在原图上搜索的模式)数据\n * @param directed 是否计算有向图,默认 false\n * @param k 参数 k,表示 k-近邻\n * @param length 参数 length\n * @param nodeLabelProp 节点数据中代表节点标签(分类信息)的属性名。默认为 cluster\n * @param edgeLabelProp 边数据中代表边标签(分类信息)的属性名。默认为 cluster\n */\n\n\nexports.getNeighborsAsync = getNeighborsAsync;\n\nvar GADDIAsync = function GADDIAsync(graphData, pattern, directed, k, length, nodeLabelProp, edgeLabelProp) {\n if (directed === void 0) {\n directed = false;\n }\n\n if (nodeLabelProp === void 0) {\n nodeLabelProp = 'cluster';\n }\n\n if (edgeLabelProp === void 0) {\n edgeLabelProp = 'cluster';\n }\n\n return (0, _createWorker.default)(_constant.ALGORITHM.GADDI).apply(void 0, [graphData, pattern, directed, k, length, nodeLabelProp, edgeLabelProp]);\n};\n\nexports.GADDIAsync = GADDIAsync;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _constant = require(\"./constant\");\n\nvar _index = _interopRequireDefault(require(\"./index.worker\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * 创建一个在worker中运行的算法\n * @param type 算法类型\n */\nvar createWorker = function createWorker(type) {\n return function () {\n var data = [];\n\n for (var _i = 0; _i < arguments.length; _i++) {\n data[_i] = arguments[_i];\n }\n\n return new Promise(function (resolve, reject) {\n var worker = new _index.default();\n worker.postMessage({\n _algorithmType: type,\n data: data\n });\n\n worker.onmessage = function (event) {\n var _a = event.data,\n data = _a.data,\n _algorithmType = _a._algorithmType;\n\n if (_constant.MESSAGE.SUCCESS === _algorithmType) {\n resolve(data);\n } else {\n reject();\n }\n\n worker.terminate();\n };\n });\n };\n};\n\nvar _default = createWorker;\nexports.default = _default;","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar algorithm = _interopRequireWildcard(require(\"./algorithm\"));\n\nvar _constant = require(\"./constant\");\n\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\n\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\nvar ctx = typeof self !== 'undefined' ? self : {};\n\nctx.onmessage = function (event) {\n var _a = event.data,\n _algorithmType = _a._algorithmType,\n data = _a.data; // 如果发送内容没有私有类型。说明不是自己发的。不管\n // fix: https://github.com/antvis/algorithm/issues/25\n\n if (!_algorithmType) {\n return;\n }\n\n if (typeof algorithm[_algorithmType] === 'function') {\n var result = algorithm[_algorithmType].apply(algorithm, data);\n\n ctx.postMessage({\n _algorithmType: _constant.MESSAGE.SUCCESS,\n data: result\n });\n return;\n }\n\n ctx.postMessage({\n _algorithmType: _constant.MESSAGE.FAILURE\n });\n}; // https://stackoverflow.com/questions/50210416/webpack-worker-loader-fails-to-compile-typescript-worker\n\n\nvar _default = null;\nexports.default = _default;","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"getAdjMatrix\", {\n enumerable: true,\n get: function get() {\n return _adjacentMatrix.default;\n }\n});\nObject.defineProperty(exports, \"breadthFirstSearch\", {\n enumerable: true,\n get: function get() {\n return _bfs.default;\n }\n});\nObject.defineProperty(exports, \"connectedComponent\", {\n enumerable: true,\n get: function get() {\n return _connectedComponent.default;\n }\n});\nObject.defineProperty(exports, \"getDegree\", {\n enumerable: true,\n get: function get() {\n return _degree.default;\n }\n});\nObject.defineProperty(exports, \"getInDegree\", {\n enumerable: true,\n get: function get() {\n return _degree.getInDegree;\n }\n});\nObject.defineProperty(exports, \"getOutDegree\", {\n enumerable: true,\n get: function get() {\n return _degree.getOutDegree;\n }\n});\nObject.defineProperty(exports, \"detectCycle\", {\n enumerable: true,\n get: function get() {\n return _detectCycle.default;\n }\n});\nObject.defineProperty(exports, \"depthFirstSearch\", {\n enumerable: true,\n get: function get() {\n return _dfs.default;\n }\n});\nObject.defineProperty(exports, \"dijkstra\", {\n enumerable: true,\n get: function get() {\n return _dijkstra.default;\n }\n});\nObject.defineProperty(exports, \"findAllPath\", {\n enumerable: true,\n get: function get() {\n return _findPath.findAllPath;\n }\n});\nObject.defineProperty(exports, \"findShortestPath\", {\n enumerable: true,\n get: function get() {\n return _findPath.findShortestPath;\n }\n});\nObject.defineProperty(exports, \"floydWarshall\", {\n enumerable: true,\n get: function get() {\n return _floydWarshall.default;\n }\n});\nObject.defineProperty(exports, \"labelPropagation\", {\n enumerable: true,\n get: function get() {\n return _labelPropagation.default;\n }\n});\nObject.defineProperty(exports, \"louvain\", {\n enumerable: true,\n get: function get() {\n return _louvain.default;\n }\n});\nObject.defineProperty(exports, \"minimumSpanningTree\", {\n enumerable: true,\n get: function get() {\n return _mts.default;\n }\n});\nObject.defineProperty(exports, \"pageRank\", {\n enumerable: true,\n get: function get() {\n return _pageRank.default;\n }\n});\nObject.defineProperty(exports, \"GADDI\", {\n enumerable: true,\n get: function get() {\n return _gaddi.default;\n }\n});\nObject.defineProperty(exports, \"getNeighbors\", {\n enumerable: true,\n get: function get() {\n return _util.getNeighbors;\n }\n});\n\nvar _adjacentMatrix = _interopRequireDefault(require(\"../adjacent-matrix\"));\n\nvar _bfs = _interopRequireDefault(require(\"../bfs\"));\n\nvar _connectedComponent = _interopRequireDefault(require(\"../connected-component\"));\n\nvar _degree = _interopRequireWildcard(require(\"../degree\"));\n\nvar _detectCycle = _interopRequireDefault(require(\"../detect-cycle\"));\n\nvar _dfs = _interopRequireDefault(require(\"../dfs\"));\n\nvar _dijkstra = _interopRequireDefault(require(\"../dijkstra\"));\n\nvar _findPath = require(\"../find-path\");\n\nvar _floydWarshall = _interopRequireDefault(require(\"../floydWarshall\"));\n\nvar _labelPropagation = _interopRequireDefault(require(\"../label-propagation\"));\n\nvar _louvain = _interopRequireDefault(require(\"../louvain\"));\n\nvar _mts = _interopRequireDefault(require(\"../mts\"));\n\nvar _pageRank = _interopRequireDefault(require(\"../pageRank\"));\n\nvar _gaddi = _interopRequireDefault(require(\"../gaddi\"));\n\nvar _util = require(\"../util\");\n\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\n\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _queue = _interopRequireDefault(require(\"./structs/queue\"));\n\nvar _util = require(\"./util\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n *\n * @param callbacks\n * allowTraversal: 确定 BFS 是否从顶点沿着边遍历到其邻居,默认情况下,同一个节点只能遍历一次\n * enterNode: 当 BFS 访问某个节点时调用\n * leaveNode: 当 BFS 访问访问结束某个节点时调用\n */\nfunction initCallbacks(callbacks) {\n if (callbacks === void 0) {\n callbacks = {};\n }\n\n var initiatedCallback = callbacks;\n\n var stubCallback = function stubCallback() {};\n\n var allowTraversalCallback = function () {\n var seen = {};\n return function (_a) {\n var next = _a.next;\n var id = next;\n\n if (!seen[id]) {\n seen[id] = true;\n return true;\n }\n\n return false;\n };\n }();\n\n initiatedCallback.allowTraversal = callbacks.allowTraversal || allowTraversalCallback;\n initiatedCallback.enter = callbacks.enter || stubCallback;\n initiatedCallback.leave = callbacks.leave || stubCallback;\n return initiatedCallback;\n}\n/**\n * 广度优先遍历图\n * @param graph Graph 图实例\n * @param startNode 开始遍历的节点\n * @param originalCallbacks 回调\n */\n\n\nvar breadthFirstSearch = function breadthFirstSearch(graphData, startNodeId, originalCallbacks) {\n var callbacks = initCallbacks(originalCallbacks);\n var nodeQueue = new _queue.default();\n var _a = graphData.edges,\n edges = _a === void 0 ? [] : _a; // 初始化队列元素\n\n nodeQueue.enqueue(startNodeId);\n var previousNode = '';\n\n var _loop_1 = function _loop_1() {\n var currentNode = nodeQueue.dequeue();\n callbacks.enter({\n current: currentNode,\n previous: previousNode\n }); // 将所有邻居添加到队列中以便遍历\n\n (0, _util.getNeighbors)(currentNode, edges, 'target').forEach(function (nextNode) {\n if (callbacks.allowTraversal({\n previous: previousNode,\n current: currentNode,\n next: nextNode\n })) {\n nodeQueue.enqueue(nextNode);\n }\n });\n callbacks.leave({\n current: currentNode,\n previous: previousNode\n }); // 下一次循环之前存储当前顶点\n\n previousNode = currentNode;\n }; // 遍历队列中的所有顶点\n\n\n while (!nodeQueue.isEmpty()) {\n _loop_1();\n }\n};\n\nvar _default = breadthFirstSearch;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _linkedList = _interopRequireDefault(require(\"./linked-list\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar Queue = function () {\n function Queue() {\n this.linkedList = new _linkedList.default();\n }\n /**\n * 队列是否为空\n */\n\n\n Queue.prototype.isEmpty = function () {\n return !this.linkedList.head;\n };\n /**\n * 读取队列头部的元素, 不删除队列中的元素\n */\n\n\n Queue.prototype.peek = function () {\n if (!this.linkedList.head) {\n return null;\n }\n\n return this.linkedList.head.value;\n };\n /**\n * 在队列的尾部新增一个元素\n * @param value\n */\n\n\n Queue.prototype.enqueue = function (value) {\n this.linkedList.append(value);\n };\n /**\n * 删除队列中的头部元素,如果队列为空,则返回 null\n */\n\n\n Queue.prototype.dequeue = function () {\n var removeHead = this.linkedList.deleteHead();\n return removeHead ? removeHead.value : null;\n };\n\n Queue.prototype.toString = function (callback) {\n return this.linkedList.toString(callback);\n };\n\n return Queue;\n}();\n\nvar _default = Queue;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = exports.LinkedListNode = void 0;\n\nvar defaultComparator = function defaultComparator(a, b) {\n if (a === b) {\n return true;\n }\n\n return false;\n};\n/**\n * 链表中单个元素节点\n */\n\n\nvar LinkedListNode = function () {\n function LinkedListNode(value, next) {\n if (next === void 0) {\n next = null;\n }\n\n this.value = value;\n this.next = next;\n }\n\n LinkedListNode.prototype.toString = function (callback) {\n return callback ? callback(this.value) : \"\" + this.value;\n };\n\n return LinkedListNode;\n}();\n\nexports.LinkedListNode = LinkedListNode;\n\nvar LinkedList = function () {\n function LinkedList(comparator) {\n if (comparator === void 0) {\n comparator = defaultComparator;\n }\n\n this.head = null;\n this.tail = null;\n this.compare = comparator;\n }\n /**\n * 将指定元素添加到链表头部\n * @param value\n */\n\n\n LinkedList.prototype.prepend = function (value) {\n // 在头部添加一个节点\n var newNode = new LinkedListNode(value, this.head);\n this.head = newNode;\n\n if (!this.tail) {\n this.tail = newNode;\n }\n\n return this;\n };\n /**\n * 将指定元素添加到链表中\n * @param value\n */\n\n\n LinkedList.prototype.append = function (value) {\n var newNode = new LinkedListNode(value); // 如果不存在头节点,则将创建的新节点作为头节点\n\n if (!this.head) {\n this.head = newNode;\n this.tail = newNode;\n return this;\n } // 将新节点附加到链表末尾\n\n\n this.tail.next = newNode;\n this.tail = newNode;\n return this;\n };\n /**\n * 删除指定元素\n * @param value 要删除的元素\n */\n\n\n LinkedList.prototype.delete = function (value) {\n if (!this.head) {\n return null;\n }\n\n var deleteNode = null; // 如果删除的是头部元素,则将next作为头元素\n\n while (this.head && this.compare(this.head.value, value)) {\n deleteNode = this.head;\n this.head = this.head.next;\n }\n\n var currentNode = this.head;\n\n if (currentNode !== null) {\n // 如果删除了节点以后,将next节点前移\n while (currentNode.next) {\n if (this.compare(currentNode.next.value, value)) {\n deleteNode = currentNode.next;\n currentNode.next = currentNode.next.next;\n } else {\n currentNode = currentNode.next;\n }\n }\n } // 检查尾部节点是否被删除\n\n\n if (this.compare(this.tail.value, value)) {\n this.tail = currentNode;\n }\n\n return deleteNode;\n };\n /**\n * 查找指定的元素\n * @param param0\n */\n\n\n LinkedList.prototype.find = function (_a) {\n var _b = _a.value,\n value = _b === void 0 ? undefined : _b,\n _c = _a.callback,\n callback = _c === void 0 ? undefined : _c;\n\n if (!this.head) {\n return null;\n }\n\n var currentNode = this.head;\n\n while (currentNode) {\n // 如果指定了 callback,则按指定的 callback 查找\n if (callback && callback(currentNode.value)) {\n return currentNode;\n } // 如果指定了 value,则按 value 查找\n\n\n if (value !== undefined && this.compare(currentNode.value, value)) {\n return currentNode;\n }\n\n currentNode = currentNode.next;\n }\n\n return null;\n };\n /**\n * 删除尾部节点\n */\n\n\n LinkedList.prototype.deleteTail = function () {\n var deletedTail = this.tail;\n\n if (this.head === this.tail) {\n // 链表中只有一个元素\n this.head = null;\n this.tail = null;\n return deletedTail;\n }\n\n var currentNode = this.head;\n\n while (currentNode.next) {\n if (!currentNode.next.next) {\n currentNode.next = null;\n } else {\n currentNode = currentNode.next;\n }\n }\n\n this.tail = currentNode;\n return deletedTail;\n };\n /**\n * 删除头部节点\n */\n\n\n LinkedList.prototype.deleteHead = function () {\n if (!this.head) {\n return null;\n }\n\n var deletedHead = this.head;\n\n if (this.head.next) {\n this.head = this.head.next;\n } else {\n this.head = null;\n this.tail = null;\n }\n\n return deletedHead;\n };\n /**\n * 将一组元素转成链表中的节点\n * @param values 链表中的元素\n */\n\n\n LinkedList.prototype.fromArray = function (values) {\n var _this = this;\n\n values.forEach(function (value) {\n return _this.append(value);\n });\n return this;\n };\n /**\n * 将链表中的节点转成数组元素\n */\n\n\n LinkedList.prototype.toArray = function () {\n var nodes = [];\n var currentNode = this.head;\n\n while (currentNode) {\n nodes.push(currentNode);\n currentNode = currentNode.next;\n }\n\n return nodes;\n };\n /**\n * 反转链表中的元素节点\n */\n\n\n LinkedList.prototype.reverse = function () {\n var currentNode = this.head;\n var prevNode = null;\n var nextNode = null;\n\n while (currentNode) {\n // 存储下一个元素节点\n nextNode = currentNode.next; // 更改当前节点的下一个节点,以便将它连接到上一个节点上\n\n currentNode.next = prevNode; // 将 prevNode 和 currentNode 向前移动一步\n\n prevNode = currentNode;\n currentNode = nextNode;\n }\n\n this.tail = this.head;\n this.head = prevNode;\n };\n\n LinkedList.prototype.toString = function (callback) {\n if (callback === void 0) {\n callback = undefined;\n }\n\n return this.toArray().map(function (node) {\n return node.toString(callback);\n }).toString();\n };\n\n return LinkedList;\n}();\n\nvar _default = LinkedList;\nexports.default = _default;","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = exports.detectAllCycles = exports.detectAllDirectedCycle = exports.detectAllUndirectedCycle = void 0;\n\nvar _dfs = _interopRequireDefault(require(\"./dfs\"));\n\nvar _connectedComponent = _interopRequireWildcard(require(\"./connected-component\"));\n\nvar _util = require(\"./util\");\n\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\n\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar detectDirectedCycle = function detectDirectedCycle(graphData) {\n var cycle = null;\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a;\n var dfsParentMap = {}; // 所有没有被访问的节点集合\n\n var unvisitedSet = {}; // 正在被访问的节点集合\n\n var visitingSet = {}; // 所有已经被访问过的节点集合\n\n var visitedSet = {}; // 初始化 unvisitedSet\n\n nodes.forEach(function (node) {\n unvisitedSet[node.id] = node;\n });\n var callbacks = {\n enter: function enter(_a) {\n var currentNode = _a.current,\n previousNode = _a.previous;\n\n if (visitingSet[currentNode]) {\n // 如果当前节点正在访问中,则说明检测到环路了\n cycle = {};\n var currentCycleNode = currentNode;\n var previousCycleNode = previousNode;\n\n while (previousCycleNode !== currentNode) {\n cycle[currentCycleNode] = previousCycleNode;\n currentCycleNode = previousCycleNode;\n previousCycleNode = dfsParentMap[previousCycleNode];\n }\n\n cycle[currentCycleNode] = previousCycleNode;\n } else {\n // 如果不存在正在访问集合中,则将其放入正在访问集合,并从未访问集合中删除\n visitingSet[currentNode] = currentNode;\n delete unvisitedSet[currentNode]; // 更新 DSF parents 列表\n\n dfsParentMap[currentNode] = previousNode;\n }\n },\n leave: function leave(_a) {\n var currentNode = _a.current; // 如果所有的节点的子节点都已经访问过了,则从正在访问集合中删除掉,并将其移入到已访问集合中,\n // 同时也意味着当前节点的所有邻居节点都被访问过了\n\n visitedSet[currentNode] = currentNode;\n delete visitingSet[currentNode];\n },\n allowTraversal: function allowTraversal(_a) {\n var nextNode = _a.next; // 如果检测到环路则需要终止所有进一步的遍历,否则会导致无限循环遍历\n\n if (cycle) {\n return false;\n } // 仅允许遍历没有访问的节点,visitedSet 中的都已经访问过了\n\n\n return !visitedSet[nextNode];\n }\n }; // 开始遍历节点\n\n while (Object.keys(unvisitedSet).length) {\n // 从第一个节点开始进行 DFS 遍历\n var firsetUnVisitedKey = Object.keys(unvisitedSet)[0];\n (0, _dfs.default)(graphData, firsetUnVisitedKey, callbacks);\n }\n\n return cycle;\n};\n/**\n * 检测无向图中的所有Base cycles\n * refer: https://www.codeproject.com/Articles/1158232/Enumerating-All-Cycles-in-an-Undirected-Graph\n * @param graph\n * @param nodeIds 节点 ID 的数组\n * @param include 包含或排除指定的节点\n * @return [{[key: string]: INode}] 返回一组base cycles\n */\n\n\nvar detectAllUndirectedCycle = function detectAllUndirectedCycle(graphData, nodeIds, include) {\n var _a, _b;\n\n if (include === void 0) {\n include = true;\n }\n\n var allCycles = [];\n var components = (0, _connectedComponent.default)(graphData, false); // loop through all connected components\n\n for (var _i = 0, components_1 = components; _i < components_1.length; _i++) {\n var component = components_1[_i];\n if (!component.length) continue;\n var root = component[0];\n var rootId = root.id;\n var stack = [root];\n var parent_1 = (_a = {}, _a[rootId] = root, _a);\n var used = (_b = {}, _b[rootId] = new Set(), _b); // walk a spanning tree to find cycles\n\n while (stack.length > 0) {\n var curNode = stack.pop();\n var curNodeId = curNode.id;\n var neighbors = (0, _util.getNeighbors)(curNodeId, graphData.edges);\n\n var _loop_1 = function _loop_1(i) {\n var _c;\n\n var neighborId = neighbors[i];\n var neighbor = graphData.nodes.find(function (node) {\n return node.id === neighborId;\n }); // const neighborId = neighbor.get('id');\n\n if (neighborId === curNodeId) {\n // 自环\n allCycles.push((_c = {}, _c[neighborId] = curNode, _c));\n } else if (!(neighborId in used)) {\n // visit a new node\n parent_1[neighborId] = curNode;\n stack.push(neighbor);\n used[neighborId] = new Set([curNode]);\n } else if (!used[curNodeId].has(neighbor)) {\n // a cycle found\n var cycleValid = true;\n var cyclePath = [neighbor, curNode];\n var p = parent_1[curNodeId];\n\n while (used[neighborId].size && !used[neighborId].has(p)) {\n cyclePath.push(p);\n if (p === parent_1[p.id]) break;else p = parent_1[p.id];\n }\n\n cyclePath.push(p);\n\n if (nodeIds && include) {\n // 如果有指定包含的节点\n cycleValid = false;\n\n if (cyclePath.findIndex(function (node) {\n return nodeIds.indexOf(node.id) > -1;\n }) > -1) {\n cycleValid = true;\n }\n } else if (nodeIds && !include) {\n // 如果有指定不包含的节点\n if (cyclePath.findIndex(function (node) {\n return nodeIds.indexOf(node.id) > -1;\n }) > -1) {\n cycleValid = false;\n }\n } // 把 node list 形式转换为 cycle 的格式\n\n\n if (cycleValid) {\n var cycle = {};\n\n for (var index = 1; index < cyclePath.length; index += 1) {\n cycle[cyclePath[index - 1].id] = cyclePath[index];\n }\n\n if (cyclePath.length) {\n cycle[cyclePath[cyclePath.length - 1].id] = cyclePath[0];\n }\n\n allCycles.push(cycle);\n }\n\n used[neighborId].add(curNode);\n }\n };\n\n for (var i = 0; i < neighbors.length; i += 1) {\n _loop_1(i);\n }\n }\n }\n\n return allCycles;\n};\n/**\n * Johnson's algorithm, 时间复杂度 O((V + E)(C + 1))$ and space bounded by O(V + E)\n * refer: https://www.cs.tufts.edu/comp/150GA/homeworks/hw1/Johnson%2075.PDF\n * refer: https://networkx.github.io/documentation/stable/_modules/networkx/algorithms/cycles.html#simple_cycles\n * @param graph\n * @param nodeIds 节点 ID 的数组\n * @param include 包含或排除指定的节点\n * @return [{[key: string]: INode}] 返回所有的 simple cycles\n */\n\n\nexports.detectAllUndirectedCycle = detectAllUndirectedCycle;\n\nvar detectAllDirectedCycle = function detectAllDirectedCycle(graphData, nodeIds, include) {\n if (include === void 0) {\n include = true;\n }\n\n var path = []; // stack of nodes in current path\n\n var blocked = new Set();\n var B = []; // remember portions of the graph that yield no elementary circuit\n\n var allCycles = [];\n var idx2Node = {};\n var node2Idx = {}; // 辅助函数: unblock all blocked nodes\n\n var unblock = function unblock(thisNode) {\n var stack = [thisNode];\n\n while (stack.length > 0) {\n var node = stack.pop();\n\n if (blocked.has(node)) {\n blocked.delete(node);\n B[node.id].forEach(function (n) {\n stack.push(n);\n });\n B[node.id].clear();\n }\n }\n };\n\n var circuit = function circuit(node, start, adjList) {\n var closed = false; // whether a path is closed\n\n if (nodeIds && include === false && nodeIds.indexOf(node.id) > -1) return closed;\n path.push(node);\n blocked.add(node);\n var neighbors = adjList[node.id];\n\n for (var i = 0; i < neighbors.length; i += 1) {\n var neighbor = idx2Node[neighbors[i]];\n\n if (neighbor === start) {\n var cycle = {};\n\n for (var index = 1; index < path.length; index += 1) {\n cycle[path[index - 1].id] = path[index];\n }\n\n if (path.length) {\n cycle[path[path.length - 1].id] = path[0];\n }\n\n allCycles.push(cycle);\n closed = true;\n } else if (!blocked.has(neighbor)) {\n if (circuit(neighbor, start, adjList)) {\n closed = true;\n }\n }\n }\n\n if (closed) {\n unblock(node);\n } else {\n for (var i = 0; i < neighbors.length; i += 1) {\n var neighbor = idx2Node[neighbors[i]];\n\n if (!B[neighbor.id].has(node)) {\n B[neighbor.id].add(node);\n }\n }\n }\n\n path.pop();\n return closed;\n };\n\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a; // Johnson's algorithm 要求给节点赋顺序,先按节点在数组中的顺序\n\n for (var i = 0; i < nodes.length; i += 1) {\n var node = nodes[i];\n var nodeId = node.id;\n node2Idx[nodeId] = i;\n idx2Node[i] = node;\n } // 如果有指定包含的节点,则把指定节点排序在前,以便提早结束搜索\n\n\n if (nodeIds && include) {\n var _loop_2 = function _loop_2(i) {\n var nodeId = nodeIds[i];\n node2Idx[nodes[i].id] = node2Idx[nodeId];\n node2Idx[nodeId] = 0;\n idx2Node[0] = nodes.find(function (node) {\n return node.id === nodeId;\n });\n idx2Node[node2Idx[nodes[i].id]] = nodes[i];\n };\n\n for (var i = 0; i < nodeIds.length; i++) {\n _loop_2(i);\n }\n } // 返回 节点顺序 >= nodeOrder 的强连通分量的adjList\n\n\n var getMinComponentAdj = function getMinComponentAdj(components) {\n var _a;\n\n var minCompIdx;\n var minIdx = Infinity; // Find least component and the lowest node\n\n for (var i = 0; i < components.length; i += 1) {\n var comp = components[i];\n\n for (var j = 0; j < comp.length; j++) {\n var nodeIdx_1 = node2Idx[comp[j].id];\n\n if (nodeIdx_1 < minIdx) {\n minIdx = nodeIdx_1;\n minCompIdx = i;\n }\n }\n }\n\n var component = components[minCompIdx];\n var adjList = [];\n\n for (var i = 0; i < component.length; i += 1) {\n var node = component[i];\n adjList[node.id] = [];\n\n for (var _i = 0, _b = (0, _util.getNeighbors)(node.id, graphData.edges, 'target').filter(function (n) {\n return component.map(function (c) {\n return c.id;\n }).indexOf(n) > -1;\n }); _i < _b.length; _i++) {\n var neighbor = _b[_i]; // 对自环情况 (点连向自身) 特殊处理:记录自环,但不加入adjList\n\n if (neighbor === node.id && !(include === false && nodeIds.indexOf(node.id) > -1)) {\n allCycles.push((_a = {}, _a[node.id] = node, _a));\n } else {\n adjList[node.id].push(node2Idx[neighbor]);\n }\n }\n }\n\n return {\n component: component,\n adjList: adjList,\n minIdx: minIdx\n };\n };\n\n var nodeIdx = 0;\n\n while (nodeIdx < nodes.length) {\n var subgraphNodes = nodes.filter(function (n) {\n return node2Idx[n.id] >= nodeIdx;\n });\n var sccs = (0, _connectedComponent.detectStrongConnectComponents)({\n nodes: subgraphNodes,\n edges: graphData.edges\n }).filter(function (component) {\n return component.length > 1;\n });\n if (sccs.length === 0) break;\n var scc = getMinComponentAdj(sccs);\n var minIdx = scc.minIdx,\n adjList = scc.adjList,\n component = scc.component;\n\n if (component.length > 1) {\n component.forEach(function (node) {\n B[node.id] = new Set();\n });\n var startNode = idx2Node[minIdx]; // startNode 不在指定要包含的节点中,提前结束搜索\n\n if (nodeIds && include && nodeIds.indexOf(startNode.id) === -1) return allCycles;\n circuit(startNode, startNode, adjList);\n nodeIdx = minIdx + 1;\n } else {\n break;\n }\n }\n\n return allCycles;\n};\n/**\n * 查找图中所有满足要求的圈\n * @param graph\n * @param directed 是否为有向图\n * @param nodeIds 节点 ID 的数组,若不指定,则返回图中所有的圈\n * @param include 包含或排除指定的节点\n * @return [{[key: string]: Node}] 包含所有环的数组,每个环用一个Object表示,其中key为节点id,value为该节点在环中指向的下一个节点\n */\n\n\nexports.detectAllDirectedCycle = detectAllDirectedCycle;\n\nvar detectAllCycles = function detectAllCycles(graphData, directed, nodeIds, include) {\n if (include === void 0) {\n include = true;\n }\n\n if (directed) return detectAllDirectedCycle(graphData, nodeIds, include);\n return detectAllUndirectedCycle(graphData, nodeIds, include);\n};\n\nexports.detectAllCycles = detectAllCycles;\nvar _default = detectDirectedCycle;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.findAllPath = exports.findShortestPath = void 0;\n\nvar _dijkstra = _interopRequireDefault(require(\"./dijkstra\"));\n\nvar _util = require(\"./util\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar findShortestPath = function findShortestPath(graphData, start, end, directed, weightPropertyName) {\n var _a = (0, _dijkstra.default)(graphData, start, directed, weightPropertyName),\n length = _a.length,\n path = _a.path,\n allPath = _a.allPath;\n\n return {\n length: length[end],\n path: path[end],\n allPath: allPath[end]\n };\n};\n\nexports.findShortestPath = findShortestPath;\n\nvar findAllPath = function findAllPath(graphData, start, end, directed) {\n var _a;\n\n if (start === end) return [[start]];\n var _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var visited = [start];\n var isVisited = (_a = {}, _a[start] = true, _a);\n var stack = []; // 辅助栈,用于存储访问过的节点的邻居节点\n\n var allPath = [];\n var neighbors = directed ? (0, _util.getNeighbors)(start, edges, 'target') : (0, _util.getNeighbors)(start, edges);\n stack.push(neighbors);\n\n while (visited.length > 0 && stack.length > 0) {\n var children = stack[stack.length - 1];\n\n if (children.length) {\n var child = children.shift();\n\n if (child) {\n visited.push(child);\n isVisited[child] = true;\n neighbors = directed ? (0, _util.getNeighbors)(child, edges, 'target') : (0, _util.getNeighbors)(child, edges);\n stack.push(neighbors.filter(function (neighbor) {\n return !isVisited[neighbor];\n }));\n }\n } else {\n var node = visited.pop();\n isVisited[node] = false;\n stack.pop();\n continue;\n }\n\n if (visited[visited.length - 1] === end) {\n var path = visited.map(function (node) {\n return node;\n });\n allPath.push(path);\n var node = visited.pop();\n isVisited[node] = false;\n stack.pop();\n }\n }\n\n return allPath;\n};\n\nexports.findAllPath = findAllPath;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _adjacentMatrix = _interopRequireDefault(require(\"./adjacent-matrix\"));\n\nvar _util = require(\"./util\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * 标签传播算法\n * @param graphData 图数据\n * @param directed 是否有向图,默认为 false\n * @param weightPropertyName 权重的属性字段\n * @param maxIteration 最大迭代次数\n */\nvar labelPropagation = function labelPropagation(graphData, directed, weightPropertyName, maxIteration) {\n if (directed === void 0) {\n directed = false;\n }\n\n if (weightPropertyName === void 0) {\n weightPropertyName = 'weight';\n }\n\n if (maxIteration === void 0) {\n maxIteration = 1000;\n } // the origin data\n\n\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var clusters = {};\n var nodeMap = {}; // init the clusters and nodeMap\n\n nodes.forEach(function (node, i) {\n var cid = (0, _util.uniqueId)();\n node.clusterId = cid;\n clusters[cid] = {\n id: cid,\n nodes: [node]\n };\n nodeMap[node.id] = {\n node: node,\n idx: i\n };\n }); // the adjacent matrix of calNodes inside clusters\n\n var adjMatrix = (0, _adjacentMatrix.default)(graphData, directed); // the sum of each row in adjacent matrix\n\n var ks = [];\n /**\n * neighbor nodes (id for key and weight for value) for each node\n * neighbors = {\n * id(node_id): { id(neighbor_1_id): weight(weight of the edge), id(neighbor_2_id): weight(weight of the edge), ... },\n * ...\n * }\n */\n\n var neighbors = {};\n adjMatrix.forEach(function (row, i) {\n var k = 0;\n var iid = nodes[i].id;\n neighbors[iid] = {};\n row.forEach(function (entry, j) {\n if (!entry) return;\n k += entry;\n var jid = nodes[j].id;\n neighbors[iid][jid] = entry;\n });\n ks.push(k);\n });\n var iter = 0;\n\n var _loop_1 = function _loop_1() {\n var changed = false;\n nodes.forEach(function (node) {\n var neighborClusters = {};\n Object.keys(neighbors[node.id]).forEach(function (neighborId) {\n var neighborWeight = neighbors[node.id][neighborId];\n var neighborNode = nodeMap[neighborId].node;\n var neighborClusterId = neighborNode.clusterId;\n if (!neighborClusters[neighborClusterId]) neighborClusters[neighborClusterId] = 0;\n neighborClusters[neighborClusterId] += neighborWeight;\n }); // find the cluster with max weight\n\n var maxWeight = -Infinity;\n var bestClusterIds = [];\n Object.keys(neighborClusters).forEach(function (clusterId) {\n if (maxWeight < neighborClusters[clusterId]) {\n maxWeight = neighborClusters[clusterId];\n bestClusterIds = [clusterId];\n } else if (maxWeight === neighborClusters[clusterId]) {\n bestClusterIds.push(clusterId);\n }\n });\n if (bestClusterIds.length === 1 && bestClusterIds[0] === node.clusterId) return;\n var selfClusterIdx = bestClusterIds.indexOf(node.clusterId);\n if (selfClusterIdx >= 0) bestClusterIds.splice(selfClusterIdx, 1);\n\n if (bestClusterIds && bestClusterIds.length) {\n changed = true; // remove from origin cluster\n\n var selfCluster = clusters[node.clusterId];\n var nodeInSelfClusterIdx = selfCluster.nodes.indexOf(node);\n selfCluster.nodes.splice(nodeInSelfClusterIdx, 1); // move the node to the best cluster\n\n var randomIdx = Math.floor(Math.random() * bestClusterIds.length);\n var bestCluster = clusters[bestClusterIds[randomIdx]];\n bestCluster.nodes.push(node);\n node.clusterId = bestCluster.id;\n }\n });\n if (!changed) return \"break\";\n iter++;\n };\n\n while (iter < maxIteration) {\n var state_1 = _loop_1();\n\n if (state_1 === \"break\") break;\n } // delete the empty clusters\n\n\n Object.keys(clusters).forEach(function (clusterId) {\n var cluster = clusters[clusterId];\n\n if (!cluster.nodes || !cluster.nodes.length) {\n delete clusters[clusterId];\n }\n }); // get the cluster edges\n\n var clusterEdges = [];\n var clusterEdgeMap = {};\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var weight = edge[weightPropertyName] || 1;\n var sourceClusterId = nodeMap[source].node.clusterId;\n var targetClusterId = nodeMap[target].node.clusterId;\n var newEdgeId = sourceClusterId + \"---\" + targetClusterId;\n\n if (clusterEdgeMap[newEdgeId]) {\n clusterEdgeMap[newEdgeId].weight += weight;\n clusterEdgeMap[newEdgeId].count++;\n } else {\n var newEdge = {\n source: sourceClusterId,\n target: targetClusterId,\n weight: weight,\n count: 1\n };\n clusterEdgeMap[newEdgeId] = newEdge;\n clusterEdges.push(newEdge);\n }\n });\n var clustersArray = [];\n Object.keys(clusters).forEach(function (clusterId) {\n clustersArray.push(clusters[clusterId]);\n });\n return {\n clusters: clustersArray,\n clusterEdges: clusterEdges\n };\n};\n\nvar _default = labelPropagation;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _adjacentMatrix = _interopRequireDefault(require(\"./adjacent-matrix\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar getModularity = function getModularity(nodes, adjMatrix, ks, m) {\n var length = adjMatrix.length;\n var param = 2 * m;\n var modularity = 0;\n\n for (var i = 0; i < length; i++) {\n var clusteri = nodes[i].clusterId;\n\n for (var j = 0; j < length; j++) {\n var clusterj = nodes[j].clusterId;\n if (clusteri !== clusterj) continue;\n var entry = adjMatrix[i][j] || 0;\n var ki = ks[i] || 0;\n var kj = ks[j] || 0;\n modularity += entry - ki * kj / param;\n }\n }\n\n modularity *= 1 / param;\n return modularity;\n};\n/**\n * 社区发现 louvain 算法\n * @param graphData 图数据\n * @param directed 是否有向图,默认为 false\n * @param weightPropertyName 权重的属性字段\n * @param threshold\n */\n\n\nvar louvain = function louvain(graphData, directed, weightPropertyName, threshold) {\n if (directed === void 0) {\n directed = false;\n }\n\n if (weightPropertyName === void 0) {\n weightPropertyName = 'weight';\n }\n\n if (threshold === void 0) {\n threshold = 0.0001;\n } // the origin data\n\n\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var uniqueId = 1;\n var clusters = {};\n var nodeMap = {}; // init the clusters and nodeMap\n\n nodes.forEach(function (node, i) {\n var cid = String(uniqueId++);\n node.clusterId = cid;\n clusters[cid] = {\n id: cid,\n nodes: [node]\n };\n nodeMap[node.id] = {\n node: node,\n idx: i\n };\n }); // the adjacent matrix of calNodes inside clusters\n\n var adjMatrix = (0, _adjacentMatrix.default)(graphData, directed); // the sum of each row in adjacent matrix\n\n var ks = [];\n /**\n * neighbor nodes (id for key and weight for value) for each node\n * neighbors = {\n * id(node_id): { id(neighbor_1_id): weight(weight of the edge), id(neighbor_2_id): weight(weight of the edge), ... },\n * ...\n * }\n */\n\n var neighbors = {}; // the sum of the weights of all edges in the graph\n\n var m = 0;\n adjMatrix.forEach(function (row, i) {\n var k = 0;\n var iid = nodes[i].id;\n neighbors[iid] = {};\n row.forEach(function (entry, j) {\n if (!entry) return;\n k += entry;\n var jid = nodes[j].id;\n neighbors[iid][jid] = entry;\n m += entry;\n });\n ks.push(k);\n });\n m /= 2;\n var totalModularity = Infinity;\n var previousModularity = Infinity;\n var iter = 0;\n\n while (true) {\n // whether to terminate the iterations\n totalModularity = getModularity(nodes, adjMatrix, ks, m);\n if (Math.abs(totalModularity - previousModularity) < threshold || iter > 100) break;\n previousModularity = totalModularity;\n iter++; // pre compute some values for current clusters\n\n Object.keys(clusters).forEach(function (clusterId) {\n // sum of weights of edges to nodes in cluster\n var sumTot = 0;\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var sourceClusterId = nodeMap[source].node.clusterId;\n var targetClusterId = nodeMap[target].node.clusterId;\n\n if (sourceClusterId === clusterId && targetClusterId !== clusterId || targetClusterId === clusterId && sourceClusterId !== clusterId) {\n sumTot = sumTot + (edge[weightPropertyName] || 1);\n }\n });\n clusters[clusterId].sumTot = sumTot;\n }); // move the nodes to increase the delta modularity\n\n nodes.forEach(function (node, i) {\n var selfCluster = clusters[node.clusterId];\n var bestIncrease = 0;\n var bestCluster;\n var commonParam = ks[i] / (2 * m); // sum of weights of edges from node to nodes in cluster\n\n var kiin = 0;\n var selfClusterNodes = selfCluster.nodes;\n selfClusterNodes.forEach(function (scNode) {\n var scNodeIdx = nodeMap[scNode.id].idx;\n kiin += adjMatrix[i][scNodeIdx] || 0;\n }); // the modurarity for **removing** the node i from the origin cluster of node i\n\n var removeModurarity = kiin - selfCluster.sumTot * commonParam; // the neightbors of the node\n\n var nodeNeighborIds = neighbors[node.id];\n Object.keys(nodeNeighborIds).forEach(function (neighborNodeId) {\n var neighborNode = nodeMap[neighborNodeId].node;\n var neighborClusterId = neighborNode.clusterId; // if the node and the neighbor of node are in the same cluster, reutrn\n\n if (neighborClusterId === node.clusterId) return;\n var neighborCluster = clusters[neighborClusterId];\n var clusterNodes = neighborCluster.nodes; // if the cluster is empty, remove the cluster and return\n\n if (!clusterNodes || !clusterNodes.length) return; // sum of weights of edges from node to nodes in cluster\n\n var neighborClusterKiin = 0;\n clusterNodes.forEach(function (cNode) {\n var cNodeIdx = nodeMap[cNode.id].idx;\n neighborClusterKiin += adjMatrix[i][cNodeIdx] || 0;\n }); // modurarity for **adding** node i into this neighbor cluster\n\n var addModurarity = neighborClusterKiin - neighborCluster.sumTot * commonParam; // the increase modurarity is the difference between addModurarity and removeModurarity\n\n var increase = addModurarity - removeModurarity; // find the best cluster to move node i into\n\n if (increase > bestIncrease) {\n bestIncrease = increase;\n bestCluster = neighborCluster;\n }\n }); // if found a best cluster to move into\n\n if (bestIncrease > 0) {\n bestCluster.nodes.push(node);\n var previousClusterId_1 = node.clusterId;\n node.clusterId = bestCluster.id; // move the node to the best cluster\n\n var nodeInSelfClusterIdx = selfCluster.nodes.indexOf(node); // remove from origin cluster\n\n selfCluster.nodes.splice(nodeInSelfClusterIdx, 1); // update sumTot for clusters\n // sum of weights of edges to nodes in cluster\n\n var neighborClusterSumTot_1 = 0;\n var selfClusterSumTot_1 = 0;\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var sourceClusterId = nodeMap[source].node.clusterId;\n var targetClusterId = nodeMap[target].node.clusterId;\n\n if (sourceClusterId === bestCluster.id && targetClusterId !== bestCluster.id || targetClusterId === bestCluster.id && sourceClusterId !== bestCluster.id) {\n neighborClusterSumTot_1 = neighborClusterSumTot_1 + (edge[weightPropertyName] || 1);\n }\n\n if (sourceClusterId === previousClusterId_1 && targetClusterId !== previousClusterId_1 || targetClusterId === previousClusterId_1 && sourceClusterId !== previousClusterId_1) {\n selfClusterSumTot_1 = selfClusterSumTot_1 + (edge[weightPropertyName] || 1);\n }\n }); // the nodes of the clusters to move into and remove are changed, update their sumTot\n\n bestCluster.sumTot = neighborClusterSumTot_1;\n selfCluster.sumTot = selfClusterSumTot_1;\n }\n });\n } // delete the empty clusters, assign increasing clusterId\n\n\n var newClusterIdMap = {};\n var clusterIdx = 0;\n Object.keys(clusters).forEach(function (clusterId) {\n var cluster = clusters[clusterId];\n\n if (!cluster.nodes || !cluster.nodes.length) {\n delete clusters[clusterId];\n return;\n }\n\n var newId = String(clusterIdx + 1);\n\n if (newId === clusterId) {\n return;\n }\n\n cluster.id = newId;\n cluster.nodes = cluster.nodes.map(function (item) {\n return {\n id: item.id,\n clusterId: newId\n };\n });\n clusters[newId] = cluster;\n newClusterIdMap[clusterId] = newId;\n delete clusters[clusterId];\n clusterIdx++;\n });\n nodes.forEach(function (node) {\n if (node.clusterId && newClusterIdMap[node.clusterId]) node.clusterId = newClusterIdMap[node.clusterId];\n }); // get the cluster edges\n\n var clusterEdges = [];\n var clusterEdgeMap = {};\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var weight = edge[weightPropertyName] || 1;\n var sourceClusterId = nodeMap[source].node.clusterId;\n var targetClusterId = nodeMap[target].node.clusterId;\n var newEdgeId = sourceClusterId + \"---\" + targetClusterId;\n\n if (clusterEdgeMap[newEdgeId]) {\n clusterEdgeMap[newEdgeId].weight += weight;\n clusterEdgeMap[newEdgeId].count++;\n } else {\n var newEdge = {\n source: sourceClusterId,\n target: targetClusterId,\n weight: weight,\n count: 1\n };\n clusterEdgeMap[newEdgeId] = newEdge;\n clusterEdges.push(newEdge);\n }\n });\n var clustersArray = [];\n Object.keys(clusters).forEach(function (clusterId) {\n clustersArray.push(clusters[clusterId]);\n });\n return {\n clusters: clustersArray,\n clusterEdges: clusterEdges\n };\n};\n\nvar _default = louvain;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _unionFind = _interopRequireDefault(require(\"./structs/union-find\"));\n\nvar _binaryHeap = _interopRequireDefault(require(\"./structs/binary-heap\"));\n\nvar _util = require(\"./util\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Prim algorithm,use priority queue,复杂度 O(E+V*logV), V: 节点数量,E: 边的数量\n * refer: https://en.wikipedia.org/wiki/Prim%27s_algorithm\n * @param graph\n * @param weight 指定用于作为边权重的属性,若不指定,则认为所有边权重一致\n */\nvar primMST = function primMST(graphData, weight) {\n var selectedEdges = [];\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n\n if (nodes.length === 0) {\n return selectedEdges;\n } // 从nodes[0]开始\n\n\n var currNode = nodes[0];\n var visited = new Set();\n visited.add(currNode); // 用二叉堆维护距已加入节点的其他节点的边的权值\n\n var compareWeight = function compareWeight(a, b) {\n if (weight) {\n return a.weight - b.weight;\n }\n\n return 0;\n };\n\n var edgeQueue = new _binaryHeap.default(compareWeight);\n (0, _util.getEdgesByNodeId)(currNode.id, edges).forEach(function (edge) {\n edgeQueue.insert(edge);\n });\n\n while (!edgeQueue.isEmpty()) {\n // 选取与已加入的结点之间边权最小的结点\n var currEdge = edgeQueue.delMin();\n var source = currEdge.source;\n var target = currEdge.target;\n if (visited.has(source) && visited.has(target)) continue;\n selectedEdges.push(currEdge);\n\n if (!visited.has(source)) {\n visited.add(source);\n (0, _util.getEdgesByNodeId)(source, edges).forEach(function (edge) {\n edgeQueue.insert(edge);\n });\n }\n\n if (!visited.has(target)) {\n visited.add(target);\n (0, _util.getEdgesByNodeId)(target, edges).forEach(function (edge) {\n edgeQueue.insert(edge);\n });\n }\n }\n\n return selectedEdges;\n};\n/**\n * Kruskal algorithm,复杂度 O(E*logE), E: 边的数量\n * refer: https://en.wikipedia.org/wiki/Kruskal%27s_algorithm\n * @param graph\n * @param weight 指定用于作为边权重的属性,若不指定,则认为所有边权重一致\n * @return IEdge[] 返回构成MST的边的数组\n */\n\n\nvar kruskalMST = function kruskalMST(graphData, weight) {\n var selectedEdges = [];\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n\n if (nodes.length === 0) {\n return selectedEdges;\n } // 若指定weight,则将所有的边按权值从小到大排序\n\n\n var weightEdges = edges.map(function (edge) {\n return edge;\n });\n\n if (weight) {\n weightEdges.sort(function (a, b) {\n return a.weight - b.weight;\n });\n }\n\n var disjointSet = new _unionFind.default(nodes.map(function (n) {\n return n.id;\n })); // 从权值最小的边开始,如果这条边连接的两个节点于图G中不在同一个连通分量中,则添加这条边\n // 直到遍历完所有点或边\n\n while (weightEdges.length > 0) {\n var curEdge = weightEdges.shift();\n var source = curEdge.source;\n var target = curEdge.target;\n\n if (!disjointSet.connected(source, target)) {\n selectedEdges.push(curEdge);\n disjointSet.union(source, target);\n }\n }\n\n return selectedEdges;\n};\n/**\n * 最小生成树\n * refer: https://en.wikipedia.org/wiki/Kruskal%27s_algorithm\n * @param graph\n * @param weight 指定用于作为边权重的属性,若不指定,则认为所有边权重一致\n * @param algo 'prim' | 'kruskal' 算法类型\n * @return EdgeConfig[] 返回构成MST的边的数组\n */\n\n\nvar minimumSpanningTree = function minimumSpanningTree(graphData, weight, algo) {\n var algos = {\n prim: primMST,\n kruskal: kruskalMST\n };\n if (!algo) return kruskalMST(graphData, weight);\n return algos[algo](graphData, weight);\n};\n\nvar _default = minimumSpanningTree;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\n/**\n * 并查集 Disjoint set to support quick union\n */\nvar UnionFind = function () {\n function UnionFind(items) {\n this.count = items.length;\n this.parent = {};\n\n for (var _i = 0, items_1 = items; _i < items_1.length; _i++) {\n var i = items_1[_i];\n this.parent[i] = i;\n }\n } // find the root of the item\n\n\n UnionFind.prototype.find = function (item) {\n while (this.parent[item] !== item) {\n item = this.parent[item];\n }\n\n return item;\n };\n\n UnionFind.prototype.union = function (a, b) {\n var rootA = this.find(a);\n var rootB = this.find(b);\n if (rootA === rootB) return; // make the element with smaller root the parent\n\n if (rootA < rootB) {\n if (this.parent[b] !== b) this.union(this.parent[b], a);\n this.parent[b] = this.parent[a];\n } else {\n if (this.parent[a] !== a) this.union(this.parent[a], b);\n this.parent[a] = this.parent[b];\n }\n }; // whether a and b are connected, i.e. a and b have the same root\n\n\n UnionFind.prototype.connected = function (a, b) {\n return this.find(a) === this.find(b);\n };\n\n return UnionFind;\n}();\n\nvar _default = UnionFind;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar defaultCompare = function defaultCompare(a, b) {\n return a - b;\n};\n\nvar MinBinaryHeap = function () {\n function MinBinaryHeap(compareFn) {\n if (compareFn === void 0) {\n compareFn = defaultCompare;\n }\n\n this.compareFn = compareFn;\n this.list = [];\n }\n\n MinBinaryHeap.prototype.getLeft = function (index) {\n return 2 * index + 1;\n };\n\n MinBinaryHeap.prototype.getRight = function (index) {\n return 2 * index + 2;\n };\n\n MinBinaryHeap.prototype.getParent = function (index) {\n if (index === 0) {\n return null;\n }\n\n return Math.floor((index - 1) / 2);\n };\n\n MinBinaryHeap.prototype.isEmpty = function () {\n return this.list.length <= 0;\n };\n\n MinBinaryHeap.prototype.top = function () {\n return this.isEmpty() ? undefined : this.list[0];\n };\n\n MinBinaryHeap.prototype.delMin = function () {\n var top = this.top();\n var bottom = this.list.pop();\n\n if (this.list.length > 0) {\n this.list[0] = bottom;\n this.moveDown(0);\n }\n\n return top;\n };\n\n MinBinaryHeap.prototype.insert = function (value) {\n if (value !== null) {\n this.list.push(value);\n var index = this.list.length - 1;\n this.moveUp(index);\n return true;\n }\n\n return false;\n };\n\n MinBinaryHeap.prototype.moveUp = function (index) {\n var parent = this.getParent(index);\n\n while (index && index > 0 && this.compareFn(this.list[parent], this.list[index]) > 0) {\n // swap\n var tmp = this.list[parent];\n this.list[parent] = this.list[index];\n this.list[index] = tmp; // [this.list[index], this.list[parent]] = [this.list[parent], this.list[index]]\n\n index = parent;\n parent = this.getParent(index);\n }\n };\n\n MinBinaryHeap.prototype.moveDown = function (index) {\n var _a;\n\n var element = index;\n var left = this.getLeft(index);\n var right = this.getRight(index);\n var size = this.list.length;\n\n if (left !== null && left < size && this.compareFn(this.list[element], this.list[left]) > 0) {\n element = left;\n } else if (right !== null && right < size && this.compareFn(this.list[element], this.list[right]) > 0) {\n element = right;\n }\n\n if (index !== element) {\n _a = [this.list[element], this.list[index]], this.list[index] = _a[0], this.list[element] = _a[1];\n this.moveDown(element);\n }\n };\n\n return MinBinaryHeap;\n}();\n\nvar _default = MinBinaryHeap;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _degree = _interopRequireDefault(require(\"./degree\"));\n\nvar _util = require(\"./util\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * PageRank https://en.wikipedia.org/wiki/PageRank\n * refer: https://github.com/anvaka/ngraph.pagerank\n * @param graph\n * @param epsilon 判断是否收敛的精度值,默认 0.000001\n * @param linkProb 阻尼系数(dumping factor),指任意时刻,用户访问到某节点后继续访问该节点链接的下一个节点的概率,经验值 0.85\n */\nvar pageRank = function pageRank(graphData, epsilon, linkProb) {\n if (typeof epsilon !== 'number') epsilon = 0.000001;\n if (typeof linkProb !== 'number') linkProb = 0.85;\n var distance = 1;\n var leakedRank = 0;\n var maxIterations = 1000;\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var nodesCount = nodes.length;\n var currentRank;\n var curRanks = {};\n var prevRanks = {}; // Initialize pageranks 初始化\n\n for (var j = 0; j < nodesCount; ++j) {\n var node = nodes[j];\n var nodeId = node.id;\n curRanks[nodeId] = 1 / nodesCount;\n prevRanks[nodeId] = 1 / nodesCount;\n }\n\n var nodeDegree = (0, _degree.default)(graphData);\n\n while (maxIterations > 0 && distance > epsilon) {\n leakedRank = 0;\n\n for (var j = 0; j < nodesCount; ++j) {\n var node = nodes[j];\n var nodeId = node.id;\n currentRank = 0;\n\n if (nodeDegree[node.id].inDegree === 0) {\n curRanks[nodeId] = 0;\n } else {\n var neighbors = (0, _util.getNeighbors)(nodeId, edges, 'source');\n\n for (var i = 0; i < neighbors.length; ++i) {\n var neighbor = neighbors[i];\n var outDegree = nodeDegree[neighbor].outDegree;\n if (outDegree > 0) currentRank += prevRanks[neighbor] / outDegree;\n }\n\n curRanks[nodeId] = linkProb * currentRank;\n leakedRank += curRanks[nodeId];\n }\n }\n\n leakedRank = (1 - leakedRank) / nodesCount;\n distance = 0;\n\n for (var j = 0; j < nodesCount; ++j) {\n var node = nodes[j];\n var nodeId = node.id;\n currentRank = curRanks[nodeId] + leakedRank;\n distance += Math.abs(currentRank - prevRanks[nodeId]);\n prevRanks[nodeId] = currentRank;\n }\n\n maxIterations -= 1;\n }\n\n return prevRanks;\n};\n\nvar _default = pageRank;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _tslib = require(\"tslib\");\n\nvar _floydWarshall = _interopRequireDefault(require(\"./floydWarshall\"));\n\nvar _gSpan = _interopRequireDefault(require(\"./gSpan/gSpan\"));\n\nvar _dijkstra = _interopRequireDefault(require(\"./dijkstra\"));\n\nvar _util = require(\"./util\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * 为 graphData 中每个节点生成邻居单元数组\n * @param graphData\n * @param spm\n * @param nodeLabelProp\n * @param k k-近邻\n */\nvar findKNeighborUnits = function findKNeighborUnits(graphData, spm, nodeLabelProp, k) {\n if (nodeLabelProp === void 0) {\n nodeLabelProp = 'cluster';\n }\n\n if (k === void 0) {\n k = 2;\n }\n\n var units = [];\n var nodes = graphData.nodes;\n spm.forEach(function (row, i) {\n units.push(findKNeighborUnit(nodes, row, i, nodeLabelProp, k));\n });\n return units;\n};\n\nvar findKNeighborUnit = function findKNeighborUnit(nodes, row, i, nodeLabelProp, k) {\n var unitNodeIdxs = [i];\n var neighbors = [];\n var labelCountMap = {};\n row.forEach(function (v, j) {\n if (v <= k && i !== j) {\n unitNodeIdxs.push(j);\n neighbors.push(nodes[j]);\n var label = nodes[j][nodeLabelProp];\n if (!labelCountMap[label]) labelCountMap[label] = {\n count: 1,\n dists: [v]\n };else {\n labelCountMap[label].count++;\n labelCountMap[label].dists.push(v);\n }\n }\n }); // 将 labelCountMap 中的 dists 按照从小到大排序,方便后面使用\n\n Object.keys(labelCountMap).forEach(function (label) {\n labelCountMap[label].dists = labelCountMap[label].dists.sort(function (a, b) {\n return a - b;\n });\n });\n return {\n nodeIdx: i,\n nodeId: nodes[i].id,\n nodeIdxs: unitNodeIdxs,\n neighbors: neighbors,\n neighborNum: unitNodeIdxs.length - 1,\n nodeLabelCountMap: labelCountMap\n };\n};\n/**\n * 随机寻找点对,满足距离小于 k\n * @param k 参数 k,表示 k-近邻\n * @param nodeNum 参数 length\n * @param maxNodePairNum 寻找点对的数量不超过 maxNodePairNum\n * @param spm 最短路径矩阵\n */\n\n\nvar findNodePairsRandomly = function findNodePairsRandomly(k, nodeNum, maxNodePairNum, kNeighborUnits, spm) {\n // 每个节点需要随机找出的点对数\n var nodePairNumEachNode = Math.ceil(maxNodePairNum / nodeNum);\n var nodePairMap = {};\n var foundNodePairCount = 0; // 遍历节点,为每个节点随机找出 nodePairNumEachNode 个点对,满足距离小于 k。找到的点对数量超过 maxNodePairNum 或所有节点遍历结束时终止\n\n kNeighborUnits.forEach(function (unit, i) {\n // 若未达到 nodePairNumEachNode,或循环次数小于最大循环次数(2 * nodeNum),继续循环\n var nodePairForICount = 0;\n var outerLoopCount = 0;\n var neighbors = unit.nodeIdxs; // the first one is the center node\n\n var neighborNum = unit.neighborNum - 1;\n\n while (nodePairForICount < nodePairNumEachNode) {\n // 另一端节点在节点数组中的的 index\n var oidx = neighbors[1 + Math.floor(Math.random() * neighborNum)];\n var innerLoopCount = 0; // 若随机得到的另一端 idx 不符合条件,则继续 random。条件是不是同一个节点、这个点对没有被记录过、距离小于 k\n\n while (nodePairMap[i + \"-\" + oidx] || nodePairMap[oidx + \"-\" + i]) {\n oidx = Math.floor(Math.random() * nodeNum);\n innerLoopCount++;\n if (innerLoopCount > 2 * nodeNum) break; // 循环次数大于最大循环次数(2 * nodeNum)跳出循环,避免死循环\n }\n\n if (innerLoopCount < 2 * nodeNum) {\n // 未达到最大循环次数,说明找到了合适的另一端\n nodePairMap[i + \"-\" + oidx] = {\n start: i,\n end: oidx,\n distance: spm[i][oidx]\n };\n nodePairForICount++;\n foundNodePairCount++; // 如果当前找到的点对数量达到了上限,返回结果\n\n if (foundNodePairCount >= maxNodePairNum) return nodePairMap;\n }\n\n outerLoopCount++;\n if (outerLoopCount > 2 * nodeNum) break; // 循环次数大于最大循环次数(2 * nodeNum)跳出循环,避免死循环\n } // 这个节点没有找到足够 nodePairNumEachNode 的点对。更新 nodePairNumEachNode,让后续节点找更多的点对\n\n\n if (nodePairForICount < nodePairNumEachNode) {\n var gap = nodePairNumEachNode - nodePairForICount;\n nodePairNumEachNode = (nodePairNumEachNode + gap) / (nodeNum - i - 1);\n }\n });\n return nodePairMap;\n};\n/**\n * 计算所有 nodePairMap 中节点对的相交邻居诱导子图\n * @param nodePairMap 节点对 map,key 为 node1.id-node2.id,value 为 { startNodeIdx, endNodeIdx, distance }\n * @param neighborUnits 每个节点的邻居元数组\n * @param graphData 原图数据\n * @param edgeMap 边的 map,方便检索\n * @param cachedInducedGraphMap 缓存的结果,下次进入该函数将继续更新该缓存,若 key 在缓存中存在则不需要重复计算\n */\n\n\nvar getIntersectNeighborInducedGraph = function getIntersectNeighborInducedGraph(nodePairMap, neighborUnits, graphData, cachedInducedGraphMap) {\n var nodes = graphData.nodes;\n if (!cachedInducedGraphMap) cachedInducedGraphMap = {};\n Object.keys(nodePairMap).forEach(function (key) {\n var _a, _b;\n\n if (cachedInducedGraphMap && cachedInducedGraphMap[key]) return;\n cachedInducedGraphMap[key] = {\n nodes: [],\n edges: []\n };\n var pair = nodePairMap[key];\n var startUnitNodeIds = (_a = neighborUnits[pair.start]) === null || _a === void 0 ? void 0 : _a.nodeIdxs;\n var endUnitNodeIds = (_b = neighborUnits[pair.end]) === null || _b === void 0 ? void 0 : _b.nodeIdxs;\n if (!startUnitNodeIds || !endUnitNodeIds) return; // 不存在邻元,返回空图\n\n var endSet = new Set(endUnitNodeIds);\n var intersect = startUnitNodeIds.filter(function (x) {\n return endSet.has(x);\n }); // 可能会爆栈(在 1580 + 6 nodes full-connected 时出现)\n\n if (!intersect || !intersect.length) return; // 没有交集,返回空图\n\n var intersectIdMap = {};\n var intersectLength = intersect.length;\n\n for (var i = 0; i < intersectLength; i++) {\n var node = nodes[intersect[i]];\n cachedInducedGraphMap[key].nodes.push(node); // 将交集中的点加入诱导子图\n\n intersectIdMap[node.id] = true;\n } // 遍历所有边数据,如果边的两端都在交集中,将该边加入诱导子图\n\n\n graphData.edges.forEach(function (edge) {\n if (intersectIdMap[edge.source] && intersectIdMap[edge.target]) cachedInducedGraphMap[key].edges.push(edge);\n });\n });\n return cachedInducedGraphMap;\n};\n/**\n * 计算 strcutre 在 graph 上的匹配数量\n * @param graph 图数据\n * @param structure 目前支持只有两个节点一条边的最简单结构\n * @param nodeLabelProp 节点类型字段名\n * @param edgeLabelProp 边类型字段名\n */\n\n\nvar getMatchedCount = function getMatchedCount(graph, structure, nodeLabelProp, edgeLabelProp) {\n var nodeMap = {};\n graph.nodes.forEach(function (node) {\n nodeMap[node.id] = node;\n });\n var count = 0;\n graph.edges.forEach(function (e) {\n var sourceLabel = nodeMap[e.source][nodeLabelProp];\n var targetLabel = nodeMap[e.target][nodeLabelProp];\n var strNodeLabel1 = structure === null || structure === void 0 ? void 0 : structure.nodes[0][nodeLabelProp];\n var strNodeLabel2 = structure === null || structure === void 0 ? void 0 : structure.nodes[1][nodeLabelProp];\n var strEdgeLabel = structure === null || structure === void 0 ? void 0 : structure.edges[0][edgeLabelProp];\n if (e[edgeLabelProp] !== strEdgeLabel) return;\n\n if (sourceLabel === strNodeLabel1 && targetLabel === strNodeLabel2 || sourceLabel === strNodeLabel2 && targetLabel === strNodeLabel1) {\n count++;\n }\n });\n return count;\n};\n/**\n * structures 中寻找最具有代表性的一个。这个结构是使得 matchedCountMap 的分组方式类内间距最小,类间间距最大\n * @param matchedCountMap 每个 structure 分类后的各图匹配数量,格式 { [strcture.idx]: { [interInducedGraphKey]: count } }\n * @param structureNum strcuture 个数,与 matchedCountMap.length 对应\n * @param structures\n */\n\n\nvar findRepresentStructure = function findRepresentStructure(matchedCountMap, structureNum, structures) {\n var maxOffset = Infinity,\n representClusterType = 0;\n\n var _loop_1 = function _loop_1(i) {\n // 一种分组的 map,key 是 intGraph 的 key,value 是 structures[i] 的匹配个数\n var countMapI = matchedCountMap[i]; // 按照 value 为该组排序,生成 keys 的数组:\n\n var sortedGraphKeys = Object.keys(countMapI).sort(function (a, b) {\n return countMapI[a] - countMapI[b];\n }); // 共 100 个 graphKeys,将 graphKeys 按顺序分为 groupNum 组\n\n var groupNum = 10;\n var clusters = []; // 总共有 groupNum 个项\n\n sortedGraphKeys.forEach(function (key, j) {\n if (!clusters[j % groupNum]) clusters[j % groupNum] = {\n graphs: [],\n totalCount: 0,\n aveCount: 0\n };\n clusters[j % groupNum].graphs.push(key);\n clusters[j % groupNum].totalCount += countMapI[key];\n }); // 计算 cluster 与 cluster 之间的距离 innerDist,每个 cluster 内部的距离 intraDist\n\n var aveIntraDist = 0; // 该类的类内平均值\n\n var aveCounts = []; // 类内平均匹配数量,将用于计算类间距离\n\n clusters.forEach(function (graphsInCluster) {\n // 类内均值\n var aveCount = graphsInCluster.totalCount / graphsInCluster.graphs.length;\n graphsInCluster.aveCount = aveCount;\n aveCounts.push(aveCount); // 对于每类,计算类内间距平均值\n\n var aveIntraPerCluster = 0;\n var graphsNum = graphsInCluster.length;\n graphsInCluster.graphs.forEach(function (graphKey1, j) {\n var graph1Count = countMapI[graphKey1];\n graphsInCluster.graphs.forEach(function (graphKey2, k) {\n if (j === k) return;\n aveIntraPerCluster += Math.abs(graph1Count - countMapI[graphKey2]);\n });\n });\n aveIntraPerCluster /= graphsNum * (graphsNum - 1) / 2;\n aveIntraDist += aveIntraPerCluster;\n });\n aveIntraDist /= clusters.length; // 用类内均值计算类间距\n\n var aveInterDist = 0; // 类间间距平均值\n\n aveCounts.forEach(function (aveCount1, j) {\n aveCounts.forEach(function (aveCount2, k) {\n if (j === k) return;\n aveInterDist += Math.abs(aveCount1 - aveCount2);\n });\n aveInterDist /= aveCounts.length * (aveCounts.length - 1) / 2;\n }); // 寻找 (类间间距均值-类内间距均值) 最大的一种分组方式(对应的 structure 就是最终要找的唯一 DS(G))\n\n var offset = aveInterDist - aveIntraDist;\n\n if (maxOffset < offset) {\n maxOffset = offset;\n representClusterType = i;\n }\n };\n\n for (var i = 0; i < structureNum; i++) {\n _loop_1(i);\n }\n\n return {\n structure: structures[representClusterType],\n structureCountMap: matchedCountMap[representClusterType]\n };\n};\n\nvar getNodeMaps = function getNodeMaps(nodes, nodeLabelProp) {\n var nodeMap = {},\n nodeLabelMap = {};\n nodes.forEach(function (node, i) {\n nodeMap[node.id] = {\n idx: i,\n node: node,\n degree: 0,\n inDegree: 0,\n outDegree: 0\n };\n var label = node[nodeLabelProp];\n if (!nodeLabelMap[label]) nodeLabelMap[label] = [];\n nodeLabelMap[label].push(node);\n });\n return {\n nodeMap: nodeMap,\n nodeLabelMap: nodeLabelMap\n };\n};\n\nvar getEdgeMaps = function getEdgeMaps(edges, edgeLabelProp, nodeMap) {\n var edgeMap = {},\n edgeLabelMap = {};\n edges.forEach(function (edge, i) {\n edgeMap[\"\" + _util.uniqueId] = {\n idx: i,\n edge: edge\n };\n var label = edge[edgeLabelProp];\n if (!edgeLabelMap[label]) edgeLabelMap[label] = [];\n edgeLabelMap[label].push(edge);\n var sourceNode = nodeMap[edge.source];\n\n if (sourceNode) {\n sourceNode.degree++;\n sourceNode.outDegree++;\n }\n\n var targetNode = nodeMap[edge.target];\n\n if (targetNode) {\n targetNode.degree++;\n targetNode.inDegree++;\n }\n });\n return {\n edgeMap: edgeMap,\n edgeLabelMap: edgeLabelMap\n };\n};\n/**\n * 输出最短路径的 map,key 为 sourceNode.id-targetNode.id,value 为这两个节点的最短路径长度\n * @param nodes\n * @param spm\n * @param directed\n */\n\n\nvar getSpmMap = function getSpmMap(nodes, spm, directed) {\n var length = spm.length;\n var map = {};\n spm.forEach(function (row, i) {\n var start = directed ? 0 : i + 1;\n var iId = nodes[i].id;\n\n for (var j = start; j < length; j++) {\n if (i === j) continue;\n var jId = nodes[j].id;\n var dist = row[j];\n map[iId + \"-\" + jId] = dist;\n if (!directed) map[jId + \"-\" + iId] = dist;\n }\n });\n return map;\n};\n/**\n * 计算一对节点(node1,node2)的 NDS 距离\n * @param graph 原图数据\n * @param node1\n * @param node2\n */\n\n\nvar getNDSDist = function getNDSDist(graph, node1, node2, nodeMap, spDist, kNeighborUnits, structure, nodeLabelProp, edgeLabelProp, cachedNDSMap, cachedInterInducedGraph) {\n var _a;\n\n var key = node1.id + \"-\" + node2.id;\n if (cachedNDSMap && cachedNDSMap[key]) return cachedNDSMap[key];\n var interInducedGraph = cachedInterInducedGraph ? cachedInterInducedGraph[key] : undefined; // 若没有缓存相交邻居诱导子图,计算\n\n if (!interInducedGraph) {\n var pairMap = (_a = {}, _a[key] = {\n start: nodeMap[node1.id].idx,\n end: nodeMap[node2.id].idx,\n distance: spDist\n }, _a);\n cachedInterInducedGraph = getIntersectNeighborInducedGraph(pairMap, kNeighborUnits, graph, cachedInterInducedGraph);\n interInducedGraph = cachedInterInducedGraph[key];\n }\n\n return getMatchedCount(interInducedGraph, structure, nodeLabelProp, edgeLabelProp);\n};\n/**\n * 计算 pattern 上绩点的度数并存储到 minPatternNodeLabelDegreeMap\n */\n\n\nvar stashPatternNodeLabelDegreeMap = function stashPatternNodeLabelDegreeMap(minPatternNodeLabelDegreeMap, neighborLabel, patternNodeMap, patternNodeLabelMap) {\n var _a, _b, _c;\n\n var minPatternNodeLabelDegree = (_a = minPatternNodeLabelDegreeMap[neighborLabel]) === null || _a === void 0 ? void 0 : _a.degree;\n var minPatternNodeLabelInDegree = (_b = minPatternNodeLabelDegreeMap[neighborLabel]) === null || _b === void 0 ? void 0 : _b.inDegree;\n var minPatternNodeLabelOutDegree = (_c = minPatternNodeLabelDegreeMap[neighborLabel]) === null || _c === void 0 ? void 0 : _c.outDegree;\n\n if (minPatternNodeLabelDegreeMap[neighborLabel] === undefined) {\n minPatternNodeLabelDegree = Infinity;\n minPatternNodeLabelInDegree = Infinity;\n minPatternNodeLabelOutDegree = Infinity;\n patternNodeLabelMap[neighborLabel].forEach(function (patternNodeWithLabel) {\n var patternNodeDegree = patternNodeMap[patternNodeWithLabel.id].degree;\n if (minPatternNodeLabelDegree > patternNodeDegree) minPatternNodeLabelDegree = patternNodeDegree;\n var patternNodeInDegree = patternNodeMap[patternNodeWithLabel.id].inDegree;\n if (minPatternNodeLabelInDegree > patternNodeInDegree) minPatternNodeLabelInDegree = patternNodeInDegree;\n var patternNodeOutDegree = patternNodeMap[patternNodeWithLabel.id].outDegree;\n if (minPatternNodeLabelOutDegree > patternNodeOutDegree) minPatternNodeLabelOutDegree = patternNodeOutDegree;\n });\n minPatternNodeLabelDegreeMap[neighborLabel] = {\n degree: minPatternNodeLabelDegree,\n inDegree: minPatternNodeLabelInDegree,\n outDegree: minPatternNodeLabelOutDegree\n };\n }\n\n return {\n minPatternNodeLabelDegree: minPatternNodeLabelDegree,\n minPatternNodeLabelInDegree: minPatternNodeLabelInDegree,\n minPatternNodeLabelOutDegree: minPatternNodeLabelOutDegree\n };\n};\n/**\n * GADDI 模式匹配\n * @param graphData 原图数据\n * @param pattern 搜索图(需要在原图上搜索的模式)数据\n * @param directed 是否计算有向图,默认 false\n * @param k 参数 k,表示 k-近邻\n * @param length 参数 length\n * @param nodeLabelProp 节点数据中代表节点标签(分类信息)的属性名。默认为 cluster\n * @param edgeLabelProp 边数据中代表边标签(分类信息)的属性名。默认为 cluster\n */\n\n\nvar GADDI = function GADDI(graphData, pattern, directed, k, length, nodeLabelProp, edgeLabelProp) {\n if (directed === void 0) {\n directed = false;\n }\n\n if (nodeLabelProp === void 0) {\n nodeLabelProp = 'cluster';\n }\n\n if (edgeLabelProp === void 0) {\n edgeLabelProp = 'cluster';\n }\n\n if (!graphData || !graphData.nodes) return; // 分为三步:\n // 0. 预计算:节点/边数,邻接矩阵、最短路径矩阵\n // 1. 处理原图 graphData。再分为 1~5 小步\n // 2. 匹配\n // console.log(\"----- stage-pre: preprocessing -------\");\n // -------- 第零步,预计算:节点/边数,邻接矩阵、最短路径矩阵-------\n\n var nodeNum = graphData.nodes.length;\n if (!nodeNum) return; // console.log(\"----- stage-pre.1: calc shortest path matrix for graph -------\");\n\n var spm = (0, _floydWarshall.default)(graphData, directed); // console.log(\n // \"----- stage-pre.2: calc shortest path matrix for pattern -------\"\n // );\n\n var patternSpm = (0, _floydWarshall.default)(pattern, directed); // console.log(\n // \"----- stage-pre.3: calc shortest path matrix map for graph -------\"\n // );\n\n var spmMap = getSpmMap(graphData.nodes, spm, directed); // console.log(\n // \"----- stage-pre.4: calc shortest path matrix map for pattern -------\"\n // );\n\n var patternSpmMap = getSpmMap(pattern.nodes, patternSpm, directed); // console.log(\"----- stage-pre.5: establish maps -------\");\n // 节点的 map,以 id 为 id 映射,方便后续快速检索\n\n var _a = getNodeMaps(graphData.nodes, nodeLabelProp),\n nodeMap = _a.nodeMap,\n nodeLabelMap = _a.nodeLabelMap;\n\n var _b = getNodeMaps(pattern.nodes, nodeLabelProp),\n patternNodeMap = _b.nodeMap,\n patternNodeLabelMap = _b.nodeLabelMap; // 计算节点度数\n\n\n getEdgeMaps(graphData.edges, edgeLabelProp, nodeMap);\n var patternEdgeLabelMap = getEdgeMaps(pattern.edges, edgeLabelProp, patternNodeMap).edgeLabelMap; // 若未指定 length,自动计算 pattern 半径(最短路径最大值)\n\n if (!length) length = Math.max.apply(Math, (0, _tslib.__spreadArray)((0, _tslib.__spreadArray)([], patternSpm[0]), [2]));\n if (!k) k = length; // console.log(\"params\", directed, length, k);\n // console.log(\"----- stage-pre.6: calc k neighbor units -------\");\n // 计算每个节点的 k 邻元集合\n\n var kNeighborUnits = findKNeighborUnits(graphData, spm, nodeLabelProp, k);\n var patternKNeighborUnits = findKNeighborUnits(pattern, patternSpm, nodeLabelProp, k); // console.log(\n // \"----- stage0: going to processing graph and find intersect neighbor induced graphs -------\"\n // );\n // console.log(\"----- stage0.1: going to select random node pairs -------\");\n // -------- 第一步,处理原图 graphData-------\n // 1.1. 随机选择最多 100 个点对,满足距离小于 Length 和 k\n // 当 graphData 少于 20 个节点,则不能找出 100 个点对,只找出不多于 n(n-1)/2 个点对\n\n var maxNodePairNum = Math.min(100, nodeNum * (nodeNum - 1) / 2);\n var nodePairsMap = findNodePairsRandomly(k, nodeNum, maxNodePairNum, patternKNeighborUnits, spm); // console.log(\n // \"----- stage0.2: going to calculate intersect neighbor induced graphs -------\"\n // );\n // 1.2. 生成上面节点对的相应相交邻居诱导子图。格式为 {'beginNodeIdx-endNodeIdx': {nodes: [], edges: []}}\n\n var intGMap = getIntersectNeighborInducedGraph(nodePairsMap, kNeighborUnits, graphData); // 1.3. 使用 gSpan 算法(frequent graph mining)计算 ISIntG 的前 10 个频率最高的子结构(3-4条边)\n\n var top = 10,\n minSupport = 1,\n minNodeNum = 1,\n maxNodeNum = 4;\n var params = {\n graphs: intGMap,\n nodeLabelProp: nodeLabelProp,\n edgeLabelProp: edgeLabelProp,\n minSupport: minSupport,\n minNodeNum: minNodeNum,\n maxNodeNum: maxNodeNum,\n directed: directed\n }; // console.log(\n // \"----- stage1: (gSpan) going to find frequent structure dsG -------\"\n // );\n // console.log(\"----- stage1.1: going to run gSpan -------\");\n // 暂时假设生成的 sub structure 都只有一条边\n\n var freStructures = (0, _gSpan.default)(params).slice(0, top); // structureNum 可能小于 top\n\n var structureNum = freStructures.length; // 1.4. 计算上述 10 个子结构在 intGMap 中每个诱导子图的匹配个数\n\n var matchedCountMap = [];\n freStructures.forEach(function (structure, i) {\n matchedCountMap[i] = {};\n Object.keys(intGMap).forEach(function (key) {\n var graph = intGMap[key];\n var subStructureCount = getMatchedCount(graph, structure, nodeLabelProp, edgeLabelProp);\n matchedCountMap[i][key] = subStructureCount;\n });\n }); // console.log(\n // \"----- stage1.1: going to find the most represent strucutre -------\"\n // );\n // 1.5. 对于每个子结构,根据匹配个数为 intGMap 中的诱导子图分组,生成 structureNum 种分组\n // 计算每种分组的类间距和类内间距,找到类间距最大、类内间距最小的一种分组,这种分组对应的子结构被选为唯一代表性子结构 DS(G)\n\n var _c = findRepresentStructure(matchedCountMap, structureNum, freStructures),\n dsG = _c.structure,\n ndsDist = _c.structureCountMap; // -------- 第二步,匹配-------\n // 2.1 从 Q 中的第一个标签的第一个节点开始,寻找 G 中的匹配\n\n\n var beginPNode = pattern.nodes[0];\n var label = beginPNode[nodeLabelProp]; // 2.1.1 找到 G 中标签与之相同的节点\n\n var candidates = nodeLabelMap[label]; // console.log(\"----- stage2: going to find candidates -------\");\n // 全局缓存,避免重复计算\n\n var minPatternNodeLabelDegreeMap = {}; // key 是 label,value 是该 label 节点的最小度数\n\n var patternIntGraphMap = {},\n patternNDSDist = {},\n // key 为 node.id-node.id\n patternNDSDistMap = {}; // key 为 node.id-label2,value nds距离值数组(按从大到小排序,无需关心具体对应哪个 node2)\n // 2.2.2 对于 Q 中的另一个标签的 k 个节点,计算它们到 node 的最短路径以及 NDS 距离\n\n var patternSpDist = {};\n var patternSpDistBack = {};\n Object.keys(patternNodeLabelMap).forEach(function (label2, j) {\n patternSpDist[label2] = [];\n\n if (directed) {\n patternSpDistBack[label2] = [];\n }\n\n var maxDist = -Infinity;\n var patternNodesWithLabel2 = patternNodeLabelMap[label2];\n var patternNodePairMap = {};\n patternNodesWithLabel2.forEach(function (nodeWithLabel2) {\n var dist = patternSpmMap[beginPNode.id + \"-\" + nodeWithLabel2.id];\n dist && patternSpDist[label2].push(dist);\n if (maxDist < dist) maxDist = dist;\n patternNodePairMap[beginPNode.id + \"-\" + nodeWithLabel2.id] = {\n start: 0,\n end: patternNodeMap[nodeWithLabel2.id].idx,\n distance: dist\n };\n\n if (directed) {\n var distBack = patternSpmMap[nodeWithLabel2.id + \"-\" + beginPNode.id];\n distBack && patternSpDistBack[label2].push(distBack);\n }\n }); // spDist[label2] 按照从小到大排序\n\n patternSpDist[label2] = patternSpDist[label2].sort(function (a, b) {\n return a - b;\n });\n if (directed) patternSpDistBack[label2] = patternSpDistBack[label2].sort(function (a, b) {\n return a - b;\n }); // 计算 Q 中所有 label2 节点到 beginPNode 的 NDS 距离\n // 所有 label2 节点到 beginPNode 的邻居相交诱导子图:\n // key: node1.id-node2.id\n\n patternIntGraphMap = getIntersectNeighborInducedGraph(patternNodePairMap, patternKNeighborUnits, pattern, patternIntGraphMap); // pattern 中 beginNode 到当前 label2 节点 的 NDS 距离(数组,无需关心具体对应到哪个节点)\n\n var currentPatternNDSDistArray = [];\n Object.keys(patternNodePairMap).forEach(function (key) {\n if (patternNDSDist[key]) {\n currentPatternNDSDistArray.push(patternNDSDist[key]);\n return; // 缓存过则不需要再次计算\n }\n\n var patternIntGraph = patternIntGraphMap[key];\n patternNDSDist[key] = getMatchedCount(patternIntGraph, dsG, nodeLabelProp, edgeLabelProp);\n currentPatternNDSDistArray.push(patternNDSDist[key]);\n }); // 根据值为 currentPatternNDSDist 从大到小排序\n\n currentPatternNDSDistArray = currentPatternNDSDistArray.sort(function (a, b) {\n return b - a;\n });\n patternNDSDistMap[beginPNode.id + \"-\" + label2] = currentPatternNDSDistArray;\n if (label2 === label) return;\n var candidatesNum = candidates.length;\n\n var _loop_4 = function _loop_4(m) {\n var cNode = candidates[m]; // prune1:若 candidates 中节点 cNode 的 kNeighborUnits 中标签为 label2 的节点个数少于 pattern 中 label2 个数,删去它\n\n var graphNeighborUnit = kNeighborUnits[nodeMap[cNode.id].idx];\n var graphNeighborUnitCountMap = graphNeighborUnit.nodeLabelCountMap[label2];\n var patternLabel2Num = patternNodeLabelMap[label2].length;\n\n if (!graphNeighborUnitCountMap || graphNeighborUnitCountMap.count < patternLabel2Num) {\n candidates.splice(m, 1);\n return \"continue\";\n } // prune2:若 candidates 中节点 cNode 到 kNeighborUnits 中标签为 label2 的节点最短路径大于 patternSpDist[label2],删去它\n // (prune2 规则即:candidate 相关的最短路径的最大 spDist[label2].length 个,按照大小顺序依次和 patternSpDist[label2] 中的值比较,只要遇到一个是 G > Q 的,就删去这个 candidate)\n\n\n var prune2Invalid = false;\n\n for (var n = 0; n < patternLabel2Num; n++) {\n if (graphNeighborUnitCountMap.dists[n] > patternSpDist[label2][n]) {\n prune2Invalid = true;\n break;\n }\n }\n\n if (prune2Invalid) {\n candidates.splice(m, 1);\n return \"continue\";\n } // prune3:若 candidates 中节点 cNode 到 kNeighborUnits 中标签为 label2 的节点 NDS 距离小于 patternNDSDist[beginNode.id-label2],删去它\n // TODO:prune3,currentPatternNDSDistArray 与 currentNDSDist 的比较\n // 计算 G 中所有 label2 节点到 cNode 的 NDS 距离\n // 所有 label2 节点到 cNode 的邻居相交诱导子图:\n\n\n var cNodePairMap = {};\n graphNeighborUnit.neighbors.forEach(function (neighborNode) {\n var dist = spmMap[cNode.id + \"-\" + neighborNode.id];\n cNodePairMap[cNode.id + \"-\" + neighborNode.id] = {\n start: nodeMap[cNode.id].idx,\n end: nodeMap[neighborNode.id].idx,\n distance: dist\n };\n }); // 更新 intGMap\n\n intGMap = getIntersectNeighborInducedGraph(cNodePairMap, kNeighborUnits, graphData, intGMap); // candidate 到它周围 label2 节点的 NDS 距离, key 是 node.id-node.id\n\n var currentNDSDistArray = [];\n Object.keys(cNodePairMap).forEach(function (key) {\n if (ndsDist[key]) {\n currentNDSDistArray.push(ndsDist[key]);\n return; // 缓存过则不需要再次计算\n }\n\n var intGraph = intGMap[key];\n ndsDist[key] = getMatchedCount(intGraph, dsG, nodeLabelProp, edgeLabelProp);\n currentNDSDistArray.push(ndsDist[key]);\n }); // 根据值为 currentNDSDistArray 从大到小排序\n\n currentNDSDistArray = currentNDSDistArray.sort(function (a, b) {\n return b - a;\n });\n var prune3Invalid = false;\n\n for (var n = 0; n < patternLabel2Num; n++) {\n if (currentNDSDistArray[n] < currentPatternNDSDistArray[n]) {\n prune3Invalid = true;\n break;\n }\n }\n\n if (prune3Invalid) {\n candidates.splice(m, 1);\n return \"continue\";\n }\n };\n\n for (var m = candidatesNum - 1; m >= 0; m--) {\n _loop_4(m);\n }\n });\n var candidateGraphs = []; // console.log(\n // \"----- stage3: going to splice neighbors for each candidate graph -------\"\n // );\n // candidates 经过筛选后,以每个 candidate 为中心,生成 Length-neighbor 的邻居诱导子图\n // 并在诱导子图中去除不可能在 Q 上找到匹配的点:在 Q 上不存在的 label,其他 label 到 candidate 的最大最短距离符合 Q、NDS 距离符合 Q\n\n candidates.forEach(function (candidate) {\n var nodeIdx = nodeMap[candidate.id].idx;\n var lengthNeighborUnit = findKNeighborUnit(graphData.nodes, spm[nodeIdx], nodeIdx, nodeLabelProp, length);\n var neighborNodes = lengthNeighborUnit.neighbors; // 删除不可能找到匹配的邻居点\n\n var neighborNum = neighborNodes.length;\n var unmatched = false;\n\n for (var i = neighborNum - 1; i >= 0; i--) {\n // 如果通过裁剪,符合条件的节点数量已过少,说明不能匹配这个 candidate 相关的图\n if (neighborNodes.length + 1 < pattern.nodes.length) {\n unmatched = true;\n return;\n }\n\n var neighborNode = neighborNodes[i];\n var neighborLabel = neighborNode[nodeLabelProp]; // prune1: 若该邻居点的 label 不存在于 pattern 中,移除这个点\n\n if (!patternNodeLabelMap[neighborLabel] || !patternNodeLabelMap[neighborLabel].length) {\n neighborNodes.splice(i, 1);\n continue;\n } // prune2: 若该邻居点到 candidate 的最短路径比和它有相同 label 的节点到 beginPNode 的最大最短路径长度长,移除这个点\n // prune2.1: 如果没有这个标签到 beginPNode 的距离记录,说明 pattern 上(可能 beginPNode 是这个 label)没有其他这个 label 的节点\n\n\n if (!patternSpDist[neighborLabel] || !patternSpDist[neighborLabel].length) {\n neighborNodes.splice(i, 1);\n continue;\n }\n\n var key = candidate.id + \"-\" + neighborNode.id; // prune2.2\n\n var distToCandidate = spmMap[key];\n var idx = patternSpDist[neighborLabel].length - 1;\n var maxDistWithLabelInPattern = patternSpDist[neighborLabel][idx]; // patternSpDist[neighborLabel] 已经按照从小到大排序\n\n if (distToCandidate > maxDistWithLabelInPattern) {\n neighborNodes.splice(i, 1);\n continue;\n }\n\n if (directed) {\n var keyBack = neighborNode.id + \"-\" + candidate.id;\n var distFromCandidate = spmMap[keyBack];\n idx = patternSpDistBack[neighborLabel].length - 1;\n var maxBackDistWithLabelInPattern = patternSpDistBack[neighborLabel][idx];\n\n if (distFromCandidate > maxBackDistWithLabelInPattern) {\n neighborNodes.splice(i, 1);\n continue;\n }\n } // prune3: 若该邻居点到 candidate 的 NDS 距离比和它有相同 label 的节点到 beginPNode 的最小 NDS 距离小,移除这个点\n\n\n var ndsToCandidate = ndsDist[key] ? ndsDist[key] : getNDSDist(graphData, candidate, neighborNode, nodeMap, distToCandidate, kNeighborUnits, dsG, nodeLabelProp, edgeLabelProp, ndsDist, intGMap);\n var patternKey = beginPNode.id + \"-\" + neighborLabel;\n var minNdsWithLabelInPattern = patternNDSDistMap[patternKey][patternNDSDistMap[patternKey].length - 1]; // patternNDSDist[key] 一定存在\n\n if (ndsToCandidate < minNdsWithLabelInPattern) {\n neighborNodes.splice(i, 1);\n continue;\n } // prune4: 若该邻居点的度数小于 pattern 同 label 节点最小度数,删去该点\n\n\n var _a = stashPatternNodeLabelDegreeMap(minPatternNodeLabelDegreeMap, neighborLabel, patternNodeMap, patternNodeLabelMap),\n minPatternNodeLabelDegree = _a.minPatternNodeLabelDegree,\n minPatternNodeLabelInDegree = _a.minPatternNodeLabelInDegree,\n minPatternNodeLabelOutDegree = _a.minPatternNodeLabelOutDegree;\n\n if (nodeMap[neighborNode.id].degree < minPatternNodeLabelDegree) {\n neighborNodes.splice(i, 1);\n continue;\n }\n } // 节点在个数上符合匹配(不少于 pattern 的节点个数),现在筛选相关边\n\n\n if (!unmatched) {\n candidateGraphs.push({\n nodes: [candidate].concat(neighborNodes)\n });\n }\n }); // console.log(\n // \"----- stage4: going to splice edges and neighbors for each candidate graph -------\"\n // );\n\n var undirectedLengthsToBeginPNode = (0, _dijkstra.default)(pattern, beginPNode.id, false).length;\n var undirectedLengthsToBeginPNodeLabelMap = {};\n\n if (directed) {\n Object.keys(undirectedLengthsToBeginPNode).forEach(function (nodeId) {\n var nodeLabel = patternNodeMap[nodeId].node[nodeLabelProp];\n if (!undirectedLengthsToBeginPNodeLabelMap[nodeLabel]) undirectedLengthsToBeginPNodeLabelMap[nodeLabel] = [undirectedLengthsToBeginPNode[nodeId]];else undirectedLengthsToBeginPNodeLabelMap[nodeLabel].push(undirectedLengthsToBeginPNode[nodeId]);\n });\n Object.keys(undirectedLengthsToBeginPNodeLabelMap).forEach(function (pLabel) {\n undirectedLengthsToBeginPNodeLabelMap[pLabel].sort(function (a, b) {\n return a - b;\n });\n });\n } else {\n undirectedLengthsToBeginPNodeLabelMap = patternSpDist;\n } // 现在 candidateGraphs 里面只有节点,进行边的筛选\n\n\n var candidateGraphNum = candidateGraphs.length;\n\n var _loop_2 = function _loop_2(i) {\n var candidateGraph = candidateGraphs[i];\n var candidate = candidateGraph.nodes[0];\n var candidateNodeLabelCountMap = {};\n var candidateNodeMap = {};\n candidateGraph.nodes.forEach(function (node, q) {\n candidateNodeMap[node.id] = {\n idx: q,\n node: node,\n degree: 0,\n inDegree: 0,\n outDegree: 0\n };\n var cNodeLabel = node[nodeLabelProp];\n if (!candidateNodeLabelCountMap[cNodeLabel]) candidateNodeLabelCountMap[cNodeLabel] = 1;else candidateNodeLabelCountMap[cNodeLabel]++;\n }); // 根据 candidate 和 neighborNodes 中的节点生成 G 的诱导子图\n // 即,将 graphData 上两端都在 candidateGraph.nodes 中的边放入 candidateEdges\n\n var candidateEdges = [];\n var edgeLabelCountMap = {};\n graphData.edges.forEach(function (edge) {\n if (candidateNodeMap[edge.source] && candidateNodeMap[edge.target]) {\n candidateEdges.push(edge);\n if (!edgeLabelCountMap[edge[edgeLabelProp]]) edgeLabelCountMap[edge[edgeLabelProp]] = 1;else edgeLabelCountMap[edge[edgeLabelProp]]++;\n candidateNodeMap[edge.source].degree++;\n candidateNodeMap[edge.target].degree++;\n candidateNodeMap[edge.source].outDegree++;\n candidateNodeMap[edge.target].inDegree++;\n }\n }); // prune:若有一个 edgeLabel 在 candidateGraph 上的个数少于 pattern,去除该图\n\n var pattenrEdgeLabelNum = Object.keys(patternEdgeLabelMap).length;\n var prunedByEdgeLabel = false;\n\n for (var e = 0; e < pattenrEdgeLabelNum; e++) {\n var label_1 = Object.keys(patternEdgeLabelMap)[e];\n\n if (!edgeLabelCountMap[label_1] || edgeLabelCountMap[label_1] < patternEdgeLabelMap[label_1].length) {\n prunedByEdgeLabel = true;\n break;\n }\n }\n\n if (prunedByEdgeLabel) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n } // 遍历 candidateEdges,进行边的筛选\n\n\n var candidateEdgeNum = candidateEdges.length; // prune:若边数过少,去除该图\n\n if (candidateEdgeNum < pattern.edges.length) {\n candidateGraphs.splice(i, 1);\n return \"break\";\n }\n\n var candidateGraphInvalid = false;\n\n var _loop_5 = function _loop_5(e) {\n var edge = candidateEdges[e];\n var edgeLabel = edge[edgeLabelProp];\n var patternEdgesWithLabel = patternEdgeLabelMap[edgeLabel]; // prune 1: 若边的 label 不存在于 pattern 边 label 中,去除该边\n\n if (!patternEdgesWithLabel || !patternEdgesWithLabel.length) {\n edgeLabelCountMap[edgeLabel]--; // 若这个 label 的 count 减少之后,该 label 的边数不足,去除该图\n\n if (patternEdgesWithLabel && edgeLabelCountMap[edgeLabel] < patternEdgesWithLabel.length) {\n candidateGraphInvalid = true;\n return \"break\";\n }\n\n candidateEdges.splice(e, 1);\n candidateNodeMap[edge.source].degree--;\n candidateNodeMap[edge.target].degree--;\n candidateNodeMap[edge.source].outDegree--;\n candidateNodeMap[edge.target].inDegree--;\n return \"continue\";\n } // prune 2: 若边的 label +两端 label 的三元组关系不能在 pattern 中找到,去除该边\n\n\n var sourceLabel = candidateNodeMap[edge.source].node[nodeLabelProp];\n var targetLabel = candidateNodeMap[edge.target].node[nodeLabelProp];\n var edgeMatched = false;\n patternEdgesWithLabel.forEach(function (patternEdge) {\n var patternSource = patternNodeMap[patternEdge.source].node;\n var patternTarget = patternNodeMap[patternEdge.target].node;\n if (patternSource[nodeLabelProp] === sourceLabel && patternTarget[nodeLabelProp] === targetLabel) edgeMatched = true;\n if (!directed && patternSource[nodeLabelProp] === targetLabel && patternTarget[nodeLabelProp] === sourceLabel) edgeMatched = true;\n });\n\n if (!edgeMatched) {\n edgeLabelCountMap[edgeLabel]--; // 若这个 label 的 count 减少之后,该 label 的边数不足,去除该图\n\n if (patternEdgesWithLabel && edgeLabelCountMap[edgeLabel] < patternEdgesWithLabel.length) {\n candidateGraphInvalid = true;\n return \"break\";\n }\n\n candidateEdges.splice(e, 1);\n candidateNodeMap[edge.source].degree--;\n candidateNodeMap[edge.target].degree--;\n candidateNodeMap[edge.source].outDegree--;\n candidateNodeMap[edge.target].inDegree--;\n return \"continue\";\n }\n };\n\n for (var e = candidateEdgeNum - 1; e >= 0; e--) {\n var state_2 = _loop_5(e);\n\n if (state_2 === \"break\") break;\n } // prune2: 删除边的过程中,发现边数过少/边 label 数过少时,去除该图\n\n\n if (candidateGraphInvalid) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n }\n\n candidateGraph.edges = candidateEdges;\n var lengthsToCandidate = (0, _dijkstra.default)(candidateGraph, candidateGraph.nodes[0].id, false).length;\n Object.keys(lengthsToCandidate).reverse().forEach(function (targetId) {\n if (targetId === candidateGraph.nodes[0].id || candidateGraphInvalid) return; // prune4: 通过上述裁剪,可能导致该邻居子图变为不连通。裁剪掉目前在这个邻居子图中和 candidate(第一个节点)不连通的节点\n\n if (lengthsToCandidate[targetId] === Infinity) {\n var targetNodeLabel = candidateNodeMap[targetId].node[nodeLabelProp];\n candidateNodeLabelCountMap[targetNodeLabel]--;\n\n if (candidateNodeLabelCountMap[targetNodeLabel] < patternNodeLabelMap[targetNodeLabel].length) {\n candidateGraphInvalid = true;\n return;\n }\n\n var idx = candidateGraph.nodes.indexOf(candidateNodeMap[targetId].node);\n candidateGraph.nodes.splice(idx, 1);\n candidateNodeMap[targetId] = undefined;\n return;\n } // prune5: 经过边裁剪后,可能又出现了最短路径过长的节点 (比 pattern 中同 label 的节点到 beginNode 最大最短距离远),删去这些节点\n\n\n var nLabel = nodeMap[targetId].node[nodeLabelProp];\n\n if (!undirectedLengthsToBeginPNodeLabelMap[nLabel] || !undirectedLengthsToBeginPNodeLabelMap[nLabel].length || lengthsToCandidate[targetId] > undirectedLengthsToBeginPNodeLabelMap[nLabel][undirectedLengthsToBeginPNodeLabelMap[nLabel].length - 1]) {\n var targetNodeLabel = candidateNodeMap[targetId].node[nodeLabelProp];\n candidateNodeLabelCountMap[targetNodeLabel]--;\n\n if (candidateNodeLabelCountMap[targetNodeLabel] < patternNodeLabelMap[targetNodeLabel].length) {\n candidateGraphInvalid = true;\n return;\n }\n\n var idx = candidateGraph.nodes.indexOf(candidateNodeMap[targetId].node);\n candidateGraph.nodes.splice(idx, 1);\n candidateNodeMap[targetId] = undefined;\n }\n });\n\n if (candidateGraphInvalid) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n }\n\n var degreeChanged = true;\n var loopCount = 0;\n\n while (degreeChanged && !candidateGraphInvalid) {\n degreeChanged = false; // candidate 度数不足,删去该图\n\n var condition = directed ? candidateNodeMap[candidate.id].degree < patternNodeMap[beginPNode.id].degree || candidateNodeMap[candidate.id].inDegree < patternNodeMap[beginPNode.id].inDegree || candidateNodeMap[candidate.id].outDegree < patternNodeMap[beginPNode.id].outDegree : candidateNodeMap[candidate.id].degree < patternNodeMap[beginPNode.id].degree;\n\n if (condition) {\n candidateGraphInvalid = true;\n break;\n } // candidate label 个数不足,删去该图\n\n\n if (candidateNodeLabelCountMap[candidate[nodeLabelProp]] < patternNodeLabelMap[candidate[nodeLabelProp]].length) {\n candidateGraphInvalid = true;\n break;\n } // prune6:去除度数过小的节点\n\n\n var currentCandidateNodeNum = candidateGraph.nodes.length;\n\n for (var o = currentCandidateNodeNum - 1; o >= 0; o--) {\n var cgNode = candidateGraph.nodes[o];\n var nodeDegree = candidateNodeMap[cgNode.id].degree;\n var nodeInDegree = candidateNodeMap[cgNode.id].inDegree;\n var nodeOutDegree = candidateNodeMap[cgNode.id].outDegree;\n var cNodeLabel = cgNode[nodeLabelProp];\n\n var _d = stashPatternNodeLabelDegreeMap(minPatternNodeLabelDegreeMap, cNodeLabel, patternNodeMap, patternNodeLabelMap),\n minPatternNodeLabelDegree = _d.minPatternNodeLabelDegree,\n minPatternNodeLabelInDegree = _d.minPatternNodeLabelInDegree,\n minPatternNodeLabelOutDegree = _d.minPatternNodeLabelOutDegree;\n\n var deleteCondition = directed ? nodeDegree < minPatternNodeLabelDegree || nodeInDegree < minPatternNodeLabelInDegree || nodeOutDegree < minPatternNodeLabelOutDegree : nodeDegree < minPatternNodeLabelDegree;\n\n if (deleteCondition) {\n candidateNodeLabelCountMap[cgNode[nodeLabelProp]]--; // 节点 label 个数不足\n\n if (candidateNodeLabelCountMap[cgNode[nodeLabelProp]] < patternNodeLabelMap[cgNode[nodeLabelProp]].length) {\n candidateGraphInvalid = true;\n break;\n }\n\n candidateGraph.nodes.splice(o, 1);\n candidateNodeMap[cgNode.id] = undefined;\n degreeChanged = true;\n }\n }\n\n if (candidateGraphInvalid || !degreeChanged && loopCount !== 0) break; // 经过 prune5 节点裁剪,删去端点已经不在 candidateGraph 中的边\n\n candidateEdgeNum = candidateEdges.length;\n\n for (var y = candidateEdgeNum - 1; y >= 0; y--) {\n var cedge = candidateEdges[y];\n\n if (!candidateNodeMap[cedge.source] || !candidateNodeMap[cedge.target]) {\n candidateEdges.splice(y, 1);\n var edgeLabel = cedge[edgeLabelProp];\n edgeLabelCountMap[edgeLabel]--;\n\n if (candidateNodeMap[cedge.source]) {\n candidateNodeMap[cedge.source].degree--;\n candidateNodeMap[cedge.source].outDegree--;\n }\n\n if (candidateNodeMap[cedge.target]) {\n candidateNodeMap[cedge.target].degree--;\n candidateNodeMap[cedge.target].inDegree--;\n } // 边 label 数量不足\n\n\n if (patternEdgeLabelMap[edgeLabel] && edgeLabelCountMap[edgeLabel] < patternEdgeLabelMap[edgeLabel].length) {\n candidateGraphInvalid = true;\n break;\n }\n\n degreeChanged = true;\n }\n }\n\n loopCount++;\n }\n\n if (candidateGraphInvalid) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n } // prune: 若节点/边数过少,节点/边 label 过少,去掉这个图\n\n\n if (candidateGraphInvalid || candidateGraph.nodes.length < pattern.nodes.length || candidateEdges.length < pattern.edges.length) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n }\n };\n\n for (var i = candidateGraphNum - 1; i >= 0; i--) {\n var state_1 = _loop_2(i);\n\n if (state_1 === \"break\") break;\n } // 此时已经生成的多个 candidateGraphs,可能有重复\n // console.log(\n // \"----- stage5: going to splice dulplicated candidate graphs -------\"\n // );\n // 删去 candidateGraphs 中一模一样的子图,通过边的 node-node-edgeLabel 作为 key,这类边个数作为 value,进行匹配\n\n\n var currentLength = candidateGraphs.length;\n\n var _loop_3 = function _loop_3(i) {\n var cg1 = candidateGraphs[i];\n var cg1EdgeMap = {}; // [node1.id-node2.id-edge.label]: count\n\n cg1.edges.forEach(function (edge) {\n var key = edge.source + \"-\" + edge.target + \"-\" + edge.label;\n if (!cg1EdgeMap[key]) cg1EdgeMap[key] = 1;else cg1EdgeMap[key]++;\n });\n\n var _loop_6 = function _loop_6(j) {\n var cg2 = candidateGraphs[j];\n var cg2EdgeMap = {}; // [node1.id-node2.id-edge.label]: count\n\n cg2.edges.forEach(function (edge) {\n var key = edge.source + \"-\" + edge.target + \"-\" + edge.label;\n if (!cg2EdgeMap[key]) cg2EdgeMap[key] = 1;else cg2EdgeMap[key]++;\n });\n var same = true;\n\n if (Object.keys(cg2EdgeMap).length !== Object.keys(cg1EdgeMap).length) {\n same = false;\n } else {\n Object.keys(cg1EdgeMap).forEach(function (key) {\n if (cg2EdgeMap[key] !== cg1EdgeMap[key]) same = false;\n });\n }\n\n if (same) {\n candidateGraphs.splice(j, 1);\n }\n };\n\n for (var j = currentLength - 1; j > i; j--) {\n _loop_6(j);\n }\n\n currentLength = candidateGraphs.length;\n };\n\n for (var i = 0; i <= currentLength - 1; i++) {\n _loop_3(i);\n }\n\n return candidateGraphs;\n};\n\nvar _default = GADDI;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _util = require(\"@antv/util\");\n\nvar _struct = require(\"./struct\");\n\nvar DFSedge = function () {\n function DFSedge(fromNode, toNode, fromNodeLabel, edgeLabel, toNodeLabel) {\n this.fromNode = fromNode;\n this.toNode = toNode;\n this.nodeEdgeNodeLabel = {\n nodeLabel1: fromNodeLabel || _struct.VACANT_NODE_LABEL,\n edgeLabel: edgeLabel || _struct.VACANT_EDGE_LABEL,\n nodeLabel2: toNodeLabel || _struct.VACANT_NODE_LABEL\n };\n }\n\n DFSedge.prototype.equalTo = function (other) {\n return this.fromNode === other.formNode && this.toNode === other.toNode && this.nodeEdgeNodeLabel === other.nodeEdgeNodeLabel;\n };\n\n DFSedge.prototype.notEqualTo = function (other) {\n return !this.equalTo(other);\n };\n\n return DFSedge;\n}(); // DFScode 是 DESedge 的数组\n\n\nvar DFScode = function () {\n function DFScode() {\n this.rmpath = [];\n this.dfsEdgeList = [];\n }\n\n DFScode.prototype.equalTo = function (other) {\n var aLength = this.dfsEdgeList.length;\n var bLength = other.length;\n if (aLength !== bLength) return false;\n\n for (var i = 0; i < aLength; i++) {\n if (this.dfsEdgeList[i] !== other[i]) return false;\n }\n\n return true;\n };\n\n DFScode.prototype.notEqualTo = function (other) {\n return !this.equalTo(other);\n };\n /** 增加一条 edge 到 DFScode */\n\n\n DFScode.prototype.pushBack = function (fromNode, toNode, fromNodeLabel, edgeLabel, toNodeLabel) {\n this.dfsEdgeList.push(new DFSedge(fromNode, toNode, fromNodeLabel, edgeLabel, toNodeLabel));\n return this.dfsEdgeList;\n };\n /** 根据 dfs 构建图 */\n\n\n DFScode.prototype.toGraph = function (graphId, directed) {\n if (graphId === void 0) {\n graphId = _struct.VACANT_GRAPH_ID;\n }\n\n if (directed === void 0) {\n directed = false;\n }\n\n var graph = new _struct.Graph(graphId, true, directed);\n this.dfsEdgeList.forEach(function (dfsEdge) {\n var fromNodeId = dfsEdge.fromNode;\n var toNodeId = dfsEdge.toNode;\n var _a = dfsEdge.nodeEdgeNodeLabel,\n nodeLabel1 = _a.nodeLabel1,\n edgeLabel = _a.edgeLabel,\n nodeLabel2 = _a.nodeLabel2;\n if (nodeLabel1 !== _struct.VACANT_NODE_LABEL) graph.addNode(fromNodeId, nodeLabel1);\n if (nodeLabel2 !== _struct.VACANT_NODE_LABEL) graph.addNode(toNodeId, nodeLabel2);\n graph.addEdge(undefined, fromNodeId, toNodeId, edgeLabel);\n });\n return graph;\n }; // 建立 rightmost path\n\n\n DFScode.prototype.buildRmpath = function () {\n this.rmpath = [];\n var oldFrom = undefined;\n var selfLength = this.dfsEdgeList.length;\n\n for (var i = selfLength - 1; i >= 0; i--) {\n var dfsEdge = this.dfsEdgeList[i];\n var fromNodeIdx = dfsEdge.fromNode;\n var toNodeIdx = dfsEdge.toNode;\n\n if (fromNodeIdx < toNodeIdx && (oldFrom === undefined || toNodeIdx === oldFrom)) {\n this.rmpath.push(i);\n oldFrom = fromNodeIdx;\n }\n }\n\n return this.rmpath;\n };\n\n DFScode.prototype.getNodeNum = function () {\n var nodeMap = {};\n this.dfsEdgeList.forEach(function (dfsEdge) {\n if (!nodeMap[dfsEdge.fromNode]) nodeMap[dfsEdge.fromNode] = true;\n if (!nodeMap[dfsEdge.toNode]) nodeMap[dfsEdge.toNode] = true;\n });\n return Object.keys(nodeMap).length;\n };\n\n return DFScode;\n}();\n\nvar History = function () {\n function History(pdfs) {\n this.his = {};\n this.nodesUsed = {};\n this.edgesUsed = {};\n this.edges = [];\n if (!pdfs) return;\n\n while (pdfs) {\n var e = pdfs.edge;\n this.edges.push(e);\n this.nodesUsed[e.from] = 1;\n this.nodesUsed[e.to] = 1;\n this.edgesUsed[e.id] = 1;\n pdfs = pdfs.preNode;\n } // 倒序\n\n\n this.edges = this.edges.reverse();\n }\n\n History.prototype.hasNode = function (node) {\n return this.nodesUsed[node.id] === 1;\n };\n\n History.prototype.hasEdge = function (edge) {\n return this.edgesUsed[edge.id] === 1;\n };\n\n return History;\n}();\n\nvar GSpan = function () {\n function GSpan(_a) {\n var graphs = _a.graphs,\n _b = _a.minSupport,\n minSupport = _b === void 0 ? 2 : _b,\n _c = _a.minNodeNum,\n minNodeNum = _c === void 0 ? 1 : _c,\n _d = _a.maxNodeNum,\n maxNodeNum = _d === void 0 ? 4 : _d,\n _e = _a.top,\n top = _e === void 0 ? 10 : _e,\n _f = _a.directed,\n directed = _f === void 0 ? false : _f,\n _g = _a.verbose,\n verbose = _g === void 0 ? false : _g; // -------- 第零步,初始化-------\n\n this.graphs = graphs;\n this.dfsCode = new DFScode();\n this.support = 0;\n this.frequentSize1Subgraphs = [];\n this.frequentSubgraphs = [];\n this.minSupport = minSupport;\n this.top = top;\n this.directed = directed;\n this.counter = 0; // TODO? timestamp = {}\n\n this.maxNodeNum = maxNodeNum;\n this.minNodeNum = minNodeNum;\n this.verbose = verbose;\n if (this.maxNodeNum < this.minNodeNum) this.maxNodeNum = this.minNodeNum;\n this.reportDF = []; // matrix\n } // Line 352\n\n\n GSpan.prototype.findForwardRootEdges = function (graph, fromNode) {\n var _this = this;\n\n var result = [];\n var nodeMap = graph.nodeMap;\n fromNode.edges.forEach(function (edge) {\n if (_this.directed || fromNode.label <= nodeMap[edge.to].label) result.push(edge);\n });\n return result;\n };\n\n GSpan.prototype.findBackwardEdge = function (graph, edge1, edge2, history) {\n if (!this.directed && edge1 === edge2) return null;\n var nodeMap = graph.nodeMap;\n var edge2To = nodeMap[edge2.to];\n var edge2ToEdges = edge2To.edges;\n var edgeLength = edge2ToEdges.length;\n\n for (var i = 0; i < edgeLength; i++) {\n var edge = edge2ToEdges[i];\n if (history.hasEdge(edge) || edge.to !== edge1.from) continue;\n\n if (!this.directed) {\n if (edge1.label < edge.label || edge1.label === edge.label && nodeMap[edge1.to].label <= nodeMap[edge2.to].label) {\n return edge;\n }\n } else {\n if (nodeMap[edge1.from].label < nodeMap[edge2.to].label || nodeMap[edge1.from].label === nodeMap[edge2.to].label && edge1.label <= edge.label) {\n return edge;\n }\n }\n }\n\n return null;\n };\n\n GSpan.prototype.findForwardPureEdges = function (graph, rightmostEdge, minNodeLabel, history) {\n var result = [];\n var rightmostEdgeToId = rightmostEdge.to;\n var edges = graph.nodeMap[rightmostEdgeToId].edges;\n var edgeLength = edges.length;\n\n for (var i = 0; i < edgeLength; i++) {\n var edge = edges[i];\n var toNode = graph.nodeMap[edge.to];\n\n if (minNodeLabel <= toNode.label && !history.hasNode(toNode)) {\n result.push(edge);\n }\n }\n\n return result;\n };\n\n GSpan.prototype.findForwardRmpathEdges = function (graph, rightmostEdge, minNodeLabel, history) {\n var result = [];\n var nodeMap = graph.nodeMap;\n var toNodeLabel = nodeMap[rightmostEdge.to].label;\n var fromNode = nodeMap[rightmostEdge.from];\n var edges = fromNode.edges;\n var edgeLength = edges.length;\n\n for (var i = 0; i < edgeLength; i++) {\n var edge = edges[i];\n var newToNodeLabel = nodeMap[edge.to].label;\n\n if (rightmostEdge.to === edge.to || minNodeLabel > newToNodeLabel || history.hasNode(nodeMap[edge.to])) {\n continue;\n }\n\n if (rightmostEdge.label < edge.label || rightmostEdge.label === edge.label && toNodeLabel <= newToNodeLabel) {\n result.push(edge);\n }\n }\n\n return result;\n };\n\n GSpan.prototype.getSupport = function (projected) {\n var graphMap = {};\n projected.forEach(function (pro) {\n if (!graphMap[pro.graphId]) graphMap[pro.graphId] = true;\n });\n return Object.keys(graphMap).length;\n };\n\n GSpan.prototype.findMinLabel = function (obj) {\n var minLabel = undefined;\n Object.keys(obj).forEach(function (nodeEdgeNodeLabel) {\n var _a = obj[nodeEdgeNodeLabel],\n nodeLabel1 = _a.nodeLabel1,\n edgeLabel = _a.edgeLabel,\n nodeLabel2 = _a.nodeLabel2;\n\n if (!minLabel) {\n minLabel = {\n nodeLabel1: nodeLabel1,\n edgeLabel: edgeLabel,\n nodeLabel2: nodeLabel2\n };\n return;\n }\n\n if (nodeLabel1 < minLabel.nodeLabel1 || nodeLabel1 === minLabel.nodeLabel1 && edgeLabel < minLabel.edgeLabel || nodeLabel1 === minLabel.nodeLabel1 && edgeLabel === minLabel.edgeLabel && nodeLabel2 < minLabel.nodeLabel2) {\n minLabel = {\n nodeLabel1: nodeLabel1,\n edgeLabel: edgeLabel,\n nodeLabel2: nodeLabel2\n };\n }\n });\n return minLabel;\n };\n\n GSpan.prototype.isMin = function () {\n var _this = this;\n\n var dfsCode = this.dfsCode;\n if (this.verbose) console.log(\"isMin checking\", dfsCode);\n if (dfsCode.dfsEdgeList.length === 1) return true;\n var directed = this.directed;\n var graph = dfsCode.toGraph(_struct.VACANT_GRAPH_ID, directed);\n var nodeMap = graph.nodeMap;\n var dfsCodeMin = new DFScode();\n var root = {};\n graph.nodes.forEach(function (node) {\n var forwardEdges = _this.findForwardRootEdges(graph, node);\n\n forwardEdges.forEach(function (edge) {\n var otherNode = nodeMap[edge.to];\n var nodeEdgeNodeLabel = node.label + \"-\" + edge.label + \"-\" + otherNode.label;\n if (!root[nodeEdgeNodeLabel]) root[nodeEdgeNodeLabel] = {\n projected: [],\n nodeLabel1: node.label,\n edgeLabel: edge.label,\n nodeLabel2: otherNode.label\n };\n var pdfs = {\n graphId: graph.id,\n edge: edge,\n preNode: null\n };\n root[nodeEdgeNodeLabel].projected.push(pdfs);\n });\n }); // 比较 root 中每一项的 nodeEdgeNodeLabel 大小,按照 nodeLabel1、edgeLabe、nodeLabel2 的顺序比较\n\n var minLabel = this.findMinLabel(root); // line 419\n\n dfsCodeMin.dfsEdgeList.push(new DFSedge(0, 1, minLabel.nodeLabel1, minLabel.edgeLabel, minLabel.nodeLabel2)); // line 423\n\n var projectIsMin = function projectIsMin(projected) {\n // right most path\n var rmpath = dfsCodeMin.buildRmpath();\n var minNodeLabel = dfsCodeMin.dfsEdgeList[0].nodeEdgeNodeLabel.nodeLabel1;\n var maxToC = dfsCodeMin.dfsEdgeList[rmpath[0]].toNode; // node id\n\n var backwardRoot = {};\n var flag = false,\n newTo = 0;\n var end = directed ? -1 : 0; // 遍历到 1 还是到 0\n\n var _loop_1 = function _loop_1(i) {\n if (flag) return \"break\"; // line 435\n\n projected.forEach(function (p) {\n var history = new History(p);\n\n var backwardEdge = _this.findBackwardEdge(graph, history.edges[rmpath[i]], history.edges[rmpath[0]], history);\n\n if (backwardEdge) {\n // Line 441\n if (!backwardRoot[backwardEdge.label]) {\n backwardRoot[backwardEdge.label] = {\n projected: [],\n edgeLabel: backwardEdge.label\n };\n }\n\n backwardRoot[backwardEdge.label].projected.push({\n graphId: graph.id,\n edge: backwardRoot,\n preNode: p\n });\n newTo = dfsCodeMin.dfsEdgeList[rmpath[i]].fromNode;\n flag = true;\n }\n });\n };\n\n for (var i = rmpath.length - 1; i > end; i--) {\n var state_1 = _loop_1(i);\n\n if (state_1 === \"break\") break;\n }\n\n if (flag) {\n var minBackwardEdgeLabel = _this.findMinLabel(backwardRoot);\n\n dfsCodeMin.dfsEdgeList.push(new DFSedge(maxToC, newTo, _struct.VACANT_NODE_LABEL, minBackwardEdgeLabel.edgeLabel, _struct.VACANT_NODE_LABEL));\n var idx_1 = dfsCodeMin.dfsEdgeList.length - 1;\n if (_this.dfsCode.dfsEdgeList[idx_1] !== dfsCodeMin.dfsEdgeList[idx_1]) return false;\n return projectIsMin(backwardRoot[minBackwardEdgeLabel.edgeLabel].projected);\n }\n\n var forwardRoot = {};\n flag = false;\n var newFrom = 0;\n projected.forEach(function (p) {\n var history = new History(p);\n\n var forwardPureEdges = _this.findForwardPureEdges(graph, history.edges[rmpath[0]], minNodeLabel, history);\n\n if (forwardPureEdges.length > 0) {\n flag = true;\n newFrom = maxToC;\n forwardPureEdges.forEach(function (edge) {\n var key = edge.label + \"-\" + nodeMap[edge.to].label;\n if (!forwardRoot[key]) forwardRoot[key] = {\n projected: [],\n edgeLabel: edge.label,\n nodeLabel2: nodeMap[edge.to].label\n };\n forwardRoot[key].projected.push({\n graphId: graph.id,\n edge: edge,\n preNode: p\n });\n });\n }\n });\n var pathLength = rmpath.length;\n\n var _loop_2 = function _loop_2(i) {\n if (flag) return \"break\";\n var value = rmpath[i];\n projected.forEach(function (p) {\n var history = new History(p);\n\n var forwardRmpathEdges = _this.findForwardRmpathEdges(graph, history.edges[value], minNodeLabel, history);\n\n if (forwardRmpathEdges.length > 0) {\n flag = true;\n newFrom = dfsCodeMin.dfsEdgeList[value].fromNode;\n forwardRmpathEdges.forEach(function (edge) {\n var key = edge.label + \"-\" + nodeMap[edge.to].label;\n if (!forwardRoot[key]) forwardRoot[key] = {\n projected: [],\n edgeLabel: edge.label,\n nodeLabel2: nodeMap[edge.to].label\n };\n forwardRoot[key].projected.push({\n graphId: graph.id,\n edge: edge,\n preNode: p\n });\n });\n }\n });\n };\n\n for (var i = 0; i < pathLength; i++) {\n var state_2 = _loop_2(i);\n\n if (state_2 === \"break\") break;\n }\n\n if (!flag) return true;\n\n var forwardMinEdgeNodeLabel = _this.findMinLabel(forwardRoot);\n\n dfsCodeMin.dfsEdgeList.push(new DFSedge(newFrom, maxToC + 1, _struct.VACANT_NODE_LABEL, forwardMinEdgeNodeLabel.edgeLabel, forwardMinEdgeNodeLabel.nodeLabel2));\n var idx = dfsCodeMin.dfsEdgeList.length - 1;\n if (dfsCode.dfsEdgeList[idx] !== dfsCodeMin.dfsEdgeList[idx]) return false;\n return projectIsMin(forwardRoot[forwardMinEdgeNodeLabel.edgeLabel + \"-\" + forwardMinEdgeNodeLabel.nodeLabel2].projected);\n };\n\n var key = minLabel.nodeLabel1 + \"-\" + minLabel.edgeLabel + \"-\" + minLabel.nodeLabel2;\n return projectIsMin(root[key].projected);\n };\n\n GSpan.prototype.report = function () {\n if (this.dfsCode.getNodeNum() < this.minNodeNum) return;\n this.counter++;\n var graph = this.dfsCode.toGraph(this.counter, this.directed);\n this.frequentSubgraphs.push((0, _util.clone)(graph));\n };\n\n GSpan.prototype.subGraphMining = function (projected) {\n var _this = this;\n\n var support = this.getSupport(projected);\n if (support < this.minSupport) return;\n if (!this.isMin()) return;\n this.report();\n var nodeNum = this.dfsCode.getNodeNum();\n var rmpath = this.dfsCode.buildRmpath();\n var maxToC = this.dfsCode.dfsEdgeList[rmpath[0]].toNode;\n var minNodeLabel = this.dfsCode.dfsEdgeList[0].nodeEdgeNodeLabel.nodeLabel1;\n var forwardRoot = {};\n var backwardRoot = {};\n projected.forEach(function (p) {\n var graph = _this.graphs[p.graphId];\n var nodeMap = graph.nodeMap;\n var history = new History(p); // backward Line 526\n\n for (var i = rmpath.length - 1; i >= 0; i--) {\n var backwardEdge = _this.findBackwardEdge(graph, history.edges[rmpath[i]], history.edges[rmpath[0]], history);\n\n if (backwardEdge) {\n var key = _this.dfsCode.dfsEdgeList[rmpath[i]].fromNode + \"-\" + backwardEdge.label;\n if (!backwardRoot[key]) backwardRoot[key] = {\n projected: [],\n toNodeId: _this.dfsCode.dfsEdgeList[rmpath[i]].fromNode,\n edgeLabel: backwardEdge.label\n };\n backwardRoot[key].projected.push({\n graphId: p.graphId,\n edge: backwardEdge,\n preNode: p\n });\n }\n } // pure forward\n\n\n if (nodeNum >= _this.maxNodeNum) return;\n\n var forwardPureEdges = _this.findForwardPureEdges(graph, history.edges[rmpath[0]], minNodeLabel, history);\n\n forwardPureEdges.forEach(function (edge) {\n var key = maxToC + \"-\" + edge.label + \"-\" + nodeMap[edge.to].label;\n if (!forwardRoot[key]) forwardRoot[key] = {\n projected: [],\n fromNodeId: maxToC,\n edgeLabel: edge.label,\n nodeLabel2: nodeMap[edge.to].label\n };\n forwardRoot[key].projected.push({\n graphId: p.graphId,\n edge: edge,\n preNode: p\n });\n });\n\n var _loop_3 = function _loop_3(i) {\n var forwardRmpathEdges = _this.findForwardRmpathEdges(graph, history.edges[rmpath[i]], minNodeLabel, history);\n\n forwardRmpathEdges.forEach(function (edge) {\n var key = _this.dfsCode.dfsEdgeList[rmpath[i]].fromNode + \"-\" + edge.label + \"-\" + nodeMap[edge.to].label;\n if (!forwardRoot[key]) forwardRoot[key] = {\n projected: [],\n fromNodeId: _this.dfsCode.dfsEdgeList[rmpath[i]].fromNode,\n edgeLabel: edge.label,\n nodeLabel2: nodeMap[edge.to].label\n };\n forwardRoot[key].projected.push({\n graphId: p.graphId,\n edge: edge,\n preNode: p\n });\n });\n }; // rmpath forward\n\n\n for (var i = 0; i < rmpath.length; i++) {\n _loop_3(i);\n }\n }); // backward\n\n Object.keys(backwardRoot).forEach(function (key) {\n var _a = backwardRoot[key],\n toNodeId = _a.toNodeId,\n edgeLabel = _a.edgeLabel;\n\n _this.dfsCode.dfsEdgeList.push(new DFSedge(maxToC, toNodeId, \"-1\", edgeLabel, \"-1\"));\n\n _this.subGraphMining(backwardRoot[key].projected);\n\n _this.dfsCode.dfsEdgeList.pop();\n }); // forward\n\n Object.keys(forwardRoot).forEach(function (key) {\n var _a = forwardRoot[key],\n fromNodeId = _a.fromNodeId,\n edgeLabel = _a.edgeLabel,\n nodeLabel2 = _a.nodeLabel2;\n\n _this.dfsCode.dfsEdgeList.push(new DFSedge(fromNodeId, maxToC + 1, _struct.VACANT_NODE_LABEL, edgeLabel, nodeLabel2));\n\n _this.subGraphMining(forwardRoot[key].projected);\n\n _this.dfsCode.dfsEdgeList.pop();\n });\n };\n\n GSpan.prototype.generate1EdgeFrequentSubGraphs = function () {\n var graphs = this.graphs;\n var directed = this.directed;\n var minSupport = this.minSupport;\n var frequentSize1Subgraphs = this.frequentSize1Subgraphs;\n var nodeLabelCounter = {},\n nodeEdgeNodeCounter = {}; // 保存各个图和各自节点的关系 map,key 格式为 graphKey-node类型\n\n var nodeLableCounted = {}; // 保存各个图和各自边的关系 map,key 格式为 graphKey-fromNode类型-edge类型-toNode类型\n\n var nodeEdgeNodeLabelCounted = {};\n Object.keys(graphs).forEach(function (key) {\n // Line 271\n var graph = graphs[key];\n var nodeMap = graph.nodeMap; // 遍历节点,记录对应图 与 每个节点的 label 到 nodeLableCounted\n\n graph.nodes.forEach(function (node, i) {\n // Line 272\n var nodeLabel = node.label;\n var graphNodeKey = key + \"-\" + nodeLabel;\n\n if (!nodeLableCounted[graphNodeKey]) {\n var counter = nodeLabelCounter[nodeLabel] || 0;\n counter++;\n nodeLabelCounter[nodeLabel] = counter;\n }\n\n nodeLableCounted[graphNodeKey] = {\n graphKey: key,\n label: nodeLabel\n }; // 遍历该节点的所有边,记录各个图和各自边的关系到 nodeEdgeNodeLabelCounted. Line 276\n\n node.edges.forEach(function (edge) {\n var nodeLabel1 = nodeLabel;\n var nodeLabel2 = nodeMap[edge.to].label;\n\n if (!directed && nodeLabel1 > nodeLabel2) {\n var tmp = nodeLabel2;\n nodeLabel2 = nodeLabel1;\n nodeLabel1 = tmp;\n }\n\n var edgeLabel = edge.label;\n var graphNodeEdgeNodeKey = key + \"-\" + nodeLabel1 + \"-\" + edgeLabel + \"-\" + nodeLabel2;\n var nodeEdgeNodeKey = nodeLabel1 + \"-\" + edgeLabel + \"-\" + nodeLabel2;\n\n if (!nodeEdgeNodeCounter[nodeEdgeNodeKey]) {\n var counter = nodeEdgeNodeCounter[nodeEdgeNodeKey] || 0;\n counter++;\n nodeEdgeNodeCounter[nodeEdgeNodeKey] = counter; // Line281\n }\n\n nodeEdgeNodeLabelCounted[graphNodeEdgeNodeKey] = {\n graphId: key,\n nodeLabel1: nodeLabel1,\n edgeLabel: edgeLabel,\n nodeLabel2: nodeLabel2\n };\n });\n });\n }); // 计算频繁的节点\n\n Object.keys(nodeLabelCounter).forEach(function (label) {\n var count = nodeLabelCounter[label];\n if (count < minSupport) return;\n var g = {\n nodes: [],\n edges: []\n };\n g.nodes.push({\n id: \"0\",\n label: label\n });\n frequentSize1Subgraphs.push(g); // if (minNodeNum <= 1) reportSize1 TODO\n });\n return frequentSize1Subgraphs;\n };\n\n GSpan.prototype.run = function () {\n var _this = this; // -------- 第一步, _generate_1edge_frequent_subgraphs:频繁的单个节点-------\n\n\n this.frequentSize1Subgraphs = this.generate1EdgeFrequentSubGraphs();\n if (this.maxNodeNum < 2) return;\n var graphs = this.graphs;\n var directed = this.directed; // PDFS 数组的 map Line 304\n\n var root = {};\n Object.keys(graphs).forEach(function (graphId) {\n var graph = graphs[graphId];\n var nodeMap = graph.nodeMap; // Line 306\n\n graph.nodes.forEach(function (node) {\n var forwardRootEdges = _this.findForwardRootEdges(graph, node); // Line 308\n\n\n forwardRootEdges.forEach(function (edge) {\n var toNode = nodeMap[edge.to];\n var nodeEdgeNodeLabel = node.label + \"-\" + edge.label + \"-\" + toNode.label;\n if (!root[nodeEdgeNodeLabel]) root[nodeEdgeNodeLabel] = {\n projected: [],\n nodeLabel1: node.label,\n edgeLabel: edge.label,\n nodeLabel2: toNode.label\n };\n var pdfs = {\n graphId: graphId,\n edge: edge,\n preNode: null\n };\n root[nodeEdgeNodeLabel].projected.push(pdfs);\n });\n });\n }); // Line 313\n\n Object.keys(root).forEach(function (nodeEdgeNodeLabel) {\n var _a = root[nodeEdgeNodeLabel],\n projected = _a.projected,\n nodeLabel1 = _a.nodeLabel1,\n edgeLabel = _a.edgeLabel,\n nodeLabel2 = _a.nodeLabel2;\n\n _this.dfsCode.dfsEdgeList.push(new DFSedge(0, 1, nodeLabel1, edgeLabel, nodeLabel2));\n\n _this.subGraphMining(projected);\n\n _this.dfsCode.dfsEdgeList.pop();\n });\n };\n\n return GSpan;\n}();\n\nvar formatGraphs = function formatGraphs(graphs, directed, nodeLabelProp, edgeLabelProp) {\n var result = {};\n Object.keys(graphs).forEach(function (key, i) {\n var graph = graphs[key];\n var fGraph = new _struct.Graph(i, true, directed);\n var nodeIdxMap = {};\n graph.nodes.forEach(function (node, j) {\n fGraph.addNode(j, node[nodeLabelProp]);\n nodeIdxMap[node.id] = j;\n });\n graph.edges.forEach(function (edge, k) {\n var sourceIdx = nodeIdxMap[edge.source];\n var targetIdx = nodeIdxMap[edge.target];\n fGraph.addEdge(-1, sourceIdx, targetIdx, edge[edgeLabelProp]);\n });\n if (fGraph && fGraph.getNodeNum()) result[fGraph.id] = fGraph;\n });\n return result;\n};\n\nvar toGraphDatas = function toGraphDatas(graphs, nodeLabelProp, edgeLabelProp) {\n var result = [];\n graphs.forEach(function (graph) {\n var graphData = {\n nodes: [],\n edges: []\n };\n graph.nodes.forEach(function (node) {\n var _a;\n\n graphData.nodes.push((_a = {\n id: \"\" + node.id\n }, _a[nodeLabelProp] = node.label, _a));\n });\n graph.edges.forEach(function (edge) {\n var _a;\n\n graphData.edges.push((_a = {\n source: \"\" + edge.from,\n target: \"\" + edge.to\n }, _a[edgeLabelProp] = edge.label, _a));\n });\n result.push(graphData);\n });\n return result;\n};\n\nvar DEFAULT_LABEL_NAME = \"cluster\";\n/**\n * gSpan 频繁子图计算算法(frequent graph mining)\n * @param params 参数\n */\n\nvar gSpan = function gSpan(params) {\n // ------- 将图数据 GraphData 的 map 转换为格式 -------\n var graphs = params.graphs,\n _a = params.directed,\n directed = _a === void 0 ? false : _a,\n _b = params.nodeLabelProp,\n nodeLabelProp = _b === void 0 ? DEFAULT_LABEL_NAME : _b,\n _c = params.edgeLabelProp,\n edgeLabelProp = _c === void 0 ? DEFAULT_LABEL_NAME : _c;\n var formattedGraphs = formatGraphs(graphs, directed, nodeLabelProp, edgeLabelProp);\n var minSupport = params.minSupport,\n maxNodeNum = params.maxNodeNum,\n minNodeNum = params.minNodeNum,\n verbose = params.verbose,\n top = params.top; // ------- 初始化与执行算法 -------\n\n var algoParams = {\n graphs: formattedGraphs,\n minSupport: minSupport,\n maxNodeNum: maxNodeNum,\n minNodeNum: minNodeNum,\n top: top,\n verbose: verbose,\n directed: directed\n };\n var calculator = new GSpan(algoParams);\n calculator.run();\n var result = toGraphDatas(calculator.frequentSubgraphs, nodeLabelProp, edgeLabelProp);\n return result;\n};\n\nvar _default = gSpan;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Graph = exports.Node = exports.Edge = exports.AUTO_EDGE_ID = exports.VACANT_GRAPH_ID = exports.VACANT_NODE_LABEL = exports.VACANT_EDGE_LABEL = exports.VACANT_NODE_ID = exports.VACANT_EDGE_ID = void 0;\nvar VACANT_EDGE_ID = -1;\nexports.VACANT_EDGE_ID = VACANT_EDGE_ID;\nvar VACANT_NODE_ID = -1;\nexports.VACANT_NODE_ID = VACANT_NODE_ID;\nvar VACANT_EDGE_LABEL = \"-1\";\nexports.VACANT_EDGE_LABEL = VACANT_EDGE_LABEL;\nvar VACANT_NODE_LABEL = \"-1\";\nexports.VACANT_NODE_LABEL = VACANT_NODE_LABEL;\nvar VACANT_GRAPH_ID = -1;\nexports.VACANT_GRAPH_ID = VACANT_GRAPH_ID;\nvar AUTO_EDGE_ID = \"-1\";\nexports.AUTO_EDGE_ID = AUTO_EDGE_ID;\n\nvar Edge = function () {\n function Edge(id, from, to, label) {\n if (id === void 0) {\n id = VACANT_EDGE_ID;\n }\n\n if (from === void 0) {\n from = VACANT_NODE_ID;\n }\n\n if (to === void 0) {\n to = VACANT_NODE_ID;\n }\n\n if (label === void 0) {\n label = VACANT_EDGE_LABEL;\n }\n\n this.id = id;\n this.from = from;\n this.to = to;\n this.label = label;\n }\n\n return Edge;\n}();\n\nexports.Edge = Edge;\n\nvar Node = function () {\n function Node(id, label) {\n if (id === void 0) {\n id = VACANT_NODE_ID;\n }\n\n if (label === void 0) {\n label = VACANT_NODE_LABEL;\n }\n\n this.id = id;\n this.label = label;\n this.edges = [];\n this.edgeMap = {};\n }\n\n Node.prototype.addEdge = function (edge) {\n this.edges.push(edge);\n this.edgeMap[edge.id] = edge;\n };\n\n return Node;\n}();\n\nexports.Node = Node;\n\nvar Graph = function () {\n function Graph(id, edgeIdAutoIncrease, directed) {\n if (id === void 0) {\n id = VACANT_NODE_ID;\n }\n\n if (edgeIdAutoIncrease === void 0) {\n edgeIdAutoIncrease = true;\n }\n\n if (directed === void 0) {\n directed = false;\n }\n\n this.id = id;\n this.edgeIdAutoIncrease = edgeIdAutoIncrease;\n this.edges = [];\n this.nodes = [];\n this.nodeMap = {};\n this.edgeMap = {};\n this.nodeLabelMap = {};\n this.edgeLabelMap = {};\n this.counter = 0;\n this.directed = directed;\n }\n\n Graph.prototype.getNodeNum = function () {\n return this.nodes.length;\n };\n\n Graph.prototype.addNode = function (id, label) {\n if (this.nodeMap[id]) return;\n var node = new Node(id, label);\n this.nodes.push(node);\n this.nodeMap[id] = node;\n if (!this.nodeLabelMap[label]) this.nodeLabelMap[label] = [];\n this.nodeLabelMap[label].push(id);\n };\n\n Graph.prototype.addEdge = function (id, from, to, label) {\n if (this.edgeIdAutoIncrease || id === undefined) id = this.counter++;\n if (this.nodeMap[from] && this.nodeMap[to] && this.nodeMap[to].edgeMap[id]) return;\n var edge = new Edge(id, from, to, label);\n this.edges.push(edge);\n this.edgeMap[id] = edge;\n this.nodeMap[from].addEdge(edge);\n if (!this.edgeLabelMap[label]) this.edgeLabelMap[label] = [];\n this.edgeLabelMap[label].push(edge);\n\n if (!this.directed) {\n var rEdge = new Edge(id, to, from, label);\n this.nodeMap[to].addEdge(rEdge);\n this.edgeLabelMap[label].push(rEdge);\n }\n };\n\n return Graph;\n}();\n\nexports.Graph = Graph;","/* MIT license */\nvar colorNames = require('color-name');\nvar swizzle = require('simple-swizzle');\n\nvar reverseNames = {};\n\n// create a list of reverse color names\nfor (var name in colorNames) {\n\tif (colorNames.hasOwnProperty(name)) {\n\t\treverseNames[colorNames[name]] = name;\n\t}\n}\n\nvar cs = module.exports = {\n\tto: {},\n\tget: {}\n};\n\ncs.get = function (string) {\n\tvar prefix = string.substring(0, 3).toLowerCase();\n\tvar val;\n\tvar model;\n\tswitch (prefix) {\n\t\tcase 'hsl':\n\t\t\tval = cs.get.hsl(string);\n\t\t\tmodel = 'hsl';\n\t\t\tbreak;\n\t\tcase 'hwb':\n\t\t\tval = cs.get.hwb(string);\n\t\t\tmodel = 'hwb';\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tval = cs.get.rgb(string);\n\t\t\tmodel = 'rgb';\n\t\t\tbreak;\n\t}\n\n\tif (!val) {\n\t\treturn null;\n\t}\n\n\treturn {model: model, value: val};\n};\n\ncs.get.rgb = function (string) {\n\tif (!string) {\n\t\treturn null;\n\t}\n\n\tvar abbr = /^#([a-f0-9]{3,4})$/i;\n\tvar hex = /^#([a-f0-9]{6})([a-f0-9]{2})?$/i;\n\tvar rgba = /^rgba?\\(\\s*([+-]?\\d+)\\s*,\\s*([+-]?\\d+)\\s*,\\s*([+-]?\\d+)\\s*(?:,\\s*([+-]?[\\d\\.]+)\\s*)?\\)$/;\n\tvar per = /^rgba?\\(\\s*([+-]?[\\d\\.]+)\\%\\s*,\\s*([+-]?[\\d\\.]+)\\%\\s*,\\s*([+-]?[\\d\\.]+)\\%\\s*(?:,\\s*([+-]?[\\d\\.]+)\\s*)?\\)$/;\n\tvar keyword = /(\\D+)/;\n\n\tvar rgb = [0, 0, 0, 1];\n\tvar match;\n\tvar i;\n\tvar hexAlpha;\n\n\tif (match = string.match(hex)) {\n\t\thexAlpha = match[2];\n\t\tmatch = match[1];\n\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\t// https://jsperf.com/slice-vs-substr-vs-substring-methods-long-string/19\n\t\t\tvar i2 = i * 2;\n\t\t\trgb[i] = parseInt(match.slice(i2, i2 + 2), 16);\n\t\t}\n\n\t\tif (hexAlpha) {\n\t\t\trgb[3] = parseInt(hexAlpha, 16) / 255;\n\t\t}\n\t} else if (match = string.match(abbr)) {\n\t\tmatch = match[1];\n\t\thexAlpha = match[3];\n\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\trgb[i] = parseInt(match[i] + match[i], 16);\n\t\t}\n\n\t\tif (hexAlpha) {\n\t\t\trgb[3] = parseInt(hexAlpha + hexAlpha, 16) / 255;\n\t\t}\n\t} else if (match = string.match(rgba)) {\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\trgb[i] = parseInt(match[i + 1], 0);\n\t\t}\n\n\t\tif (match[4]) {\n\t\t\trgb[3] = parseFloat(match[4]);\n\t\t}\n\t} else if (match = string.match(per)) {\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\trgb[i] = Math.round(parseFloat(match[i + 1]) * 2.55);\n\t\t}\n\n\t\tif (match[4]) {\n\t\t\trgb[3] = parseFloat(match[4]);\n\t\t}\n\t} else if (match = string.match(keyword)) {\n\t\tif (match[1] === 'transparent') {\n\t\t\treturn [0, 0, 0, 0];\n\t\t}\n\n\t\trgb = colorNames[match[1]];\n\n\t\tif (!rgb) {\n\t\t\treturn null;\n\t\t}\n\n\t\trgb[3] = 1;\n\n\t\treturn rgb;\n\t} else {\n\t\treturn null;\n\t}\n\n\tfor (i = 0; i < 3; i++) {\n\t\trgb[i] = clamp(rgb[i], 0, 255);\n\t}\n\trgb[3] = clamp(rgb[3], 0, 1);\n\n\treturn rgb;\n};\n\ncs.get.hsl = function (string) {\n\tif (!string) {\n\t\treturn null;\n\t}\n\n\tvar hsl = /^hsla?\\(\\s*([+-]?(?:\\d{0,3}\\.)?\\d+)(?:deg)?\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*(?:[,|\\/]\\s*([+-]?[\\d\\.]+)\\s*)?\\)$/;\n\tvar match = string.match(hsl);\n\n\tif (match) {\n\t\tvar alpha = parseFloat(match[4]);\n\t\tvar h = (parseFloat(match[1]) + 360) % 360;\n\t\tvar s = clamp(parseFloat(match[2]), 0, 100);\n\t\tvar l = clamp(parseFloat(match[3]), 0, 100);\n\t\tvar a = clamp(isNaN(alpha) ? 1 : alpha, 0, 1);\n\n\t\treturn [h, s, l, a];\n\t}\n\n\treturn null;\n};\n\ncs.get.hwb = function (string) {\n\tif (!string) {\n\t\treturn null;\n\t}\n\n\tvar hwb = /^hwb\\(\\s*([+-]?\\d{0,3}(?:\\.\\d+)?)(?:deg)?\\s*,\\s*([+-]?[\\d\\.]+)%\\s*,\\s*([+-]?[\\d\\.]+)%\\s*(?:,\\s*([+-]?[\\d\\.]+)\\s*)?\\)$/;\n\tvar match = string.match(hwb);\n\n\tif (match) {\n\t\tvar alpha = parseFloat(match[4]);\n\t\tvar h = ((parseFloat(match[1]) % 360) + 360) % 360;\n\t\tvar w = clamp(parseFloat(match[2]), 0, 100);\n\t\tvar b = clamp(parseFloat(match[3]), 0, 100);\n\t\tvar a = clamp(isNaN(alpha) ? 1 : alpha, 0, 1);\n\t\treturn [h, w, b, a];\n\t}\n\n\treturn null;\n};\n\ncs.to.hex = function () {\n\tvar rgba = swizzle(arguments);\n\n\treturn (\n\t\t'#' +\n\t\thexDouble(rgba[0]) +\n\t\thexDouble(rgba[1]) +\n\t\thexDouble(rgba[2]) +\n\t\t(rgba[3] < 1\n\t\t\t? (hexDouble(Math.round(rgba[3] * 255)))\n\t\t\t: '')\n\t);\n};\n\ncs.to.rgb = function () {\n\tvar rgba = swizzle(arguments);\n\n\treturn rgba.length < 4 || rgba[3] === 1\n\t\t? 'rgb(' + Math.round(rgba[0]) + ', ' + Math.round(rgba[1]) + ', ' + Math.round(rgba[2]) + ')'\n\t\t: 'rgba(' + Math.round(rgba[0]) + ', ' + Math.round(rgba[1]) + ', ' + Math.round(rgba[2]) + ', ' + rgba[3] + ')';\n};\n\ncs.to.rgb.percent = function () {\n\tvar rgba = swizzle(arguments);\n\n\tvar r = Math.round(rgba[0] / 255 * 100);\n\tvar g = Math.round(rgba[1] / 255 * 100);\n\tvar b = Math.round(rgba[2] / 255 * 100);\n\n\treturn rgba.length < 4 || rgba[3] === 1\n\t\t? 'rgb(' + r + '%, ' + g + '%, ' + b + '%)'\n\t\t: 'rgba(' + r + '%, ' + g + '%, ' + b + '%, ' + rgba[3] + ')';\n};\n\ncs.to.hsl = function () {\n\tvar hsla = swizzle(arguments);\n\treturn hsla.length < 4 || hsla[3] === 1\n\t\t? 'hsl(' + hsla[0] + ', ' + hsla[1] + '%, ' + hsla[2] + '%)'\n\t\t: 'hsla(' + hsla[0] + ', ' + hsla[1] + '%, ' + hsla[2] + '%, ' + hsla[3] + ')';\n};\n\n// hwb is a bit different than rgb(a) & hsl(a) since there is no alpha specific syntax\n// (hwb have alpha optional & 1 is default value)\ncs.to.hwb = function () {\n\tvar hwba = swizzle(arguments);\n\n\tvar a = '';\n\tif (hwba.length >= 4 && hwba[3] !== 1) {\n\t\ta = ', ' + hwba[3];\n\t}\n\n\treturn 'hwb(' + hwba[0] + ', ' + hwba[1] + '%, ' + hwba[2] + '%' + a + ')';\n};\n\ncs.to.keyword = function (rgb) {\n\treturn reverseNames[rgb.slice(0, 3)];\n};\n\n// helpers\nfunction clamp(num, min, max) {\n\treturn Math.min(Math.max(min, num), max);\n}\n\nfunction hexDouble(num) {\n\tvar str = num.toString(16).toUpperCase();\n\treturn (str.length < 2) ? '0' + str : str;\n}\n","'use strict'\r\n\r\nmodule.exports = {\r\n\t\"aliceblue\": [240, 248, 255],\r\n\t\"antiquewhite\": [250, 235, 215],\r\n\t\"aqua\": [0, 255, 255],\r\n\t\"aquamarine\": [127, 255, 212],\r\n\t\"azure\": [240, 255, 255],\r\n\t\"beige\": [245, 245, 220],\r\n\t\"bisque\": [255, 228, 196],\r\n\t\"black\": [0, 0, 0],\r\n\t\"blanchedalmond\": [255, 235, 205],\r\n\t\"blue\": [0, 0, 255],\r\n\t\"blueviolet\": [138, 43, 226],\r\n\t\"brown\": [165, 42, 42],\r\n\t\"burlywood\": [222, 184, 135],\r\n\t\"cadetblue\": [95, 158, 160],\r\n\t\"chartreuse\": [127, 255, 0],\r\n\t\"chocolate\": [210, 105, 30],\r\n\t\"coral\": [255, 127, 80],\r\n\t\"cornflowerblue\": [100, 149, 237],\r\n\t\"cornsilk\": [255, 248, 220],\r\n\t\"crimson\": [220, 20, 60],\r\n\t\"cyan\": [0, 255, 255],\r\n\t\"darkblue\": [0, 0, 139],\r\n\t\"darkcyan\": [0, 139, 139],\r\n\t\"darkgoldenrod\": [184, 134, 11],\r\n\t\"darkgray\": [169, 169, 169],\r\n\t\"darkgreen\": [0, 100, 0],\r\n\t\"darkgrey\": [169, 169, 169],\r\n\t\"darkkhaki\": [189, 183, 107],\r\n\t\"darkmagenta\": [139, 0, 139],\r\n\t\"darkolivegreen\": [85, 107, 47],\r\n\t\"darkorange\": [255, 140, 0],\r\n\t\"darkorchid\": [153, 50, 204],\r\n\t\"darkred\": [139, 0, 0],\r\n\t\"darksalmon\": [233, 150, 122],\r\n\t\"darkseagreen\": [143, 188, 143],\r\n\t\"darkslateblue\": [72, 61, 139],\r\n\t\"darkslategray\": [47, 79, 79],\r\n\t\"darkslategrey\": [47, 79, 79],\r\n\t\"darkturquoise\": [0, 206, 209],\r\n\t\"darkviolet\": [148, 0, 211],\r\n\t\"deeppink\": [255, 20, 147],\r\n\t\"deepskyblue\": [0, 191, 255],\r\n\t\"dimgray\": [105, 105, 105],\r\n\t\"dimgrey\": [105, 105, 105],\r\n\t\"dodgerblue\": [30, 144, 255],\r\n\t\"firebrick\": [178, 34, 34],\r\n\t\"floralwhite\": [255, 250, 240],\r\n\t\"forestgreen\": [34, 139, 34],\r\n\t\"fuchsia\": [255, 0, 255],\r\n\t\"gainsboro\": [220, 220, 220],\r\n\t\"ghostwhite\": [248, 248, 255],\r\n\t\"gold\": [255, 215, 0],\r\n\t\"goldenrod\": [218, 165, 32],\r\n\t\"gray\": [128, 128, 128],\r\n\t\"green\": [0, 128, 0],\r\n\t\"greenyellow\": [173, 255, 47],\r\n\t\"grey\": [128, 128, 128],\r\n\t\"honeydew\": [240, 255, 240],\r\n\t\"hotpink\": [255, 105, 180],\r\n\t\"indianred\": [205, 92, 92],\r\n\t\"indigo\": [75, 0, 130],\r\n\t\"ivory\": [255, 255, 240],\r\n\t\"khaki\": [240, 230, 140],\r\n\t\"lavender\": [230, 230, 250],\r\n\t\"lavenderblush\": [255, 240, 245],\r\n\t\"lawngreen\": [124, 252, 0],\r\n\t\"lemonchiffon\": [255, 250, 205],\r\n\t\"lightblue\": [173, 216, 230],\r\n\t\"lightcoral\": [240, 128, 128],\r\n\t\"lightcyan\": [224, 255, 255],\r\n\t\"lightgoldenrodyellow\": [250, 250, 210],\r\n\t\"lightgray\": [211, 211, 211],\r\n\t\"lightgreen\": [144, 238, 144],\r\n\t\"lightgrey\": [211, 211, 211],\r\n\t\"lightpink\": [255, 182, 193],\r\n\t\"lightsalmon\": [255, 160, 122],\r\n\t\"lightseagreen\": [32, 178, 170],\r\n\t\"lightskyblue\": [135, 206, 250],\r\n\t\"lightslategray\": [119, 136, 153],\r\n\t\"lightslategrey\": [119, 136, 153],\r\n\t\"lightsteelblue\": [176, 196, 222],\r\n\t\"lightyellow\": [255, 255, 224],\r\n\t\"lime\": [0, 255, 0],\r\n\t\"limegreen\": [50, 205, 50],\r\n\t\"linen\": [250, 240, 230],\r\n\t\"magenta\": [255, 0, 255],\r\n\t\"maroon\": [128, 0, 0],\r\n\t\"mediumaquamarine\": [102, 205, 170],\r\n\t\"mediumblue\": [0, 0, 205],\r\n\t\"mediumorchid\": [186, 85, 211],\r\n\t\"mediumpurple\": [147, 112, 219],\r\n\t\"mediumseagreen\": [60, 179, 113],\r\n\t\"mediumslateblue\": [123, 104, 238],\r\n\t\"mediumspringgreen\": [0, 250, 154],\r\n\t\"mediumturquoise\": [72, 209, 204],\r\n\t\"mediumvioletred\": [199, 21, 133],\r\n\t\"midnightblue\": [25, 25, 112],\r\n\t\"mintcream\": [245, 255, 250],\r\n\t\"mistyrose\": [255, 228, 225],\r\n\t\"moccasin\": [255, 228, 181],\r\n\t\"navajowhite\": [255, 222, 173],\r\n\t\"navy\": [0, 0, 128],\r\n\t\"oldlace\": [253, 245, 230],\r\n\t\"olive\": [128, 128, 0],\r\n\t\"olivedrab\": [107, 142, 35],\r\n\t\"orange\": [255, 165, 0],\r\n\t\"orangered\": [255, 69, 0],\r\n\t\"orchid\": [218, 112, 214],\r\n\t\"palegoldenrod\": [238, 232, 170],\r\n\t\"palegreen\": [152, 251, 152],\r\n\t\"paleturquoise\": [175, 238, 238],\r\n\t\"palevioletred\": [219, 112, 147],\r\n\t\"papayawhip\": [255, 239, 213],\r\n\t\"peachpuff\": [255, 218, 185],\r\n\t\"peru\": [205, 133, 63],\r\n\t\"pink\": [255, 192, 203],\r\n\t\"plum\": [221, 160, 221],\r\n\t\"powderblue\": [176, 224, 230],\r\n\t\"purple\": [128, 0, 128],\r\n\t\"rebeccapurple\": [102, 51, 153],\r\n\t\"red\": [255, 0, 0],\r\n\t\"rosybrown\": [188, 143, 143],\r\n\t\"royalblue\": [65, 105, 225],\r\n\t\"saddlebrown\": [139, 69, 19],\r\n\t\"salmon\": [250, 128, 114],\r\n\t\"sandybrown\": [244, 164, 96],\r\n\t\"seagreen\": [46, 139, 87],\r\n\t\"seashell\": [255, 245, 238],\r\n\t\"sienna\": [160, 82, 45],\r\n\t\"silver\": [192, 192, 192],\r\n\t\"skyblue\": [135, 206, 235],\r\n\t\"slateblue\": [106, 90, 205],\r\n\t\"slategray\": [112, 128, 144],\r\n\t\"slategrey\": [112, 128, 144],\r\n\t\"snow\": [255, 250, 250],\r\n\t\"springgreen\": [0, 255, 127],\r\n\t\"steelblue\": [70, 130, 180],\r\n\t\"tan\": [210, 180, 140],\r\n\t\"teal\": [0, 128, 128],\r\n\t\"thistle\": [216, 191, 216],\r\n\t\"tomato\": [255, 99, 71],\r\n\t\"turquoise\": [64, 224, 208],\r\n\t\"violet\": [238, 130, 238],\r\n\t\"wheat\": [245, 222, 179],\r\n\t\"white\": [255, 255, 255],\r\n\t\"whitesmoke\": [245, 245, 245],\r\n\t\"yellow\": [255, 255, 0],\r\n\t\"yellowgreen\": [154, 205, 50]\r\n};\r\n","'use strict';\n\nvar isArrayish = require('is-arrayish');\n\nvar concat = Array.prototype.concat;\nvar slice = Array.prototype.slice;\n\nvar swizzle = module.exports = function swizzle(args) {\n\tvar results = [];\n\n\tfor (var i = 0, len = args.length; i < len; i++) {\n\t\tvar arg = args[i];\n\n\t\tif (isArrayish(arg)) {\n\t\t\t// http://jsperf.com/javascript-array-concat-vs-push/98\n\t\t\tresults = concat.call(results, slice.call(arg));\n\t\t} else {\n\t\t\tresults.push(arg);\n\t\t}\n\t}\n\n\treturn results;\n};\n\nswizzle.wrap = function (fn) {\n\treturn function () {\n\t\treturn fn(swizzle(arguments));\n\t};\n};\n","module.exports = function isArrayish(obj) {\n\tif (!obj || typeof obj === 'string') {\n\t\treturn false;\n\t}\n\n\treturn obj instanceof Array || Array.isArray(obj) ||\n\t\t(obj.length >= 0 && (obj.splice instanceof Function ||\n\t\t\t(Object.getOwnPropertyDescriptor(obj, (obj.length - 1)) && obj.constructor.name !== 'String')));\n};\n","var conversions = require('./conversions');\nvar route = require('./route');\n\nvar convert = {};\n\nvar models = Object.keys(conversions);\n\nfunction wrapRaw(fn) {\n\tvar wrappedFn = function (args) {\n\t\tif (args === undefined || args === null) {\n\t\t\treturn args;\n\t\t}\n\n\t\tif (arguments.length > 1) {\n\t\t\targs = Array.prototype.slice.call(arguments);\n\t\t}\n\n\t\treturn fn(args);\n\t};\n\n\t// preserve .conversion property if there is one\n\tif ('conversion' in fn) {\n\t\twrappedFn.conversion = fn.conversion;\n\t}\n\n\treturn wrappedFn;\n}\n\nfunction wrapRounded(fn) {\n\tvar wrappedFn = function (args) {\n\t\tif (args === undefined || args === null) {\n\t\t\treturn args;\n\t\t}\n\n\t\tif (arguments.length > 1) {\n\t\t\targs = Array.prototype.slice.call(arguments);\n\t\t}\n\n\t\tvar result = fn(args);\n\n\t\t// we're assuming the result is an array here.\n\t\t// see notice in conversions.js; don't use box types\n\t\t// in conversion functions.\n\t\tif (typeof result === 'object') {\n\t\t\tfor (var len = result.length, i = 0; i < len; i++) {\n\t\t\t\tresult[i] = Math.round(result[i]);\n\t\t\t}\n\t\t}\n\n\t\treturn result;\n\t};\n\n\t// preserve .conversion property if there is one\n\tif ('conversion' in fn) {\n\t\twrappedFn.conversion = fn.conversion;\n\t}\n\n\treturn wrappedFn;\n}\n\nmodels.forEach(function (fromModel) {\n\tconvert[fromModel] = {};\n\n\tObject.defineProperty(convert[fromModel], 'channels', {value: conversions[fromModel].channels});\n\tObject.defineProperty(convert[fromModel], 'labels', {value: conversions[fromModel].labels});\n\n\tvar routes = route(fromModel);\n\tvar routeModels = Object.keys(routes);\n\n\trouteModels.forEach(function (toModel) {\n\t\tvar fn = routes[toModel];\n\n\t\tconvert[fromModel][toModel] = wrapRounded(fn);\n\t\tconvert[fromModel][toModel].raw = wrapRaw(fn);\n\t});\n});\n\nmodule.exports = convert;\n","'use strict'\r\n\r\nmodule.exports = {\r\n\t\"aliceblue\": [240, 248, 255],\r\n\t\"antiquewhite\": [250, 235, 215],\r\n\t\"aqua\": [0, 255, 255],\r\n\t\"aquamarine\": [127, 255, 212],\r\n\t\"azure\": [240, 255, 255],\r\n\t\"beige\": [245, 245, 220],\r\n\t\"bisque\": [255, 228, 196],\r\n\t\"black\": [0, 0, 0],\r\n\t\"blanchedalmond\": [255, 235, 205],\r\n\t\"blue\": [0, 0, 255],\r\n\t\"blueviolet\": [138, 43, 226],\r\n\t\"brown\": [165, 42, 42],\r\n\t\"burlywood\": [222, 184, 135],\r\n\t\"cadetblue\": [95, 158, 160],\r\n\t\"chartreuse\": [127, 255, 0],\r\n\t\"chocolate\": [210, 105, 30],\r\n\t\"coral\": [255, 127, 80],\r\n\t\"cornflowerblue\": [100, 149, 237],\r\n\t\"cornsilk\": [255, 248, 220],\r\n\t\"crimson\": [220, 20, 60],\r\n\t\"cyan\": [0, 255, 255],\r\n\t\"darkblue\": [0, 0, 139],\r\n\t\"darkcyan\": [0, 139, 139],\r\n\t\"darkgoldenrod\": [184, 134, 11],\r\n\t\"darkgray\": [169, 169, 169],\r\n\t\"darkgreen\": [0, 100, 0],\r\n\t\"darkgrey\": [169, 169, 169],\r\n\t\"darkkhaki\": [189, 183, 107],\r\n\t\"darkmagenta\": [139, 0, 139],\r\n\t\"darkolivegreen\": [85, 107, 47],\r\n\t\"darkorange\": [255, 140, 0],\r\n\t\"darkorchid\": [153, 50, 204],\r\n\t\"darkred\": [139, 0, 0],\r\n\t\"darksalmon\": [233, 150, 122],\r\n\t\"darkseagreen\": [143, 188, 143],\r\n\t\"darkslateblue\": [72, 61, 139],\r\n\t\"darkslategray\": [47, 79, 79],\r\n\t\"darkslategrey\": [47, 79, 79],\r\n\t\"darkturquoise\": [0, 206, 209],\r\n\t\"darkviolet\": [148, 0, 211],\r\n\t\"deeppink\": [255, 20, 147],\r\n\t\"deepskyblue\": [0, 191, 255],\r\n\t\"dimgray\": [105, 105, 105],\r\n\t\"dimgrey\": [105, 105, 105],\r\n\t\"dodgerblue\": [30, 144, 255],\r\n\t\"firebrick\": [178, 34, 34],\r\n\t\"floralwhite\": [255, 250, 240],\r\n\t\"forestgreen\": [34, 139, 34],\r\n\t\"fuchsia\": [255, 0, 255],\r\n\t\"gainsboro\": [220, 220, 220],\r\n\t\"ghostwhite\": [248, 248, 255],\r\n\t\"gold\": [255, 215, 0],\r\n\t\"goldenrod\": [218, 165, 32],\r\n\t\"gray\": [128, 128, 128],\r\n\t\"green\": [0, 128, 0],\r\n\t\"greenyellow\": [173, 255, 47],\r\n\t\"grey\": [128, 128, 128],\r\n\t\"honeydew\": [240, 255, 240],\r\n\t\"hotpink\": [255, 105, 180],\r\n\t\"indianred\": [205, 92, 92],\r\n\t\"indigo\": [75, 0, 130],\r\n\t\"ivory\": [255, 255, 240],\r\n\t\"khaki\": [240, 230, 140],\r\n\t\"lavender\": [230, 230, 250],\r\n\t\"lavenderblush\": [255, 240, 245],\r\n\t\"lawngreen\": [124, 252, 0],\r\n\t\"lemonchiffon\": [255, 250, 205],\r\n\t\"lightblue\": [173, 216, 230],\r\n\t\"lightcoral\": [240, 128, 128],\r\n\t\"lightcyan\": [224, 255, 255],\r\n\t\"lightgoldenrodyellow\": [250, 250, 210],\r\n\t\"lightgray\": [211, 211, 211],\r\n\t\"lightgreen\": [144, 238, 144],\r\n\t\"lightgrey\": [211, 211, 211],\r\n\t\"lightpink\": [255, 182, 193],\r\n\t\"lightsalmon\": [255, 160, 122],\r\n\t\"lightseagreen\": [32, 178, 170],\r\n\t\"lightskyblue\": [135, 206, 250],\r\n\t\"lightslategray\": [119, 136, 153],\r\n\t\"lightslategrey\": [119, 136, 153],\r\n\t\"lightsteelblue\": [176, 196, 222],\r\n\t\"lightyellow\": [255, 255, 224],\r\n\t\"lime\": [0, 255, 0],\r\n\t\"limegreen\": [50, 205, 50],\r\n\t\"linen\": [250, 240, 230],\r\n\t\"magenta\": [255, 0, 255],\r\n\t\"maroon\": [128, 0, 0],\r\n\t\"mediumaquamarine\": [102, 205, 170],\r\n\t\"mediumblue\": [0, 0, 205],\r\n\t\"mediumorchid\": [186, 85, 211],\r\n\t\"mediumpurple\": [147, 112, 219],\r\n\t\"mediumseagreen\": [60, 179, 113],\r\n\t\"mediumslateblue\": [123, 104, 238],\r\n\t\"mediumspringgreen\": [0, 250, 154],\r\n\t\"mediumturquoise\": [72, 209, 204],\r\n\t\"mediumvioletred\": [199, 21, 133],\r\n\t\"midnightblue\": [25, 25, 112],\r\n\t\"mintcream\": [245, 255, 250],\r\n\t\"mistyrose\": [255, 228, 225],\r\n\t\"moccasin\": [255, 228, 181],\r\n\t\"navajowhite\": [255, 222, 173],\r\n\t\"navy\": [0, 0, 128],\r\n\t\"oldlace\": [253, 245, 230],\r\n\t\"olive\": [128, 128, 0],\r\n\t\"olivedrab\": [107, 142, 35],\r\n\t\"orange\": [255, 165, 0],\r\n\t\"orangered\": [255, 69, 0],\r\n\t\"orchid\": [218, 112, 214],\r\n\t\"palegoldenrod\": [238, 232, 170],\r\n\t\"palegreen\": [152, 251, 152],\r\n\t\"paleturquoise\": [175, 238, 238],\r\n\t\"palevioletred\": [219, 112, 147],\r\n\t\"papayawhip\": [255, 239, 213],\r\n\t\"peachpuff\": [255, 218, 185],\r\n\t\"peru\": [205, 133, 63],\r\n\t\"pink\": [255, 192, 203],\r\n\t\"plum\": [221, 160, 221],\r\n\t\"powderblue\": [176, 224, 230],\r\n\t\"purple\": [128, 0, 128],\r\n\t\"rebeccapurple\": [102, 51, 153],\r\n\t\"red\": [255, 0, 0],\r\n\t\"rosybrown\": [188, 143, 143],\r\n\t\"royalblue\": [65, 105, 225],\r\n\t\"saddlebrown\": [139, 69, 19],\r\n\t\"salmon\": [250, 128, 114],\r\n\t\"sandybrown\": [244, 164, 96],\r\n\t\"seagreen\": [46, 139, 87],\r\n\t\"seashell\": [255, 245, 238],\r\n\t\"sienna\": [160, 82, 45],\r\n\t\"silver\": [192, 192, 192],\r\n\t\"skyblue\": [135, 206, 235],\r\n\t\"slateblue\": [106, 90, 205],\r\n\t\"slategray\": [112, 128, 144],\r\n\t\"slategrey\": [112, 128, 144],\r\n\t\"snow\": [255, 250, 250],\r\n\t\"springgreen\": [0, 255, 127],\r\n\t\"steelblue\": [70, 130, 180],\r\n\t\"tan\": [210, 180, 140],\r\n\t\"teal\": [0, 128, 128],\r\n\t\"thistle\": [216, 191, 216],\r\n\t\"tomato\": [255, 99, 71],\r\n\t\"turquoise\": [64, 224, 208],\r\n\t\"violet\": [238, 130, 238],\r\n\t\"wheat\": [245, 222, 179],\r\n\t\"white\": [255, 255, 255],\r\n\t\"whitesmoke\": [245, 245, 245],\r\n\t\"yellow\": [255, 255, 0],\r\n\t\"yellowgreen\": [154, 205, 50]\r\n};\r\n","var conversions = require('./conversions');\n\n/*\n\tthis function routes a model to all other models.\n\n\tall functions that are routed have a property `.conversion` attached\n\tto the returned synthetic function. This property is an array\n\tof strings, each with the steps in between the 'from' and 'to'\n\tcolor models (inclusive).\n\n\tconversions that are not possible simply are not included.\n*/\n\nfunction buildGraph() {\n\tvar graph = {};\n\t// https://jsperf.com/object-keys-vs-for-in-with-closure/3\n\tvar models = Object.keys(conversions);\n\n\tfor (var len = models.length, i = 0; i < len; i++) {\n\t\tgraph[models[i]] = {\n\t\t\t// http://jsperf.com/1-vs-infinity\n\t\t\t// micro-opt, but this is simple.\n\t\t\tdistance: -1,\n\t\t\tparent: null\n\t\t};\n\t}\n\n\treturn graph;\n}\n\n// https://en.wikipedia.org/wiki/Breadth-first_search\nfunction deriveBFS(fromModel) {\n\tvar graph = buildGraph();\n\tvar queue = [fromModel]; // unshift -> queue -> pop\n\n\tgraph[fromModel].distance = 0;\n\n\twhile (queue.length) {\n\t\tvar current = queue.pop();\n\t\tvar adjacents = Object.keys(conversions[current]);\n\n\t\tfor (var len = adjacents.length, i = 0; i < len; i++) {\n\t\t\tvar adjacent = adjacents[i];\n\t\t\tvar node = graph[adjacent];\n\n\t\t\tif (node.distance === -1) {\n\t\t\t\tnode.distance = graph[current].distance + 1;\n\t\t\t\tnode.parent = current;\n\t\t\t\tqueue.unshift(adjacent);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn graph;\n}\n\nfunction link(from, to) {\n\treturn function (args) {\n\t\treturn to(from(args));\n\t};\n}\n\nfunction wrapConversion(toModel, graph) {\n\tvar path = [graph[toModel].parent, toModel];\n\tvar fn = conversions[graph[toModel].parent][toModel];\n\n\tvar cur = graph[toModel].parent;\n\twhile (graph[cur].parent) {\n\t\tpath.unshift(graph[cur].parent);\n\t\tfn = link(conversions[graph[cur].parent][cur], fn);\n\t\tcur = graph[cur].parent;\n\t}\n\n\tfn.conversion = path;\n\treturn fn;\n}\n\nmodule.exports = function (fromModel) {\n\tvar graph = deriveBFS(fromModel);\n\tvar conversion = {};\n\n\tvar models = Object.keys(graph);\n\tfor (var len = models.length, i = 0; i < len; i++) {\n\t\tvar toModel = models[i];\n\t\tvar node = graph[toModel];\n\n\t\tif (node.parent === null) {\n\t\t\t// no possible conversion, or this node is the source model.\n\t\t\tcontinue;\n\t\t}\n\n\t\tconversion[toModel] = wrapConversion(toModel, graph);\n\t}\n\n\treturn conversion;\n};\n\n","/**\n * Copyright (c) 2014, Chris Pettitt\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n *\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the documentation\n * and/or other materials provided with the distribution.\n *\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nvar lib = require(\"./lib\");\n\nmodule.exports = {\n Graph: lib.Graph,\n json: require(\"./lib/json\"),\n alg: require(\"./lib/alg\"),\n version: lib.version\n};\n","// Includes only the \"core\" of graphlib\nmodule.exports = {\n Graph: require(\"./graph\"),\n version: require(\"./version\")\n};\n","var baseClone = require('./_baseClone');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\nfunction clone(value) {\n return baseClone(value, CLONE_SYMBOLS_FLAG);\n}\n\nmodule.exports = clone;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nmodule.exports = listCacheDelete;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nmodule.exports = listCacheSet;\n","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nmodule.exports = stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nmodule.exports = stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n","var ListCache = require('./_ListCache'),\n Map = require('./_Map'),\n MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nmodule.exports = stackSet;\n","var isFunction = require('./isFunction'),\n isMasked = require('./_isMasked'),\n isObject = require('./isObject'),\n toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n","var Hash = require('./_Hash'),\n ListCache = require('./_ListCache'),\n Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nmodule.exports = mapCacheClear;\n","var hashClear = require('./_hashClear'),\n hashDelete = require('./_hashDelete'),\n hashGet = require('./_hashGet'),\n hashHas = require('./_hashHas'),\n hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nmodule.exports = hashClear;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = hashDelete;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nmodule.exports = hashSet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = mapCacheDelete;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nmodule.exports = isKeyable;\n","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nmodule.exports = mapCacheSet;\n","var copyObject = require('./_copyObject'),\n keys = require('./keys');\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n}\n\nmodule.exports = baseAssign;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nmodule.exports = baseTimes;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = stubFalse;\n","var baseGetTag = require('./_baseGetTag'),\n isLength = require('./isLength'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n","var overArg = require('./_overArg');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nmodule.exports = nativeKeys;\n","var copyObject = require('./_copyObject'),\n keysIn = require('./keysIn');\n\n/**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n}\n\nmodule.exports = baseAssignIn;\n","var isObject = require('./isObject'),\n isPrototype = require('./_isPrototype'),\n nativeKeysIn = require('./_nativeKeysIn');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n if (!isObject(object)) {\n return nativeKeysIn(object);\n }\n var isProto = isPrototype(object),\n result = [];\n\n for (var key in object) {\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeysIn;\n","/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n var result = [];\n if (object != null) {\n for (var key in Object(object)) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = nativeKeysIn;\n","var copyObject = require('./_copyObject'),\n getSymbols = require('./_getSymbols');\n\n/**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n}\n\nmodule.exports = copySymbols;\n","var copyObject = require('./_copyObject'),\n getSymbolsIn = require('./_getSymbolsIn');\n\n/**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n}\n\nmodule.exports = copySymbolsIn;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbolsIn = require('./_getSymbolsIn'),\n keysIn = require('./keysIn');\n\n/**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n}\n\nmodule.exports = getAllKeysIn;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nmodule.exports = DataView;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nmodule.exports = Promise;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n}\n\nmodule.exports = initCloneArray;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer'),\n cloneDataView = require('./_cloneDataView'),\n cloneRegExp = require('./_cloneRegExp'),\n cloneSymbol = require('./_cloneSymbol'),\n cloneTypedArray = require('./_cloneTypedArray');\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n}\n\nmodule.exports = initCloneByTag;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\nmodule.exports = cloneDataView;\n","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n}\n\nmodule.exports = cloneRegExp;\n","var Symbol = require('./_Symbol');\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nmodule.exports = cloneSymbol;\n","var baseIsMap = require('./_baseIsMap'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsMap = nodeUtil && nodeUtil.isMap;\n\n/**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\nvar isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\nmodule.exports = isMap;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]';\n\n/**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\nfunction baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n}\n\nmodule.exports = baseIsMap;\n","var baseIsSet = require('./_baseIsSet'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsSet = nodeUtil && nodeUtil.isSet;\n\n/**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\nvar isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\nmodule.exports = isSet;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar setTag = '[object Set]';\n\n/**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\nfunction baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n}\n\nmodule.exports = baseIsSet;\n","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n}\n\nmodule.exports = createBaseFor;\n","var isArrayLike = require('./isArrayLike');\n\n/**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n}\n\nmodule.exports = createBaseEach;\n","var baseEach = require('./_baseEach');\n\n/**\n * The base implementation of `_.filter` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction baseFilter(collection, predicate) {\n var result = [];\n baseEach(collection, function(value, index, collection) {\n if (predicate(value, index, collection)) {\n result.push(value);\n }\n });\n return result;\n}\n\nmodule.exports = baseFilter;\n","var baseIsMatch = require('./_baseIsMatch'),\n getMatchData = require('./_getMatchData'),\n matchesStrictComparable = require('./_matchesStrictComparable');\n\n/**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n}\n\nmodule.exports = baseMatches;\n","var Stack = require('./_Stack'),\n baseIsEqual = require('./_baseIsEqual');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\nfunction baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\n}\n\nmodule.exports = baseIsMatch;\n","var Stack = require('./_Stack'),\n equalArrays = require('./_equalArrays'),\n equalByTag = require('./_equalByTag'),\n equalObjects = require('./_equalObjects'),\n getTag = require('./_getTag'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isTypedArray = require('./isTypedArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\nmodule.exports = baseIsEqualDeep;\n","/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\nmodule.exports = setCacheAdd;\n","/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\nmodule.exports = setCacheHas;\n","/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\nmodule.exports = arraySome;\n","var Symbol = require('./_Symbol'),\n Uint8Array = require('./_Uint8Array'),\n eq = require('./eq'),\n equalArrays = require('./_equalArrays'),\n mapToArray = require('./_mapToArray'),\n setToArray = require('./_setToArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\nmodule.exports = equalByTag;\n","/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\nmodule.exports = mapToArray;\n","var getAllKeys = require('./_getAllKeys');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Check that cyclic values are equal.\n var objStacked = stack.get(object);\n var othStacked = stack.get(other);\n if (objStacked && othStacked) {\n return objStacked == other && othStacked == object;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalObjects;\n","var isStrictComparable = require('./_isStrictComparable'),\n keys = require('./keys');\n\n/**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\nfunction getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\n}\n\nmodule.exports = getMatchData;\n","var baseIsEqual = require('./_baseIsEqual'),\n get = require('./get'),\n hasIn = require('./hasIn'),\n isKey = require('./_isKey'),\n isStrictComparable = require('./_isStrictComparable'),\n matchesStrictComparable = require('./_matchesStrictComparable'),\n toKey = require('./_toKey');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n };\n}\n\nmodule.exports = baseMatchesProperty;\n","var baseGet = require('./_baseGet');\n\n/**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\nfunction get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n}\n\nmodule.exports = get;\n","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nmodule.exports = stringToPath;\n","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nmodule.exports = memoizeCapped;\n","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n","var Symbol = require('./_Symbol'),\n arrayMap = require('./_arrayMap'),\n isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\n","/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n return object != null && key in Object(object);\n}\n\nmodule.exports = baseHasIn;\n","var baseProperty = require('./_baseProperty'),\n basePropertyDeep = require('./_basePropertyDeep'),\n isKey = require('./_isKey'),\n toKey = require('./_toKey');\n\n/**\n * Creates a function that returns the value at `path` of a given object.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var objects = [\n * { 'a': { 'b': 2 } },\n * { 'a': { 'b': 1 } }\n * ];\n *\n * _.map(objects, _.property('a.b'));\n * // => [2, 1]\n *\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\n * // => [1, 2]\n */\nfunction property(path) {\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\n}\n\nmodule.exports = property;\n","var baseGet = require('./_baseGet');\n\n/**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n}\n\nmodule.exports = basePropertyDeep;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.has` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHas(object, key) {\n return object != null && hasOwnProperty.call(object, key);\n}\n\nmodule.exports = baseHas;\n","var baseKeys = require('./_baseKeys'),\n getTag = require('./_getTag'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isArrayLike = require('./isArrayLike'),\n isBuffer = require('./isBuffer'),\n isPrototype = require('./_isPrototype'),\n isTypedArray = require('./isTypedArray');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n setTag = '[object Set]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if `value` is an empty object, collection, map, or set.\n *\n * Objects are considered empty if they have no own enumerable string keyed\n * properties.\n *\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\n * jQuery-like collections are considered empty if they have a `length` of `0`.\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\n * @example\n *\n * _.isEmpty(null);\n * // => true\n *\n * _.isEmpty(true);\n * // => true\n *\n * _.isEmpty(1);\n * // => true\n *\n * _.isEmpty([1, 2, 3]);\n * // => false\n *\n * _.isEmpty({ 'a': 1 });\n * // => false\n */\nfunction isEmpty(value) {\n if (value == null) {\n return true;\n }\n if (isArrayLike(value) &&\n (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\n isBuffer(value) || isTypedArray(value) || isArguments(value))) {\n return !value.length;\n }\n var tag = getTag(value);\n if (tag == mapTag || tag == setTag) {\n return !value.size;\n }\n if (isPrototype(value)) {\n return !baseKeys(value).length;\n }\n for (var key in value) {\n if (hasOwnProperty.call(value, key)) {\n return false;\n }\n }\n return true;\n}\n\nmodule.exports = isEmpty;\n","/**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n if (initAccum && length) {\n accumulator = array[++index];\n }\n while (++index < length) {\n accumulator = iteratee(accumulator, array[index], index, array);\n }\n return accumulator;\n}\n\nmodule.exports = arrayReduce;\n","/**\n * The base implementation of `_.reduce` and `_.reduceRight`, without support\n * for iteratee shorthands, which iterates over `collection` using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} accumulator The initial value.\n * @param {boolean} initAccum Specify using the first or last element of\n * `collection` as the initial value.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the accumulated value.\n */\nfunction baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {\n eachFunc(collection, function(value, index, collection) {\n accumulator = initAccum\n ? (initAccum = false, value)\n : iteratee(accumulator, value, index, collection);\n });\n return accumulator;\n}\n\nmodule.exports = baseReduce;\n","var baseKeys = require('./_baseKeys'),\n getTag = require('./_getTag'),\n isArrayLike = require('./isArrayLike'),\n isString = require('./isString'),\n stringSize = require('./_stringSize');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n setTag = '[object Set]';\n\n/**\n * Gets the size of `collection` by returning its length for array-like\n * values or the number of own enumerable string keyed properties for objects.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @returns {number} Returns the collection size.\n * @example\n *\n * _.size([1, 2, 3]);\n * // => 3\n *\n * _.size({ 'a': 1, 'b': 2 });\n * // => 2\n *\n * _.size('pebbles');\n * // => 7\n */\nfunction size(collection) {\n if (collection == null) {\n return 0;\n }\n if (isArrayLike(collection)) {\n return isString(collection) ? stringSize(collection) : collection.length;\n }\n var tag = getTag(collection);\n if (tag == mapTag || tag == setTag) {\n return collection.size;\n }\n return baseKeys(collection).length;\n}\n\nmodule.exports = size;\n","var baseGetTag = require('./_baseGetTag'),\n isArray = require('./isArray'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar stringTag = '[object String]';\n\n/**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\nfunction isString(value) {\n return typeof value == 'string' ||\n (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\n}\n\nmodule.exports = isString;\n","var asciiSize = require('./_asciiSize'),\n hasUnicode = require('./_hasUnicode'),\n unicodeSize = require('./_unicodeSize');\n\n/**\n * Gets the number of symbols in `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the string size.\n */\nfunction stringSize(string) {\n return hasUnicode(string)\n ? unicodeSize(string)\n : asciiSize(string);\n}\n\nmodule.exports = stringSize;\n","var baseProperty = require('./_baseProperty');\n\n/**\n * Gets the size of an ASCII `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\nvar asciiSize = baseProperty('length');\n\nmodule.exports = asciiSize;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsZWJ = '\\\\u200d';\n\n/** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\nvar reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\n\n/**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\nfunction hasUnicode(string) {\n return reHasUnicode.test(string);\n}\n\nmodule.exports = hasUnicode;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsAstral = '[' + rsAstralRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\nvar reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n/**\n * Gets the size of a Unicode `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\nfunction unicodeSize(string) {\n var result = reUnicode.lastIndex = 0;\n while (reUnicode.test(string)) {\n ++result;\n }\n return result;\n}\n\nmodule.exports = unicodeSize;\n","var arrayEach = require('./_arrayEach'),\n baseCreate = require('./_baseCreate'),\n baseForOwn = require('./_baseForOwn'),\n baseIteratee = require('./_baseIteratee'),\n getPrototype = require('./_getPrototype'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isFunction = require('./isFunction'),\n isObject = require('./isObject'),\n isTypedArray = require('./isTypedArray');\n\n/**\n * An alternative to `_.reduce`; this method transforms `object` to a new\n * `accumulator` object which is the result of running each of its own\n * enumerable string keyed properties thru `iteratee`, with each invocation\n * potentially mutating the `accumulator` object. If `accumulator` is not\n * provided, a new object with the same `[[Prototype]]` will be used. The\n * iteratee is invoked with four arguments: (accumulator, value, key, object).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The custom accumulator value.\n * @returns {*} Returns the accumulated value.\n * @example\n *\n * _.transform([2, 3, 4], function(result, n) {\n * result.push(n *= n);\n * return n % 2 == 0;\n * }, []);\n * // => [4, 9]\n *\n * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] }\n */\nfunction transform(object, iteratee, accumulator) {\n var isArr = isArray(object),\n isArrLike = isArr || isBuffer(object) || isTypedArray(object);\n\n iteratee = baseIteratee(iteratee, 4);\n if (accumulator == null) {\n var Ctor = object && object.constructor;\n if (isArrLike) {\n accumulator = isArr ? new Ctor : [];\n }\n else if (isObject(object)) {\n accumulator = isFunction(Ctor) ? baseCreate(getPrototype(object)) : {};\n }\n else {\n accumulator = {};\n }\n }\n (isArrLike ? arrayEach : baseForOwn)(object, function(value, index, object) {\n return iteratee(accumulator, value, index, object);\n });\n return accumulator;\n}\n\nmodule.exports = transform;\n","var baseFlatten = require('./_baseFlatten'),\n baseRest = require('./_baseRest'),\n baseUniq = require('./_baseUniq'),\n isArrayLikeObject = require('./isArrayLikeObject');\n\n/**\n * Creates an array of unique values, in order, from all given arrays using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.union([2], [1, 2]);\n * // => [2, 1]\n */\nvar union = baseRest(function(arrays) {\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\n});\n\nmodule.exports = union;\n","var Symbol = require('./_Symbol'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray');\n\n/** Built-in value references. */\nvar spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined;\n\n/**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\nfunction isFlattenable(value) {\n return isArray(value) || isArguments(value) ||\n !!(spreadableSymbol && value && value[spreadableSymbol]);\n}\n\nmodule.exports = isFlattenable;\n","/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n switch (args.length) {\n case 0: return func.call(thisArg);\n case 1: return func.call(thisArg, args[0]);\n case 2: return func.call(thisArg, args[0], args[1]);\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\n }\n return func.apply(thisArg, args);\n}\n\nmodule.exports = apply;\n","var constant = require('./constant'),\n defineProperty = require('./_defineProperty'),\n identity = require('./identity');\n\n/**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar baseSetToString = !defineProperty ? identity : function(func, string) {\n return defineProperty(func, 'toString', {\n 'configurable': true,\n 'enumerable': false,\n 'value': constant(string),\n 'writable': true\n });\n};\n\nmodule.exports = baseSetToString;\n","/** Used to detect hot functions by number of calls within a span of milliseconds. */\nvar HOT_COUNT = 800,\n HOT_SPAN = 16;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeNow = Date.now;\n\n/**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\nfunction shortOut(func) {\n var count = 0,\n lastCalled = 0;\n\n return function() {\n var stamp = nativeNow(),\n remaining = HOT_SPAN - (stamp - lastCalled);\n\n lastCalled = stamp;\n if (remaining > 0) {\n if (++count >= HOT_COUNT) {\n return arguments[0];\n }\n } else {\n count = 0;\n }\n return func.apply(undefined, arguments);\n };\n}\n\nmodule.exports = shortOut;\n","var SetCache = require('./_SetCache'),\n arrayIncludes = require('./_arrayIncludes'),\n arrayIncludesWith = require('./_arrayIncludesWith'),\n cacheHas = require('./_cacheHas'),\n createSet = require('./_createSet'),\n setToArray = require('./_setToArray');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * The base implementation of `_.uniqBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\nfunction baseUniq(array, iteratee, comparator) {\n var index = -1,\n includes = arrayIncludes,\n length = array.length,\n isCommon = true,\n result = [],\n seen = result;\n\n if (comparator) {\n isCommon = false;\n includes = arrayIncludesWith;\n }\n else if (length >= LARGE_ARRAY_SIZE) {\n var set = iteratee ? null : createSet(array);\n if (set) {\n return setToArray(set);\n }\n isCommon = false;\n includes = cacheHas;\n seen = new SetCache;\n }\n else {\n seen = iteratee ? [] : result;\n }\n outer:\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (isCommon && computed === computed) {\n var seenIndex = seen.length;\n while (seenIndex--) {\n if (seen[seenIndex] === computed) {\n continue outer;\n }\n }\n if (iteratee) {\n seen.push(computed);\n }\n result.push(value);\n }\n else if (!includes(seen, computed, comparator)) {\n if (seen !== result) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n}\n\nmodule.exports = baseUniq;\n","var baseIndexOf = require('./_baseIndexOf');\n\n/**\n * A specialized version of `_.includes` for arrays without support for\n * specifying an index to search from.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludes(array, value) {\n var length = array == null ? 0 : array.length;\n return !!length && baseIndexOf(array, value, 0) > -1;\n}\n\nmodule.exports = arrayIncludes;\n","var baseFindIndex = require('./_baseFindIndex'),\n baseIsNaN = require('./_baseIsNaN'),\n strictIndexOf = require('./_strictIndexOf');\n\n/**\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseIndexOf(array, value, fromIndex) {\n return value === value\n ? strictIndexOf(array, value, fromIndex)\n : baseFindIndex(array, baseIsNaN, fromIndex);\n}\n\nmodule.exports = baseIndexOf;\n","/**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\nfunction baseIsNaN(value) {\n return value !== value;\n}\n\nmodule.exports = baseIsNaN;\n","/**\n * A specialized version of `_.indexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction strictIndexOf(array, value, fromIndex) {\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (array[index] === value) {\n return index;\n }\n }\n return -1;\n}\n\nmodule.exports = strictIndexOf;\n","/**\n * This function is like `arrayIncludes` except that it accepts a comparator.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludesWith(array, value, comparator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (comparator(value, array[index])) {\n return true;\n }\n }\n return false;\n}\n\nmodule.exports = arrayIncludesWith;\n","var Set = require('./_Set'),\n noop = require('./noop'),\n setToArray = require('./_setToArray');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Creates a set object of `values`.\n *\n * @private\n * @param {Array} values The values to add to the set.\n * @returns {Object} Returns the new set.\n */\nvar createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\n return new Set(values);\n};\n\nmodule.exports = createSet;\n","/**\n * This method returns `undefined`.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Util\n * @example\n *\n * _.times(2, _.noop);\n * // => [undefined, undefined]\n */\nfunction noop() {\n // No operation performed.\n}\n\nmodule.exports = noop;\n","var arrayMap = require('./_arrayMap');\n\n/**\n * The base implementation of `_.values` and `_.valuesIn` which creates an\n * array of `object` property values corresponding to the property names\n * of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the array of property values.\n */\nfunction baseValues(object, props) {\n return arrayMap(props, function(key) {\n return object[key];\n });\n}\n\nmodule.exports = baseValues;\n","module.exports = '2.1.8';\n","var _ = require(\"./lodash\");\nvar Graph = require(\"./graph\");\n\nmodule.exports = {\n write: write,\n read: read\n};\n\nfunction write(g) {\n var json = {\n options: {\n directed: g.isDirected(),\n multigraph: g.isMultigraph(),\n compound: g.isCompound()\n },\n nodes: writeNodes(g),\n edges: writeEdges(g)\n };\n if (!_.isUndefined(g.graph())) {\n json.value = _.clone(g.graph());\n }\n return json;\n}\n\nfunction writeNodes(g) {\n return _.map(g.nodes(), function(v) {\n var nodeValue = g.node(v);\n var parent = g.parent(v);\n var node = { v: v };\n if (!_.isUndefined(nodeValue)) {\n node.value = nodeValue;\n }\n if (!_.isUndefined(parent)) {\n node.parent = parent;\n }\n return node;\n });\n}\n\nfunction writeEdges(g) {\n return _.map(g.edges(), function(e) {\n var edgeValue = g.edge(e);\n var edge = { v: e.v, w: e.w };\n if (!_.isUndefined(e.name)) {\n edge.name = e.name;\n }\n if (!_.isUndefined(edgeValue)) {\n edge.value = edgeValue;\n }\n return edge;\n });\n}\n\nfunction read(json) {\n var g = new Graph(json.options).setGraph(json.value);\n _.each(json.nodes, function(entry) {\n g.setNode(entry.v, entry.value);\n if (entry.parent) {\n g.setParent(entry.v, entry.parent);\n }\n });\n _.each(json.edges, function(entry) {\n g.setEdge({ v: entry.v, w: entry.w, name: entry.name }, entry.value);\n });\n return g;\n}\n","module.exports = {\n components: require(\"./components\"),\n dijkstra: require(\"./dijkstra\"),\n dijkstraAll: require(\"./dijkstra-all\"),\n findCycles: require(\"./find-cycles\"),\n floydWarshall: require(\"./floyd-warshall\"),\n isAcyclic: require(\"./is-acyclic\"),\n postorder: require(\"./postorder\"),\n preorder: require(\"./preorder\"),\n prim: require(\"./prim\"),\n tarjan: require(\"./tarjan\"),\n topsort: require(\"./topsort\")\n};\n","var _ = require(\"../lodash\");\n\nmodule.exports = components;\n\nfunction components(g) {\n var visited = {};\n var cmpts = [];\n var cmpt;\n\n function dfs(v) {\n if (_.has(visited, v)) return;\n visited[v] = true;\n cmpt.push(v);\n _.each(g.successors(v), dfs);\n _.each(g.predecessors(v), dfs);\n }\n\n _.each(g.nodes(), function(v) {\n cmpt = [];\n dfs(v);\n if (cmpt.length) {\n cmpts.push(cmpt);\n }\n });\n\n return cmpts;\n}\n","var dijkstra = require(\"./dijkstra\");\nvar _ = require(\"../lodash\");\n\nmodule.exports = dijkstraAll;\n\nfunction dijkstraAll(g, weightFunc, edgeFunc) {\n return _.transform(g.nodes(), function(acc, v) {\n acc[v] = dijkstra(g, v, weightFunc, edgeFunc);\n }, {});\n}\n","var _ = require(\"../lodash\");\nvar tarjan = require(\"./tarjan\");\n\nmodule.exports = findCycles;\n\nfunction findCycles(g) {\n return _.filter(tarjan(g), function(cmpt) {\n return cmpt.length > 1 || (cmpt.length === 1 && g.hasEdge(cmpt[0], cmpt[0]));\n });\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = floydWarshall;\n\nvar DEFAULT_WEIGHT_FUNC = _.constant(1);\n\nfunction floydWarshall(g, weightFn, edgeFn) {\n return runFloydWarshall(g,\n weightFn || DEFAULT_WEIGHT_FUNC,\n edgeFn || function(v) { return g.outEdges(v); });\n}\n\nfunction runFloydWarshall(g, weightFn, edgeFn) {\n var results = {};\n var nodes = g.nodes();\n\n nodes.forEach(function(v) {\n results[v] = {};\n results[v][v] = { distance: 0 };\n nodes.forEach(function(w) {\n if (v !== w) {\n results[v][w] = { distance: Number.POSITIVE_INFINITY };\n }\n });\n edgeFn(v).forEach(function(edge) {\n var w = edge.v === v ? edge.w : edge.v;\n var d = weightFn(edge);\n results[v][w] = { distance: d, predecessor: v };\n });\n });\n\n nodes.forEach(function(k) {\n var rowK = results[k];\n nodes.forEach(function(i) {\n var rowI = results[i];\n nodes.forEach(function(j) {\n var ik = rowI[k];\n var kj = rowK[j];\n var ij = rowI[j];\n var altDistance = ik.distance + kj.distance;\n if (altDistance < ij.distance) {\n ij.distance = altDistance;\n ij.predecessor = kj.predecessor;\n }\n });\n });\n });\n\n return results;\n}\n","var topsort = require(\"./topsort\");\n\nmodule.exports = isAcyclic;\n\nfunction isAcyclic(g) {\n try {\n topsort(g);\n } catch (e) {\n if (e instanceof topsort.CycleException) {\n return false;\n }\n throw e;\n }\n return true;\n}\n","var dfs = require(\"./dfs\");\n\nmodule.exports = postorder;\n\nfunction postorder(g, vs) {\n return dfs(g, vs, \"post\");\n}\n","var dfs = require(\"./dfs\");\n\nmodule.exports = preorder;\n\nfunction preorder(g, vs) {\n return dfs(g, vs, \"pre\");\n}\n","var _ = require(\"../lodash\");\nvar Graph = require(\"../graph\");\nvar PriorityQueue = require(\"../data/priority-queue\");\n\nmodule.exports = prim;\n\nfunction prim(g, weightFunc) {\n var result = new Graph();\n var parents = {};\n var pq = new PriorityQueue();\n var v;\n\n function updateNeighbors(edge) {\n var w = edge.v === v ? edge.w : edge.v;\n var pri = pq.priority(w);\n if (pri !== undefined) {\n var edgeWeight = weightFunc(edge);\n if (edgeWeight < pri) {\n parents[w] = v;\n pq.decrease(w, edgeWeight);\n }\n }\n }\n\n if (g.nodeCount() === 0) {\n return result;\n }\n\n _.each(g.nodes(), function(v) {\n pq.add(v, Number.POSITIVE_INFINITY);\n result.setNode(v);\n });\n\n // Start from an arbitrary node\n pq.decrease(g.nodes()[0], 0);\n\n var init = false;\n while (pq.size() > 0) {\n v = pq.removeMin();\n if (_.has(parents, v)) {\n result.setEdge(v, parents[v]);\n } else if (init) {\n throw new Error(\"Input graph is not connected: \" + g);\n } else {\n init = true;\n }\n\n g.nodeEdges(v).forEach(updateNeighbors);\n }\n\n return result;\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\");\nvar acyclic = require(\"./acyclic\");\nvar normalize = require(\"./normalize\");\nvar rank = require(\"./rank\");\nvar normalizeRanks = require(\"./util\").normalizeRanks;\nvar parentDummyChains = require(\"./parent-dummy-chains\");\nvar removeEmptyRanks = require(\"./util\").removeEmptyRanks;\nvar nestingGraph = require(\"./nesting-graph\");\nvar addBorderSegments = require(\"./add-border-segments\");\nvar coordinateSystem = require(\"./coordinate-system\");\nvar order = require(\"./order\");\nvar position = require(\"./position\");\nvar util = require(\"./util\");\nvar Graph = require(\"./graphlib\").Graph;\n\nmodule.exports = layout;\n\nfunction layout(g, opts) {\n var time = opts && opts.debugTiming ? util.time : util.notime;\n time(\"layout\", function() {\n var layoutGraph = \n time(\" buildLayoutGraph\", function() { return buildLayoutGraph(g); });\n time(\" runLayout\", function() { runLayout(layoutGraph, time); });\n time(\" updateInputGraph\", function() { updateInputGraph(g, layoutGraph); });\n });\n}\n\nfunction runLayout(g, time) {\n time(\" makeSpaceForEdgeLabels\", function() { makeSpaceForEdgeLabels(g); });\n time(\" removeSelfEdges\", function() { removeSelfEdges(g); });\n time(\" acyclic\", function() { acyclic.run(g); });\n time(\" nestingGraph.run\", function() { nestingGraph.run(g); });\n time(\" rank\", function() { rank(util.asNonCompoundGraph(g)); });\n time(\" injectEdgeLabelProxies\", function() { injectEdgeLabelProxies(g); });\n time(\" removeEmptyRanks\", function() { removeEmptyRanks(g); });\n time(\" nestingGraph.cleanup\", function() { nestingGraph.cleanup(g); });\n time(\" normalizeRanks\", function() { normalizeRanks(g); });\n time(\" assignRankMinMax\", function() { assignRankMinMax(g); });\n time(\" removeEdgeLabelProxies\", function() { removeEdgeLabelProxies(g); });\n time(\" normalize.run\", function() { normalize.run(g); });\n time(\" parentDummyChains\", function() { parentDummyChains(g); });\n time(\" addBorderSegments\", function() { addBorderSegments(g); });\n time(\" order\", function() { order(g); });\n time(\" insertSelfEdges\", function() { insertSelfEdges(g); });\n time(\" adjustCoordinateSystem\", function() { coordinateSystem.adjust(g); });\n time(\" position\", function() { position(g); });\n time(\" positionSelfEdges\", function() { positionSelfEdges(g); });\n time(\" removeBorderNodes\", function() { removeBorderNodes(g); });\n time(\" normalize.undo\", function() { normalize.undo(g); });\n time(\" fixupEdgeLabelCoords\", function() { fixupEdgeLabelCoords(g); });\n time(\" undoCoordinateSystem\", function() { coordinateSystem.undo(g); });\n time(\" translateGraph\", function() { translateGraph(g); });\n time(\" assignNodeIntersects\", function() { assignNodeIntersects(g); });\n time(\" reversePoints\", function() { reversePointsForReversedEdges(g); });\n time(\" acyclic.undo\", function() { acyclic.undo(g); });\n}\n\n/*\n * Copies final layout information from the layout graph back to the input\n * graph. This process only copies whitelisted attributes from the layout graph\n * to the input graph, so it serves as a good place to determine what\n * attributes can influence layout.\n */\nfunction updateInputGraph(inputGraph, layoutGraph) {\n _.forEach(inputGraph.nodes(), function(v) {\n var inputLabel = inputGraph.node(v);\n var layoutLabel = layoutGraph.node(v);\n\n if (inputLabel) {\n inputLabel.x = layoutLabel.x;\n inputLabel.y = layoutLabel.y;\n\n if (layoutGraph.children(v).length) {\n inputLabel.width = layoutLabel.width;\n inputLabel.height = layoutLabel.height;\n }\n }\n });\n\n _.forEach(inputGraph.edges(), function(e) {\n var inputLabel = inputGraph.edge(e);\n var layoutLabel = layoutGraph.edge(e);\n\n inputLabel.points = layoutLabel.points;\n if (_.has(layoutLabel, \"x\")) {\n inputLabel.x = layoutLabel.x;\n inputLabel.y = layoutLabel.y;\n }\n });\n\n inputGraph.graph().width = layoutGraph.graph().width;\n inputGraph.graph().height = layoutGraph.graph().height;\n}\n\nvar graphNumAttrs = [\"nodesep\", \"edgesep\", \"ranksep\", \"marginx\", \"marginy\"];\nvar graphDefaults = { ranksep: 50, edgesep: 20, nodesep: 50, rankdir: \"tb\" };\nvar graphAttrs = [\"acyclicer\", \"ranker\", \"rankdir\", \"align\"];\nvar nodeNumAttrs = [\"width\", \"height\"];\nvar nodeDefaults = { width: 0, height: 0 };\nvar edgeNumAttrs = [\"minlen\", \"weight\", \"width\", \"height\", \"labeloffset\"];\nvar edgeDefaults = {\n minlen: 1, weight: 1, width: 0, height: 0,\n labeloffset: 10, labelpos: \"r\"\n};\nvar edgeAttrs = [\"labelpos\"];\n\n/*\n * Constructs a new graph from the input graph, which can be used for layout.\n * This process copies only whitelisted attributes from the input graph to the\n * layout graph. Thus this function serves as a good place to determine what\n * attributes can influence layout.\n */\nfunction buildLayoutGraph(inputGraph) {\n var g = new Graph({ multigraph: true, compound: true });\n var graph = canonicalize(inputGraph.graph());\n\n g.setGraph(_.merge({},\n graphDefaults,\n selectNumberAttrs(graph, graphNumAttrs),\n _.pick(graph, graphAttrs)));\n\n _.forEach(inputGraph.nodes(), function(v) {\n var node = canonicalize(inputGraph.node(v));\n g.setNode(v, _.defaults(selectNumberAttrs(node, nodeNumAttrs), nodeDefaults));\n g.setParent(v, inputGraph.parent(v));\n });\n\n _.forEach(inputGraph.edges(), function(e) {\n var edge = canonicalize(inputGraph.edge(e));\n g.setEdge(e, _.merge({},\n edgeDefaults,\n selectNumberAttrs(edge, edgeNumAttrs),\n _.pick(edge, edgeAttrs)));\n });\n\n return g;\n}\n\n/*\n * This idea comes from the Gansner paper: to account for edge labels in our\n * layout we split each rank in half by doubling minlen and halving ranksep.\n * Then we can place labels at these mid-points between nodes.\n *\n * We also add some minimal padding to the width to push the label for the edge\n * away from the edge itself a bit.\n */\nfunction makeSpaceForEdgeLabels(g) {\n var graph = g.graph();\n graph.ranksep /= 2;\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n edge.minlen *= 2;\n if (edge.labelpos.toLowerCase() !== \"c\") {\n if (graph.rankdir === \"TB\" || graph.rankdir === \"BT\") {\n edge.width += edge.labeloffset;\n } else {\n edge.height += edge.labeloffset;\n }\n }\n });\n}\n\n/*\n * Creates temporary dummy nodes that capture the rank in which each edge's\n * label is going to, if it has one of non-zero width and height. We do this\n * so that we can safely remove empty ranks while preserving balance for the\n * label's position.\n */\nfunction injectEdgeLabelProxies(g) {\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (edge.width && edge.height) {\n var v = g.node(e.v);\n var w = g.node(e.w);\n var label = { rank: (w.rank - v.rank) / 2 + v.rank, e: e };\n util.addDummyNode(g, \"edge-proxy\", label, \"_ep\");\n }\n });\n}\n\nfunction assignRankMinMax(g) {\n var maxRank = 0;\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n if (node.borderTop) {\n node.minRank = g.node(node.borderTop).rank;\n node.maxRank = g.node(node.borderBottom).rank;\n maxRank = _.max(maxRank, node.maxRank);\n }\n });\n g.graph().maxRank = maxRank;\n}\n\nfunction removeEdgeLabelProxies(g) {\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n if (node.dummy === \"edge-proxy\") {\n g.edge(node.e).labelRank = node.rank;\n g.removeNode(v);\n }\n });\n}\n\nfunction translateGraph(g) {\n var minX = Number.POSITIVE_INFINITY;\n var maxX = 0;\n var minY = Number.POSITIVE_INFINITY;\n var maxY = 0;\n var graphLabel = g.graph();\n var marginX = graphLabel.marginx || 0;\n var marginY = graphLabel.marginy || 0;\n\n function getExtremes(attrs) {\n var x = attrs.x;\n var y = attrs.y;\n var w = attrs.width;\n var h = attrs.height;\n minX = Math.min(minX, x - w / 2);\n maxX = Math.max(maxX, x + w / 2);\n minY = Math.min(minY, y - h / 2);\n maxY = Math.max(maxY, y + h / 2);\n }\n\n _.forEach(g.nodes(), function(v) { getExtremes(g.node(v)); });\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (_.has(edge, \"x\")) {\n getExtremes(edge);\n }\n });\n\n minX -= marginX;\n minY -= marginY;\n\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n node.x -= minX;\n node.y -= minY;\n });\n\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n _.forEach(edge.points, function(p) {\n p.x -= minX;\n p.y -= minY;\n });\n if (_.has(edge, \"x\")) { edge.x -= minX; }\n if (_.has(edge, \"y\")) { edge.y -= minY; }\n });\n\n graphLabel.width = maxX - minX + marginX;\n graphLabel.height = maxY - minY + marginY;\n}\n\nfunction assignNodeIntersects(g) {\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n var nodeV = g.node(e.v);\n var nodeW = g.node(e.w);\n var p1, p2;\n if (!edge.points) {\n edge.points = [];\n p1 = nodeW;\n p2 = nodeV;\n } else {\n p1 = edge.points[0];\n p2 = edge.points[edge.points.length - 1];\n }\n edge.points.unshift(util.intersectRect(nodeV, p1));\n edge.points.push(util.intersectRect(nodeW, p2));\n });\n}\n\nfunction fixupEdgeLabelCoords(g) {\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (_.has(edge, \"x\")) {\n if (edge.labelpos === \"l\" || edge.labelpos === \"r\") {\n edge.width -= edge.labeloffset;\n }\n switch (edge.labelpos) {\n case \"l\": edge.x -= edge.width / 2 + edge.labeloffset; break;\n case \"r\": edge.x += edge.width / 2 + edge.labeloffset; break;\n }\n }\n });\n}\n\nfunction reversePointsForReversedEdges(g) {\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (edge.reversed) {\n edge.points.reverse();\n }\n });\n}\n\nfunction removeBorderNodes(g) {\n _.forEach(g.nodes(), function(v) {\n if (g.children(v).length) {\n var node = g.node(v);\n var t = g.node(node.borderTop);\n var b = g.node(node.borderBottom);\n var l = g.node(_.last(node.borderLeft));\n var r = g.node(_.last(node.borderRight));\n\n node.width = Math.abs(r.x - l.x);\n node.height = Math.abs(b.y - t.y);\n node.x = l.x + node.width / 2;\n node.y = t.y + node.height / 2;\n }\n });\n\n _.forEach(g.nodes(), function(v) {\n if (g.node(v).dummy === \"border\") {\n g.removeNode(v);\n }\n });\n}\n\nfunction removeSelfEdges(g) {\n _.forEach(g.edges(), function(e) {\n if (e.v === e.w) {\n var node = g.node(e.v);\n if (!node.selfEdges) {\n node.selfEdges = [];\n }\n node.selfEdges.push({ e: e, label: g.edge(e) });\n g.removeEdge(e);\n }\n });\n}\n\nfunction insertSelfEdges(g) {\n var layers = util.buildLayerMatrix(g);\n _.forEach(layers, function(layer) {\n var orderShift = 0;\n _.forEach(layer, function(v, i) {\n var node = g.node(v);\n node.order = i + orderShift;\n _.forEach(node.selfEdges, function(selfEdge) {\n util.addDummyNode(g, \"selfedge\", {\n width: selfEdge.label.width,\n height: selfEdge.label.height,\n rank: node.rank,\n order: i + (++orderShift),\n e: selfEdge.e,\n label: selfEdge.label\n }, \"_se\");\n });\n delete node.selfEdges;\n });\n });\n}\n\nfunction positionSelfEdges(g) {\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n if (node.dummy === \"selfedge\") {\n var selfNode = g.node(node.e.v);\n var x = selfNode.x + selfNode.width / 2;\n var y = selfNode.y;\n var dx = node.x - x;\n var dy = selfNode.height / 2;\n g.setEdge(node.e, node.label);\n g.removeNode(v);\n node.label.points = [\n { x: x + 2 * dx / 3, y: y - dy },\n { x: x + 5 * dx / 6, y: y - dy },\n { x: x + dx , y: y },\n { x: x + 5 * dx / 6, y: y + dy },\n { x: x + 2 * dx / 3, y: y + dy }\n ];\n node.label.x = node.x;\n node.label.y = node.y;\n }\n });\n}\n\nfunction selectNumberAttrs(obj, attrs) {\n return _.mapValues(_.pick(obj, attrs), Number);\n}\n\nfunction canonicalize(attrs) {\n var newAttrs = {};\n _.forEach(attrs, function(v, k) {\n newAttrs[k.toLowerCase()] = v;\n });\n return newAttrs;\n}\n","var baseClone = require('./_baseClone');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\nfunction cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n}\n\nmodule.exports = cloneDeep;\n","var baseRest = require('./_baseRest'),\n eq = require('./eq'),\n isIterateeCall = require('./_isIterateeCall'),\n keysIn = require('./keysIn');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns own and inherited enumerable string keyed properties of source\n * objects to the destination object for all destination properties that\n * resolve to `undefined`. Source objects are applied from left to right.\n * Once a property is set, additional values of the same property are ignored.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaultsDeep\n * @example\n *\n * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\nvar defaults = baseRest(function(object, sources) {\n object = Object(object);\n\n var index = -1;\n var length = sources.length;\n var guard = length > 2 ? sources[2] : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n length = 1;\n }\n\n while (++index < length) {\n var source = sources[index];\n var props = keysIn(source);\n var propsIndex = -1;\n var propsLength = props.length;\n\n while (++propsIndex < propsLength) {\n var key = props[propsIndex];\n var value = object[key];\n\n if (value === undefined ||\n (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n object[key] = source[key];\n }\n }\n }\n\n return object;\n});\n\nmodule.exports = defaults;\n","var createFind = require('./_createFind'),\n findIndex = require('./findIndex');\n\n/**\n * Iterates over elements of `collection`, returning the first element\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false },\n * { 'user': 'pebbles', 'age': 1, 'active': true }\n * ];\n *\n * _.find(users, function(o) { return o.age < 40; });\n * // => object for 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.find(users, { 'age': 1, 'active': true });\n * // => object for 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.find(users, ['active', false]);\n * // => object for 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.find(users, 'active');\n * // => object for 'barney'\n */\nvar find = createFind(findIndex);\n\nmodule.exports = find;\n","var baseIteratee = require('./_baseIteratee'),\n isArrayLike = require('./isArrayLike'),\n keys = require('./keys');\n\n/**\n * Creates a `_.find` or `_.findLast` function.\n *\n * @private\n * @param {Function} findIndexFunc The function to find the collection index.\n * @returns {Function} Returns the new find function.\n */\nfunction createFind(findIndexFunc) {\n return function(collection, predicate, fromIndex) {\n var iterable = Object(collection);\n if (!isArrayLike(collection)) {\n var iteratee = baseIteratee(predicate, 3);\n collection = keys(collection);\n predicate = function(key) { return iteratee(iterable[key], key, iterable); };\n }\n var index = findIndexFunc(collection, predicate, fromIndex);\n return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined;\n };\n}\n\nmodule.exports = createFind;\n","var baseFindIndex = require('./_baseFindIndex'),\n baseIteratee = require('./_baseIteratee'),\n toInteger = require('./toInteger');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * This method is like `_.find` except that it returns the index of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.findIndex(users, function(o) { return o.user == 'barney'; });\n * // => 0\n *\n * // The `_.matches` iteratee shorthand.\n * _.findIndex(users, { 'user': 'fred', 'active': false });\n * // => 1\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findIndex(users, ['active', false]);\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.findIndex(users, 'active');\n * // => 2\n */\nfunction findIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseFindIndex(array, baseIteratee(predicate, 3), index);\n}\n\nmodule.exports = findIndex;\n","var toFinite = require('./toFinite');\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\nmodule.exports = toInteger;\n","var baseTrim = require('./_baseTrim'),\n isObject = require('./isObject'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = toNumber;\n","var trimmedEndIndex = require('./_trimmedEndIndex');\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n}\n\nmodule.exports = baseTrim;\n","/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n}\n\nmodule.exports = trimmedEndIndex;\n","var baseFor = require('./_baseFor'),\n castFunction = require('./_castFunction'),\n keysIn = require('./keysIn');\n\n/**\n * Iterates over own and inherited enumerable string keyed properties of an\n * object and invokes `iteratee` for each property. The iteratee is invoked\n * with three arguments: (value, key, object). Iteratee functions may exit\n * iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forInRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forIn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed).\n */\nfunction forIn(object, iteratee) {\n return object == null\n ? object\n : baseFor(object, castFunction(iteratee), keysIn);\n}\n\nmodule.exports = forIn;\n","/**\n * Gets the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the last element of `array`.\n * @example\n *\n * _.last([1, 2, 3]);\n * // => 3\n */\nfunction last(array) {\n var length = array == null ? 0 : array.length;\n return length ? array[length - 1] : undefined;\n}\n\nmodule.exports = last;\n","var baseAssignValue = require('./_baseAssignValue'),\n baseForOwn = require('./_baseForOwn'),\n baseIteratee = require('./_baseIteratee');\n\n/**\n * Creates an object with the same keys as `object` and values generated\n * by running each own enumerable string keyed property of `object` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapKeys\n * @example\n *\n * var users = {\n * 'fred': { 'user': 'fred', 'age': 40 },\n * 'pebbles': { 'user': 'pebbles', 'age': 1 }\n * };\n *\n * _.mapValues(users, function(o) { return o.age; });\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n *\n * // The `_.property` iteratee shorthand.\n * _.mapValues(users, 'age');\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n */\nfunction mapValues(object, iteratee) {\n var result = {};\n iteratee = baseIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, key, iteratee(value, key, object));\n });\n return result;\n}\n\nmodule.exports = mapValues;\n","var baseExtremum = require('./_baseExtremum'),\n baseGt = require('./_baseGt'),\n identity = require('./identity');\n\n/**\n * Computes the maximum value of `array`. If `array` is empty or falsey,\n * `undefined` is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {*} Returns the maximum value.\n * @example\n *\n * _.max([4, 2, 8, 6]);\n * // => 8\n *\n * _.max([]);\n * // => undefined\n */\nfunction max(array) {\n return (array && array.length)\n ? baseExtremum(array, identity, baseGt)\n : undefined;\n}\n\nmodule.exports = max;\n","/**\n * The base implementation of `_.gt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n */\nfunction baseGt(value, other) {\n return value > other;\n}\n\nmodule.exports = baseGt;\n","var baseMerge = require('./_baseMerge'),\n createAssigner = require('./_createAssigner');\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n * 'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n * 'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\nvar merge = createAssigner(function(object, source, srcIndex) {\n baseMerge(object, source, srcIndex);\n});\n\nmodule.exports = merge;\n","var Stack = require('./_Stack'),\n assignMergeValue = require('./_assignMergeValue'),\n baseFor = require('./_baseFor'),\n baseMergeDeep = require('./_baseMergeDeep'),\n isObject = require('./isObject'),\n keysIn = require('./keysIn'),\n safeGet = require('./_safeGet');\n\n/**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n if (object === source) {\n return;\n }\n baseFor(source, function(srcValue, key) {\n stack || (stack = new Stack);\n if (isObject(srcValue)) {\n baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n }\n else {\n var newValue = customizer\n ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\n : undefined;\n\n if (newValue === undefined) {\n newValue = srcValue;\n }\n assignMergeValue(object, key, newValue);\n }\n }, keysIn);\n}\n\nmodule.exports = baseMerge;\n","var assignMergeValue = require('./_assignMergeValue'),\n cloneBuffer = require('./_cloneBuffer'),\n cloneTypedArray = require('./_cloneTypedArray'),\n copyArray = require('./_copyArray'),\n initCloneObject = require('./_initCloneObject'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isArrayLikeObject = require('./isArrayLikeObject'),\n isBuffer = require('./isBuffer'),\n isFunction = require('./isFunction'),\n isObject = require('./isObject'),\n isPlainObject = require('./isPlainObject'),\n isTypedArray = require('./isTypedArray'),\n safeGet = require('./_safeGet'),\n toPlainObject = require('./toPlainObject');\n\n/**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n var objValue = safeGet(object, key),\n srcValue = safeGet(source, key),\n stacked = stack.get(srcValue);\n\n if (stacked) {\n assignMergeValue(object, key, stacked);\n return;\n }\n var newValue = customizer\n ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n : undefined;\n\n var isCommon = newValue === undefined;\n\n if (isCommon) {\n var isArr = isArray(srcValue),\n isBuff = !isArr && isBuffer(srcValue),\n isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n newValue = srcValue;\n if (isArr || isBuff || isTyped) {\n if (isArray(objValue)) {\n newValue = objValue;\n }\n else if (isArrayLikeObject(objValue)) {\n newValue = copyArray(objValue);\n }\n else if (isBuff) {\n isCommon = false;\n newValue = cloneBuffer(srcValue, true);\n }\n else if (isTyped) {\n isCommon = false;\n newValue = cloneTypedArray(srcValue, true);\n }\n else {\n newValue = [];\n }\n }\n else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n newValue = objValue;\n if (isArguments(objValue)) {\n newValue = toPlainObject(objValue);\n }\n else if (!isObject(objValue) || isFunction(objValue)) {\n newValue = initCloneObject(srcValue);\n }\n }\n else {\n isCommon = false;\n }\n }\n if (isCommon) {\n // Recursively merge objects and arrays (susceptible to call stack limits).\n stack.set(srcValue, newValue);\n mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n stack['delete'](srcValue);\n }\n assignMergeValue(object, key, newValue);\n}\n\nmodule.exports = baseMergeDeep;\n","var baseGetTag = require('./_baseGetTag'),\n getPrototype = require('./_getPrototype'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n return false;\n }\n var proto = getPrototype(value);\n if (proto === null) {\n return true;\n }\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n funcToString.call(Ctor) == objectCtorString;\n}\n\nmodule.exports = isPlainObject;\n","var copyObject = require('./_copyObject'),\n keysIn = require('./keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\nfunction toPlainObject(value) {\n return copyObject(value, keysIn(value));\n}\n\nmodule.exports = toPlainObject;\n","var baseRest = require('./_baseRest'),\n isIterateeCall = require('./_isIterateeCall');\n\n/**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\nfunction createAssigner(assigner) {\n return baseRest(function(object, sources) {\n var index = -1,\n length = sources.length,\n customizer = length > 1 ? sources[length - 1] : undefined,\n guard = length > 2 ? sources[2] : undefined;\n\n customizer = (assigner.length > 3 && typeof customizer == 'function')\n ? (length--, customizer)\n : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n customizer = length < 3 ? undefined : customizer;\n length = 1;\n }\n object = Object(object);\n while (++index < length) {\n var source = sources[index];\n if (source) {\n assigner(object, source, index, customizer);\n }\n }\n return object;\n });\n}\n\nmodule.exports = createAssigner;\n","var baseExtremum = require('./_baseExtremum'),\n baseLt = require('./_baseLt'),\n identity = require('./identity');\n\n/**\n * Computes the minimum value of `array`. If `array` is empty or falsey,\n * `undefined` is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {*} Returns the minimum value.\n * @example\n *\n * _.min([4, 2, 8, 6]);\n * // => 2\n *\n * _.min([]);\n * // => undefined\n */\nfunction min(array) {\n return (array && array.length)\n ? baseExtremum(array, identity, baseLt)\n : undefined;\n}\n\nmodule.exports = min;\n","var baseExtremum = require('./_baseExtremum'),\n baseIteratee = require('./_baseIteratee'),\n baseLt = require('./_baseLt');\n\n/**\n * This method is like `_.min` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * the value is ranked. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {*} Returns the minimum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * _.minBy(objects, function(o) { return o.n; });\n * // => { 'n': 1 }\n *\n * // The `_.property` iteratee shorthand.\n * _.minBy(objects, 'n');\n * // => { 'n': 1 }\n */\nfunction minBy(array, iteratee) {\n return (array && array.length)\n ? baseExtremum(array, baseIteratee(iteratee, 2), baseLt)\n : undefined;\n}\n\nmodule.exports = minBy;\n","var root = require('./_root');\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\nmodule.exports = now;\n","var basePick = require('./_basePick'),\n flatRest = require('./_flatRest');\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\nvar pick = flatRest(function(object, paths) {\n return object == null ? {} : basePick(object, paths);\n});\n\nmodule.exports = pick;\n","var basePickBy = require('./_basePickBy'),\n hasIn = require('./hasIn');\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, paths) {\n return basePickBy(object, paths, function(value, path) {\n return hasIn(object, path);\n });\n}\n\nmodule.exports = basePick;\n","var baseGet = require('./_baseGet'),\n baseSet = require('./_baseSet'),\n castPath = require('./_castPath');\n\n/**\n * The base implementation of `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\nfunction basePickBy(object, paths, predicate) {\n var index = -1,\n length = paths.length,\n result = {};\n\n while (++index < length) {\n var path = paths[index],\n value = baseGet(object, path);\n\n if (predicate(value, path)) {\n baseSet(result, castPath(path, object), value);\n }\n }\n return result;\n}\n\nmodule.exports = basePickBy;\n","var assignValue = require('./_assignValue'),\n castPath = require('./_castPath'),\n isIndex = require('./_isIndex'),\n isObject = require('./isObject'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n}\n\nmodule.exports = baseSet;\n","var flatten = require('./flatten'),\n overRest = require('./_overRest'),\n setToString = require('./_setToString');\n\n/**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\nfunction flatRest(func) {\n return setToString(overRest(func, undefined, flatten), func + '');\n}\n\nmodule.exports = flatRest;\n","var createRange = require('./_createRange');\n\n/**\n * Creates an array of numbers (positive and/or negative) progressing from\n * `start` up to, but not including, `end`. A step of `-1` is used if a negative\n * `start` is specified without an `end` or `step`. If `end` is not specified,\n * it's set to `start` with `start` then set to `0`.\n *\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\n * floating-point values which can produce unexpected results.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @param {number} [step=1] The value to increment or decrement by.\n * @returns {Array} Returns the range of numbers.\n * @see _.inRange, _.rangeRight\n * @example\n *\n * _.range(4);\n * // => [0, 1, 2, 3]\n *\n * _.range(-4);\n * // => [0, -1, -2, -3]\n *\n * _.range(1, 5);\n * // => [1, 2, 3, 4]\n *\n * _.range(0, 20, 5);\n * // => [0, 5, 10, 15]\n *\n * _.range(0, -4, -1);\n * // => [0, -1, -2, -3]\n *\n * _.range(1, 4, 0);\n * // => [1, 1, 1]\n *\n * _.range(0);\n * // => []\n */\nvar range = createRange();\n\nmodule.exports = range;\n","var baseRange = require('./_baseRange'),\n isIterateeCall = require('./_isIterateeCall'),\n toFinite = require('./toFinite');\n\n/**\n * Creates a `_.range` or `_.rangeRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new range function.\n */\nfunction createRange(fromRight) {\n return function(start, end, step) {\n if (step && typeof step != 'number' && isIterateeCall(start, end, step)) {\n end = step = undefined;\n }\n // Ensure the sign of `-0` is preserved.\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n step = step === undefined ? (start < end ? 1 : -1) : toFinite(step);\n return baseRange(start, end, step, fromRight);\n };\n}\n\nmodule.exports = createRange;\n","/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeCeil = Math.ceil,\n nativeMax = Math.max;\n\n/**\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\n * coerce arguments.\n *\n * @private\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @param {number} step The value to increment or decrement by.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the range of numbers.\n */\nfunction baseRange(start, end, step, fromRight) {\n var index = -1,\n length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\n result = Array(length);\n\n while (length--) {\n result[fromRight ? length : ++index] = start;\n start += step;\n }\n return result;\n}\n\nmodule.exports = baseRange;\n","var baseFlatten = require('./_baseFlatten'),\n baseOrderBy = require('./_baseOrderBy'),\n baseRest = require('./_baseRest'),\n isIterateeCall = require('./_isIterateeCall');\n\n/**\n * Creates an array of elements, sorted in ascending order by the results of\n * running each element in a collection thru each iteratee. This method\n * performs a stable sort, that is, it preserves the original sort order of\n * equal elements. The iteratees are invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\n * The iteratees to sort by.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n * { 'user': 'fred', 'age': 48 },\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 30 },\n * { 'user': 'barney', 'age': 34 }\n * ];\n *\n * _.sortBy(users, [function(o) { return o.user; }]);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 30]]\n *\n * _.sortBy(users, ['user', 'age']);\n * // => objects for [['barney', 34], ['barney', 36], ['fred', 30], ['fred', 48]]\n */\nvar sortBy = baseRest(function(collection, iteratees) {\n if (collection == null) {\n return [];\n }\n var length = iteratees.length;\n if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) {\n iteratees = [];\n } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) {\n iteratees = [iteratees[0]];\n }\n return baseOrderBy(collection, baseFlatten(iteratees, 1), []);\n});\n\nmodule.exports = sortBy;\n","var arrayMap = require('./_arrayMap'),\n baseGet = require('./_baseGet'),\n baseIteratee = require('./_baseIteratee'),\n baseMap = require('./_baseMap'),\n baseSortBy = require('./_baseSortBy'),\n baseUnary = require('./_baseUnary'),\n compareMultiple = require('./_compareMultiple'),\n identity = require('./identity'),\n isArray = require('./isArray');\n\n/**\n * The base implementation of `_.orderBy` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.\n * @param {string[]} orders The sort orders of `iteratees`.\n * @returns {Array} Returns the new sorted array.\n */\nfunction baseOrderBy(collection, iteratees, orders) {\n if (iteratees.length) {\n iteratees = arrayMap(iteratees, function(iteratee) {\n if (isArray(iteratee)) {\n return function(value) {\n return baseGet(value, iteratee.length === 1 ? iteratee[0] : iteratee);\n }\n }\n return iteratee;\n });\n } else {\n iteratees = [identity];\n }\n\n var index = -1;\n iteratees = arrayMap(iteratees, baseUnary(baseIteratee));\n\n var result = baseMap(collection, function(value, key, collection) {\n var criteria = arrayMap(iteratees, function(iteratee) {\n return iteratee(value);\n });\n return { 'criteria': criteria, 'index': ++index, 'value': value };\n });\n\n return baseSortBy(result, function(object, other) {\n return compareMultiple(object, other, orders);\n });\n}\n\nmodule.exports = baseOrderBy;\n","/**\n * The base implementation of `_.sortBy` which uses `comparer` to define the\n * sort order of `array` and replaces criteria objects with their corresponding\n * values.\n *\n * @private\n * @param {Array} array The array to sort.\n * @param {Function} comparer The function to define sort order.\n * @returns {Array} Returns `array`.\n */\nfunction baseSortBy(array, comparer) {\n var length = array.length;\n\n array.sort(comparer);\n while (length--) {\n array[length] = array[length].value;\n }\n return array;\n}\n\nmodule.exports = baseSortBy;\n","var compareAscending = require('./_compareAscending');\n\n/**\n * Used by `_.orderBy` to compare multiple properties of a value to another\n * and stable sort them.\n *\n * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,\n * specify an order of \"desc\" for descending or \"asc\" for ascending sort order\n * of corresponding values.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {boolean[]|string[]} orders The order to sort by for each property.\n * @returns {number} Returns the sort order indicator for `object`.\n */\nfunction compareMultiple(object, other, orders) {\n var index = -1,\n objCriteria = object.criteria,\n othCriteria = other.criteria,\n length = objCriteria.length,\n ordersLength = orders.length;\n\n while (++index < length) {\n var result = compareAscending(objCriteria[index], othCriteria[index]);\n if (result) {\n if (index >= ordersLength) {\n return result;\n }\n var order = orders[index];\n return result * (order == 'desc' ? -1 : 1);\n }\n }\n // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications\n // that causes it, under certain circumstances, to provide the same value for\n // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247\n // for more details.\n //\n // This also ensures a stable sort in V8 and other engines.\n // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.\n return object.index - other.index;\n}\n\nmodule.exports = compareMultiple;\n","var isSymbol = require('./isSymbol');\n\n/**\n * Compares values to sort them in ascending order.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {number} Returns the sort order indicator for `value`.\n */\nfunction compareAscending(value, other) {\n if (value !== other) {\n var valIsDefined = value !== undefined,\n valIsNull = value === null,\n valIsReflexive = value === value,\n valIsSymbol = isSymbol(value);\n\n var othIsDefined = other !== undefined,\n othIsNull = other === null,\n othIsReflexive = other === other,\n othIsSymbol = isSymbol(other);\n\n if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) ||\n (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) ||\n (valIsNull && othIsDefined && othIsReflexive) ||\n (!valIsDefined && othIsReflexive) ||\n !valIsReflexive) {\n return 1;\n }\n if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) ||\n (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) ||\n (othIsNull && valIsDefined && valIsReflexive) ||\n (!othIsDefined && valIsReflexive) ||\n !othIsReflexive) {\n return -1;\n }\n }\n return 0;\n}\n\nmodule.exports = compareAscending;\n","var toString = require('./toString');\n\n/** Used to generate unique IDs. */\nvar idCounter = 0;\n\n/**\n * Generates a unique ID. If `prefix` is given, the ID is appended to it.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {string} [prefix=''] The value to prefix the ID with.\n * @returns {string} Returns the unique ID.\n * @example\n *\n * _.uniqueId('contact_');\n * // => 'contact_104'\n *\n * _.uniqueId();\n * // => '105'\n */\nfunction uniqueId(prefix) {\n var id = ++idCounter;\n return toString(prefix) + id;\n}\n\nmodule.exports = uniqueId;\n","var assignValue = require('./_assignValue'),\n baseZipObject = require('./_baseZipObject');\n\n/**\n * This method is like `_.fromPairs` except that it accepts two arrays,\n * one of property identifiers and one of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 0.4.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObject(['a', 'b'], [1, 2]);\n * // => { 'a': 1, 'b': 2 }\n */\nfunction zipObject(props, values) {\n return baseZipObject(props || [], values || [], assignValue);\n}\n\nmodule.exports = zipObject;\n","/**\n * This base implementation of `_.zipObject` which assigns values using `assignFunc`.\n *\n * @private\n * @param {Array} props The property identifiers.\n * @param {Array} values The property values.\n * @param {Function} assignFunc The function to assign values.\n * @returns {Object} Returns the new object.\n */\nfunction baseZipObject(props, values, assignFunc) {\n var index = -1,\n length = props.length,\n valsLength = values.length,\n result = {};\n\n while (++index < length) {\n var value = index < valsLength ? values[index] : undefined;\n assignFunc(result, props[index], value);\n }\n return result;\n}\n\nmodule.exports = baseZipObject;\n","\"use strict\";\n\nvar _ = require(\"./lodash\");\nvar greedyFAS = require(\"./greedy-fas\");\n\nmodule.exports = {\n run: run,\n undo: undo\n};\n\nfunction run(g) {\n var fas = (g.graph().acyclicer === \"greedy\"\n ? greedyFAS(g, weightFn(g))\n : dfsFAS(g));\n _.forEach(fas, function(e) {\n var label = g.edge(e);\n g.removeEdge(e);\n label.forwardName = e.name;\n label.reversed = true;\n g.setEdge(e.w, e.v, label, _.uniqueId(\"rev\"));\n });\n\n function weightFn(g) {\n return function(e) {\n return g.edge(e).weight;\n };\n }\n}\n\nfunction dfsFAS(g) {\n var fas = [];\n var stack = {};\n var visited = {};\n\n function dfs(v) {\n if (_.has(visited, v)) {\n return;\n }\n visited[v] = true;\n stack[v] = true;\n _.forEach(g.outEdges(v), function(e) {\n if (_.has(stack, e.w)) {\n fas.push(e);\n } else {\n dfs(e.w);\n }\n });\n delete stack[v];\n }\n\n _.forEach(g.nodes(), dfs);\n return fas;\n}\n\nfunction undo(g) {\n _.forEach(g.edges(), function(e) {\n var label = g.edge(e);\n if (label.reversed) {\n g.removeEdge(e);\n\n var forwardName = label.forwardName;\n delete label.reversed;\n delete label.forwardName;\n g.setEdge(e.w, e.v, label, forwardName);\n }\n });\n}\n","var _ = require(\"./lodash\");\nvar Graph = require(\"./graphlib\").Graph;\nvar List = require(\"./data/list\");\n\n/*\n * A greedy heuristic for finding a feedback arc set for a graph. A feedback\n * arc set is a set of edges that can be removed to make a graph acyclic.\n * The algorithm comes from: P. Eades, X. Lin, and W. F. Smyth, \"A fast and\n * effective heuristic for the feedback arc set problem.\" This implementation\n * adjusts that from the paper to allow for weighted edges.\n */\nmodule.exports = greedyFAS;\n\nvar DEFAULT_WEIGHT_FN = _.constant(1);\n\nfunction greedyFAS(g, weightFn) {\n if (g.nodeCount() <= 1) {\n return [];\n }\n var state = buildState(g, weightFn || DEFAULT_WEIGHT_FN);\n var results = doGreedyFAS(state.graph, state.buckets, state.zeroIdx);\n\n // Expand multi-edges\n return _.flatten(_.map(results, function(e) {\n return g.outEdges(e.v, e.w);\n }), true);\n}\n\nfunction doGreedyFAS(g, buckets, zeroIdx) {\n var results = [];\n var sources = buckets[buckets.length - 1];\n var sinks = buckets[0];\n\n var entry;\n while (g.nodeCount()) {\n while ((entry = sinks.dequeue())) { removeNode(g, buckets, zeroIdx, entry); }\n while ((entry = sources.dequeue())) { removeNode(g, buckets, zeroIdx, entry); }\n if (g.nodeCount()) {\n for (var i = buckets.length - 2; i > 0; --i) {\n entry = buckets[i].dequeue();\n if (entry) {\n results = results.concat(removeNode(g, buckets, zeroIdx, entry, true));\n break;\n }\n }\n }\n }\n\n return results;\n}\n\nfunction removeNode(g, buckets, zeroIdx, entry, collectPredecessors) {\n var results = collectPredecessors ? [] : undefined;\n\n _.forEach(g.inEdges(entry.v), function(edge) {\n var weight = g.edge(edge);\n var uEntry = g.node(edge.v);\n\n if (collectPredecessors) {\n results.push({ v: edge.v, w: edge.w });\n }\n\n uEntry.out -= weight;\n assignBucket(buckets, zeroIdx, uEntry);\n });\n\n _.forEach(g.outEdges(entry.v), function(edge) {\n var weight = g.edge(edge);\n var w = edge.w;\n var wEntry = g.node(w);\n wEntry[\"in\"] -= weight;\n assignBucket(buckets, zeroIdx, wEntry);\n });\n\n g.removeNode(entry.v);\n\n return results;\n}\n\nfunction buildState(g, weightFn) {\n var fasGraph = new Graph();\n var maxIn = 0;\n var maxOut = 0;\n\n _.forEach(g.nodes(), function(v) {\n fasGraph.setNode(v, { v: v, \"in\": 0, out: 0 });\n });\n\n // Aggregate weights on nodes, but also sum the weights across multi-edges\n // into a single edge for the fasGraph.\n _.forEach(g.edges(), function(e) {\n var prevWeight = fasGraph.edge(e.v, e.w) || 0;\n var weight = weightFn(e);\n var edgeWeight = prevWeight + weight;\n fasGraph.setEdge(e.v, e.w, edgeWeight);\n maxOut = Math.max(maxOut, fasGraph.node(e.v).out += weight);\n maxIn = Math.max(maxIn, fasGraph.node(e.w)[\"in\"] += weight);\n });\n\n var buckets = _.range(maxOut + maxIn + 3).map(function() { return new List(); });\n var zeroIdx = maxIn + 1;\n\n _.forEach(fasGraph.nodes(), function(v) {\n assignBucket(buckets, zeroIdx, fasGraph.node(v));\n });\n\n return { graph: fasGraph, buckets: buckets, zeroIdx: zeroIdx };\n}\n\nfunction assignBucket(buckets, zeroIdx, entry) {\n if (!entry.out) {\n buckets[0].enqueue(entry);\n } else if (!entry[\"in\"]) {\n buckets[buckets.length - 1].enqueue(entry);\n } else {\n buckets[entry.out - entry[\"in\"] + zeroIdx].enqueue(entry);\n }\n}\n","/*\n * Simple doubly linked list implementation derived from Cormen, et al.,\n * \"Introduction to Algorithms\".\n */\n\nmodule.exports = List;\n\nfunction List() {\n var sentinel = {};\n sentinel._next = sentinel._prev = sentinel;\n this._sentinel = sentinel;\n}\n\nList.prototype.dequeue = function() {\n var sentinel = this._sentinel;\n var entry = sentinel._prev;\n if (entry !== sentinel) {\n unlink(entry);\n return entry;\n }\n};\n\nList.prototype.enqueue = function(entry) {\n var sentinel = this._sentinel;\n if (entry._prev && entry._next) {\n unlink(entry);\n }\n entry._next = sentinel._next;\n sentinel._next._prev = entry;\n sentinel._next = entry;\n entry._prev = sentinel;\n};\n\nList.prototype.toString = function() {\n var strs = [];\n var sentinel = this._sentinel;\n var curr = sentinel._prev;\n while (curr !== sentinel) {\n strs.push(JSON.stringify(curr, filterOutLinks));\n curr = curr._prev;\n }\n return \"[\" + strs.join(\", \") + \"]\";\n};\n\nfunction unlink(entry) {\n entry._prev._next = entry._next;\n entry._next._prev = entry._prev;\n delete entry._next;\n delete entry._prev;\n}\n\nfunction filterOutLinks(k, v) {\n if (k !== \"_next\" && k !== \"_prev\") {\n return v;\n }\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\");\nvar util = require(\"./util\");\n\nmodule.exports = {\n run: run,\n undo: undo\n};\n\n/*\n * Breaks any long edges in the graph into short segments that span 1 layer\n * each. This operation is undoable with the denormalize function.\n *\n * Pre-conditions:\n *\n * 1. The input graph is a DAG.\n * 2. Each node in the graph has a \"rank\" property.\n *\n * Post-condition:\n *\n * 1. All edges in the graph have a length of 1.\n * 2. Dummy nodes are added where edges have been split into segments.\n * 3. The graph is augmented with a \"dummyChains\" attribute which contains\n * the first dummy in each chain of dummy nodes produced.\n */\nfunction run(g) {\n g.graph().dummyChains = [];\n _.forEach(g.edges(), function(edge) { normalizeEdge(g, edge); });\n}\n\nfunction normalizeEdge(g, e) {\n var v = e.v;\n var vRank = g.node(v).rank;\n var w = e.w;\n var wRank = g.node(w).rank;\n var name = e.name;\n var edgeLabel = g.edge(e);\n var labelRank = edgeLabel.labelRank;\n\n if (wRank === vRank + 1) return;\n\n g.removeEdge(e);\n\n var dummy, attrs, i;\n for (i = 0, ++vRank; vRank < wRank; ++i, ++vRank) {\n edgeLabel.points = [];\n attrs = {\n width: 0, height: 0,\n edgeLabel: edgeLabel, edgeObj: e,\n rank: vRank\n };\n dummy = util.addDummyNode(g, \"edge\", attrs, \"_d\");\n if (vRank === labelRank) {\n attrs.width = edgeLabel.width;\n attrs.height = edgeLabel.height;\n attrs.dummy = \"edge-label\";\n attrs.labelpos = edgeLabel.labelpos;\n }\n g.setEdge(v, dummy, { weight: edgeLabel.weight }, name);\n if (i === 0) {\n g.graph().dummyChains.push(dummy);\n }\n v = dummy;\n }\n\n g.setEdge(v, w, { weight: edgeLabel.weight }, name);\n}\n\nfunction undo(g) {\n _.forEach(g.graph().dummyChains, function(v) {\n var node = g.node(v);\n var origLabel = node.edgeLabel;\n var w;\n g.setEdge(node.edgeObj, origLabel);\n while (node.dummy) {\n w = g.successors(v)[0];\n g.removeNode(v);\n origLabel.points.push({ x: node.x, y: node.y });\n if (node.dummy === \"edge-label\") {\n origLabel.x = node.x;\n origLabel.y = node.y;\n origLabel.width = node.width;\n origLabel.height = node.height;\n }\n v = w;\n node = g.node(v);\n }\n });\n}\n","\"use strict\";\n\nvar rankUtil = require(\"./util\");\nvar longestPath = rankUtil.longestPath;\nvar feasibleTree = require(\"./feasible-tree\");\nvar networkSimplex = require(\"./network-simplex\");\n\nmodule.exports = rank;\n\n/*\n * Assigns a rank to each node in the input graph that respects the \"minlen\"\n * constraint specified on edges between nodes.\n *\n * This basic structure is derived from Gansner, et al., \"A Technique for\n * Drawing Directed Graphs.\"\n *\n * Pre-conditions:\n *\n * 1. Graph must be a connected DAG\n * 2. Graph nodes must be objects\n * 3. Graph edges must have \"weight\" and \"minlen\" attributes\n *\n * Post-conditions:\n *\n * 1. Graph nodes will have a \"rank\" attribute based on the results of the\n * algorithm. Ranks can start at any index (including negative), we'll\n * fix them up later.\n */\nfunction rank(g) {\n switch(g.graph().ranker) {\n case \"network-simplex\": networkSimplexRanker(g); break;\n case \"tight-tree\": tightTreeRanker(g); break;\n case \"longest-path\": longestPathRanker(g); break;\n default: networkSimplexRanker(g);\n }\n}\n\n// A fast and simple ranker, but results are far from optimal.\nvar longestPathRanker = longestPath;\n\nfunction tightTreeRanker(g) {\n longestPath(g);\n feasibleTree(g);\n}\n\nfunction networkSimplexRanker(g) {\n networkSimplex(g);\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar feasibleTree = require(\"./feasible-tree\");\nvar slack = require(\"./util\").slack;\nvar initRank = require(\"./util\").longestPath;\nvar preorder = require(\"../graphlib\").alg.preorder;\nvar postorder = require(\"../graphlib\").alg.postorder;\nvar simplify = require(\"../util\").simplify;\n\nmodule.exports = networkSimplex;\n\n// Expose some internals for testing purposes\nnetworkSimplex.initLowLimValues = initLowLimValues;\nnetworkSimplex.initCutValues = initCutValues;\nnetworkSimplex.calcCutValue = calcCutValue;\nnetworkSimplex.leaveEdge = leaveEdge;\nnetworkSimplex.enterEdge = enterEdge;\nnetworkSimplex.exchangeEdges = exchangeEdges;\n\n/*\n * The network simplex algorithm assigns ranks to each node in the input graph\n * and iteratively improves the ranking to reduce the length of edges.\n *\n * Preconditions:\n *\n * 1. The input graph must be a DAG.\n * 2. All nodes in the graph must have an object value.\n * 3. All edges in the graph must have \"minlen\" and \"weight\" attributes.\n *\n * Postconditions:\n *\n * 1. All nodes in the graph will have an assigned \"rank\" attribute that has\n * been optimized by the network simplex algorithm. Ranks start at 0.\n *\n *\n * A rough sketch of the algorithm is as follows:\n *\n * 1. Assign initial ranks to each node. We use the longest path algorithm,\n * which assigns ranks to the lowest position possible. In general this\n * leads to very wide bottom ranks and unnecessarily long edges.\n * 2. Construct a feasible tight tree. A tight tree is one such that all\n * edges in the tree have no slack (difference between length of edge\n * and minlen for the edge). This by itself greatly improves the assigned\n * rankings by shorting edges.\n * 3. Iteratively find edges that have negative cut values. Generally a\n * negative cut value indicates that the edge could be removed and a new\n * tree edge could be added to produce a more compact graph.\n *\n * Much of the algorithms here are derived from Gansner, et al., \"A Technique\n * for Drawing Directed Graphs.\" The structure of the file roughly follows the\n * structure of the overall algorithm.\n */\nfunction networkSimplex(g) {\n g = simplify(g);\n initRank(g);\n var t = feasibleTree(g);\n initLowLimValues(t);\n initCutValues(t, g);\n\n var e, f;\n while ((e = leaveEdge(t))) {\n f = enterEdge(t, g, e);\n exchangeEdges(t, g, e, f);\n }\n}\n\n/*\n * Initializes cut values for all edges in the tree.\n */\nfunction initCutValues(t, g) {\n var vs = postorder(t, t.nodes());\n vs = vs.slice(0, vs.length - 1);\n _.forEach(vs, function(v) {\n assignCutValue(t, g, v);\n });\n}\n\nfunction assignCutValue(t, g, child) {\n var childLab = t.node(child);\n var parent = childLab.parent;\n t.edge(child, parent).cutvalue = calcCutValue(t, g, child);\n}\n\n/*\n * Given the tight tree, its graph, and a child in the graph calculate and\n * return the cut value for the edge between the child and its parent.\n */\nfunction calcCutValue(t, g, child) {\n var childLab = t.node(child);\n var parent = childLab.parent;\n // True if the child is on the tail end of the edge in the directed graph\n var childIsTail = true;\n // The graph's view of the tree edge we're inspecting\n var graphEdge = g.edge(child, parent);\n // The accumulated cut value for the edge between this node and its parent\n var cutValue = 0;\n\n if (!graphEdge) {\n childIsTail = false;\n graphEdge = g.edge(parent, child);\n }\n\n cutValue = graphEdge.weight;\n\n _.forEach(g.nodeEdges(child), function(e) {\n var isOutEdge = e.v === child,\n other = isOutEdge ? e.w : e.v;\n\n if (other !== parent) {\n var pointsToHead = isOutEdge === childIsTail,\n otherWeight = g.edge(e).weight;\n\n cutValue += pointsToHead ? otherWeight : -otherWeight;\n if (isTreeEdge(t, child, other)) {\n var otherCutValue = t.edge(child, other).cutvalue;\n cutValue += pointsToHead ? -otherCutValue : otherCutValue;\n }\n }\n });\n\n return cutValue;\n}\n\nfunction initLowLimValues(tree, root) {\n if (arguments.length < 2) {\n root = tree.nodes()[0];\n }\n dfsAssignLowLim(tree, {}, 1, root);\n}\n\nfunction dfsAssignLowLim(tree, visited, nextLim, v, parent) {\n var low = nextLim;\n var label = tree.node(v);\n\n visited[v] = true;\n _.forEach(tree.neighbors(v), function(w) {\n if (!_.has(visited, w)) {\n nextLim = dfsAssignLowLim(tree, visited, nextLim, w, v);\n }\n });\n\n label.low = low;\n label.lim = nextLim++;\n if (parent) {\n label.parent = parent;\n } else {\n // TODO should be able to remove this when we incrementally update low lim\n delete label.parent;\n }\n\n return nextLim;\n}\n\nfunction leaveEdge(tree) {\n return _.find(tree.edges(), function(e) {\n return tree.edge(e).cutvalue < 0;\n });\n}\n\nfunction enterEdge(t, g, edge) {\n var v = edge.v;\n var w = edge.w;\n\n // For the rest of this function we assume that v is the tail and w is the\n // head, so if we don't have this edge in the graph we should flip it to\n // match the correct orientation.\n if (!g.hasEdge(v, w)) {\n v = edge.w;\n w = edge.v;\n }\n\n var vLabel = t.node(v);\n var wLabel = t.node(w);\n var tailLabel = vLabel;\n var flip = false;\n\n // If the root is in the tail of the edge then we need to flip the logic that\n // checks for the head and tail nodes in the candidates function below.\n if (vLabel.lim > wLabel.lim) {\n tailLabel = wLabel;\n flip = true;\n }\n\n var candidates = _.filter(g.edges(), function(edge) {\n return flip === isDescendant(t, t.node(edge.v), tailLabel) &&\n flip !== isDescendant(t, t.node(edge.w), tailLabel);\n });\n\n return _.minBy(candidates, function(edge) { return slack(g, edge); });\n}\n\nfunction exchangeEdges(t, g, e, f) {\n var v = e.v;\n var w = e.w;\n t.removeEdge(v, w);\n t.setEdge(f.v, f.w, {});\n initLowLimValues(t);\n initCutValues(t, g);\n updateRanks(t, g);\n}\n\nfunction updateRanks(t, g) {\n var root = _.find(t.nodes(), function(v) { return !g.node(v).parent; });\n var vs = preorder(t, root);\n vs = vs.slice(1);\n _.forEach(vs, function(v) {\n var parent = t.node(v).parent,\n edge = g.edge(v, parent),\n flipped = false;\n\n if (!edge) {\n edge = g.edge(parent, v);\n flipped = true;\n }\n\n g.node(v).rank = g.node(parent).rank + (flipped ? edge.minlen : -edge.minlen);\n });\n}\n\n/*\n * Returns true if the edge is in the tree.\n */\nfunction isTreeEdge(tree, u, v) {\n return tree.hasEdge(u, v);\n}\n\n/*\n * Returns true if the specified node is descendant of the root node per the\n * assigned low and lim attributes in the tree.\n */\nfunction isDescendant(tree, vLabel, rootLabel) {\n return rootLabel.low <= vLabel.lim && vLabel.lim <= rootLabel.lim;\n}\n","var _ = require(\"./lodash\");\n\nmodule.exports = parentDummyChains;\n\nfunction parentDummyChains(g) {\n var postorderNums = postorder(g);\n\n _.forEach(g.graph().dummyChains, function(v) {\n var node = g.node(v);\n var edgeObj = node.edgeObj;\n var pathData = findPath(g, postorderNums, edgeObj.v, edgeObj.w);\n var path = pathData.path;\n var lca = pathData.lca;\n var pathIdx = 0;\n var pathV = path[pathIdx];\n var ascending = true;\n\n while (v !== edgeObj.w) {\n node = g.node(v);\n\n if (ascending) {\n while ((pathV = path[pathIdx]) !== lca &&\n g.node(pathV).maxRank < node.rank) {\n pathIdx++;\n }\n\n if (pathV === lca) {\n ascending = false;\n }\n }\n\n if (!ascending) {\n while (pathIdx < path.length - 1 &&\n g.node(pathV = path[pathIdx + 1]).minRank <= node.rank) {\n pathIdx++;\n }\n pathV = path[pathIdx];\n }\n\n g.setParent(v, pathV);\n v = g.successors(v)[0];\n }\n });\n}\n\n// Find a path from v to w through the lowest common ancestor (LCA). Return the\n// full path and the LCA.\nfunction findPath(g, postorderNums, v, w) {\n var vPath = [];\n var wPath = [];\n var low = Math.min(postorderNums[v].low, postorderNums[w].low);\n var lim = Math.max(postorderNums[v].lim, postorderNums[w].lim);\n var parent;\n var lca;\n\n // Traverse up from v to find the LCA\n parent = v;\n do {\n parent = g.parent(parent);\n vPath.push(parent);\n } while (parent &&\n (postorderNums[parent].low > low || lim > postorderNums[parent].lim));\n lca = parent;\n\n // Traverse from w to LCA\n parent = w;\n while ((parent = g.parent(parent)) !== lca) {\n wPath.push(parent);\n }\n\n return { path: vPath.concat(wPath.reverse()), lca: lca };\n}\n\nfunction postorder(g) {\n var result = {};\n var lim = 0;\n\n function dfs(v) {\n var low = lim;\n _.forEach(g.children(v), dfs);\n result[v] = { low: low, lim: lim++ };\n }\n _.forEach(g.children(), dfs);\n\n return result;\n}\n","var _ = require(\"./lodash\");\nvar util = require(\"./util\");\n\nmodule.exports = {\n run: run,\n cleanup: cleanup\n};\n\n/*\n * A nesting graph creates dummy nodes for the tops and bottoms of subgraphs,\n * adds appropriate edges to ensure that all cluster nodes are placed between\n * these boundries, and ensures that the graph is connected.\n *\n * In addition we ensure, through the use of the minlen property, that nodes\n * and subgraph border nodes to not end up on the same rank.\n *\n * Preconditions:\n *\n * 1. Input graph is a DAG\n * 2. Nodes in the input graph has a minlen attribute\n *\n * Postconditions:\n *\n * 1. Input graph is connected.\n * 2. Dummy nodes are added for the tops and bottoms of subgraphs.\n * 3. The minlen attribute for nodes is adjusted to ensure nodes do not\n * get placed on the same rank as subgraph border nodes.\n *\n * The nesting graph idea comes from Sander, \"Layout of Compound Directed\n * Graphs.\"\n */\nfunction run(g) {\n var root = util.addDummyNode(g, \"root\", {}, \"_root\");\n var depths = treeDepths(g);\n var height = _.max(_.values(depths)) - 1; // Note: depths is an Object not an array\n var nodeSep = 2 * height + 1;\n\n g.graph().nestingRoot = root;\n\n // Multiply minlen by nodeSep to align nodes on non-border ranks.\n _.forEach(g.edges(), function(e) { g.edge(e).minlen *= nodeSep; });\n\n // Calculate a weight that is sufficient to keep subgraphs vertically compact\n var weight = sumWeights(g) + 1;\n\n // Create border nodes and link them up\n _.forEach(g.children(), function(child) {\n dfs(g, root, nodeSep, weight, height, depths, child);\n });\n\n // Save the multiplier for node layers for later removal of empty border\n // layers.\n g.graph().nodeRankFactor = nodeSep;\n}\n\nfunction dfs(g, root, nodeSep, weight, height, depths, v) {\n var children = g.children(v);\n if (!children.length) {\n if (v !== root) {\n g.setEdge(root, v, { weight: 0, minlen: nodeSep });\n }\n return;\n }\n\n var top = util.addBorderNode(g, \"_bt\");\n var bottom = util.addBorderNode(g, \"_bb\");\n var label = g.node(v);\n\n g.setParent(top, v);\n label.borderTop = top;\n g.setParent(bottom, v);\n label.borderBottom = bottom;\n\n _.forEach(children, function(child) {\n dfs(g, root, nodeSep, weight, height, depths, child);\n\n var childNode = g.node(child);\n var childTop = childNode.borderTop ? childNode.borderTop : child;\n var childBottom = childNode.borderBottom ? childNode.borderBottom : child;\n var thisWeight = childNode.borderTop ? weight : 2 * weight;\n var minlen = childTop !== childBottom ? 1 : height - depths[v] + 1;\n\n g.setEdge(top, childTop, {\n weight: thisWeight,\n minlen: minlen,\n nestingEdge: true\n });\n\n g.setEdge(childBottom, bottom, {\n weight: thisWeight,\n minlen: minlen,\n nestingEdge: true\n });\n });\n\n if (!g.parent(v)) {\n g.setEdge(root, top, { weight: 0, minlen: height + depths[v] });\n }\n}\n\nfunction treeDepths(g) {\n var depths = {};\n function dfs(v, depth) {\n var children = g.children(v);\n if (children && children.length) {\n _.forEach(children, function(child) {\n dfs(child, depth + 1);\n });\n }\n depths[v] = depth;\n }\n _.forEach(g.children(), function(v) { dfs(v, 1); });\n return depths;\n}\n\nfunction sumWeights(g) {\n return _.reduce(g.edges(), function(acc, e) {\n return acc + g.edge(e).weight;\n }, 0);\n}\n\nfunction cleanup(g) {\n var graphLabel = g.graph();\n g.removeNode(graphLabel.nestingRoot);\n delete graphLabel.nestingRoot;\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (edge.nestingEdge) {\n g.removeEdge(e);\n }\n });\n}\n","var _ = require(\"./lodash\");\nvar util = require(\"./util\");\n\nmodule.exports = addBorderSegments;\n\nfunction addBorderSegments(g) {\n function dfs(v) {\n var children = g.children(v);\n var node = g.node(v);\n if (children.length) {\n _.forEach(children, dfs);\n }\n\n if (_.has(node, \"minRank\")) {\n node.borderLeft = [];\n node.borderRight = [];\n for (var rank = node.minRank, maxRank = node.maxRank + 1;\n rank < maxRank;\n ++rank) {\n addBorderNode(g, \"borderLeft\", \"_bl\", v, node, rank);\n addBorderNode(g, \"borderRight\", \"_br\", v, node, rank);\n }\n }\n }\n\n _.forEach(g.children(), dfs);\n}\n\nfunction addBorderNode(g, prop, prefix, sg, sgNode, rank) {\n var label = { width: 0, height: 0, rank: rank, borderType: prop };\n var prev = sgNode[prop][rank - 1];\n var curr = util.addDummyNode(g, \"border\", label, prefix);\n sgNode[prop][rank] = curr;\n g.setParent(curr, sg);\n if (prev) {\n g.setEdge(prev, curr, { weight: 1 });\n }\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\");\n\nmodule.exports = {\n adjust: adjust,\n undo: undo\n};\n\nfunction adjust(g) {\n var rankDir = g.graph().rankdir.toLowerCase();\n if (rankDir === \"lr\" || rankDir === \"rl\") {\n swapWidthHeight(g);\n }\n}\n\nfunction undo(g) {\n var rankDir = g.graph().rankdir.toLowerCase();\n if (rankDir === \"bt\" || rankDir === \"rl\") {\n reverseY(g);\n }\n\n if (rankDir === \"lr\" || rankDir === \"rl\") {\n swapXY(g);\n swapWidthHeight(g);\n }\n}\n\nfunction swapWidthHeight(g) {\n _.forEach(g.nodes(), function(v) { swapWidthHeightOne(g.node(v)); });\n _.forEach(g.edges(), function(e) { swapWidthHeightOne(g.edge(e)); });\n}\n\nfunction swapWidthHeightOne(attrs) {\n var w = attrs.width;\n attrs.width = attrs.height;\n attrs.height = w;\n}\n\nfunction reverseY(g) {\n _.forEach(g.nodes(), function(v) { reverseYOne(g.node(v)); });\n\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n _.forEach(edge.points, reverseYOne);\n if (_.has(edge, \"y\")) {\n reverseYOne(edge);\n }\n });\n}\n\nfunction reverseYOne(attrs) {\n attrs.y = -attrs.y;\n}\n\nfunction swapXY(g) {\n _.forEach(g.nodes(), function(v) { swapXYOne(g.node(v)); });\n\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n _.forEach(edge.points, swapXYOne);\n if (_.has(edge, \"x\")) {\n swapXYOne(edge);\n }\n });\n}\n\nfunction swapXYOne(attrs) {\n var x = attrs.x;\n attrs.x = attrs.y;\n attrs.y = x;\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar initOrder = require(\"./init-order\");\nvar crossCount = require(\"./cross-count\");\nvar sortSubgraph = require(\"./sort-subgraph\");\nvar buildLayerGraph = require(\"./build-layer-graph\");\nvar addSubgraphConstraints = require(\"./add-subgraph-constraints\");\nvar Graph = require(\"../graphlib\").Graph;\nvar util = require(\"../util\");\n\nmodule.exports = order;\n\n/*\n * Applies heuristics to minimize edge crossings in the graph and sets the best\n * order solution as an order attribute on each node.\n *\n * Pre-conditions:\n *\n * 1. Graph must be DAG\n * 2. Graph nodes must be objects with a \"rank\" attribute\n * 3. Graph edges must have the \"weight\" attribute\n *\n * Post-conditions:\n *\n * 1. Graph nodes will have an \"order\" attribute based on the results of the\n * algorithm.\n */\nfunction order(g) {\n var maxRank = util.maxRank(g),\n downLayerGraphs = buildLayerGraphs(g, _.range(1, maxRank + 1), \"inEdges\"),\n upLayerGraphs = buildLayerGraphs(g, _.range(maxRank - 1, -1, -1), \"outEdges\");\n\n var layering = initOrder(g);\n assignOrder(g, layering);\n\n var bestCC = Number.POSITIVE_INFINITY,\n best;\n\n for (var i = 0, lastBest = 0; lastBest < 4; ++i, ++lastBest) {\n sweepLayerGraphs(i % 2 ? downLayerGraphs : upLayerGraphs, i % 4 >= 2);\n\n layering = util.buildLayerMatrix(g);\n var cc = crossCount(g, layering);\n if (cc < bestCC) {\n lastBest = 0;\n best = _.cloneDeep(layering);\n bestCC = cc;\n }\n }\n\n assignOrder(g, best);\n}\n\nfunction buildLayerGraphs(g, ranks, relationship) {\n return _.map(ranks, function(rank) {\n return buildLayerGraph(g, rank, relationship);\n });\n}\n\nfunction sweepLayerGraphs(layerGraphs, biasRight) {\n var cg = new Graph();\n _.forEach(layerGraphs, function(lg) {\n var root = lg.graph().root;\n var sorted = sortSubgraph(lg, root, cg, biasRight);\n _.forEach(sorted.vs, function(v, i) {\n lg.node(v).order = i;\n });\n addSubgraphConstraints(lg, cg, sorted.vs);\n });\n}\n\nfunction assignOrder(g, layering) {\n _.forEach(layering, function(layer) {\n _.forEach(layer, function(v, i) {\n g.node(v).order = i;\n });\n });\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\n\nmodule.exports = initOrder;\n\n/*\n * Assigns an initial order value for each node by performing a DFS search\n * starting from nodes in the first rank. Nodes are assigned an order in their\n * rank as they are first visited.\n *\n * This approach comes from Gansner, et al., \"A Technique for Drawing Directed\n * Graphs.\"\n *\n * Returns a layering matrix with an array per layer and each layer sorted by\n * the order of its nodes.\n */\nfunction initOrder(g) {\n var visited = {};\n var simpleNodes = _.filter(g.nodes(), function(v) {\n return !g.children(v).length;\n });\n var maxRank = _.max(_.map(simpleNodes, function(v) { return g.node(v).rank; }));\n var layers = _.map(_.range(maxRank + 1), function() { return []; });\n\n function dfs(v) {\n if (_.has(visited, v)) return;\n visited[v] = true;\n var node = g.node(v);\n layers[node.rank].push(v);\n _.forEach(g.successors(v), dfs);\n }\n\n var orderedVs = _.sortBy(simpleNodes, function(v) { return g.node(v).rank; });\n _.forEach(orderedVs, dfs);\n\n return layers;\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\n\nmodule.exports = crossCount;\n\n/*\n * A function that takes a layering (an array of layers, each with an array of\n * ordererd nodes) and a graph and returns a weighted crossing count.\n *\n * Pre-conditions:\n *\n * 1. Input graph must be simple (not a multigraph), directed, and include\n * only simple edges.\n * 2. Edges in the input graph must have assigned weights.\n *\n * Post-conditions:\n *\n * 1. The graph and layering matrix are left unchanged.\n *\n * This algorithm is derived from Barth, et al., \"Bilayer Cross Counting.\"\n */\nfunction crossCount(g, layering) {\n var cc = 0;\n for (var i = 1; i < layering.length; ++i) {\n cc += twoLayerCrossCount(g, layering[i-1], layering[i]);\n }\n return cc;\n}\n\nfunction twoLayerCrossCount(g, northLayer, southLayer) {\n // Sort all of the edges between the north and south layers by their position\n // in the north layer and then the south. Map these edges to the position of\n // their head in the south layer.\n var southPos = _.zipObject(southLayer,\n _.map(southLayer, function (v, i) { return i; }));\n var southEntries = _.flatten(_.map(northLayer, function(v) {\n return _.sortBy(_.map(g.outEdges(v), function(e) {\n return { pos: southPos[e.w], weight: g.edge(e).weight };\n }), \"pos\");\n }), true);\n\n // Build the accumulator tree\n var firstIndex = 1;\n while (firstIndex < southLayer.length) firstIndex <<= 1;\n var treeSize = 2 * firstIndex - 1;\n firstIndex -= 1;\n var tree = _.map(new Array(treeSize), function() { return 0; });\n\n // Calculate the weighted crossings\n var cc = 0;\n _.forEach(southEntries.forEach(function(entry) {\n var index = entry.pos + firstIndex;\n tree[index] += entry.weight;\n var weightSum = 0;\n while (index > 0) {\n if (index % 2) {\n weightSum += tree[index + 1];\n }\n index = (index - 1) >> 1;\n tree[index] += entry.weight;\n }\n cc += entry.weight * weightSum;\n }));\n\n return cc;\n}\n","var _ = require(\"../lodash\");\nvar barycenter = require(\"./barycenter\");\nvar resolveConflicts = require(\"./resolve-conflicts\");\nvar sort = require(\"./sort\");\n\nmodule.exports = sortSubgraph;\n\nfunction sortSubgraph(g, v, cg, biasRight) {\n var movable = g.children(v);\n var node = g.node(v);\n var bl = node ? node.borderLeft : undefined;\n var br = node ? node.borderRight: undefined;\n var subgraphs = {};\n\n if (bl) {\n movable = _.filter(movable, function(w) {\n return w !== bl && w !== br;\n });\n }\n\n var barycenters = barycenter(g, movable);\n _.forEach(barycenters, function(entry) {\n if (g.children(entry.v).length) {\n var subgraphResult = sortSubgraph(g, entry.v, cg, biasRight);\n subgraphs[entry.v] = subgraphResult;\n if (_.has(subgraphResult, \"barycenter\")) {\n mergeBarycenters(entry, subgraphResult);\n }\n }\n });\n\n var entries = resolveConflicts(barycenters, cg);\n expandSubgraphs(entries, subgraphs);\n\n var result = sort(entries, biasRight);\n\n if (bl) {\n result.vs = _.flatten([bl, result.vs, br], true);\n if (g.predecessors(bl).length) {\n var blPred = g.node(g.predecessors(bl)[0]),\n brPred = g.node(g.predecessors(br)[0]);\n if (!_.has(result, \"barycenter\")) {\n result.barycenter = 0;\n result.weight = 0;\n }\n result.barycenter = (result.barycenter * result.weight +\n blPred.order + brPred.order) / (result.weight + 2);\n result.weight += 2;\n }\n }\n\n return result;\n}\n\nfunction expandSubgraphs(entries, subgraphs) {\n _.forEach(entries, function(entry) {\n entry.vs = _.flatten(entry.vs.map(function(v) {\n if (subgraphs[v]) {\n return subgraphs[v].vs;\n }\n return v;\n }), true);\n });\n}\n\nfunction mergeBarycenters(target, other) {\n if (!_.isUndefined(target.barycenter)) {\n target.barycenter = (target.barycenter * target.weight +\n other.barycenter * other.weight) /\n (target.weight + other.weight);\n target.weight += other.weight;\n } else {\n target.barycenter = other.barycenter;\n target.weight = other.weight;\n }\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = barycenter;\n\nfunction barycenter(g, movable) {\n return _.map(movable, function(v) {\n var inV = g.inEdges(v);\n if (!inV.length) {\n return { v: v };\n } else {\n var result = _.reduce(inV, function(acc, e) {\n var edge = g.edge(e),\n nodeU = g.node(e.v);\n return {\n sum: acc.sum + (edge.weight * nodeU.order),\n weight: acc.weight + edge.weight\n };\n }, { sum: 0, weight: 0 });\n\n return {\n v: v,\n barycenter: result.sum / result.weight,\n weight: result.weight\n };\n }\n });\n}\n\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\n\nmodule.exports = resolveConflicts;\n\n/*\n * Given a list of entries of the form {v, barycenter, weight} and a\n * constraint graph this function will resolve any conflicts between the\n * constraint graph and the barycenters for the entries. If the barycenters for\n * an entry would violate a constraint in the constraint graph then we coalesce\n * the nodes in the conflict into a new node that respects the contraint and\n * aggregates barycenter and weight information.\n *\n * This implementation is based on the description in Forster, \"A Fast and\n * Simple Hueristic for Constrained Two-Level Crossing Reduction,\" thought it\n * differs in some specific details.\n *\n * Pre-conditions:\n *\n * 1. Each entry has the form {v, barycenter, weight}, or if the node has\n * no barycenter, then {v}.\n *\n * Returns:\n *\n * A new list of entries of the form {vs, i, barycenter, weight}. The list\n * `vs` may either be a singleton or it may be an aggregation of nodes\n * ordered such that they do not violate constraints from the constraint\n * graph. The property `i` is the lowest original index of any of the\n * elements in `vs`.\n */\nfunction resolveConflicts(entries, cg) {\n var mappedEntries = {};\n _.forEach(entries, function(entry, i) {\n var tmp = mappedEntries[entry.v] = {\n indegree: 0,\n \"in\": [],\n out: [],\n vs: [entry.v],\n i: i\n };\n if (!_.isUndefined(entry.barycenter)) {\n tmp.barycenter = entry.barycenter;\n tmp.weight = entry.weight;\n }\n });\n\n _.forEach(cg.edges(), function(e) {\n var entryV = mappedEntries[e.v];\n var entryW = mappedEntries[e.w];\n if (!_.isUndefined(entryV) && !_.isUndefined(entryW)) {\n entryW.indegree++;\n entryV.out.push(mappedEntries[e.w]);\n }\n });\n\n var sourceSet = _.filter(mappedEntries, function(entry) {\n return !entry.indegree;\n });\n\n return doResolveConflicts(sourceSet);\n}\n\nfunction doResolveConflicts(sourceSet) {\n var entries = [];\n\n function handleIn(vEntry) {\n return function(uEntry) {\n if (uEntry.merged) {\n return;\n }\n if (_.isUndefined(uEntry.barycenter) ||\n _.isUndefined(vEntry.barycenter) ||\n uEntry.barycenter >= vEntry.barycenter) {\n mergeEntries(vEntry, uEntry);\n }\n };\n }\n\n function handleOut(vEntry) {\n return function(wEntry) {\n wEntry[\"in\"].push(vEntry);\n if (--wEntry.indegree === 0) {\n sourceSet.push(wEntry);\n }\n };\n }\n\n while (sourceSet.length) {\n var entry = sourceSet.pop();\n entries.push(entry);\n _.forEach(entry[\"in\"].reverse(), handleIn(entry));\n _.forEach(entry.out, handleOut(entry));\n }\n\n return _.map(_.filter(entries, function(entry) { return !entry.merged; }),\n function(entry) {\n return _.pick(entry, [\"vs\", \"i\", \"barycenter\", \"weight\"]);\n });\n\n}\n\nfunction mergeEntries(target, source) {\n var sum = 0;\n var weight = 0;\n\n if (target.weight) {\n sum += target.barycenter * target.weight;\n weight += target.weight;\n }\n\n if (source.weight) {\n sum += source.barycenter * source.weight;\n weight += source.weight;\n }\n\n target.vs = source.vs.concat(target.vs);\n target.barycenter = sum / weight;\n target.weight = weight;\n target.i = Math.min(source.i, target.i);\n source.merged = true;\n}\n","var _ = require(\"../lodash\");\nvar util = require(\"../util\");\n\nmodule.exports = sort;\n\nfunction sort(entries, biasRight) {\n var parts = util.partition(entries, function(entry) {\n return _.has(entry, \"barycenter\");\n });\n var sortable = parts.lhs,\n unsortable = _.sortBy(parts.rhs, function(entry) { return -entry.i; }),\n vs = [],\n sum = 0,\n weight = 0,\n vsIndex = 0;\n\n sortable.sort(compareWithBias(!!biasRight));\n\n vsIndex = consumeUnsortable(vs, unsortable, vsIndex);\n\n _.forEach(sortable, function (entry) {\n vsIndex += entry.vs.length;\n vs.push(entry.vs);\n sum += entry.barycenter * entry.weight;\n weight += entry.weight;\n vsIndex = consumeUnsortable(vs, unsortable, vsIndex);\n });\n\n var result = { vs: _.flatten(vs, true) };\n if (weight) {\n result.barycenter = sum / weight;\n result.weight = weight;\n }\n return result;\n}\n\nfunction consumeUnsortable(vs, unsortable, index) {\n var last;\n while (unsortable.length && (last = _.last(unsortable)).i <= index) {\n unsortable.pop();\n vs.push(last.vs);\n index++;\n }\n return index;\n}\n\nfunction compareWithBias(bias) {\n return function(entryV, entryW) {\n if (entryV.barycenter < entryW.barycenter) {\n return -1;\n } else if (entryV.barycenter > entryW.barycenter) {\n return 1;\n }\n\n return !bias ? entryV.i - entryW.i : entryW.i - entryV.i;\n };\n}\n","var _ = require(\"../lodash\");\nvar Graph = require(\"../graphlib\").Graph;\n\nmodule.exports = buildLayerGraph;\n\n/*\n * Constructs a graph that can be used to sort a layer of nodes. The graph will\n * contain all base and subgraph nodes from the request layer in their original\n * hierarchy and any edges that are incident on these nodes and are of the type\n * requested by the \"relationship\" parameter.\n *\n * Nodes from the requested rank that do not have parents are assigned a root\n * node in the output graph, which is set in the root graph attribute. This\n * makes it easy to walk the hierarchy of movable nodes during ordering.\n *\n * Pre-conditions:\n *\n * 1. Input graph is a DAG\n * 2. Base nodes in the input graph have a rank attribute\n * 3. Subgraph nodes in the input graph has minRank and maxRank attributes\n * 4. Edges have an assigned weight\n *\n * Post-conditions:\n *\n * 1. Output graph has all nodes in the movable rank with preserved\n * hierarchy.\n * 2. Root nodes in the movable layer are made children of the node\n * indicated by the root attribute of the graph.\n * 3. Non-movable nodes incident on movable nodes, selected by the\n * relationship parameter, are included in the graph (without hierarchy).\n * 4. Edges incident on movable nodes, selected by the relationship\n * parameter, are added to the output graph.\n * 5. The weights for copied edges are aggregated as need, since the output\n * graph is not a multi-graph.\n */\nfunction buildLayerGraph(g, rank, relationship) {\n var root = createRootNode(g),\n result = new Graph({ compound: true }).setGraph({ root: root })\n .setDefaultNodeLabel(function(v) { return g.node(v); });\n\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v),\n parent = g.parent(v);\n\n if (node.rank === rank || node.minRank <= rank && rank <= node.maxRank) {\n result.setNode(v);\n result.setParent(v, parent || root);\n\n // This assumes we have only short edges!\n _.forEach(g[relationship](v), function(e) {\n var u = e.v === v ? e.w : e.v,\n edge = result.edge(u, v),\n weight = !_.isUndefined(edge) ? edge.weight : 0;\n result.setEdge(u, v, { weight: g.edge(e).weight + weight });\n });\n\n if (_.has(node, \"minRank\")) {\n result.setNode(v, {\n borderLeft: node.borderLeft[rank],\n borderRight: node.borderRight[rank]\n });\n }\n }\n });\n\n return result;\n}\n\nfunction createRootNode(g) {\n var v;\n while (g.hasNode((v = _.uniqueId(\"_root\"))));\n return v;\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = addSubgraphConstraints;\n\nfunction addSubgraphConstraints(g, cg, vs) {\n var prev = {},\n rootPrev;\n\n _.forEach(vs, function(v) {\n var child = g.parent(v),\n parent,\n prevChild;\n while (child) {\n parent = g.parent(child);\n if (parent) {\n prevChild = prev[parent];\n prev[parent] = child;\n } else {\n prevChild = rootPrev;\n rootPrev = child;\n }\n if (prevChild && prevChild !== child) {\n cg.setEdge(prevChild, child);\n return;\n }\n child = parent;\n }\n });\n\n /*\n function dfs(v) {\n var children = v ? g.children(v) : g.children();\n if (children.length) {\n var min = Number.POSITIVE_INFINITY,\n subgraphs = [];\n _.each(children, function(child) {\n var childMin = dfs(child);\n if (g.children(child).length) {\n subgraphs.push({ v: child, order: childMin });\n }\n min = Math.min(min, childMin);\n });\n _.reduce(_.sortBy(subgraphs, \"order\"), function(prev, curr) {\n cg.setEdge(prev.v, curr.v);\n return curr;\n });\n return min;\n }\n return g.node(v).order;\n }\n dfs(undefined);\n */\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar util = require(\"../util\");\nvar positionX = require(\"./bk\").positionX;\n\nmodule.exports = position;\n\nfunction position(g) {\n g = util.asNonCompoundGraph(g);\n\n positionY(g);\n _.forEach(positionX(g), function(x, v) {\n g.node(v).x = x;\n });\n}\n\nfunction positionY(g) {\n var layering = util.buildLayerMatrix(g);\n var rankSep = g.graph().ranksep;\n var prevY = 0;\n _.forEach(layering, function(layer) {\n var maxHeight = _.max(_.map(layer, function(v) { return g.node(v).height; }));\n _.forEach(layer, function(v) {\n g.node(v).y = prevY + maxHeight / 2;\n });\n prevY += maxHeight + rankSep;\n });\n}\n\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar Graph = require(\"../graphlib\").Graph;\nvar util = require(\"../util\");\n\n/*\n * This module provides coordinate assignment based on Brandes and Köpf, \"Fast\n * and Simple Horizontal Coordinate Assignment.\"\n */\n\nmodule.exports = {\n positionX: positionX,\n findType1Conflicts: findType1Conflicts,\n findType2Conflicts: findType2Conflicts,\n addConflict: addConflict,\n hasConflict: hasConflict,\n verticalAlignment: verticalAlignment,\n horizontalCompaction: horizontalCompaction,\n alignCoordinates: alignCoordinates,\n findSmallestWidthAlignment: findSmallestWidthAlignment,\n balance: balance\n};\n\n/*\n * Marks all edges in the graph with a type-1 conflict with the \"type1Conflict\"\n * property. A type-1 conflict is one where a non-inner segment crosses an\n * inner segment. An inner segment is an edge with both incident nodes marked\n * with the \"dummy\" property.\n *\n * This algorithm scans layer by layer, starting with the second, for type-1\n * conflicts between the current layer and the previous layer. For each layer\n * it scans the nodes from left to right until it reaches one that is incident\n * on an inner segment. It then scans predecessors to determine if they have\n * edges that cross that inner segment. At the end a final scan is done for all\n * nodes on the current rank to see if they cross the last visited inner\n * segment.\n *\n * This algorithm (safely) assumes that a dummy node will only be incident on a\n * single node in the layers being scanned.\n */\nfunction findType1Conflicts(g, layering) {\n var conflicts = {};\n\n function visitLayer(prevLayer, layer) {\n var\n // last visited node in the previous layer that is incident on an inner\n // segment.\n k0 = 0,\n // Tracks the last node in this layer scanned for crossings with a type-1\n // segment.\n scanPos = 0,\n prevLayerLength = prevLayer.length,\n lastNode = _.last(layer);\n\n _.forEach(layer, function(v, i) {\n var w = findOtherInnerSegmentNode(g, v),\n k1 = w ? g.node(w).order : prevLayerLength;\n\n if (w || v === lastNode) {\n _.forEach(layer.slice(scanPos, i +1), function(scanNode) {\n _.forEach(g.predecessors(scanNode), function(u) {\n var uLabel = g.node(u),\n uPos = uLabel.order;\n if ((uPos < k0 || k1 < uPos) &&\n !(uLabel.dummy && g.node(scanNode).dummy)) {\n addConflict(conflicts, u, scanNode);\n }\n });\n });\n scanPos = i + 1;\n k0 = k1;\n }\n });\n\n return layer;\n }\n\n _.reduce(layering, visitLayer);\n return conflicts;\n}\n\nfunction findType2Conflicts(g, layering) {\n var conflicts = {};\n\n function scan(south, southPos, southEnd, prevNorthBorder, nextNorthBorder) {\n var v;\n _.forEach(_.range(southPos, southEnd), function(i) {\n v = south[i];\n if (g.node(v).dummy) {\n _.forEach(g.predecessors(v), function(u) {\n var uNode = g.node(u);\n if (uNode.dummy &&\n (uNode.order < prevNorthBorder || uNode.order > nextNorthBorder)) {\n addConflict(conflicts, u, v);\n }\n });\n }\n });\n }\n\n\n function visitLayer(north, south) {\n var prevNorthPos = -1,\n nextNorthPos,\n southPos = 0;\n\n _.forEach(south, function(v, southLookahead) {\n if (g.node(v).dummy === \"border\") {\n var predecessors = g.predecessors(v);\n if (predecessors.length) {\n nextNorthPos = g.node(predecessors[0]).order;\n scan(south, southPos, southLookahead, prevNorthPos, nextNorthPos);\n southPos = southLookahead;\n prevNorthPos = nextNorthPos;\n }\n }\n scan(south, southPos, south.length, nextNorthPos, north.length);\n });\n\n return south;\n }\n\n _.reduce(layering, visitLayer);\n return conflicts;\n}\n\nfunction findOtherInnerSegmentNode(g, v) {\n if (g.node(v).dummy) {\n return _.find(g.predecessors(v), function(u) {\n return g.node(u).dummy;\n });\n }\n}\n\nfunction addConflict(conflicts, v, w) {\n if (v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n\n var conflictsV = conflicts[v];\n if (!conflictsV) {\n conflicts[v] = conflictsV = {};\n }\n conflictsV[w] = true;\n}\n\nfunction hasConflict(conflicts, v, w) {\n if (v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n return _.has(conflicts[v], w);\n}\n\n/*\n * Try to align nodes into vertical \"blocks\" where possible. This algorithm\n * attempts to align a node with one of its median neighbors. If the edge\n * connecting a neighbor is a type-1 conflict then we ignore that possibility.\n * If a previous node has already formed a block with a node after the node\n * we're trying to form a block with, we also ignore that possibility - our\n * blocks would be split in that scenario.\n */\nfunction verticalAlignment(g, layering, conflicts, neighborFn) {\n var root = {},\n align = {},\n pos = {};\n\n // We cache the position here based on the layering because the graph and\n // layering may be out of sync. The layering matrix is manipulated to\n // generate different extreme alignments.\n _.forEach(layering, function(layer) {\n _.forEach(layer, function(v, order) {\n root[v] = v;\n align[v] = v;\n pos[v] = order;\n });\n });\n\n _.forEach(layering, function(layer) {\n var prevIdx = -1;\n _.forEach(layer, function(v) {\n var ws = neighborFn(v);\n if (ws.length) {\n ws = _.sortBy(ws, function(w) { return pos[w]; });\n var mp = (ws.length - 1) / 2;\n for (var i = Math.floor(mp), il = Math.ceil(mp); i <= il; ++i) {\n var w = ws[i];\n if (align[v] === v &&\n prevIdx < pos[w] &&\n !hasConflict(conflicts, v, w)) {\n align[w] = v;\n align[v] = root[v] = root[w];\n prevIdx = pos[w];\n }\n }\n }\n });\n });\n\n return { root: root, align: align };\n}\n\nfunction horizontalCompaction(g, layering, root, align, reverseSep) {\n // This portion of the algorithm differs from BK due to a number of problems.\n // Instead of their algorithm we construct a new block graph and do two\n // sweeps. The first sweep places blocks with the smallest possible\n // coordinates. The second sweep removes unused space by moving blocks to the\n // greatest coordinates without violating separation.\n var xs = {},\n blockG = buildBlockGraph(g, layering, root, reverseSep),\n borderType = reverseSep ? \"borderLeft\" : \"borderRight\";\n\n function iterate(setXsFunc, nextNodesFunc) {\n var stack = blockG.nodes();\n var elem = stack.pop();\n var visited = {};\n while (elem) {\n if (visited[elem]) {\n setXsFunc(elem);\n } else {\n visited[elem] = true;\n stack.push(elem);\n stack = stack.concat(nextNodesFunc(elem));\n }\n\n elem = stack.pop();\n }\n }\n\n // First pass, assign smallest coordinates\n function pass1(elem) {\n xs[elem] = blockG.inEdges(elem).reduce(function(acc, e) {\n return Math.max(acc, xs[e.v] + blockG.edge(e));\n }, 0);\n }\n\n // Second pass, assign greatest coordinates\n function pass2(elem) {\n var min = blockG.outEdges(elem).reduce(function(acc, e) {\n return Math.min(acc, xs[e.w] - blockG.edge(e));\n }, Number.POSITIVE_INFINITY);\n\n var node = g.node(elem);\n if (min !== Number.POSITIVE_INFINITY && node.borderType !== borderType) {\n xs[elem] = Math.max(xs[elem], min);\n }\n }\n\n iterate(pass1, blockG.predecessors.bind(blockG));\n iterate(pass2, blockG.successors.bind(blockG));\n\n // Assign x coordinates to all nodes\n _.forEach(align, function(v) {\n xs[v] = xs[root[v]];\n });\n\n return xs;\n}\n\n\nfunction buildBlockGraph(g, layering, root, reverseSep) {\n var blockGraph = new Graph(),\n graphLabel = g.graph(),\n sepFn = sep(graphLabel.nodesep, graphLabel.edgesep, reverseSep);\n\n _.forEach(layering, function(layer) {\n var u;\n _.forEach(layer, function(v) {\n var vRoot = root[v];\n blockGraph.setNode(vRoot);\n if (u) {\n var uRoot = root[u],\n prevMax = blockGraph.edge(uRoot, vRoot);\n blockGraph.setEdge(uRoot, vRoot, Math.max(sepFn(g, v, u), prevMax || 0));\n }\n u = v;\n });\n });\n\n return blockGraph;\n}\n\n/*\n * Returns the alignment that has the smallest width of the given alignments.\n */\nfunction findSmallestWidthAlignment(g, xss) {\n return _.minBy(_.values(xss), function (xs) {\n var max = Number.NEGATIVE_INFINITY;\n var min = Number.POSITIVE_INFINITY;\n\n _.forIn(xs, function (x, v) {\n var halfWidth = width(g, v) / 2;\n\n max = Math.max(x + halfWidth, max);\n min = Math.min(x - halfWidth, min);\n });\n\n return max - min;\n });\n}\n\n/*\n * Align the coordinates of each of the layout alignments such that\n * left-biased alignments have their minimum coordinate at the same point as\n * the minimum coordinate of the smallest width alignment and right-biased\n * alignments have their maximum coordinate at the same point as the maximum\n * coordinate of the smallest width alignment.\n */\nfunction alignCoordinates(xss, alignTo) {\n var alignToVals = _.values(alignTo),\n alignToMin = _.min(alignToVals),\n alignToMax = _.max(alignToVals);\n\n _.forEach([\"u\", \"d\"], function(vert) {\n _.forEach([\"l\", \"r\"], function(horiz) {\n var alignment = vert + horiz,\n xs = xss[alignment],\n delta;\n if (xs === alignTo) return;\n\n var xsVals = _.values(xs);\n delta = horiz === \"l\" ? alignToMin - _.min(xsVals) : alignToMax - _.max(xsVals);\n\n if (delta) {\n xss[alignment] = _.mapValues(xs, function(x) { return x + delta; });\n }\n });\n });\n}\n\nfunction balance(xss, align) {\n return _.mapValues(xss.ul, function(ignore, v) {\n if (align) {\n return xss[align.toLowerCase()][v];\n } else {\n var xs = _.sortBy(_.map(xss, v));\n return (xs[1] + xs[2]) / 2;\n }\n });\n}\n\nfunction positionX(g) {\n var layering = util.buildLayerMatrix(g);\n var conflicts = _.merge(\n findType1Conflicts(g, layering),\n findType2Conflicts(g, layering));\n\n var xss = {};\n var adjustedLayering;\n _.forEach([\"u\", \"d\"], function(vert) {\n adjustedLayering = vert === \"u\" ? layering : _.values(layering).reverse();\n _.forEach([\"l\", \"r\"], function(horiz) {\n if (horiz === \"r\") {\n adjustedLayering = _.map(adjustedLayering, function(inner) {\n return _.values(inner).reverse();\n });\n }\n\n var neighborFn = (vert === \"u\" ? g.predecessors : g.successors).bind(g);\n var align = verticalAlignment(g, adjustedLayering, conflicts, neighborFn);\n var xs = horizontalCompaction(g, adjustedLayering,\n align.root, align.align, horiz === \"r\");\n if (horiz === \"r\") {\n xs = _.mapValues(xs, function(x) { return -x; });\n }\n xss[vert + horiz] = xs;\n });\n });\n\n var smallestWidth = findSmallestWidthAlignment(g, xss);\n alignCoordinates(xss, smallestWidth);\n return balance(xss, g.graph().align);\n}\n\nfunction sep(nodeSep, edgeSep, reverseSep) {\n return function(g, v, w) {\n var vLabel = g.node(v);\n var wLabel = g.node(w);\n var sum = 0;\n var delta;\n\n sum += vLabel.width / 2;\n if (_.has(vLabel, \"labelpos\")) {\n switch (vLabel.labelpos.toLowerCase()) {\n case \"l\": delta = -vLabel.width / 2; break;\n case \"r\": delta = vLabel.width / 2; break;\n }\n }\n if (delta) {\n sum += reverseSep ? delta : -delta;\n }\n delta = 0;\n\n sum += (vLabel.dummy ? edgeSep : nodeSep) / 2;\n sum += (wLabel.dummy ? edgeSep : nodeSep) / 2;\n\n sum += wLabel.width / 2;\n if (_.has(wLabel, \"labelpos\")) {\n switch (wLabel.labelpos.toLowerCase()) {\n case \"l\": delta = wLabel.width / 2; break;\n case \"r\": delta = -wLabel.width / 2; break;\n }\n }\n if (delta) {\n sum += reverseSep ? delta : -delta;\n }\n delta = 0;\n\n return sum;\n };\n}\n\nfunction width(g, v) {\n return g.node(v).width;\n}\n","var _ = require(\"./lodash\");\nvar util = require(\"./util\");\nvar Graph = require(\"./graphlib\").Graph;\n\nmodule.exports = {\n debugOrdering: debugOrdering\n};\n\n/* istanbul ignore next */\nfunction debugOrdering(g) {\n var layerMatrix = util.buildLayerMatrix(g);\n\n var h = new Graph({ compound: true, multigraph: true }).setGraph({});\n\n _.forEach(g.nodes(), function(v) {\n h.setNode(v, { label: v });\n h.setParent(v, \"layer\" + g.node(v).rank);\n });\n\n _.forEach(g.edges(), function(e) {\n h.setEdge(e.v, e.w, {}, e.name);\n });\n\n _.forEach(layerMatrix, function(layer, i) {\n var layerV = \"layer\" + i;\n h.setNode(layerV, { rank: \"same\" });\n _.reduce(layer, function(u, v) {\n h.setEdge(u, v, { style: \"invis\" });\n return v;\n });\n });\n\n return h;\n}\n","module.exports = \"0.8.5\";\n","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n \"use strict\";\n\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function define(obj, key, value) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n return obj[key];\n }\n try {\n // IE 8 has a broken Object.defineProperty that only works on DOM objects.\n define({}, \"\");\n } catch (err) {\n define = function(obj, key, value) {\n return obj[key] = value;\n };\n }\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n return generator;\n }\n exports.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype &&\n NativeIteratorPrototype !== Op &&\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n }\n\n var Gp = GeneratorFunctionPrototype.prototype =\n Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = GeneratorFunctionPrototype;\n define(Gp, \"constructor\", GeneratorFunctionPrototype);\n define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction);\n GeneratorFunction.displayName = define(\n GeneratorFunctionPrototype,\n toStringTagSymbol,\n \"GeneratorFunction\"\n );\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n define(prototype, method, function(arg) {\n return this._invoke(method, arg);\n });\n });\n }\n\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n } else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n define(genFun, toStringTagSymbol, \"GeneratorFunction\");\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return { __await: arg };\n };\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") {\n reject(record.arg);\n } else {\n var result = record.arg;\n var value = result.value;\n if (value &&\n typeof value === \"object\" &&\n hasOwn.call(value, \"__await\")) {\n return PromiseImpl.resolve(value.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n }\n\n return PromiseImpl.resolve(value).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n\n var previousPromise;\n\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(\n callInvokeWithMethodAndArg,\n // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg\n ) : callInvokeWithMethodAndArg();\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n });\n exports.AsyncIterator = AsyncIterator;\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList),\n PromiseImpl\n );\n\n return exports.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n if (method === \"throw\") {\n throw arg;\n }\n\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n context.method = method;\n context.arg = arg;\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (context.method === \"next\") {\n // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n\n } else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n\n context.dispatchException(context.arg);\n\n } else if (context.method === \"return\") {\n context.abrupt(\"return\", context.arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n if (record.arg === ContinueSentinel) {\n continue;\n }\n\n return {\n value: record.arg,\n done: context.done\n };\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method always terminates the yield* loop.\n context.delegate = null;\n\n if (context.method === \"throw\") {\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n\n if (context.method === \"throw\") {\n // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n }\n\n context.method = \"throw\";\n context.arg = new TypeError(\n \"The iterator does not provide a 'throw' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n\n var info = record.arg;\n\n if (! info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n\n } else {\n // Re-yield the result returned by the delegate method.\n return info;\n }\n\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n define(Gp, toStringTagSymbol, \"Generator\");\n\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n define(Gp, iteratorSymbol, function() {\n return this;\n });\n\n define(Gp, \"toString\", function() {\n return \"[object Generator]\";\n });\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n\n exports.keys = function(object) {\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n exports.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.method = \"next\";\n this.arg = undefined;\n\n this.tryEntries.forEach(resetTryEntry);\n\n if (!skipTempReset) {\n for (var name in this) {\n // Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" &&\n hasOwn.call(this, name) &&\n !isNaN(+name.slice(1))) {\n this[name] = undefined;\n }\n }\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n\n return !! caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n\n return this.complete(record);\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n\n return ContinueSentinel;\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n if (this.method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n }\n\n return ContinueSentinel;\n }\n };\n\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n\n}(\n // If this script is executing as a CommonJS module, use module.exports\n // as the regeneratorRuntime namespace. Otherwise create a new empty\n // object. Either way, the resulting object will be used to initialize\n // the regeneratorRuntime variable at the top of this file.\n typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, in modern engines\n // we can explicitly access globalThis. In older engines we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n if (typeof globalThis === \"object\") {\n globalThis.regeneratorRuntime = runtime;\n } else {\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n }\n}\n","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\n\nmodule.exports = _arrayWithHoles;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}\n\nmodule.exports = _iterableToArrayLimit;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableRest;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from) {\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)\n to[j] = from[i];\n return to;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Container = void 0;\nvar binding_1 = require(\"../bindings/binding\");\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_reader_1 = require(\"../planning/metadata_reader\");\nvar planner_1 = require(\"../planning/planner\");\nvar resolver_1 = require(\"../resolution/resolver\");\nvar binding_to_syntax_1 = require(\"../syntax/binding_to_syntax\");\nvar id_1 = require(\"../utils/id\");\nvar serialization_1 = require(\"../utils/serialization\");\nvar container_snapshot_1 = require(\"./container_snapshot\");\nvar lookup_1 = require(\"./lookup\");\nvar Container = (function () {\n function Container(containerOptions) {\n this._appliedMiddleware = [];\n var options = containerOptions || {};\n if (typeof options !== \"object\") {\n throw new Error(\"\" + ERROR_MSGS.CONTAINER_OPTIONS_MUST_BE_AN_OBJECT);\n }\n if (options.defaultScope === undefined) {\n options.defaultScope = literal_types_1.BindingScopeEnum.Transient;\n }\n else if (options.defaultScope !== literal_types_1.BindingScopeEnum.Singleton &&\n options.defaultScope !== literal_types_1.BindingScopeEnum.Transient &&\n options.defaultScope !== literal_types_1.BindingScopeEnum.Request) {\n throw new Error(\"\" + ERROR_MSGS.CONTAINER_OPTIONS_INVALID_DEFAULT_SCOPE);\n }\n if (options.autoBindInjectable === undefined) {\n options.autoBindInjectable = false;\n }\n else if (typeof options.autoBindInjectable !== \"boolean\") {\n throw new Error(\"\" + ERROR_MSGS.CONTAINER_OPTIONS_INVALID_AUTO_BIND_INJECTABLE);\n }\n if (options.skipBaseClassChecks === undefined) {\n options.skipBaseClassChecks = false;\n }\n else if (typeof options.skipBaseClassChecks !== \"boolean\") {\n throw new Error(\"\" + ERROR_MSGS.CONTAINER_OPTIONS_INVALID_SKIP_BASE_CHECK);\n }\n this.options = {\n autoBindInjectable: options.autoBindInjectable,\n defaultScope: options.defaultScope,\n skipBaseClassChecks: options.skipBaseClassChecks\n };\n this.id = id_1.id();\n this._bindingDictionary = new lookup_1.Lookup();\n this._snapshots = [];\n this._middleware = null;\n this.parent = null;\n this._metadataReader = new metadata_reader_1.MetadataReader();\n }\n Container.merge = function (container1, container2) {\n var container3 = [];\n for (var _i = 2; _i < arguments.length; _i++) {\n container3[_i - 2] = arguments[_i];\n }\n var container = new Container();\n var targetContainers = __spreadArray([container1, container2], container3).map(function (targetContainer) { return planner_1.getBindingDictionary(targetContainer); });\n var bindingDictionary = planner_1.getBindingDictionary(container);\n function copyDictionary(origin, destination) {\n origin.traverse(function (key, value) {\n value.forEach(function (binding) {\n destination.add(binding.serviceIdentifier, binding.clone());\n });\n });\n }\n targetContainers.forEach(function (targetBindingDictionary) {\n copyDictionary(targetBindingDictionary, bindingDictionary);\n });\n return container;\n };\n Container.prototype.load = function () {\n var modules = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n modules[_i] = arguments[_i];\n }\n var getHelpers = this._getContainerModuleHelpersFactory();\n for (var _a = 0, modules_1 = modules; _a < modules_1.length; _a++) {\n var currentModule = modules_1[_a];\n var containerModuleHelpers = getHelpers(currentModule.id);\n currentModule.registry(containerModuleHelpers.bindFunction, containerModuleHelpers.unbindFunction, containerModuleHelpers.isboundFunction, containerModuleHelpers.rebindFunction);\n }\n };\n Container.prototype.loadAsync = function () {\n var modules = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n modules[_i] = arguments[_i];\n }\n return __awaiter(this, void 0, void 0, function () {\n var getHelpers, _a, modules_2, currentModule, containerModuleHelpers;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n getHelpers = this._getContainerModuleHelpersFactory();\n _a = 0, modules_2 = modules;\n _b.label = 1;\n case 1:\n if (!(_a < modules_2.length)) return [3, 4];\n currentModule = modules_2[_a];\n containerModuleHelpers = getHelpers(currentModule.id);\n return [4, currentModule.registry(containerModuleHelpers.bindFunction, containerModuleHelpers.unbindFunction, containerModuleHelpers.isboundFunction, containerModuleHelpers.rebindFunction)];\n case 2:\n _b.sent();\n _b.label = 3;\n case 3:\n _a++;\n return [3, 1];\n case 4: return [2];\n }\n });\n });\n };\n Container.prototype.unload = function () {\n var _this = this;\n var modules = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n modules[_i] = arguments[_i];\n }\n var conditionFactory = function (expected) { return function (item) {\n return item.moduleId === expected;\n }; };\n modules.forEach(function (module) {\n var condition = conditionFactory(module.id);\n _this._bindingDictionary.removeByCondition(condition);\n });\n };\n Container.prototype.bind = function (serviceIdentifier) {\n var scope = this.options.defaultScope || literal_types_1.BindingScopeEnum.Transient;\n var binding = new binding_1.Binding(serviceIdentifier, scope);\n this._bindingDictionary.add(serviceIdentifier, binding);\n return new binding_to_syntax_1.BindingToSyntax(binding);\n };\n Container.prototype.rebind = function (serviceIdentifier) {\n this.unbind(serviceIdentifier);\n return this.bind(serviceIdentifier);\n };\n Container.prototype.unbind = function (serviceIdentifier) {\n try {\n this._bindingDictionary.remove(serviceIdentifier);\n }\n catch (e) {\n throw new Error(ERROR_MSGS.CANNOT_UNBIND + \" \" + serialization_1.getServiceIdentifierAsString(serviceIdentifier));\n }\n };\n Container.prototype.unbindAll = function () {\n this._bindingDictionary = new lookup_1.Lookup();\n };\n Container.prototype.isBound = function (serviceIdentifier) {\n var bound = this._bindingDictionary.hasKey(serviceIdentifier);\n if (!bound && this.parent) {\n bound = this.parent.isBound(serviceIdentifier);\n }\n return bound;\n };\n Container.prototype.isBoundNamed = function (serviceIdentifier, named) {\n return this.isBoundTagged(serviceIdentifier, METADATA_KEY.NAMED_TAG, named);\n };\n Container.prototype.isBoundTagged = function (serviceIdentifier, key, value) {\n var bound = false;\n if (this._bindingDictionary.hasKey(serviceIdentifier)) {\n var bindings = this._bindingDictionary.get(serviceIdentifier);\n var request_1 = planner_1.createMockRequest(this, serviceIdentifier, key, value);\n bound = bindings.some(function (b) { return b.constraint(request_1); });\n }\n if (!bound && this.parent) {\n bound = this.parent.isBoundTagged(serviceIdentifier, key, value);\n }\n return bound;\n };\n Container.prototype.snapshot = function () {\n this._snapshots.push(container_snapshot_1.ContainerSnapshot.of(this._bindingDictionary.clone(), this._middleware));\n };\n Container.prototype.restore = function () {\n var snapshot = this._snapshots.pop();\n if (snapshot === undefined) {\n throw new Error(ERROR_MSGS.NO_MORE_SNAPSHOTS_AVAILABLE);\n }\n this._bindingDictionary = snapshot.bindings;\n this._middleware = snapshot.middleware;\n };\n Container.prototype.createChild = function (containerOptions) {\n var child = new Container(containerOptions || this.options);\n child.parent = this;\n return child;\n };\n Container.prototype.applyMiddleware = function () {\n var middlewares = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n middlewares[_i] = arguments[_i];\n }\n this._appliedMiddleware = this._appliedMiddleware.concat(middlewares);\n var initial = (this._middleware) ? this._middleware : this._planAndResolve();\n this._middleware = middlewares.reduce(function (prev, curr) { return curr(prev); }, initial);\n };\n Container.prototype.applyCustomMetadataReader = function (metadataReader) {\n this._metadataReader = metadataReader;\n };\n Container.prototype.get = function (serviceIdentifier) {\n return this._get(false, false, literal_types_1.TargetTypeEnum.Variable, serviceIdentifier);\n };\n Container.prototype.getTagged = function (serviceIdentifier, key, value) {\n return this._get(false, false, literal_types_1.TargetTypeEnum.Variable, serviceIdentifier, key, value);\n };\n Container.prototype.getNamed = function (serviceIdentifier, named) {\n return this.getTagged(serviceIdentifier, METADATA_KEY.NAMED_TAG, named);\n };\n Container.prototype.getAll = function (serviceIdentifier) {\n return this._get(true, true, literal_types_1.TargetTypeEnum.Variable, serviceIdentifier);\n };\n Container.prototype.getAllTagged = function (serviceIdentifier, key, value) {\n return this._get(false, true, literal_types_1.TargetTypeEnum.Variable, serviceIdentifier, key, value);\n };\n Container.prototype.getAllNamed = function (serviceIdentifier, named) {\n return this.getAllTagged(serviceIdentifier, METADATA_KEY.NAMED_TAG, named);\n };\n Container.prototype.resolve = function (constructorFunction) {\n var tempContainer = this.createChild();\n tempContainer.bind(constructorFunction).toSelf();\n this._appliedMiddleware.forEach(function (m) {\n tempContainer.applyMiddleware(m);\n });\n return tempContainer.get(constructorFunction);\n };\n Container.prototype._getContainerModuleHelpersFactory = function () {\n var _this = this;\n var setModuleId = function (bindingToSyntax, moduleId) {\n bindingToSyntax._binding.moduleId = moduleId;\n };\n var getBindFunction = function (moduleId) {\n return function (serviceIdentifier) {\n var _bind = _this.bind.bind(_this);\n var bindingToSyntax = _bind(serviceIdentifier);\n setModuleId(bindingToSyntax, moduleId);\n return bindingToSyntax;\n };\n };\n var getUnbindFunction = function (moduleId) {\n return function (serviceIdentifier) {\n var _unbind = _this.unbind.bind(_this);\n _unbind(serviceIdentifier);\n };\n };\n var getIsboundFunction = function (moduleId) {\n return function (serviceIdentifier) {\n var _isBound = _this.isBound.bind(_this);\n return _isBound(serviceIdentifier);\n };\n };\n var getRebindFunction = function (moduleId) {\n return function (serviceIdentifier) {\n var _rebind = _this.rebind.bind(_this);\n var bindingToSyntax = _rebind(serviceIdentifier);\n setModuleId(bindingToSyntax, moduleId);\n return bindingToSyntax;\n };\n };\n return function (mId) { return ({\n bindFunction: getBindFunction(mId),\n isboundFunction: getIsboundFunction(mId),\n rebindFunction: getRebindFunction(mId),\n unbindFunction: getUnbindFunction(mId)\n }); };\n };\n Container.prototype._get = function (avoidConstraints, isMultiInject, targetType, serviceIdentifier, key, value) {\n var result = null;\n var defaultArgs = {\n avoidConstraints: avoidConstraints,\n contextInterceptor: function (context) { return context; },\n isMultiInject: isMultiInject,\n key: key,\n serviceIdentifier: serviceIdentifier,\n targetType: targetType,\n value: value\n };\n if (this._middleware) {\n result = this._middleware(defaultArgs);\n if (result === undefined || result === null) {\n throw new Error(ERROR_MSGS.INVALID_MIDDLEWARE_RETURN);\n }\n }\n else {\n result = this._planAndResolve()(defaultArgs);\n }\n return result;\n };\n Container.prototype._planAndResolve = function () {\n var _this = this;\n return function (args) {\n var context = planner_1.plan(_this._metadataReader, _this, args.isMultiInject, args.targetType, args.serviceIdentifier, args.key, args.value, args.avoidConstraints);\n context = args.contextInterceptor(context);\n var result = resolver_1.resolve(context);\n return result;\n };\n };\n return Container;\n}());\nexports.Container = Container;\n//# sourceMappingURL=container.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Binding = void 0;\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar id_1 = require(\"../utils/id\");\nvar Binding = (function () {\n function Binding(serviceIdentifier, scope) {\n this.id = id_1.id();\n this.activated = false;\n this.serviceIdentifier = serviceIdentifier;\n this.scope = scope;\n this.type = literal_types_1.BindingTypeEnum.Invalid;\n this.constraint = function (request) { return true; };\n this.implementationType = null;\n this.cache = null;\n this.factory = null;\n this.provider = null;\n this.onActivation = null;\n this.dynamicValue = null;\n }\n Binding.prototype.clone = function () {\n var clone = new Binding(this.serviceIdentifier, this.scope);\n clone.activated = (clone.scope === literal_types_1.BindingScopeEnum.Singleton) ? this.activated : false;\n clone.implementationType = this.implementationType;\n clone.dynamicValue = this.dynamicValue;\n clone.scope = this.scope;\n clone.type = this.type;\n clone.factory = this.factory;\n clone.provider = this.provider;\n clone.constraint = this.constraint;\n clone.onActivation = this.onActivation;\n clone.cache = this.cache;\n return clone;\n };\n return Binding;\n}());\nexports.Binding = Binding;\n//# sourceMappingURL=binding.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getBindingDictionary = exports.createMockRequest = exports.plan = void 0;\nvar binding_count_1 = require(\"../bindings/binding_count\");\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar exceptions_1 = require(\"../utils/exceptions\");\nvar serialization_1 = require(\"../utils/serialization\");\nvar context_1 = require(\"./context\");\nvar metadata_1 = require(\"./metadata\");\nvar plan_1 = require(\"./plan\");\nvar reflection_utils_1 = require(\"./reflection_utils\");\nvar request_1 = require(\"./request\");\nvar target_1 = require(\"./target\");\nfunction getBindingDictionary(cntnr) {\n return cntnr._bindingDictionary;\n}\nexports.getBindingDictionary = getBindingDictionary;\nfunction _createTarget(isMultiInject, targetType, serviceIdentifier, name, key, value) {\n var metadataKey = isMultiInject ? METADATA_KEY.MULTI_INJECT_TAG : METADATA_KEY.INJECT_TAG;\n var injectMetadata = new metadata_1.Metadata(metadataKey, serviceIdentifier);\n var target = new target_1.Target(targetType, name, serviceIdentifier, injectMetadata);\n if (key !== undefined) {\n var tagMetadata = new metadata_1.Metadata(key, value);\n target.metadata.push(tagMetadata);\n }\n return target;\n}\nfunction _getActiveBindings(metadataReader, avoidConstraints, context, parentRequest, target) {\n var bindings = getBindings(context.container, target.serviceIdentifier);\n var activeBindings = [];\n if (bindings.length === binding_count_1.BindingCount.NoBindingsAvailable &&\n context.container.options.autoBindInjectable &&\n typeof target.serviceIdentifier === \"function\" &&\n metadataReader.getConstructorMetadata(target.serviceIdentifier).compilerGeneratedMetadata) {\n context.container.bind(target.serviceIdentifier).toSelf();\n bindings = getBindings(context.container, target.serviceIdentifier);\n }\n if (!avoidConstraints) {\n activeBindings = bindings.filter(function (binding) {\n var request = new request_1.Request(binding.serviceIdentifier, context, parentRequest, binding, target);\n return binding.constraint(request);\n });\n }\n else {\n activeBindings = bindings;\n }\n _validateActiveBindingCount(target.serviceIdentifier, activeBindings, target, context.container);\n return activeBindings;\n}\nfunction _validateActiveBindingCount(serviceIdentifier, bindings, target, container) {\n switch (bindings.length) {\n case binding_count_1.BindingCount.NoBindingsAvailable:\n if (target.isOptional()) {\n return bindings;\n }\n else {\n var serviceIdentifierString = serialization_1.getServiceIdentifierAsString(serviceIdentifier);\n var msg = ERROR_MSGS.NOT_REGISTERED;\n msg += serialization_1.listMetadataForTarget(serviceIdentifierString, target);\n msg += serialization_1.listRegisteredBindingsForServiceIdentifier(container, serviceIdentifierString, getBindings);\n throw new Error(msg);\n }\n case binding_count_1.BindingCount.OnlyOneBindingAvailable:\n if (!target.isArray()) {\n return bindings;\n }\n case binding_count_1.BindingCount.MultipleBindingsAvailable:\n default:\n if (!target.isArray()) {\n var serviceIdentifierString = serialization_1.getServiceIdentifierAsString(serviceIdentifier);\n var msg = ERROR_MSGS.AMBIGUOUS_MATCH + \" \" + serviceIdentifierString;\n msg += serialization_1.listRegisteredBindingsForServiceIdentifier(container, serviceIdentifierString, getBindings);\n throw new Error(msg);\n }\n else {\n return bindings;\n }\n }\n}\nfunction _createSubRequests(metadataReader, avoidConstraints, serviceIdentifier, context, parentRequest, target) {\n var activeBindings;\n var childRequest;\n if (parentRequest === null) {\n activeBindings = _getActiveBindings(metadataReader, avoidConstraints, context, null, target);\n childRequest = new request_1.Request(serviceIdentifier, context, null, activeBindings, target);\n var thePlan = new plan_1.Plan(context, childRequest);\n context.addPlan(thePlan);\n }\n else {\n activeBindings = _getActiveBindings(metadataReader, avoidConstraints, context, parentRequest, target);\n childRequest = parentRequest.addChildRequest(target.serviceIdentifier, activeBindings, target);\n }\n activeBindings.forEach(function (binding) {\n var subChildRequest = null;\n if (target.isArray()) {\n subChildRequest = childRequest.addChildRequest(binding.serviceIdentifier, binding, target);\n }\n else {\n if (binding.cache) {\n return;\n }\n subChildRequest = childRequest;\n }\n if (binding.type === literal_types_1.BindingTypeEnum.Instance && binding.implementationType !== null) {\n var dependencies = reflection_utils_1.getDependencies(metadataReader, binding.implementationType);\n if (!context.container.options.skipBaseClassChecks) {\n var baseClassDependencyCount = reflection_utils_1.getBaseClassDependencyCount(metadataReader, binding.implementationType);\n if (dependencies.length < baseClassDependencyCount) {\n var error = ERROR_MSGS.ARGUMENTS_LENGTH_MISMATCH(reflection_utils_1.getFunctionName(binding.implementationType));\n throw new Error(error);\n }\n }\n dependencies.forEach(function (dependency) {\n _createSubRequests(metadataReader, false, dependency.serviceIdentifier, context, subChildRequest, dependency);\n });\n }\n });\n}\nfunction getBindings(container, serviceIdentifier) {\n var bindings = [];\n var bindingDictionary = getBindingDictionary(container);\n if (bindingDictionary.hasKey(serviceIdentifier)) {\n bindings = bindingDictionary.get(serviceIdentifier);\n }\n else if (container.parent !== null) {\n bindings = getBindings(container.parent, serviceIdentifier);\n }\n return bindings;\n}\nfunction plan(metadataReader, container, isMultiInject, targetType, serviceIdentifier, key, value, avoidConstraints) {\n if (avoidConstraints === void 0) { avoidConstraints = false; }\n var context = new context_1.Context(container);\n var target = _createTarget(isMultiInject, targetType, serviceIdentifier, \"\", key, value);\n try {\n _createSubRequests(metadataReader, avoidConstraints, serviceIdentifier, context, null, target);\n return context;\n }\n catch (error) {\n if (exceptions_1.isStackOverflowExeption(error)) {\n if (context.plan) {\n serialization_1.circularDependencyToException(context.plan.rootRequest);\n }\n }\n throw error;\n }\n}\nexports.plan = plan;\nfunction createMockRequest(container, serviceIdentifier, key, value) {\n var target = new target_1.Target(literal_types_1.TargetTypeEnum.Variable, \"\", serviceIdentifier, new metadata_1.Metadata(key, value));\n var context = new context_1.Context(container);\n var request = new request_1.Request(serviceIdentifier, context, null, [], target);\n return request;\n}\nexports.createMockRequest = createMockRequest;\n//# sourceMappingURL=planner.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingCount = void 0;\nvar BindingCount = {\n MultipleBindingsAvailable: 2,\n NoBindingsAvailable: 0,\n OnlyOneBindingAvailable: 1\n};\nexports.BindingCount = BindingCount;\n//# sourceMappingURL=binding_count.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Context = void 0;\nvar id_1 = require(\"../utils/id\");\nvar Context = (function () {\n function Context(container) {\n this.id = id_1.id();\n this.container = container;\n }\n Context.prototype.addPlan = function (plan) {\n this.plan = plan;\n };\n Context.prototype.setCurrentRequest = function (currentRequest) {\n this.currentRequest = currentRequest;\n };\n return Context;\n}());\nexports.Context = Context;\n//# sourceMappingURL=context.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Plan = void 0;\nvar Plan = (function () {\n function Plan(parentContext, rootRequest) {\n this.parentContext = parentContext;\n this.rootRequest = rootRequest;\n }\n return Plan;\n}());\nexports.Plan = Plan;\n//# sourceMappingURL=plan.js.map","\"use strict\";\nvar __spreadArray = (this && this.__spreadArray) || function (to, from) {\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)\n to[j] = from[i];\n return to;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getFunctionName = exports.getBaseClassDependencyCount = exports.getDependencies = void 0;\nvar inject_1 = require(\"../annotation/inject\");\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar serialization_1 = require(\"../utils/serialization\");\nObject.defineProperty(exports, \"getFunctionName\", { enumerable: true, get: function () { return serialization_1.getFunctionName; } });\nvar target_1 = require(\"./target\");\nfunction getDependencies(metadataReader, func) {\n var constructorName = serialization_1.getFunctionName(func);\n var targets = getTargets(metadataReader, constructorName, func, false);\n return targets;\n}\nexports.getDependencies = getDependencies;\nfunction getTargets(metadataReader, constructorName, func, isBaseClass) {\n var metadata = metadataReader.getConstructorMetadata(func);\n var serviceIdentifiers = metadata.compilerGeneratedMetadata;\n if (serviceIdentifiers === undefined) {\n var msg = ERROR_MSGS.MISSING_INJECTABLE_ANNOTATION + \" \" + constructorName + \".\";\n throw new Error(msg);\n }\n var constructorArgsMetadata = metadata.userGeneratedMetadata;\n var keys = Object.keys(constructorArgsMetadata);\n var hasUserDeclaredUnknownInjections = (func.length === 0 && keys.length > 0);\n var hasOptionalParameters = keys.length > func.length;\n var iterations = (hasUserDeclaredUnknownInjections || hasOptionalParameters) ? keys.length : func.length;\n var constructorTargets = getConstructorArgsAsTargets(isBaseClass, constructorName, serviceIdentifiers, constructorArgsMetadata, iterations);\n var propertyTargets = getClassPropsAsTargets(metadataReader, func);\n var targets = __spreadArray(__spreadArray([], constructorTargets), propertyTargets);\n return targets;\n}\nfunction getConstructorArgsAsTarget(index, isBaseClass, constructorName, serviceIdentifiers, constructorArgsMetadata) {\n var targetMetadata = constructorArgsMetadata[index.toString()] || [];\n var metadata = formatTargetMetadata(targetMetadata);\n var isManaged = metadata.unmanaged !== true;\n var serviceIdentifier = serviceIdentifiers[index];\n var injectIdentifier = (metadata.inject || metadata.multiInject);\n serviceIdentifier = (injectIdentifier) ? (injectIdentifier) : serviceIdentifier;\n if (serviceIdentifier instanceof inject_1.LazyServiceIdentifer) {\n serviceIdentifier = serviceIdentifier.unwrap();\n }\n if (isManaged) {\n var isObject = serviceIdentifier === Object;\n var isFunction = serviceIdentifier === Function;\n var isUndefined = serviceIdentifier === undefined;\n var isUnknownType = (isObject || isFunction || isUndefined);\n if (!isBaseClass && isUnknownType) {\n var msg = ERROR_MSGS.MISSING_INJECT_ANNOTATION + \" argument \" + index + \" in class \" + constructorName + \".\";\n throw new Error(msg);\n }\n var target = new target_1.Target(literal_types_1.TargetTypeEnum.ConstructorArgument, metadata.targetName, serviceIdentifier);\n target.metadata = targetMetadata;\n return target;\n }\n return null;\n}\nfunction getConstructorArgsAsTargets(isBaseClass, constructorName, serviceIdentifiers, constructorArgsMetadata, iterations) {\n var targets = [];\n for (var i = 0; i < iterations; i++) {\n var index = i;\n var target = getConstructorArgsAsTarget(index, isBaseClass, constructorName, serviceIdentifiers, constructorArgsMetadata);\n if (target !== null) {\n targets.push(target);\n }\n }\n return targets;\n}\nfunction getClassPropsAsTargets(metadataReader, constructorFunc) {\n var classPropsMetadata = metadataReader.getPropertiesMetadata(constructorFunc);\n var targets = [];\n var keys = Object.keys(classPropsMetadata);\n for (var _i = 0, keys_1 = keys; _i < keys_1.length; _i++) {\n var key = keys_1[_i];\n var targetMetadata = classPropsMetadata[key];\n var metadata = formatTargetMetadata(classPropsMetadata[key]);\n var targetName = metadata.targetName || key;\n var serviceIdentifier = (metadata.inject || metadata.multiInject);\n var target = new target_1.Target(literal_types_1.TargetTypeEnum.ClassProperty, targetName, serviceIdentifier);\n target.metadata = targetMetadata;\n targets.push(target);\n }\n var baseConstructor = Object.getPrototypeOf(constructorFunc.prototype).constructor;\n if (baseConstructor !== Object) {\n var baseTargets = getClassPropsAsTargets(metadataReader, baseConstructor);\n targets = __spreadArray(__spreadArray([], targets), baseTargets);\n }\n return targets;\n}\nfunction getBaseClassDependencyCount(metadataReader, func) {\n var baseConstructor = Object.getPrototypeOf(func.prototype).constructor;\n if (baseConstructor !== Object) {\n var baseConstructorName = serialization_1.getFunctionName(baseConstructor);\n var targets = getTargets(metadataReader, baseConstructorName, baseConstructor, true);\n var metadata = targets.map(function (t) {\n return t.metadata.filter(function (m) {\n return m.key === METADATA_KEY.UNMANAGED_TAG;\n });\n });\n var unmanagedCount = [].concat.apply([], metadata).length;\n var dependencyCount = targets.length - unmanagedCount;\n if (dependencyCount > 0) {\n return dependencyCount;\n }\n else {\n return getBaseClassDependencyCount(metadataReader, baseConstructor);\n }\n }\n else {\n return 0;\n }\n}\nexports.getBaseClassDependencyCount = getBaseClassDependencyCount;\nfunction formatTargetMetadata(targetMetadata) {\n var targetMetadataMap = {};\n targetMetadata.forEach(function (m) {\n targetMetadataMap[m.key.toString()] = m.value;\n });\n return {\n inject: targetMetadataMap[METADATA_KEY.INJECT_TAG],\n multiInject: targetMetadataMap[METADATA_KEY.MULTI_INJECT_TAG],\n targetName: targetMetadataMap[METADATA_KEY.NAME_TAG],\n unmanaged: targetMetadataMap[METADATA_KEY.UNMANAGED_TAG]\n };\n}\n//# sourceMappingURL=reflection_utils.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.QueryableString = void 0;\nvar QueryableString = (function () {\n function QueryableString(str) {\n this.str = str;\n }\n QueryableString.prototype.startsWith = function (searchString) {\n return this.str.indexOf(searchString) === 0;\n };\n QueryableString.prototype.endsWith = function (searchString) {\n var reverseString = \"\";\n var reverseSearchString = searchString.split(\"\").reverse().join(\"\");\n reverseString = this.str.split(\"\").reverse().join(\"\");\n return this.startsWith.call({ str: reverseString }, reverseSearchString);\n };\n QueryableString.prototype.contains = function (searchString) {\n return (this.str.indexOf(searchString) !== -1);\n };\n QueryableString.prototype.equals = function (compareString) {\n return this.str === compareString;\n };\n QueryableString.prototype.value = function () {\n return this.str;\n };\n return QueryableString;\n}());\nexports.QueryableString = QueryableString;\n//# sourceMappingURL=queryable_string.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Request = void 0;\nvar id_1 = require(\"../utils/id\");\nvar Request = (function () {\n function Request(serviceIdentifier, parentContext, parentRequest, bindings, target) {\n this.id = id_1.id();\n this.serviceIdentifier = serviceIdentifier;\n this.parentContext = parentContext;\n this.parentRequest = parentRequest;\n this.target = target;\n this.childRequests = [];\n this.bindings = (Array.isArray(bindings) ? bindings : [bindings]);\n this.requestScope = parentRequest === null\n ? new Map()\n : null;\n }\n Request.prototype.addChildRequest = function (serviceIdentifier, bindings, target) {\n var child = new Request(serviceIdentifier, this.parentContext, this, bindings, target);\n this.childRequests.push(child);\n return child;\n };\n return Request;\n}());\nexports.Request = Request;\n//# sourceMappingURL=request.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.resolve = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar exceptions_1 = require(\"../utils/exceptions\");\nvar serialization_1 = require(\"../utils/serialization\");\nvar instantiation_1 = require(\"./instantiation\");\nvar invokeFactory = function (factoryType, serviceIdentifier, fn) {\n try {\n return fn();\n }\n catch (error) {\n if (exceptions_1.isStackOverflowExeption(error)) {\n throw new Error(ERROR_MSGS.CIRCULAR_DEPENDENCY_IN_FACTORY(factoryType, serviceIdentifier.toString()));\n }\n else {\n throw error;\n }\n }\n};\nvar _resolveRequest = function (requestScope) {\n return function (request) {\n request.parentContext.setCurrentRequest(request);\n var bindings = request.bindings;\n var childRequests = request.childRequests;\n var targetIsAnArray = request.target && request.target.isArray();\n var targetParentIsNotAnArray = !request.parentRequest ||\n !request.parentRequest.target ||\n !request.target ||\n !request.parentRequest.target.matchesArray(request.target.serviceIdentifier);\n if (targetIsAnArray && targetParentIsNotAnArray) {\n return childRequests.map(function (childRequest) {\n var _f = _resolveRequest(requestScope);\n return _f(childRequest);\n });\n }\n else {\n var result = null;\n if (request.target.isOptional() && bindings.length === 0) {\n return undefined;\n }\n var binding_1 = bindings[0];\n var isSingleton = binding_1.scope === literal_types_1.BindingScopeEnum.Singleton;\n var isRequestSingleton = binding_1.scope === literal_types_1.BindingScopeEnum.Request;\n if (isSingleton && binding_1.activated) {\n return binding_1.cache;\n }\n if (isRequestSingleton &&\n requestScope !== null &&\n requestScope.has(binding_1.id)) {\n return requestScope.get(binding_1.id);\n }\n if (binding_1.type === literal_types_1.BindingTypeEnum.ConstantValue) {\n result = binding_1.cache;\n binding_1.activated = true;\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Function) {\n result = binding_1.cache;\n binding_1.activated = true;\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Constructor) {\n result = binding_1.implementationType;\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.DynamicValue && binding_1.dynamicValue !== null) {\n result = invokeFactory(\"toDynamicValue\", binding_1.serviceIdentifier, function () { return binding_1.dynamicValue(request.parentContext); });\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Factory && binding_1.factory !== null) {\n result = invokeFactory(\"toFactory\", binding_1.serviceIdentifier, function () { return binding_1.factory(request.parentContext); });\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Provider && binding_1.provider !== null) {\n result = invokeFactory(\"toProvider\", binding_1.serviceIdentifier, function () { return binding_1.provider(request.parentContext); });\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Instance && binding_1.implementationType !== null) {\n result = instantiation_1.resolveInstance(binding_1.implementationType, childRequests, _resolveRequest(requestScope));\n }\n else {\n var serviceIdentifier = serialization_1.getServiceIdentifierAsString(request.serviceIdentifier);\n throw new Error(ERROR_MSGS.INVALID_BINDING_TYPE + \" \" + serviceIdentifier);\n }\n if (typeof binding_1.onActivation === \"function\") {\n result = binding_1.onActivation(request.parentContext, result);\n }\n if (isSingleton) {\n binding_1.cache = result;\n binding_1.activated = true;\n }\n if (isRequestSingleton &&\n requestScope !== null &&\n !requestScope.has(binding_1.id)) {\n requestScope.set(binding_1.id, result);\n }\n return result;\n }\n };\n};\nfunction resolve(context) {\n var _f = _resolveRequest(context.plan.rootRequest.requestScope);\n return _f(context.plan.rootRequest);\n}\nexports.resolve = resolve;\n//# sourceMappingURL=resolver.js.map","\"use strict\";\nvar __spreadArray = (this && this.__spreadArray) || function (to, from) {\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)\n to[j] = from[i];\n return to;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.resolveInstance = void 0;\nvar error_msgs_1 = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nfunction _injectProperties(instance, childRequests, resolveRequest) {\n var propertyInjectionsRequests = childRequests.filter(function (childRequest) {\n return (childRequest.target !== null &&\n childRequest.target.type === literal_types_1.TargetTypeEnum.ClassProperty);\n });\n var propertyInjections = propertyInjectionsRequests.map(resolveRequest);\n propertyInjectionsRequests.forEach(function (r, index) {\n var propertyName = \"\";\n propertyName = r.target.name.value();\n var injection = propertyInjections[index];\n instance[propertyName] = injection;\n });\n return instance;\n}\nfunction _createInstance(Func, injections) {\n return new (Func.bind.apply(Func, __spreadArray([void 0], injections)))();\n}\nfunction _postConstruct(constr, result) {\n if (Reflect.hasMetadata(METADATA_KEY.POST_CONSTRUCT, constr)) {\n var data = Reflect.getMetadata(METADATA_KEY.POST_CONSTRUCT, constr);\n try {\n result[data.value]();\n }\n catch (e) {\n throw new Error(error_msgs_1.POST_CONSTRUCT_ERROR(constr.name, e.message));\n }\n }\n}\nfunction resolveInstance(constr, childRequests, resolveRequest) {\n var result = null;\n if (childRequests.length > 0) {\n var constructorInjectionsRequests = childRequests.filter(function (childRequest) {\n return (childRequest.target !== null && childRequest.target.type === literal_types_1.TargetTypeEnum.ConstructorArgument);\n });\n var constructorInjections = constructorInjectionsRequests.map(resolveRequest);\n result = _createInstance(constr, constructorInjections);\n result = _injectProperties(result, childRequests, resolveRequest);\n }\n else {\n result = new constr();\n }\n _postConstruct(constr, result);\n return result;\n}\nexports.resolveInstance = resolveInstance;\n//# sourceMappingURL=instantiation.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingToSyntax = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar binding_in_when_on_syntax_1 = require(\"./binding_in_when_on_syntax\");\nvar binding_when_on_syntax_1 = require(\"./binding_when_on_syntax\");\nvar BindingToSyntax = (function () {\n function BindingToSyntax(binding) {\n this._binding = binding;\n }\n BindingToSyntax.prototype.to = function (constructor) {\n this._binding.type = literal_types_1.BindingTypeEnum.Instance;\n this._binding.implementationType = constructor;\n return new binding_in_when_on_syntax_1.BindingInWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toSelf = function () {\n if (typeof this._binding.serviceIdentifier !== \"function\") {\n throw new Error(\"\" + ERROR_MSGS.INVALID_TO_SELF_VALUE);\n }\n var self = this._binding.serviceIdentifier;\n return this.to(self);\n };\n BindingToSyntax.prototype.toConstantValue = function (value) {\n this._binding.type = literal_types_1.BindingTypeEnum.ConstantValue;\n this._binding.cache = value;\n this._binding.dynamicValue = null;\n this._binding.implementationType = null;\n this._binding.scope = literal_types_1.BindingScopeEnum.Singleton;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toDynamicValue = function (func) {\n this._binding.type = literal_types_1.BindingTypeEnum.DynamicValue;\n this._binding.cache = null;\n this._binding.dynamicValue = func;\n this._binding.implementationType = null;\n return new binding_in_when_on_syntax_1.BindingInWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toConstructor = function (constructor) {\n this._binding.type = literal_types_1.BindingTypeEnum.Constructor;\n this._binding.implementationType = constructor;\n this._binding.scope = literal_types_1.BindingScopeEnum.Singleton;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toFactory = function (factory) {\n this._binding.type = literal_types_1.BindingTypeEnum.Factory;\n this._binding.factory = factory;\n this._binding.scope = literal_types_1.BindingScopeEnum.Singleton;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toFunction = function (func) {\n if (typeof func !== \"function\") {\n throw new Error(ERROR_MSGS.INVALID_FUNCTION_BINDING);\n }\n var bindingWhenOnSyntax = this.toConstantValue(func);\n this._binding.type = literal_types_1.BindingTypeEnum.Function;\n this._binding.scope = literal_types_1.BindingScopeEnum.Singleton;\n return bindingWhenOnSyntax;\n };\n BindingToSyntax.prototype.toAutoFactory = function (serviceIdentifier) {\n this._binding.type = literal_types_1.BindingTypeEnum.Factory;\n this._binding.factory = function (context) {\n var autofactory = function () { return context.container.get(serviceIdentifier); };\n return autofactory;\n };\n this._binding.scope = literal_types_1.BindingScopeEnum.Singleton;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toProvider = function (provider) {\n this._binding.type = literal_types_1.BindingTypeEnum.Provider;\n this._binding.provider = provider;\n this._binding.scope = literal_types_1.BindingScopeEnum.Singleton;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toService = function (service) {\n this.toDynamicValue(function (context) { return context.container.get(service); });\n };\n return BindingToSyntax;\n}());\nexports.BindingToSyntax = BindingToSyntax;\n//# sourceMappingURL=binding_to_syntax.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingInWhenOnSyntax = void 0;\nvar binding_in_syntax_1 = require(\"./binding_in_syntax\");\nvar binding_on_syntax_1 = require(\"./binding_on_syntax\");\nvar binding_when_syntax_1 = require(\"./binding_when_syntax\");\nvar BindingInWhenOnSyntax = (function () {\n function BindingInWhenOnSyntax(binding) {\n this._binding = binding;\n this._bindingWhenSyntax = new binding_when_syntax_1.BindingWhenSyntax(this._binding);\n this._bindingOnSyntax = new binding_on_syntax_1.BindingOnSyntax(this._binding);\n this._bindingInSyntax = new binding_in_syntax_1.BindingInSyntax(binding);\n }\n BindingInWhenOnSyntax.prototype.inRequestScope = function () {\n return this._bindingInSyntax.inRequestScope();\n };\n BindingInWhenOnSyntax.prototype.inSingletonScope = function () {\n return this._bindingInSyntax.inSingletonScope();\n };\n BindingInWhenOnSyntax.prototype.inTransientScope = function () {\n return this._bindingInSyntax.inTransientScope();\n };\n BindingInWhenOnSyntax.prototype.when = function (constraint) {\n return this._bindingWhenSyntax.when(constraint);\n };\n BindingInWhenOnSyntax.prototype.whenTargetNamed = function (name) {\n return this._bindingWhenSyntax.whenTargetNamed(name);\n };\n BindingInWhenOnSyntax.prototype.whenTargetIsDefault = function () {\n return this._bindingWhenSyntax.whenTargetIsDefault();\n };\n BindingInWhenOnSyntax.prototype.whenTargetTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenTargetTagged(tag, value);\n };\n BindingInWhenOnSyntax.prototype.whenInjectedInto = function (parent) {\n return this._bindingWhenSyntax.whenInjectedInto(parent);\n };\n BindingInWhenOnSyntax.prototype.whenParentNamed = function (name) {\n return this._bindingWhenSyntax.whenParentNamed(name);\n };\n BindingInWhenOnSyntax.prototype.whenParentTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenParentTagged(tag, value);\n };\n BindingInWhenOnSyntax.prototype.whenAnyAncestorIs = function (ancestor) {\n return this._bindingWhenSyntax.whenAnyAncestorIs(ancestor);\n };\n BindingInWhenOnSyntax.prototype.whenNoAncestorIs = function (ancestor) {\n return this._bindingWhenSyntax.whenNoAncestorIs(ancestor);\n };\n BindingInWhenOnSyntax.prototype.whenAnyAncestorNamed = function (name) {\n return this._bindingWhenSyntax.whenAnyAncestorNamed(name);\n };\n BindingInWhenOnSyntax.prototype.whenAnyAncestorTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenAnyAncestorTagged(tag, value);\n };\n BindingInWhenOnSyntax.prototype.whenNoAncestorNamed = function (name) {\n return this._bindingWhenSyntax.whenNoAncestorNamed(name);\n };\n BindingInWhenOnSyntax.prototype.whenNoAncestorTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenNoAncestorTagged(tag, value);\n };\n BindingInWhenOnSyntax.prototype.whenAnyAncestorMatches = function (constraint) {\n return this._bindingWhenSyntax.whenAnyAncestorMatches(constraint);\n };\n BindingInWhenOnSyntax.prototype.whenNoAncestorMatches = function (constraint) {\n return this._bindingWhenSyntax.whenNoAncestorMatches(constraint);\n };\n BindingInWhenOnSyntax.prototype.onActivation = function (handler) {\n return this._bindingOnSyntax.onActivation(handler);\n };\n return BindingInWhenOnSyntax;\n}());\nexports.BindingInWhenOnSyntax = BindingInWhenOnSyntax;\n//# sourceMappingURL=binding_in_when_on_syntax.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingInSyntax = void 0;\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar binding_when_on_syntax_1 = require(\"./binding_when_on_syntax\");\nvar BindingInSyntax = (function () {\n function BindingInSyntax(binding) {\n this._binding = binding;\n }\n BindingInSyntax.prototype.inRequestScope = function () {\n this._binding.scope = literal_types_1.BindingScopeEnum.Request;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingInSyntax.prototype.inSingletonScope = function () {\n this._binding.scope = literal_types_1.BindingScopeEnum.Singleton;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingInSyntax.prototype.inTransientScope = function () {\n this._binding.scope = literal_types_1.BindingScopeEnum.Transient;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n return BindingInSyntax;\n}());\nexports.BindingInSyntax = BindingInSyntax;\n//# sourceMappingURL=binding_in_syntax.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ContainerSnapshot = void 0;\nvar ContainerSnapshot = (function () {\n function ContainerSnapshot() {\n }\n ContainerSnapshot.of = function (bindings, middleware) {\n var snapshot = new ContainerSnapshot();\n snapshot.bindings = bindings;\n snapshot.middleware = middleware;\n return snapshot;\n };\n return ContainerSnapshot;\n}());\nexports.ContainerSnapshot = ContainerSnapshot;\n//# sourceMappingURL=container_snapshot.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Lookup = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar Lookup = (function () {\n function Lookup() {\n this._map = new Map();\n }\n Lookup.prototype.getMap = function () {\n return this._map;\n };\n Lookup.prototype.add = function (serviceIdentifier, value) {\n if (serviceIdentifier === null || serviceIdentifier === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n if (value === null || value === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n var entry = this._map.get(serviceIdentifier);\n if (entry !== undefined) {\n entry.push(value);\n this._map.set(serviceIdentifier, entry);\n }\n else {\n this._map.set(serviceIdentifier, [value]);\n }\n };\n Lookup.prototype.get = function (serviceIdentifier) {\n if (serviceIdentifier === null || serviceIdentifier === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n var entry = this._map.get(serviceIdentifier);\n if (entry !== undefined) {\n return entry;\n }\n else {\n throw new Error(ERROR_MSGS.KEY_NOT_FOUND);\n }\n };\n Lookup.prototype.remove = function (serviceIdentifier) {\n if (serviceIdentifier === null || serviceIdentifier === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n if (!this._map.delete(serviceIdentifier)) {\n throw new Error(ERROR_MSGS.KEY_NOT_FOUND);\n }\n };\n Lookup.prototype.removeByCondition = function (condition) {\n var _this = this;\n this._map.forEach(function (entries, key) {\n var updatedEntries = entries.filter(function (entry) { return !condition(entry); });\n if (updatedEntries.length > 0) {\n _this._map.set(key, updatedEntries);\n }\n else {\n _this._map.delete(key);\n }\n });\n };\n Lookup.prototype.hasKey = function (serviceIdentifier) {\n if (serviceIdentifier === null || serviceIdentifier === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n return this._map.has(serviceIdentifier);\n };\n Lookup.prototype.clone = function () {\n var copy = new Lookup();\n this._map.forEach(function (value, key) {\n value.forEach(function (b) { return copy.add(key, b.clone()); });\n });\n return copy;\n };\n Lookup.prototype.traverse = function (func) {\n this._map.forEach(function (value, key) {\n func(key, value);\n });\n };\n return Lookup;\n}());\nexports.Lookup = Lookup;\n//# sourceMappingURL=lookup.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.AsyncContainerModule = exports.ContainerModule = void 0;\nvar id_1 = require(\"../utils/id\");\nvar ContainerModule = (function () {\n function ContainerModule(registry) {\n this.id = id_1.id();\n this.registry = registry;\n }\n return ContainerModule;\n}());\nexports.ContainerModule = ContainerModule;\nvar AsyncContainerModule = (function () {\n function AsyncContainerModule(registry) {\n this.id = id_1.id();\n this.registry = registry;\n }\n return AsyncContainerModule;\n}());\nexports.AsyncContainerModule = AsyncContainerModule;\n//# sourceMappingURL=container_module.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.injectable = void 0;\nvar ERRORS_MSGS = require(\"../constants/error_msgs\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nfunction injectable() {\n return function (target) {\n if (Reflect.hasOwnMetadata(METADATA_KEY.PARAM_TYPES, target)) {\n throw new Error(ERRORS_MSGS.DUPLICATED_INJECTABLE_DECORATOR);\n }\n var types = Reflect.getMetadata(METADATA_KEY.DESIGN_PARAM_TYPES, target) || [];\n Reflect.defineMetadata(METADATA_KEY.PARAM_TYPES, types, target);\n return target;\n };\n}\nexports.injectable = injectable;\n//# sourceMappingURL=injectable.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.tagged = void 0;\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction tagged(metadataKey, metadataValue) {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(metadataKey, metadataValue);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.tagged = tagged;\n//# sourceMappingURL=tagged.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.named = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction named(name) {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.NAMED_TAG, name);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.named = named;\n//# sourceMappingURL=named.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.optional = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction optional() {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.OPTIONAL_TAG, true);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.optional = optional;\n//# sourceMappingURL=optional.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.unmanaged = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction unmanaged() {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.UNMANAGED_TAG, true);\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n };\n}\nexports.unmanaged = unmanaged;\n//# sourceMappingURL=unmanaged.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.multiInject = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction multiInject(serviceIdentifier) {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.MULTI_INJECT_TAG, serviceIdentifier);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.multiInject = multiInject;\n//# sourceMappingURL=multi_inject.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.targetName = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction targetName(name) {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.NAME_TAG, name);\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n };\n}\nexports.targetName = targetName;\n//# sourceMappingURL=target_name.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.postConstruct = void 0;\nvar ERRORS_MSGS = require(\"../constants/error_msgs\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nfunction postConstruct() {\n return function (target, propertyKey, descriptor) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.POST_CONSTRUCT, propertyKey);\n if (Reflect.hasOwnMetadata(METADATA_KEY.POST_CONSTRUCT, target.constructor)) {\n throw new Error(ERRORS_MSGS.MULTIPLE_POST_CONSTRUCT_METHODS);\n }\n Reflect.defineMetadata(METADATA_KEY.POST_CONSTRUCT, metadata, target.constructor);\n };\n}\nexports.postConstruct = postConstruct;\n//# sourceMappingURL=post_construct.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.multiBindToService = void 0;\nvar multiBindToService = function (container) {\n return function (service) {\n return function () {\n var types = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n types[_i] = arguments[_i];\n }\n return types.forEach(function (t) { return container.bind(t).toService(service); });\n };\n };\n};\nexports.multiBindToService = multiBindToService;\n//# sourceMappingURL=binding_utils.js.map","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n module.exports[\"default\"] = module.exports, module.exports.__esModule = true;\n return _setPrototypeOf(o, p);\n}\n\nmodule.exports = _setPrototypeOf;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar INJECTION = Symbol.for(\"INJECTION\");\nfunction _proxyGetter(proto, key, resolve, doCache) {\n function getter() {\n if (doCache && !Reflect.hasMetadata(INJECTION, this, key)) {\n Reflect.defineMetadata(INJECTION, resolve(), this, key);\n }\n if (Reflect.hasMetadata(INJECTION, this, key)) {\n return Reflect.getMetadata(INJECTION, this, key);\n }\n else {\n return resolve();\n }\n }\n function setter(newVal) {\n Reflect.defineMetadata(INJECTION, newVal, this, key);\n }\n Object.defineProperty(proto, key, {\n configurable: true,\n enumerable: true,\n get: getter,\n set: setter\n });\n}\nfunction makePropertyInjectDecorator(container, doCache) {\n return function (serviceIdentifier) {\n return function (proto, key) {\n var resolve = function () {\n return container.get(serviceIdentifier);\n };\n _proxyGetter(proto, key, resolve, doCache);\n };\n };\n}\nexports.makePropertyInjectDecorator = makePropertyInjectDecorator;\nfunction makePropertyInjectNamedDecorator(container, doCache) {\n return function (serviceIdentifier, named) {\n return function (proto, key) {\n var resolve = function () {\n return container.getNamed(serviceIdentifier, named);\n };\n _proxyGetter(proto, key, resolve, doCache);\n };\n };\n}\nexports.makePropertyInjectNamedDecorator = makePropertyInjectNamedDecorator;\nfunction makePropertyInjectTaggedDecorator(container, doCache) {\n return function (serviceIdentifier, key, value) {\n return function (proto, propertyName) {\n var resolve = function () {\n return container.getTagged(serviceIdentifier, key, value);\n };\n _proxyGetter(proto, propertyName, resolve, doCache);\n };\n };\n}\nexports.makePropertyInjectTaggedDecorator = makePropertyInjectTaggedDecorator;\nfunction makePropertyMultiInjectDecorator(container, doCache) {\n return function (serviceIdentifier) {\n return function (proto, key) {\n var resolve = function () {\n return container.getAll(serviceIdentifier);\n };\n _proxyGetter(proto, key, resolve, doCache);\n };\n };\n}\nexports.makePropertyMultiInjectDecorator = makePropertyMultiInjectDecorator;\n","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\n\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}\n\nmodule.exports = _arrayWithoutHoles;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\n\nmodule.exports = _iterableToArray;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableSpread;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","module.exports = clone\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {vec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nfunction clone(a) {\n var out = new Float32Array(2)\n out[0] = a[0]\n out[1] = a[1]\n return out\n}","module.exports = fromValues\n\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\nfunction fromValues(x, y) {\n var out = new Float32Array(2)\n out[0] = x\n out[1] = y\n return out\n}","module.exports = copy\n\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the source vector\n * @returns {vec2} out\n */\nfunction copy(out, a) {\n out[0] = a[0]\n out[1] = a[1]\n return out\n}","module.exports = equals\n\nvar EPSILON = require('./epsilon')\n\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {vec2} a The first vector.\n * @param {vec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nfunction equals(a, b) {\n var a0 = a[0]\n var a1 = a[1]\n var b0 = b[0]\n var b1 = b[1]\n return (Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) &&\n Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)))\n}\n","module.exports = exactEquals\n\n/**\n * Returns whether or not the vectors exactly have the same elements in the same position (when compared with ===)\n *\n * @param {vec2} a The first vector.\n * @param {vec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nfunction exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1]\n}\n","module.exports = require('./subtract')\n","module.exports = require('./multiply')\n","module.exports = require('./divide')\n","module.exports = inverse\n\n/**\n * Returns the inverse of the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to invert\n * @returns {vec2} out\n */\nfunction inverse(out, a) {\n out[0] = 1.0 / a[0]\n out[1] = 1.0 / a[1]\n return out\n}\n","module.exports = min\n\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction min(out, a, b) {\n out[0] = Math.min(a[0], b[0])\n out[1] = Math.min(a[1], b[1])\n return out\n}","module.exports = max\n\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction max(out, a, b) {\n out[0] = Math.max(a[0], b[0])\n out[1] = Math.max(a[1], b[1])\n return out\n}","module.exports = rotate\n\n/**\n * Rotates a vec2 by an angle\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to rotate\n * @param {Number} angle the angle of rotation (in radians)\n * @returns {vec2} out\n */\nfunction rotate(out, a, angle) {\n var c = Math.cos(angle),\n s = Math.sin(angle)\n var x = a[0],\n y = a[1]\n\n out[0] = x * c - y * s\n out[1] = x * s + y * c\n\n return out\n}\n\n","module.exports = floor\n\n/**\n * Math.floor the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to floor\n * @returns {vec2} out\n */\nfunction floor(out, a) {\n out[0] = Math.floor(a[0])\n out[1] = Math.floor(a[1])\n return out\n}\n","module.exports = ceil\n\n/**\n * Math.ceil the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to ceil\n * @returns {vec2} out\n */\nfunction ceil(out, a) {\n out[0] = Math.ceil(a[0])\n out[1] = Math.ceil(a[1])\n return out\n}\n","module.exports = round\n\n/**\n * Math.round the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to round\n * @returns {vec2} out\n */\nfunction round(out, a) {\n out[0] = Math.round(a[0])\n out[1] = Math.round(a[1])\n return out\n}\n","module.exports = scale\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nfunction scale(out, a, b) {\n out[0] = a[0] * b\n out[1] = a[1] * b\n return out\n}","module.exports = scaleAndAdd\n\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\nfunction scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + (b[0] * scale)\n out[1] = a[1] + (b[1] * scale)\n return out\n}","module.exports = require('./distance')\n","module.exports = require('./squaredDistance')\n","module.exports = require('./length')\n","module.exports = require('./squaredLength')\n","module.exports = negate\n\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to negate\n * @returns {vec2} out\n */\nfunction negate(out, a) {\n out[0] = -a[0]\n out[1] = -a[1]\n return out\n}","module.exports = cross\n\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec3} out\n */\nfunction cross(out, a, b) {\n var z = a[0] * b[1] - a[1] * b[0]\n out[0] = out[1] = 0\n out[2] = z\n return out\n}","module.exports = lerp\n\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec2} out\n */\nfunction lerp(out, a, b, t) {\n var ax = a[0],\n ay = a[1]\n out[0] = ax + t * (b[0] - ax)\n out[1] = ay + t * (b[1] - ay)\n return out\n}","module.exports = random\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec2} out\n */\nfunction random(out, scale) {\n scale = scale || 1.0\n var r = Math.random() * 2.0 * Math.PI\n out[0] = Math.cos(r) * scale\n out[1] = Math.sin(r) * scale\n return out\n}","module.exports = transformMat2\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat2(out, a, m) {\n var x = a[0],\n y = a[1]\n out[0] = m[0] * x + m[2] * y\n out[1] = m[1] * x + m[3] * y\n return out\n}","module.exports = transformMat2d\n\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2d} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat2d(out, a, m) {\n var x = a[0],\n y = a[1]\n out[0] = m[0] * x + m[2] * y + m[4]\n out[1] = m[1] * x + m[3] * y + m[5]\n return out\n}","module.exports = transformMat3\n\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat3} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat3(out, a, m) {\n var x = a[0],\n y = a[1]\n out[0] = m[0] * x + m[3] * y + m[6]\n out[1] = m[1] * x + m[4] * y + m[7]\n return out\n}","module.exports = transformMat4\n\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat4(out, a, m) {\n var x = a[0], \n y = a[1]\n out[0] = m[0] * x + m[4] * y + m[12]\n out[1] = m[1] * x + m[5] * y + m[13]\n return out\n}","module.exports = forEach\n\nvar vec = require('./create')()\n\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nfunction forEach(a, stride, offset, count, fn, arg) {\n var i, l\n if(!stride) {\n stride = 2\n }\n\n if(!offset) {\n offset = 0\n }\n \n if(count) {\n l = Math.min((count * stride) + offset, a.length)\n } else {\n l = a.length\n }\n\n for(i = offset; i < l; i += stride) {\n vec[0] = a[i]\n vec[1] = a[i+1]\n fn(vec, vec, arg)\n a[i] = vec[0]\n a[i+1] = vec[1]\n }\n \n return a\n}","module.exports = limit;\n\n/**\n * Limit the magnitude of this vector to the value used for the `max`\n * parameter.\n *\n * @param {vec2} the vector to limit\n * @param {Number} max the maximum magnitude for the vector\n * @returns {vec2} out\n */\nfunction limit(out, a, max) {\n var mSq = a[0] * a[0] + a[1] * a[1];\n\n if (mSq > max * max) {\n var n = Math.sqrt(mSq);\n out[0] = a[0] / n * max;\n out[1] = a[1] / n * max;\n } else {\n out[0] = a[0];\n out[1] = a[1];\n }\n\n return out;\n}\n","import { __spreadArrays } from \"tslib\";\nimport values from './values';\nimport memoize from './memoize';\nimport isString from './is-string';\nvar ctx;\n/**\n * 计算文本的宽度\n */\nexport default memoize(function (text, font) {\n if (font === void 0) { font = {}; }\n var fontSize = font.fontSize, fontFamily = font.fontFamily, fontWeight = font.fontWeight, fontStyle = font.fontStyle, fontVariant = font.fontVariant;\n if (!ctx) {\n ctx = document.createElement('canvas').getContext('2d');\n }\n ctx.font = [fontStyle, fontVariant, fontWeight, fontSize + \"px\", fontFamily].join(' ');\n return ctx.measureText(isString(text) ? text : '').width;\n}, function (text, font) {\n if (font === void 0) { font = {}; }\n return __spreadArrays([text], values(font)).join('');\n});\n//# sourceMappingURL=measure-text-width.js.map","import { each } from '@antv/util'; // 自定义 Behavior 时候共有的方法\n\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {};\n },\n\n /**\n * register event handler, behavior will auto bind events\n * for example:\n * return {\n * click: 'onClick'\n * }\n */\n getEvents: function getEvents() {\n return {};\n },\n updateCfg: function updateCfg(cfg) {\n Object.assign(this, cfg);\n return true;\n },\n shouldBegin: function shouldBegin() {\n return true;\n },\n shouldUpdate: function shouldUpdate() {\n return true;\n },\n shouldEnd: function shouldEnd() {\n return true;\n },\n\n /**\n * auto bind events when register behavior\n * @param graph Graph instance\n */\n bind: function bind(graph) {\n var _this = this;\n\n var events = this.events;\n this.graph = graph;\n\n if (this.type === 'drag-canvas' || this.type === 'brush-select' || this.type === 'lasso-select') {\n graph.get('canvas').set('draggable', true);\n }\n\n each(events, function (handler, event) {\n graph.on(event, handler);\n }); // To avoid the tabs switching makes the keydown related behaviors disable\n\n document.addEventListener('visibilitychange', function () {\n _this.keydown = false;\n });\n },\n unbind: function unbind(graph) {\n var events = this.events;\n var draggable = graph.get('canvas').get('draggable');\n\n if (this.type === 'drag-canvas' || this.type === 'brush-select' || this.type === 'lasso-select') {\n graph.get('canvas').set('draggable', false);\n }\n\n each(events, function (handler, event) {\n graph.off(event, handler);\n });\n graph.get('canvas').set('draggable', draggable);\n },\n get: function get(val) {\n return this[val];\n },\n set: function set(key, val) {\n this[key] = val;\n return this;\n }\n};","import { clone, each, wrapBehavior } from '@antv/util';\nimport behaviorOption from './behaviorOption';\n\nvar Behavior = function () {\n function Behavior() {}\n /**\n * 自定义 Behavior\n * @param type Behavior 名称\n * @param behavior Behavior 定义的方法集合\n */\n\n\n Behavior.registerBehavior = function (type, behavior) {\n if (!behavior) {\n throw new Error(\"please specify handler for this behavior: \" + type);\n }\n\n var prototype = clone(behaviorOption);\n Object.assign(prototype, behavior); // eslint-disable-next-line func-names\n\n var base = function base(cfg) {\n var _this = this;\n\n Object.assign(this, this.getDefaultCfg(), cfg);\n var events = this.getEvents();\n this.events = null;\n var eventsToBind = {};\n\n if (events) {\n each(events, function (handle, event) {\n eventsToBind[event] = wrapBehavior(_this, handle);\n });\n this.events = eventsToBind;\n }\n };\n\n base.prototype = prototype;\n Behavior.types[type] = base;\n };\n\n Behavior.hasBehavior = function (type) {\n return !!Behavior.types[type];\n };\n\n Behavior.getBehavior = function (type) {\n return Behavior.types[type];\n }; // 所有自定义的 Behavior 的实例\n\n\n Behavior.types = {};\n return Behavior;\n}();\n\nexport default Behavior;","import Behavior from './behavior';\nexport default Behavior;","var adjMatrix = function adjMatrix(graphData, directed) {\n var nodes = graphData.nodes,\n edges = graphData.edges;\n var matrix = []; // map node with index in data.nodes\n\n var nodeMap = {};\n\n if (!nodes) {\n throw new Error(\"invalid nodes data!\");\n }\n\n if (nodes) {\n nodes.forEach(function (node, i) {\n nodeMap[node.id] = i;\n var row = [];\n matrix.push(row);\n });\n }\n\n if (edges) {\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var sIndex = nodeMap[source];\n var tIndex = nodeMap[target];\n if (!sIndex && sIndex !== 0 || !tIndex && tIndex !== 0) return;\n matrix[sIndex][tIndex] = 1;\n\n if (!directed) {\n matrix[tIndex][sIndex] = 1;\n }\n });\n }\n\n return matrix;\n};\n\nexport default adjMatrix;","var defaultComparator = function defaultComparator(a, b) {\n if (a === b) {\n return true;\n }\n\n return false;\n};\n/**\n * 链表中单个元素节点\n */\n\n\nvar LinkedListNode = function () {\n function LinkedListNode(value, next) {\n if (next === void 0) {\n next = null;\n }\n\n this.value = value;\n this.next = next;\n }\n\n LinkedListNode.prototype.toString = function (callback) {\n return callback ? callback(this.value) : \"\" + this.value;\n };\n\n return LinkedListNode;\n}();\n\nexport { LinkedListNode };\n\nvar LinkedList = function () {\n function LinkedList(comparator) {\n if (comparator === void 0) {\n comparator = defaultComparator;\n }\n\n this.head = null;\n this.tail = null;\n this.compare = comparator;\n }\n /**\n * 将指定元素添加到链表头部\n * @param value\n */\n\n\n LinkedList.prototype.prepend = function (value) {\n // 在头部添加一个节点\n var newNode = new LinkedListNode(value, this.head);\n this.head = newNode;\n\n if (!this.tail) {\n this.tail = newNode;\n }\n\n return this;\n };\n /**\n * 将指定元素添加到链表中\n * @param value\n */\n\n\n LinkedList.prototype.append = function (value) {\n var newNode = new LinkedListNode(value); // 如果不存在头节点,则将创建的新节点作为头节点\n\n if (!this.head) {\n this.head = newNode;\n this.tail = newNode;\n return this;\n } // 将新节点附加到链表末尾\n\n\n this.tail.next = newNode;\n this.tail = newNode;\n return this;\n };\n /**\n * 删除指定元素\n * @param value 要删除的元素\n */\n\n\n LinkedList.prototype.delete = function (value) {\n if (!this.head) {\n return null;\n }\n\n var deleteNode = null; // 如果删除的是头部元素,则将next作为头元素\n\n while (this.head && this.compare(this.head.value, value)) {\n deleteNode = this.head;\n this.head = this.head.next;\n }\n\n var currentNode = this.head;\n\n if (currentNode !== null) {\n // 如果删除了节点以后,将next节点前移\n while (currentNode.next) {\n if (this.compare(currentNode.next.value, value)) {\n deleteNode = currentNode.next;\n currentNode.next = currentNode.next.next;\n } else {\n currentNode = currentNode.next;\n }\n }\n } // 检查尾部节点是否被删除\n\n\n if (this.compare(this.tail.value, value)) {\n this.tail = currentNode;\n }\n\n return deleteNode;\n };\n /**\n * 查找指定的元素\n * @param param0\n */\n\n\n LinkedList.prototype.find = function (_a) {\n var _b = _a.value,\n value = _b === void 0 ? undefined : _b,\n _c = _a.callback,\n callback = _c === void 0 ? undefined : _c;\n\n if (!this.head) {\n return null;\n }\n\n var currentNode = this.head;\n\n while (currentNode) {\n // 如果指定了 callback,则按指定的 callback 查找\n if (callback && callback(currentNode.value)) {\n return currentNode;\n } // 如果指定了 value,则按 value 查找\n\n\n if (value !== undefined && this.compare(currentNode.value, value)) {\n return currentNode;\n }\n\n currentNode = currentNode.next;\n }\n\n return null;\n };\n /**\n * 删除尾部节点\n */\n\n\n LinkedList.prototype.deleteTail = function () {\n var deletedTail = this.tail;\n\n if (this.head === this.tail) {\n // 链表中只有一个元素\n this.head = null;\n this.tail = null;\n return deletedTail;\n }\n\n var currentNode = this.head;\n\n while (currentNode.next) {\n if (!currentNode.next.next) {\n currentNode.next = null;\n } else {\n currentNode = currentNode.next;\n }\n }\n\n this.tail = currentNode;\n return deletedTail;\n };\n /**\n * 删除头部节点\n */\n\n\n LinkedList.prototype.deleteHead = function () {\n if (!this.head) {\n return null;\n }\n\n var deletedHead = this.head;\n\n if (this.head.next) {\n this.head = this.head.next;\n } else {\n this.head = null;\n this.tail = null;\n }\n\n return deletedHead;\n };\n /**\n * 将一组元素转成链表中的节点\n * @param values 链表中的元素\n */\n\n\n LinkedList.prototype.fromArray = function (values) {\n var _this = this;\n\n values.forEach(function (value) {\n return _this.append(value);\n });\n return this;\n };\n /**\n * 将链表中的节点转成数组元素\n */\n\n\n LinkedList.prototype.toArray = function () {\n var nodes = [];\n var currentNode = this.head;\n\n while (currentNode) {\n nodes.push(currentNode);\n currentNode = currentNode.next;\n }\n\n return nodes;\n };\n /**\n * 反转链表中的元素节点\n */\n\n\n LinkedList.prototype.reverse = function () {\n var currentNode = this.head;\n var prevNode = null;\n var nextNode = null;\n\n while (currentNode) {\n // 存储下一个元素节点\n nextNode = currentNode.next; // 更改当前节点的下一个节点,以便将它连接到上一个节点上\n\n currentNode.next = prevNode; // 将 prevNode 和 currentNode 向前移动一步\n\n prevNode = currentNode;\n currentNode = nextNode;\n }\n\n this.tail = this.head;\n this.head = prevNode;\n };\n\n LinkedList.prototype.toString = function (callback) {\n if (callback === void 0) {\n callback = undefined;\n }\n\n return this.toArray().map(function (node) {\n return node.toString(callback);\n }).toString();\n };\n\n return LinkedList;\n}();\n\nexport default LinkedList;","import LinkedList from './linked-list';\n\nvar Queue = function () {\n function Queue() {\n this.linkedList = new LinkedList();\n }\n /**\n * 队列是否为空\n */\n\n\n Queue.prototype.isEmpty = function () {\n return !this.linkedList.head;\n };\n /**\n * 读取队列头部的元素, 不删除队列中的元素\n */\n\n\n Queue.prototype.peek = function () {\n if (!this.linkedList.head) {\n return null;\n }\n\n return this.linkedList.head.value;\n };\n /**\n * 在队列的尾部新增一个元素\n * @param value\n */\n\n\n Queue.prototype.enqueue = function (value) {\n this.linkedList.append(value);\n };\n /**\n * 删除队列中的头部元素,如果队列为空,则返回 null\n */\n\n\n Queue.prototype.dequeue = function () {\n var removeHead = this.linkedList.deleteHead();\n return removeHead ? removeHead.value : null;\n };\n\n Queue.prototype.toString = function (callback) {\n return this.linkedList.toString(callback);\n };\n\n return Queue;\n}();\n\nexport default Queue;","/**\n * 获取指定节点的所有邻居\n * @param nodeId 节点 ID\n * @param edges 图中的所有边数据\n * @param type 邻居类型\n */\nexport var getNeighbors = function getNeighbors(nodeId, edges, type) {\n if (edges === void 0) {\n edges = [];\n }\n\n var currentEdges = edges.filter(function (edge) {\n return edge.source === nodeId || edge.target === nodeId;\n });\n\n if (type === 'target') {\n // 当前节点为 source,它所指向的目标节点\n var neighhborsConverter_1 = function neighhborsConverter_1(edge) {\n return edge.source === nodeId;\n };\n\n return currentEdges.filter(neighhborsConverter_1).map(function (edge) {\n return edge.target;\n });\n }\n\n if (type === 'source') {\n // 当前节点为 target,它所指向的源节点\n var neighhborsConverter_2 = function neighhborsConverter_2(edge) {\n return edge.target === nodeId;\n };\n\n return currentEdges.filter(neighhborsConverter_2).map(function (edge) {\n return edge.source;\n });\n } // 若未指定 type ,则返回所有邻居\n\n\n var neighhborsConverter = function neighhborsConverter(edge) {\n return edge.source === nodeId ? edge.target : edge.source;\n };\n\n return currentEdges.map(neighhborsConverter);\n};\n/**\n * 获取指定节点的出边\n * @param nodeId 节点 ID\n * @param edges 图中的所有边数据\n */\n\nexport var getOutEdgesNodeId = function getOutEdgesNodeId(nodeId, edges) {\n return edges.filter(function (edge) {\n return edge.source === nodeId;\n });\n};\n/**\n * 获取指定节点的边,包括出边和入边\n * @param nodeId 节点 ID\n * @param edges 图中的所有边数据\n */\n\nexport var getEdgesByNodeId = function getEdgesByNodeId(nodeId, edges) {\n return edges.filter(function (edge) {\n return edge.source === nodeId || edge.target === nodeId;\n });\n};\n/**\n * 生成唯一的 ID,规则是序号 + 时间戳\n * @param index 序号\n */\n\nexport var uniqueId = function uniqueId(index) {\n if (index === void 0) {\n index = 0;\n }\n\n var random1 = (\"\" + Math.random()).split('.')[1].substr(0, 5);\n var random2 = (\"\" + Math.random()).split('.')[1].substr(0, 5);\n return index + \"-\" + random1 + random2;\n};","import Queue from './structs/queue';\nimport { getNeighbors } from './util';\n/**\n *\n * @param callbacks\n * allowTraversal: 确定 BFS 是否从顶点沿着边遍历到其邻居,默认情况下,同一个节点只能遍历一次\n * enterNode: 当 BFS 访问某个节点时调用\n * leaveNode: 当 BFS 访问访问结束某个节点时调用\n */\n\nfunction initCallbacks(callbacks) {\n if (callbacks === void 0) {\n callbacks = {};\n }\n\n var initiatedCallback = callbacks;\n\n var stubCallback = function stubCallback() {};\n\n var allowTraversalCallback = function () {\n var seen = {};\n return function (_a) {\n var next = _a.next;\n var id = next;\n\n if (!seen[id]) {\n seen[id] = true;\n return true;\n }\n\n return false;\n };\n }();\n\n initiatedCallback.allowTraversal = callbacks.allowTraversal || allowTraversalCallback;\n initiatedCallback.enter = callbacks.enter || stubCallback;\n initiatedCallback.leave = callbacks.leave || stubCallback;\n return initiatedCallback;\n}\n/**\n * 广度优先遍历图\n * @param graph Graph 图实例\n * @param startNode 开始遍历的节点\n * @param originalCallbacks 回调\n */\n\n\nvar breadthFirstSearch = function breadthFirstSearch(graphData, startNodeId, originalCallbacks) {\n var callbacks = initCallbacks(originalCallbacks);\n var nodeQueue = new Queue();\n var _a = graphData.edges,\n edges = _a === void 0 ? [] : _a; // 初始化队列元素\n\n nodeQueue.enqueue(startNodeId);\n var previousNode = '';\n\n var _loop_1 = function _loop_1() {\n var currentNode = nodeQueue.dequeue();\n callbacks.enter({\n current: currentNode,\n previous: previousNode\n }); // 将所有邻居添加到队列中以便遍历\n\n getNeighbors(currentNode, edges, 'target').forEach(function (nextNode) {\n if (callbacks.allowTraversal({\n previous: previousNode,\n current: currentNode,\n next: nextNode\n })) {\n nodeQueue.enqueue(nextNode);\n }\n });\n callbacks.leave({\n current: currentNode,\n previous: previousNode\n }); // 下一次循环之前存储当前顶点\n\n previousNode = currentNode;\n }; // 遍历队列中的所有顶点\n\n\n while (!nodeQueue.isEmpty()) {\n _loop_1();\n }\n};\n\nexport default breadthFirstSearch;","import { getNeighbors } from \"./util\";\n/**\n * Generate all connected components for an undirected graph\n * @param graph\n */\n\nexport var detectConnectedComponents = function detectConnectedComponents(graphData) {\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var allComponents = [];\n var visited = {};\n var nodeStack = [];\n\n var getComponent = function getComponent(node) {\n nodeStack.push(node);\n visited[node.id] = true;\n var neighbors = getNeighbors(node.id, edges);\n\n var _loop_1 = function _loop_1(i) {\n var neighbor = neighbors[i];\n\n if (!visited[neighbor]) {\n var targetNode = nodes.filter(function (node) {\n return node.id === neighbor;\n });\n\n if (targetNode.length > 0) {\n getComponent(targetNode[0]);\n }\n }\n };\n\n for (var i = 0; i < neighbors.length; ++i) {\n _loop_1(i);\n }\n };\n\n for (var i = 0; i < nodes.length; i++) {\n var node = nodes[i];\n\n if (!visited[node.id]) {\n // 对于无向图进行dfs遍历,每一次调用后都得到一个连通分量\n getComponent(node);\n var component = [];\n\n while (nodeStack.length > 0) {\n component.push(nodeStack.pop());\n }\n\n allComponents.push(component);\n }\n }\n\n return allComponents;\n};\n/**\n * Tarjan's Algorithm 复杂度 O(|V|+|E|)\n * For directed graph only\n * a directed graph is said to be strongly connected if \"every vertex is reachable from every other vertex\".\n * refer: http://en.wikipedia.org/wiki/Tarjan%27s_strongly_connected_components_algorithm\n * @param graph\n * @return a list of strongly connected components\n */\n\nexport var detectStrongConnectComponents = function detectStrongConnectComponents(graphData) {\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var nodeStack = [];\n var inStack = {}; // 辅助判断是否已经在stack中,减少查找开销\n\n var indices = {};\n var lowLink = {};\n var allComponents = [];\n var index = 0;\n\n var getComponent = function getComponent(node) {\n // Set the depth index for v to the smallest unused index\n indices[node.id] = index;\n lowLink[node.id] = index;\n index += 1;\n nodeStack.push(node);\n inStack[node.id] = true; // 考虑每个邻接点\n\n var neighbors = getNeighbors(node.id, edges, 'target').filter(function (n) {\n return nodes.map(function (node) {\n return node.id;\n }).indexOf(n) > -1;\n });\n\n var _loop_2 = function _loop_2(i) {\n var targetNodeID = neighbors[i];\n\n if (!indices[targetNodeID] && indices[targetNodeID] !== 0) {\n var targetNode = nodes.filter(function (node) {\n return node.id === targetNodeID;\n });\n\n if (targetNode.length > 0) {\n getComponent(targetNode[0]);\n } // tree edge\n\n\n lowLink[node.id] = Math.min(lowLink[node.id], lowLink[targetNodeID]);\n } else if (inStack[targetNodeID]) {\n // back edge, target node is in the current SCC\n lowLink[node.id] = Math.min(lowLink[node.id], indices[targetNodeID]);\n }\n };\n\n for (var i = 0; i < neighbors.length; i++) {\n _loop_2(i);\n } // If node is a root node, generate an SCC\n\n\n if (lowLink[node.id] === indices[node.id]) {\n var component = [];\n\n while (nodeStack.length > 0) {\n var tmpNode = nodeStack.pop();\n inStack[tmpNode.id] = false;\n component.push(tmpNode);\n if (tmpNode === node) break;\n }\n\n if (component.length > 0) {\n allComponents.push(component);\n }\n }\n };\n\n for (var _i = 0, nodes_1 = nodes; _i < nodes_1.length; _i++) {\n var node = nodes_1[_i];\n\n if (!indices[node.id] && indices[node.id] !== 0) {\n getComponent(node);\n }\n }\n\n return allComponents;\n};\nexport default function getConnectedComponents(graphData, directed) {\n if (directed) return detectStrongConnectComponents(graphData);\n return detectConnectedComponents(graphData);\n}","var degree = function degree(graphData) {\n var degrees = {};\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n nodes.forEach(function (node) {\n degrees[node.id] = {\n degree: 0,\n inDegree: 0,\n outDegree: 0\n };\n });\n edges.forEach(function (edge) {\n degrees[edge.source].degree++;\n degrees[edge.source].outDegree++;\n degrees[edge.target].degree++;\n degrees[edge.target].inDegree++;\n });\n return degrees;\n};\n\nexport default degree;\n/**\n * 获取指定节点的入度\n * @param graphData 图数据\n * @param nodeId 节点ID\n */\n\nexport var getInDegree = function getInDegree(graphData, nodeId) {\n var nodeDegree = degree(graphData);\n\n if (nodeDegree[nodeId]) {\n return degree(graphData)[nodeId].inDegree;\n }\n\n return 0;\n};\n/**\n * 获取指定节点的出度\n * @param graphData 图数据\n * @param nodeId 节点ID\n */\n\nexport var getOutDegree = function getOutDegree(graphData, nodeId) {\n var nodeDegree = degree(graphData);\n\n if (nodeDegree[nodeId]) {\n return degree(graphData)[nodeId].outDegree;\n }\n\n return 0;\n};","import { getNeighbors } from './util';\n\nfunction initCallbacks(callbacks) {\n if (callbacks === void 0) {\n callbacks = {};\n }\n\n var initiatedCallback = callbacks;\n\n var stubCallback = function stubCallback() {};\n\n var allowTraversalCallback = function () {\n var seen = {};\n return function (_a) {\n var next = _a.next;\n\n if (!seen[next]) {\n seen[next] = true;\n return true;\n }\n\n return false;\n };\n }();\n\n initiatedCallback.allowTraversal = callbacks.allowTraversal || allowTraversalCallback;\n initiatedCallback.enter = callbacks.enter || stubCallback;\n initiatedCallback.leave = callbacks.leave || stubCallback;\n return initiatedCallback;\n}\n/**\n * @param {Graph} graph\n * @param {GraphNode} currentNode\n * @param {GraphNode} previousNode\n * @param {Callbacks} callbacks\n */\n\n\nfunction depthFirstSearchRecursive(graphData, currentNode, previousNode, callbacks) {\n callbacks.enter({\n current: currentNode,\n previous: previousNode\n });\n var _a = graphData.edges,\n edges = _a === void 0 ? [] : _a;\n getNeighbors(currentNode, edges, 'target').forEach(function (nextNode) {\n if (callbacks.allowTraversal({\n previous: previousNode,\n current: currentNode,\n next: nextNode\n })) {\n depthFirstSearchRecursive(graphData, nextNode, currentNode, callbacks);\n }\n });\n callbacks.leave({\n current: currentNode,\n previous: previousNode\n });\n}\n/**\n * 深度优先遍历图\n * @param data GraphData 图数据\n * @param startNodeId 开始遍历的节点的 ID\n * @param originalCallbacks 回调\n */\n\n\nexport default function depthFirstSearch(graphData, startNodeId, callbacks) {\n depthFirstSearchRecursive(graphData, startNodeId, '', initCallbacks(callbacks));\n}","import dfs from './dfs';\nimport getConnectedComponents, { detectStrongConnectComponents } from './connected-component';\nimport { getNeighbors } from './util';\n\nvar detectDirectedCycle = function detectDirectedCycle(graphData) {\n var cycle = null;\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a;\n var dfsParentMap = {}; // 所有没有被访问的节点集合\n\n var unvisitedSet = {}; // 正在被访问的节点集合\n\n var visitingSet = {}; // 所有已经被访问过的节点集合\n\n var visitedSet = {}; // 初始化 unvisitedSet\n\n nodes.forEach(function (node) {\n unvisitedSet[node.id] = node;\n });\n var callbacks = {\n enter: function enter(_a) {\n var currentNode = _a.current,\n previousNode = _a.previous;\n\n if (visitingSet[currentNode]) {\n // 如果当前节点正在访问中,则说明检测到环路了\n cycle = {};\n var currentCycleNode = currentNode;\n var previousCycleNode = previousNode;\n\n while (previousCycleNode !== currentNode) {\n cycle[currentCycleNode] = previousCycleNode;\n currentCycleNode = previousCycleNode;\n previousCycleNode = dfsParentMap[previousCycleNode];\n }\n\n cycle[currentCycleNode] = previousCycleNode;\n } else {\n // 如果不存在正在访问集合中,则将其放入正在访问集合,并从未访问集合中删除\n visitingSet[currentNode] = currentNode;\n delete unvisitedSet[currentNode]; // 更新 DSF parents 列表\n\n dfsParentMap[currentNode] = previousNode;\n }\n },\n leave: function leave(_a) {\n var currentNode = _a.current; // 如果所有的节点的子节点都已经访问过了,则从正在访问集合中删除掉,并将其移入到已访问集合中,\n // 同时也意味着当前节点的所有邻居节点都被访问过了\n\n visitedSet[currentNode] = currentNode;\n delete visitingSet[currentNode];\n },\n allowTraversal: function allowTraversal(_a) {\n var nextNode = _a.next; // 如果检测到环路则需要终止所有进一步的遍历,否则会导致无限循环遍历\n\n if (cycle) {\n return false;\n } // 仅允许遍历没有访问的节点,visitedSet 中的都已经访问过了\n\n\n return !visitedSet[nextNode];\n }\n }; // 开始遍历节点\n\n while (Object.keys(unvisitedSet).length) {\n // 从第一个节点开始进行 DFS 遍历\n var firsetUnVisitedKey = Object.keys(unvisitedSet)[0];\n dfs(graphData, firsetUnVisitedKey, callbacks);\n }\n\n return cycle;\n};\n/**\n * 检测无向图中的所有Base cycles\n * refer: https://www.codeproject.com/Articles/1158232/Enumerating-All-Cycles-in-an-Undirected-Graph\n * @param graph\n * @param nodeIds 节点 ID 的数组\n * @param include 包含或排除指定的节点\n * @return [{[key: string]: INode}] 返回一组base cycles\n */\n\n\nexport var detectAllUndirectedCycle = function detectAllUndirectedCycle(graphData, nodeIds, include) {\n var _a, _b;\n\n if (include === void 0) {\n include = true;\n }\n\n var allCycles = [];\n var components = getConnectedComponents(graphData, false); // loop through all connected components\n\n for (var _i = 0, components_1 = components; _i < components_1.length; _i++) {\n var component = components_1[_i];\n if (!component.length) continue;\n var root = component[0];\n var rootId = root.id;\n var stack = [root];\n var parent_1 = (_a = {}, _a[rootId] = root, _a);\n var used = (_b = {}, _b[rootId] = new Set(), _b); // walk a spanning tree to find cycles\n\n while (stack.length > 0) {\n var curNode = stack.pop();\n var curNodeId = curNode.id;\n var neighbors = getNeighbors(curNodeId, graphData.edges);\n\n var _loop_1 = function _loop_1(i) {\n var _c;\n\n var neighborId = neighbors[i];\n var neighbor = graphData.nodes.find(function (node) {\n return node.id === neighborId;\n }); // const neighborId = neighbor.get('id');\n\n if (neighborId === curNodeId) {\n // 自环\n allCycles.push((_c = {}, _c[neighborId] = curNode, _c));\n } else if (!(neighborId in used)) {\n // visit a new node\n parent_1[neighborId] = curNode;\n stack.push(neighbor);\n used[neighborId] = new Set([curNode]);\n } else if (!used[curNodeId].has(neighbor)) {\n // a cycle found\n var cycleValid = true;\n var cyclePath = [neighbor, curNode];\n var p = parent_1[curNodeId];\n\n while (used[neighborId].size && !used[neighborId].has(p)) {\n cyclePath.push(p);\n if (p === parent_1[p.id]) break;else p = parent_1[p.id];\n }\n\n cyclePath.push(p);\n\n if (nodeIds && include) {\n // 如果有指定包含的节点\n cycleValid = false;\n\n if (cyclePath.findIndex(function (node) {\n return nodeIds.indexOf(node.id) > -1;\n }) > -1) {\n cycleValid = true;\n }\n } else if (nodeIds && !include) {\n // 如果有指定不包含的节点\n if (cyclePath.findIndex(function (node) {\n return nodeIds.indexOf(node.id) > -1;\n }) > -1) {\n cycleValid = false;\n }\n } // 把 node list 形式转换为 cycle 的格式\n\n\n if (cycleValid) {\n var cycle = {};\n\n for (var index = 1; index < cyclePath.length; index += 1) {\n cycle[cyclePath[index - 1].id] = cyclePath[index];\n }\n\n if (cyclePath.length) {\n cycle[cyclePath[cyclePath.length - 1].id] = cyclePath[0];\n }\n\n allCycles.push(cycle);\n }\n\n used[neighborId].add(curNode);\n }\n };\n\n for (var i = 0; i < neighbors.length; i += 1) {\n _loop_1(i);\n }\n }\n }\n\n return allCycles;\n};\n/**\n * Johnson's algorithm, 时间复杂度 O((V + E)(C + 1))$ and space bounded by O(V + E)\n * refer: https://www.cs.tufts.edu/comp/150GA/homeworks/hw1/Johnson%2075.PDF\n * refer: https://networkx.github.io/documentation/stable/_modules/networkx/algorithms/cycles.html#simple_cycles\n * @param graph\n * @param nodeIds 节点 ID 的数组\n * @param include 包含或排除指定的节点\n * @return [{[key: string]: INode}] 返回所有的 simple cycles\n */\n\nexport var detectAllDirectedCycle = function detectAllDirectedCycle(graphData, nodeIds, include) {\n if (include === void 0) {\n include = true;\n }\n\n var path = []; // stack of nodes in current path\n\n var blocked = new Set();\n var B = []; // remember portions of the graph that yield no elementary circuit\n\n var allCycles = [];\n var idx2Node = {};\n var node2Idx = {}; // 辅助函数: unblock all blocked nodes\n\n var unblock = function unblock(thisNode) {\n var stack = [thisNode];\n\n while (stack.length > 0) {\n var node = stack.pop();\n\n if (blocked.has(node)) {\n blocked.delete(node);\n B[node.id].forEach(function (n) {\n stack.push(n);\n });\n B[node.id].clear();\n }\n }\n };\n\n var circuit = function circuit(node, start, adjList) {\n var closed = false; // whether a path is closed\n\n if (nodeIds && include === false && nodeIds.indexOf(node.id) > -1) return closed;\n path.push(node);\n blocked.add(node);\n var neighbors = adjList[node.id];\n\n for (var i = 0; i < neighbors.length; i += 1) {\n var neighbor = idx2Node[neighbors[i]];\n\n if (neighbor === start) {\n var cycle = {};\n\n for (var index = 1; index < path.length; index += 1) {\n cycle[path[index - 1].id] = path[index];\n }\n\n if (path.length) {\n cycle[path[path.length - 1].id] = path[0];\n }\n\n allCycles.push(cycle);\n closed = true;\n } else if (!blocked.has(neighbor)) {\n if (circuit(neighbor, start, adjList)) {\n closed = true;\n }\n }\n }\n\n if (closed) {\n unblock(node);\n } else {\n for (var i = 0; i < neighbors.length; i += 1) {\n var neighbor = idx2Node[neighbors[i]];\n\n if (!B[neighbor.id].has(node)) {\n B[neighbor.id].add(node);\n }\n }\n }\n\n path.pop();\n return closed;\n };\n\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a; // Johnson's algorithm 要求给节点赋顺序,先按节点在数组中的顺序\n\n for (var i = 0; i < nodes.length; i += 1) {\n var node = nodes[i];\n var nodeId = node.id;\n node2Idx[nodeId] = i;\n idx2Node[i] = node;\n } // 如果有指定包含的节点,则把指定节点排序在前,以便提早结束搜索\n\n\n if (nodeIds && include) {\n var _loop_2 = function _loop_2(i) {\n var nodeId = nodeIds[i];\n node2Idx[nodes[i].id] = node2Idx[nodeId];\n node2Idx[nodeId] = 0;\n idx2Node[0] = nodes.find(function (node) {\n return node.id === nodeId;\n });\n idx2Node[node2Idx[nodes[i].id]] = nodes[i];\n };\n\n for (var i = 0; i < nodeIds.length; i++) {\n _loop_2(i);\n }\n } // 返回 节点顺序 >= nodeOrder 的强连通分量的adjList\n\n\n var getMinComponentAdj = function getMinComponentAdj(components) {\n var _a;\n\n var minCompIdx;\n var minIdx = Infinity; // Find least component and the lowest node\n\n for (var i = 0; i < components.length; i += 1) {\n var comp = components[i];\n\n for (var j = 0; j < comp.length; j++) {\n var nodeIdx_1 = node2Idx[comp[j].id];\n\n if (nodeIdx_1 < minIdx) {\n minIdx = nodeIdx_1;\n minCompIdx = i;\n }\n }\n }\n\n var component = components[minCompIdx];\n var adjList = [];\n\n for (var i = 0; i < component.length; i += 1) {\n var node = component[i];\n adjList[node.id] = [];\n\n for (var _i = 0, _b = getNeighbors(node.id, graphData.edges, 'target').filter(function (n) {\n return component.map(function (c) {\n return c.id;\n }).indexOf(n) > -1;\n }); _i < _b.length; _i++) {\n var neighbor = _b[_i]; // 对自环情况 (点连向自身) 特殊处理:记录自环,但不加入adjList\n\n if (neighbor === node.id && !(include === false && nodeIds.indexOf(node.id) > -1)) {\n allCycles.push((_a = {}, _a[node.id] = node, _a));\n } else {\n adjList[node.id].push(node2Idx[neighbor]);\n }\n }\n }\n\n return {\n component: component,\n adjList: adjList,\n minIdx: minIdx\n };\n };\n\n var nodeIdx = 0;\n\n while (nodeIdx < nodes.length) {\n var subgraphNodes = nodes.filter(function (n) {\n return node2Idx[n.id] >= nodeIdx;\n });\n var sccs = detectStrongConnectComponents({\n nodes: subgraphNodes,\n edges: graphData.edges\n }).filter(function (component) {\n return component.length > 1;\n });\n if (sccs.length === 0) break;\n var scc = getMinComponentAdj(sccs);\n var minIdx = scc.minIdx,\n adjList = scc.adjList,\n component = scc.component;\n\n if (component.length > 1) {\n component.forEach(function (node) {\n B[node.id] = new Set();\n });\n var startNode = idx2Node[minIdx]; // startNode 不在指定要包含的节点中,提前结束搜索\n\n if (nodeIds && include && nodeIds.indexOf(startNode.id) === -1) return allCycles;\n circuit(startNode, startNode, adjList);\n nodeIdx = minIdx + 1;\n } else {\n break;\n }\n }\n\n return allCycles;\n};\n/**\n * 查找图中所有满足要求的圈\n * @param graph\n * @param directed 是否为有向图\n * @param nodeIds 节点 ID 的数组,若不指定,则返回图中所有的圈\n * @param include 包含或排除指定的节点\n * @return [{[key: string]: Node}] 包含所有环的数组,每个环用一个Object表示,其中key为节点id,value为该节点在环中指向的下一个节点\n */\n\nexport var detectAllCycles = function detectAllCycles(graphData, directed, nodeIds, include) {\n if (include === void 0) {\n include = true;\n }\n\n if (directed) return detectAllDirectedCycle(graphData, nodeIds, include);\n return detectAllUndirectedCycle(graphData, nodeIds, include);\n};\nexport default detectDirectedCycle;","import { __spreadArray } from \"tslib\";\nimport { isArray } from '@antv/util';\nimport { getOutEdgesNodeId, getEdgesByNodeId } from './util';\n\nvar minVertex = function minVertex(D, nodes, marks) {\n // 找出最小的点\n var minDis = Infinity;\n var minNode;\n\n for (var i = 0; i < nodes.length; i++) {\n var nodeId = nodes[i].id;\n\n if (!marks[nodeId] && D[nodeId] <= minDis) {\n minDis = D[nodeId];\n minNode = nodes[i];\n }\n }\n\n return minNode;\n};\n\nvar dijkstra = function dijkstra(graphData, source, directed, weightPropertyName) {\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var nodeIds = [];\n var marks = {};\n var D = {};\n var prevs = {}; // key: 顶点, value: 顶点的前驱点数组(可能有多条等长的最短路径)\n\n nodes.forEach(function (node, i) {\n var id = node.id;\n nodeIds.push(id);\n D[id] = Infinity;\n if (id === source) D[id] = 0;\n });\n var nodeNum = nodes.length;\n\n var _loop_1 = function _loop_1(i) {\n // Process the vertices\n var minNode = minVertex(D, nodes, marks);\n var minNodeId = minNode.id;\n marks[minNodeId] = true;\n if (D[minNodeId] === Infinity) return \"continue\"; // Unreachable vertices cannot be the intermediate point\n\n var relatedEdges = [];\n if (directed) relatedEdges = getOutEdgesNodeId(minNodeId, edges);else relatedEdges = getEdgesByNodeId(minNodeId, edges);\n relatedEdges.forEach(function (edge) {\n var edgeTarget = edge.target;\n var edgeSource = edge.source;\n var w = edgeTarget === minNodeId ? edgeSource : edgeTarget;\n var weight = weightPropertyName && edge[weightPropertyName] ? edge[weightPropertyName] : 1;\n\n if (D[w] > D[minNode.id] + weight) {\n D[w] = D[minNode.id] + weight;\n prevs[w] = [minNode.id];\n } else if (D[w] === D[minNode.id] + weight) {\n prevs[w].push(minNode.id);\n }\n });\n };\n\n for (var i = 0; i < nodeNum; i++) {\n _loop_1(i);\n }\n\n prevs[source] = [source]; // 每个节点存可能存在多条最短路径\n\n var paths = {};\n\n for (var target in D) {\n if (D[target] !== Infinity) {\n findAllPaths(source, target, prevs, paths);\n }\n } // 兼容之前单路径\n\n\n var path = {};\n\n for (var target in paths) {\n path[target] = paths[target][0];\n }\n\n return {\n length: D,\n path: path,\n allPath: paths\n };\n};\n\nexport default dijkstra;\n\nfunction findAllPaths(source, target, prevs, foundPaths) {\n if (source === target) {\n return [source];\n }\n\n if (foundPaths[target]) {\n return foundPaths[target];\n }\n\n var paths = [];\n\n for (var _i = 0, _a = prevs[target]; _i < _a.length; _i++) {\n var prev = _a[_i];\n var prevPaths = findAllPaths(source, prev, prevs, foundPaths);\n if (!prevPaths) return;\n\n for (var _b = 0, prevPaths_1 = prevPaths; _b < prevPaths_1.length; _b++) {\n var prePath = prevPaths_1[_b];\n if (isArray(prePath)) paths.push(__spreadArray(__spreadArray([], prePath), [target]));else paths.push([prePath, target]);\n }\n }\n\n foundPaths[target] = paths;\n return foundPaths[target];\n}","import dijkstra from './dijkstra';\nimport { getNeighbors } from './util';\nexport var findShortestPath = function findShortestPath(graphData, start, end, directed, weightPropertyName) {\n var _a = dijkstra(graphData, start, directed, weightPropertyName),\n length = _a.length,\n path = _a.path,\n allPath = _a.allPath;\n\n return {\n length: length[end],\n path: path[end],\n allPath: allPath[end]\n };\n};\nexport var findAllPath = function findAllPath(graphData, start, end, directed) {\n var _a;\n\n if (start === end) return [[start]];\n var _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var visited = [start];\n var isVisited = (_a = {}, _a[start] = true, _a);\n var stack = []; // 辅助栈,用于存储访问过的节点的邻居节点\n\n var allPath = [];\n var neighbors = directed ? getNeighbors(start, edges, 'target') : getNeighbors(start, edges);\n stack.push(neighbors);\n\n while (visited.length > 0 && stack.length > 0) {\n var children = stack[stack.length - 1];\n\n if (children.length) {\n var child = children.shift();\n\n if (child) {\n visited.push(child);\n isVisited[child] = true;\n neighbors = directed ? getNeighbors(child, edges, 'target') : getNeighbors(child, edges);\n stack.push(neighbors.filter(function (neighbor) {\n return !isVisited[neighbor];\n }));\n }\n } else {\n var node = visited.pop();\n isVisited[node] = false;\n stack.pop();\n continue;\n }\n\n if (visited[visited.length - 1] === end) {\n var path = visited.map(function (node) {\n return node;\n });\n allPath.push(path);\n var node = visited.pop();\n isVisited[node] = false;\n stack.pop();\n }\n }\n\n return allPath;\n};","import getAdjMatrix from \"./adjacent-matrix\";\n\nvar floydWarshall = function floydWarshall(graphData, directed) {\n var adjacentMatrix = getAdjMatrix(graphData, directed);\n var dist = [];\n var size = adjacentMatrix.length;\n\n for (var i = 0; i < size; i += 1) {\n dist[i] = [];\n\n for (var j = 0; j < size; j += 1) {\n if (i === j) {\n dist[i][j] = 0;\n } else if (adjacentMatrix[i][j] === 0 || !adjacentMatrix[i][j]) {\n dist[i][j] = Infinity;\n } else {\n dist[i][j] = adjacentMatrix[i][j];\n }\n }\n } // floyd\n\n\n for (var k = 0; k < size; k += 1) {\n for (var i = 0; i < size; i += 1) {\n for (var j = 0; j < size; j += 1) {\n if (dist[i][j] > dist[i][k] + dist[k][j]) {\n dist[i][j] = dist[i][k] + dist[k][j];\n }\n }\n }\n }\n\n return dist;\n};\n\nexport default floydWarshall;","import getAdjMatrix from './adjacent-matrix';\nimport { uniqueId } from './util';\n/**\n * 标签传播算法\n * @param graphData 图数据\n * @param directed 是否有向图,默认为 false\n * @param weightPropertyName 权重的属性字段\n * @param maxIteration 最大迭代次数\n */\n\nvar labelPropagation = function labelPropagation(graphData, directed, weightPropertyName, maxIteration) {\n if (directed === void 0) {\n directed = false;\n }\n\n if (weightPropertyName === void 0) {\n weightPropertyName = 'weight';\n }\n\n if (maxIteration === void 0) {\n maxIteration = 1000;\n } // the origin data\n\n\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var clusters = {};\n var nodeMap = {}; // init the clusters and nodeMap\n\n nodes.forEach(function (node, i) {\n var cid = uniqueId();\n node.clusterId = cid;\n clusters[cid] = {\n id: cid,\n nodes: [node]\n };\n nodeMap[node.id] = {\n node: node,\n idx: i\n };\n }); // the adjacent matrix of calNodes inside clusters\n\n var adjMatrix = getAdjMatrix(graphData, directed); // the sum of each row in adjacent matrix\n\n var ks = [];\n /**\n * neighbor nodes (id for key and weight for value) for each node\n * neighbors = {\n * id(node_id): { id(neighbor_1_id): weight(weight of the edge), id(neighbor_2_id): weight(weight of the edge), ... },\n * ...\n * }\n */\n\n var neighbors = {};\n adjMatrix.forEach(function (row, i) {\n var k = 0;\n var iid = nodes[i].id;\n neighbors[iid] = {};\n row.forEach(function (entry, j) {\n if (!entry) return;\n k += entry;\n var jid = nodes[j].id;\n neighbors[iid][jid] = entry;\n });\n ks.push(k);\n });\n var iter = 0;\n\n var _loop_1 = function _loop_1() {\n var changed = false;\n nodes.forEach(function (node) {\n var neighborClusters = {};\n Object.keys(neighbors[node.id]).forEach(function (neighborId) {\n var neighborWeight = neighbors[node.id][neighborId];\n var neighborNode = nodeMap[neighborId].node;\n var neighborClusterId = neighborNode.clusterId;\n if (!neighborClusters[neighborClusterId]) neighborClusters[neighborClusterId] = 0;\n neighborClusters[neighborClusterId] += neighborWeight;\n }); // find the cluster with max weight\n\n var maxWeight = -Infinity;\n var bestClusterIds = [];\n Object.keys(neighborClusters).forEach(function (clusterId) {\n if (maxWeight < neighborClusters[clusterId]) {\n maxWeight = neighborClusters[clusterId];\n bestClusterIds = [clusterId];\n } else if (maxWeight === neighborClusters[clusterId]) {\n bestClusterIds.push(clusterId);\n }\n });\n if (bestClusterIds.length === 1 && bestClusterIds[0] === node.clusterId) return;\n var selfClusterIdx = bestClusterIds.indexOf(node.clusterId);\n if (selfClusterIdx >= 0) bestClusterIds.splice(selfClusterIdx, 1);\n\n if (bestClusterIds && bestClusterIds.length) {\n changed = true; // remove from origin cluster\n\n var selfCluster = clusters[node.clusterId];\n var nodeInSelfClusterIdx = selfCluster.nodes.indexOf(node);\n selfCluster.nodes.splice(nodeInSelfClusterIdx, 1); // move the node to the best cluster\n\n var randomIdx = Math.floor(Math.random() * bestClusterIds.length);\n var bestCluster = clusters[bestClusterIds[randomIdx]];\n bestCluster.nodes.push(node);\n node.clusterId = bestCluster.id;\n }\n });\n if (!changed) return \"break\";\n iter++;\n };\n\n while (iter < maxIteration) {\n var state_1 = _loop_1();\n\n if (state_1 === \"break\") break;\n } // delete the empty clusters\n\n\n Object.keys(clusters).forEach(function (clusterId) {\n var cluster = clusters[clusterId];\n\n if (!cluster.nodes || !cluster.nodes.length) {\n delete clusters[clusterId];\n }\n }); // get the cluster edges\n\n var clusterEdges = [];\n var clusterEdgeMap = {};\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var weight = edge[weightPropertyName] || 1;\n var sourceClusterId = nodeMap[source].node.clusterId;\n var targetClusterId = nodeMap[target].node.clusterId;\n var newEdgeId = sourceClusterId + \"---\" + targetClusterId;\n\n if (clusterEdgeMap[newEdgeId]) {\n clusterEdgeMap[newEdgeId].weight += weight;\n clusterEdgeMap[newEdgeId].count++;\n } else {\n var newEdge = {\n source: sourceClusterId,\n target: targetClusterId,\n weight: weight,\n count: 1\n };\n clusterEdgeMap[newEdgeId] = newEdge;\n clusterEdges.push(newEdge);\n }\n });\n var clustersArray = [];\n Object.keys(clusters).forEach(function (clusterId) {\n clustersArray.push(clusters[clusterId]);\n });\n return {\n clusters: clustersArray,\n clusterEdges: clusterEdges\n };\n};\n\nexport default labelPropagation;","import getAdjMatrix from './adjacent-matrix';\n\nvar getModularity = function getModularity(nodes, adjMatrix, ks, m) {\n var length = adjMatrix.length;\n var param = 2 * m;\n var modularity = 0;\n\n for (var i = 0; i < length; i++) {\n var clusteri = nodes[i].clusterId;\n\n for (var j = 0; j < length; j++) {\n var clusterj = nodes[j].clusterId;\n if (clusteri !== clusterj) continue;\n var entry = adjMatrix[i][j] || 0;\n var ki = ks[i] || 0;\n var kj = ks[j] || 0;\n modularity += entry - ki * kj / param;\n }\n }\n\n modularity *= 1 / param;\n return modularity;\n};\n/**\n * 社区发现 louvain 算法\n * @param graphData 图数据\n * @param directed 是否有向图,默认为 false\n * @param weightPropertyName 权重的属性字段\n * @param threshold\n */\n\n\nvar louvain = function louvain(graphData, directed, weightPropertyName, threshold) {\n if (directed === void 0) {\n directed = false;\n }\n\n if (weightPropertyName === void 0) {\n weightPropertyName = 'weight';\n }\n\n if (threshold === void 0) {\n threshold = 0.0001;\n } // the origin data\n\n\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var uniqueId = 1;\n var clusters = {};\n var nodeMap = {}; // init the clusters and nodeMap\n\n nodes.forEach(function (node, i) {\n var cid = String(uniqueId++);\n node.clusterId = cid;\n clusters[cid] = {\n id: cid,\n nodes: [node]\n };\n nodeMap[node.id] = {\n node: node,\n idx: i\n };\n }); // the adjacent matrix of calNodes inside clusters\n\n var adjMatrix = getAdjMatrix(graphData, directed); // the sum of each row in adjacent matrix\n\n var ks = [];\n /**\n * neighbor nodes (id for key and weight for value) for each node\n * neighbors = {\n * id(node_id): { id(neighbor_1_id): weight(weight of the edge), id(neighbor_2_id): weight(weight of the edge), ... },\n * ...\n * }\n */\n\n var neighbors = {}; // the sum of the weights of all edges in the graph\n\n var m = 0;\n adjMatrix.forEach(function (row, i) {\n var k = 0;\n var iid = nodes[i].id;\n neighbors[iid] = {};\n row.forEach(function (entry, j) {\n if (!entry) return;\n k += entry;\n var jid = nodes[j].id;\n neighbors[iid][jid] = entry;\n m += entry;\n });\n ks.push(k);\n });\n m /= 2;\n var totalModularity = Infinity;\n var previousModularity = Infinity;\n var iter = 0;\n\n while (true) {\n // whether to terminate the iterations\n totalModularity = getModularity(nodes, adjMatrix, ks, m);\n if (Math.abs(totalModularity - previousModularity) < threshold || iter > 100) break;\n previousModularity = totalModularity;\n iter++; // pre compute some values for current clusters\n\n Object.keys(clusters).forEach(function (clusterId) {\n // sum of weights of edges to nodes in cluster\n var sumTot = 0;\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var sourceClusterId = nodeMap[source].node.clusterId;\n var targetClusterId = nodeMap[target].node.clusterId;\n\n if (sourceClusterId === clusterId && targetClusterId !== clusterId || targetClusterId === clusterId && sourceClusterId !== clusterId) {\n sumTot = sumTot + (edge[weightPropertyName] || 1);\n }\n });\n clusters[clusterId].sumTot = sumTot;\n }); // move the nodes to increase the delta modularity\n\n nodes.forEach(function (node, i) {\n var selfCluster = clusters[node.clusterId];\n var bestIncrease = 0;\n var bestCluster;\n var commonParam = ks[i] / (2 * m); // sum of weights of edges from node to nodes in cluster\n\n var kiin = 0;\n var selfClusterNodes = selfCluster.nodes;\n selfClusterNodes.forEach(function (scNode) {\n var scNodeIdx = nodeMap[scNode.id].idx;\n kiin += adjMatrix[i][scNodeIdx] || 0;\n }); // the modurarity for **removing** the node i from the origin cluster of node i\n\n var removeModurarity = kiin - selfCluster.sumTot * commonParam; // the neightbors of the node\n\n var nodeNeighborIds = neighbors[node.id];\n Object.keys(nodeNeighborIds).forEach(function (neighborNodeId) {\n var neighborNode = nodeMap[neighborNodeId].node;\n var neighborClusterId = neighborNode.clusterId; // if the node and the neighbor of node are in the same cluster, reutrn\n\n if (neighborClusterId === node.clusterId) return;\n var neighborCluster = clusters[neighborClusterId];\n var clusterNodes = neighborCluster.nodes; // if the cluster is empty, remove the cluster and return\n\n if (!clusterNodes || !clusterNodes.length) return; // sum of weights of edges from node to nodes in cluster\n\n var neighborClusterKiin = 0;\n clusterNodes.forEach(function (cNode) {\n var cNodeIdx = nodeMap[cNode.id].idx;\n neighborClusterKiin += adjMatrix[i][cNodeIdx] || 0;\n }); // modurarity for **adding** node i into this neighbor cluster\n\n var addModurarity = neighborClusterKiin - neighborCluster.sumTot * commonParam; // the increase modurarity is the difference between addModurarity and removeModurarity\n\n var increase = addModurarity - removeModurarity; // find the best cluster to move node i into\n\n if (increase > bestIncrease) {\n bestIncrease = increase;\n bestCluster = neighborCluster;\n }\n }); // if found a best cluster to move into\n\n if (bestIncrease > 0) {\n bestCluster.nodes.push(node);\n var previousClusterId_1 = node.clusterId;\n node.clusterId = bestCluster.id; // move the node to the best cluster\n\n var nodeInSelfClusterIdx = selfCluster.nodes.indexOf(node); // remove from origin cluster\n\n selfCluster.nodes.splice(nodeInSelfClusterIdx, 1); // update sumTot for clusters\n // sum of weights of edges to nodes in cluster\n\n var neighborClusterSumTot_1 = 0;\n var selfClusterSumTot_1 = 0;\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var sourceClusterId = nodeMap[source].node.clusterId;\n var targetClusterId = nodeMap[target].node.clusterId;\n\n if (sourceClusterId === bestCluster.id && targetClusterId !== bestCluster.id || targetClusterId === bestCluster.id && sourceClusterId !== bestCluster.id) {\n neighborClusterSumTot_1 = neighborClusterSumTot_1 + (edge[weightPropertyName] || 1);\n }\n\n if (sourceClusterId === previousClusterId_1 && targetClusterId !== previousClusterId_1 || targetClusterId === previousClusterId_1 && sourceClusterId !== previousClusterId_1) {\n selfClusterSumTot_1 = selfClusterSumTot_1 + (edge[weightPropertyName] || 1);\n }\n }); // the nodes of the clusters to move into and remove are changed, update their sumTot\n\n bestCluster.sumTot = neighborClusterSumTot_1;\n selfCluster.sumTot = selfClusterSumTot_1;\n }\n });\n } // delete the empty clusters, assign increasing clusterId\n\n\n var newClusterIdMap = {};\n var clusterIdx = 0;\n Object.keys(clusters).forEach(function (clusterId) {\n var cluster = clusters[clusterId];\n\n if (!cluster.nodes || !cluster.nodes.length) {\n delete clusters[clusterId];\n return;\n }\n\n var newId = String(clusterIdx + 1);\n\n if (newId === clusterId) {\n return;\n }\n\n cluster.id = newId;\n cluster.nodes = cluster.nodes.map(function (item) {\n return {\n id: item.id,\n clusterId: newId\n };\n });\n clusters[newId] = cluster;\n newClusterIdMap[clusterId] = newId;\n delete clusters[clusterId];\n clusterIdx++;\n });\n nodes.forEach(function (node) {\n if (node.clusterId && newClusterIdMap[node.clusterId]) node.clusterId = newClusterIdMap[node.clusterId];\n }); // get the cluster edges\n\n var clusterEdges = [];\n var clusterEdgeMap = {};\n edges.forEach(function (edge) {\n var source = edge.source,\n target = edge.target;\n var weight = edge[weightPropertyName] || 1;\n var sourceClusterId = nodeMap[source].node.clusterId;\n var targetClusterId = nodeMap[target].node.clusterId;\n var newEdgeId = sourceClusterId + \"---\" + targetClusterId;\n\n if (clusterEdgeMap[newEdgeId]) {\n clusterEdgeMap[newEdgeId].weight += weight;\n clusterEdgeMap[newEdgeId].count++;\n } else {\n var newEdge = {\n source: sourceClusterId,\n target: targetClusterId,\n weight: weight,\n count: 1\n };\n clusterEdgeMap[newEdgeId] = newEdge;\n clusterEdges.push(newEdge);\n }\n });\n var clustersArray = [];\n Object.keys(clusters).forEach(function (clusterId) {\n clustersArray.push(clusters[clusterId]);\n });\n return {\n clusters: clustersArray,\n clusterEdges: clusterEdges\n };\n};\n\nexport default louvain;","/**\n * 并查集 Disjoint set to support quick union\n */\nvar UnionFind = function () {\n function UnionFind(items) {\n this.count = items.length;\n this.parent = {};\n\n for (var _i = 0, items_1 = items; _i < items_1.length; _i++) {\n var i = items_1[_i];\n this.parent[i] = i;\n }\n } // find the root of the item\n\n\n UnionFind.prototype.find = function (item) {\n while (this.parent[item] !== item) {\n item = this.parent[item];\n }\n\n return item;\n };\n\n UnionFind.prototype.union = function (a, b) {\n var rootA = this.find(a);\n var rootB = this.find(b);\n if (rootA === rootB) return; // make the element with smaller root the parent\n\n if (rootA < rootB) {\n if (this.parent[b] !== b) this.union(this.parent[b], a);\n this.parent[b] = this.parent[a];\n } else {\n if (this.parent[a] !== a) this.union(this.parent[a], b);\n this.parent[a] = this.parent[b];\n }\n }; // whether a and b are connected, i.e. a and b have the same root\n\n\n UnionFind.prototype.connected = function (a, b) {\n return this.find(a) === this.find(b);\n };\n\n return UnionFind;\n}();\n\nexport default UnionFind;","var defaultCompare = function defaultCompare(a, b) {\n return a - b;\n};\n\nvar MinBinaryHeap = function () {\n function MinBinaryHeap(compareFn) {\n if (compareFn === void 0) {\n compareFn = defaultCompare;\n }\n\n this.compareFn = compareFn;\n this.list = [];\n }\n\n MinBinaryHeap.prototype.getLeft = function (index) {\n return 2 * index + 1;\n };\n\n MinBinaryHeap.prototype.getRight = function (index) {\n return 2 * index + 2;\n };\n\n MinBinaryHeap.prototype.getParent = function (index) {\n if (index === 0) {\n return null;\n }\n\n return Math.floor((index - 1) / 2);\n };\n\n MinBinaryHeap.prototype.isEmpty = function () {\n return this.list.length <= 0;\n };\n\n MinBinaryHeap.prototype.top = function () {\n return this.isEmpty() ? undefined : this.list[0];\n };\n\n MinBinaryHeap.prototype.delMin = function () {\n var top = this.top();\n var bottom = this.list.pop();\n\n if (this.list.length > 0) {\n this.list[0] = bottom;\n this.moveDown(0);\n }\n\n return top;\n };\n\n MinBinaryHeap.prototype.insert = function (value) {\n if (value !== null) {\n this.list.push(value);\n var index = this.list.length - 1;\n this.moveUp(index);\n return true;\n }\n\n return false;\n };\n\n MinBinaryHeap.prototype.moveUp = function (index) {\n var parent = this.getParent(index);\n\n while (index && index > 0 && this.compareFn(this.list[parent], this.list[index]) > 0) {\n // swap\n var tmp = this.list[parent];\n this.list[parent] = this.list[index];\n this.list[index] = tmp; // [this.list[index], this.list[parent]] = [this.list[parent], this.list[index]]\n\n index = parent;\n parent = this.getParent(index);\n }\n };\n\n MinBinaryHeap.prototype.moveDown = function (index) {\n var _a;\n\n var element = index;\n var left = this.getLeft(index);\n var right = this.getRight(index);\n var size = this.list.length;\n\n if (left !== null && left < size && this.compareFn(this.list[element], this.list[left]) > 0) {\n element = left;\n } else if (right !== null && right < size && this.compareFn(this.list[element], this.list[right]) > 0) {\n element = right;\n }\n\n if (index !== element) {\n _a = [this.list[element], this.list[index]], this.list[index] = _a[0], this.list[element] = _a[1];\n this.moveDown(element);\n }\n };\n\n return MinBinaryHeap;\n}();\n\nexport default MinBinaryHeap;","import UnionFind from './structs/union-find';\nimport MinBinaryHeap from './structs/binary-heap';\nimport { getEdgesByNodeId } from './util';\n/**\n * Prim algorithm,use priority queue,复杂度 O(E+V*logV), V: 节点数量,E: 边的数量\n * refer: https://en.wikipedia.org/wiki/Prim%27s_algorithm\n * @param graph\n * @param weight 指定用于作为边权重的属性,若不指定,则认为所有边权重一致\n */\n\nvar primMST = function primMST(graphData, weight) {\n var selectedEdges = [];\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n\n if (nodes.length === 0) {\n return selectedEdges;\n } // 从nodes[0]开始\n\n\n var currNode = nodes[0];\n var visited = new Set();\n visited.add(currNode); // 用二叉堆维护距已加入节点的其他节点的边的权值\n\n var compareWeight = function compareWeight(a, b) {\n if (weight) {\n return a.weight - b.weight;\n }\n\n return 0;\n };\n\n var edgeQueue = new MinBinaryHeap(compareWeight);\n getEdgesByNodeId(currNode.id, edges).forEach(function (edge) {\n edgeQueue.insert(edge);\n });\n\n while (!edgeQueue.isEmpty()) {\n // 选取与已加入的结点之间边权最小的结点\n var currEdge = edgeQueue.delMin();\n var source = currEdge.source;\n var target = currEdge.target;\n if (visited.has(source) && visited.has(target)) continue;\n selectedEdges.push(currEdge);\n\n if (!visited.has(source)) {\n visited.add(source);\n getEdgesByNodeId(source, edges).forEach(function (edge) {\n edgeQueue.insert(edge);\n });\n }\n\n if (!visited.has(target)) {\n visited.add(target);\n getEdgesByNodeId(target, edges).forEach(function (edge) {\n edgeQueue.insert(edge);\n });\n }\n }\n\n return selectedEdges;\n};\n/**\n * Kruskal algorithm,复杂度 O(E*logE), E: 边的数量\n * refer: https://en.wikipedia.org/wiki/Kruskal%27s_algorithm\n * @param graph\n * @param weight 指定用于作为边权重的属性,若不指定,则认为所有边权重一致\n * @return IEdge[] 返回构成MST的边的数组\n */\n\n\nvar kruskalMST = function kruskalMST(graphData, weight) {\n var selectedEdges = [];\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n\n if (nodes.length === 0) {\n return selectedEdges;\n } // 若指定weight,则将所有的边按权值从小到大排序\n\n\n var weightEdges = edges.map(function (edge) {\n return edge;\n });\n\n if (weight) {\n weightEdges.sort(function (a, b) {\n return a.weight - b.weight;\n });\n }\n\n var disjointSet = new UnionFind(nodes.map(function (n) {\n return n.id;\n })); // 从权值最小的边开始,如果这条边连接的两个节点于图G中不在同一个连通分量中,则添加这条边\n // 直到遍历完所有点或边\n\n while (weightEdges.length > 0) {\n var curEdge = weightEdges.shift();\n var source = curEdge.source;\n var target = curEdge.target;\n\n if (!disjointSet.connected(source, target)) {\n selectedEdges.push(curEdge);\n disjointSet.union(source, target);\n }\n }\n\n return selectedEdges;\n};\n/**\n * 最小生成树\n * refer: https://en.wikipedia.org/wiki/Kruskal%27s_algorithm\n * @param graph\n * @param weight 指定用于作为边权重的属性,若不指定,则认为所有边权重一致\n * @param algo 'prim' | 'kruskal' 算法类型\n * @return EdgeConfig[] 返回构成MST的边的数组\n */\n\n\nvar minimumSpanningTree = function minimumSpanningTree(graphData, weight, algo) {\n var algos = {\n prim: primMST,\n kruskal: kruskalMST\n };\n if (!algo) return kruskalMST(graphData, weight);\n return algos[algo](graphData, weight);\n};\n\nexport default minimumSpanningTree;","import degree from './degree';\nimport { getNeighbors } from \"./util\";\n/**\n * PageRank https://en.wikipedia.org/wiki/PageRank\n * refer: https://github.com/anvaka/ngraph.pagerank\n * @param graph\n * @param epsilon 判断是否收敛的精度值,默认 0.000001\n * @param linkProb 阻尼系数(dumping factor),指任意时刻,用户访问到某节点后继续访问该节点链接的下一个节点的概率,经验值 0.85\n */\n\nvar pageRank = function pageRank(graphData, epsilon, linkProb) {\n if (typeof epsilon !== 'number') epsilon = 0.000001;\n if (typeof linkProb !== 'number') linkProb = 0.85;\n var distance = 1;\n var leakedRank = 0;\n var maxIterations = 1000;\n var _a = graphData.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = graphData.edges,\n edges = _b === void 0 ? [] : _b;\n var nodesCount = nodes.length;\n var currentRank;\n var curRanks = {};\n var prevRanks = {}; // Initialize pageranks 初始化\n\n for (var j = 0; j < nodesCount; ++j) {\n var node = nodes[j];\n var nodeId = node.id;\n curRanks[nodeId] = 1 / nodesCount;\n prevRanks[nodeId] = 1 / nodesCount;\n }\n\n var nodeDegree = degree(graphData);\n\n while (maxIterations > 0 && distance > epsilon) {\n leakedRank = 0;\n\n for (var j = 0; j < nodesCount; ++j) {\n var node = nodes[j];\n var nodeId = node.id;\n currentRank = 0;\n\n if (nodeDegree[node.id].inDegree === 0) {\n curRanks[nodeId] = 0;\n } else {\n var neighbors = getNeighbors(nodeId, edges, 'source');\n\n for (var i = 0; i < neighbors.length; ++i) {\n var neighbor = neighbors[i];\n var outDegree = nodeDegree[neighbor].outDegree;\n if (outDegree > 0) currentRank += prevRanks[neighbor] / outDegree;\n }\n\n curRanks[nodeId] = linkProb * currentRank;\n leakedRank += curRanks[nodeId];\n }\n }\n\n leakedRank = (1 - leakedRank) / nodesCount;\n distance = 0;\n\n for (var j = 0; j < nodesCount; ++j) {\n var node = nodes[j];\n var nodeId = node.id;\n currentRank = curRanks[nodeId] + leakedRank;\n distance += Math.abs(currentRank - prevRanks[nodeId]);\n prevRanks[nodeId] = currentRank;\n }\n\n maxIterations -= 1;\n }\n\n return prevRanks;\n};\n\nexport default pageRank;","export var VACANT_EDGE_ID = -1;\nexport var VACANT_NODE_ID = -1;\nexport var VACANT_EDGE_LABEL = \"-1\";\nexport var VACANT_NODE_LABEL = \"-1\";\nexport var VACANT_GRAPH_ID = -1;\nexport var AUTO_EDGE_ID = \"-1\";\n\nvar Edge = function () {\n function Edge(id, from, to, label) {\n if (id === void 0) {\n id = VACANT_EDGE_ID;\n }\n\n if (from === void 0) {\n from = VACANT_NODE_ID;\n }\n\n if (to === void 0) {\n to = VACANT_NODE_ID;\n }\n\n if (label === void 0) {\n label = VACANT_EDGE_LABEL;\n }\n\n this.id = id;\n this.from = from;\n this.to = to;\n this.label = label;\n }\n\n return Edge;\n}();\n\nexport { Edge };\n\nvar Node = function () {\n function Node(id, label) {\n if (id === void 0) {\n id = VACANT_NODE_ID;\n }\n\n if (label === void 0) {\n label = VACANT_NODE_LABEL;\n }\n\n this.id = id;\n this.label = label;\n this.edges = [];\n this.edgeMap = {};\n }\n\n Node.prototype.addEdge = function (edge) {\n this.edges.push(edge);\n this.edgeMap[edge.id] = edge;\n };\n\n return Node;\n}();\n\nexport { Node };\n\nvar Graph = function () {\n function Graph(id, edgeIdAutoIncrease, directed) {\n if (id === void 0) {\n id = VACANT_NODE_ID;\n }\n\n if (edgeIdAutoIncrease === void 0) {\n edgeIdAutoIncrease = true;\n }\n\n if (directed === void 0) {\n directed = false;\n }\n\n this.id = id;\n this.edgeIdAutoIncrease = edgeIdAutoIncrease;\n this.edges = [];\n this.nodes = [];\n this.nodeMap = {};\n this.edgeMap = {};\n this.nodeLabelMap = {};\n this.edgeLabelMap = {};\n this.counter = 0;\n this.directed = directed;\n }\n\n Graph.prototype.getNodeNum = function () {\n return this.nodes.length;\n };\n\n Graph.prototype.addNode = function (id, label) {\n if (this.nodeMap[id]) return;\n var node = new Node(id, label);\n this.nodes.push(node);\n this.nodeMap[id] = node;\n if (!this.nodeLabelMap[label]) this.nodeLabelMap[label] = [];\n this.nodeLabelMap[label].push(id);\n };\n\n Graph.prototype.addEdge = function (id, from, to, label) {\n if (this.edgeIdAutoIncrease || id === undefined) id = this.counter++;\n if (this.nodeMap[from] && this.nodeMap[to] && this.nodeMap[to].edgeMap[id]) return;\n var edge = new Edge(id, from, to, label);\n this.edges.push(edge);\n this.edgeMap[id] = edge;\n this.nodeMap[from].addEdge(edge);\n if (!this.edgeLabelMap[label]) this.edgeLabelMap[label] = [];\n this.edgeLabelMap[label].push(edge);\n\n if (!this.directed) {\n var rEdge = new Edge(id, to, from, label);\n this.nodeMap[to].addEdge(rEdge);\n this.edgeLabelMap[label].push(rEdge);\n }\n };\n\n return Graph;\n}();\n\nexport { Graph };","import { clone } from \"@antv/util\";\nimport { Graph, VACANT_NODE_LABEL, VACANT_GRAPH_ID, VACANT_EDGE_LABEL } from \"./struct\";\n\nvar DFSedge = function () {\n function DFSedge(fromNode, toNode, fromNodeLabel, edgeLabel, toNodeLabel) {\n this.fromNode = fromNode;\n this.toNode = toNode;\n this.nodeEdgeNodeLabel = {\n nodeLabel1: fromNodeLabel || VACANT_NODE_LABEL,\n edgeLabel: edgeLabel || VACANT_EDGE_LABEL,\n nodeLabel2: toNodeLabel || VACANT_NODE_LABEL\n };\n }\n\n DFSedge.prototype.equalTo = function (other) {\n return this.fromNode === other.formNode && this.toNode === other.toNode && this.nodeEdgeNodeLabel === other.nodeEdgeNodeLabel;\n };\n\n DFSedge.prototype.notEqualTo = function (other) {\n return !this.equalTo(other);\n };\n\n return DFSedge;\n}(); // DFScode 是 DESedge 的数组\n\n\nvar DFScode = function () {\n function DFScode() {\n this.rmpath = [];\n this.dfsEdgeList = [];\n }\n\n DFScode.prototype.equalTo = function (other) {\n var aLength = this.dfsEdgeList.length;\n var bLength = other.length;\n if (aLength !== bLength) return false;\n\n for (var i = 0; i < aLength; i++) {\n if (this.dfsEdgeList[i] !== other[i]) return false;\n }\n\n return true;\n };\n\n DFScode.prototype.notEqualTo = function (other) {\n return !this.equalTo(other);\n };\n /** 增加一条 edge 到 DFScode */\n\n\n DFScode.prototype.pushBack = function (fromNode, toNode, fromNodeLabel, edgeLabel, toNodeLabel) {\n this.dfsEdgeList.push(new DFSedge(fromNode, toNode, fromNodeLabel, edgeLabel, toNodeLabel));\n return this.dfsEdgeList;\n };\n /** 根据 dfs 构建图 */\n\n\n DFScode.prototype.toGraph = function (graphId, directed) {\n if (graphId === void 0) {\n graphId = VACANT_GRAPH_ID;\n }\n\n if (directed === void 0) {\n directed = false;\n }\n\n var graph = new Graph(graphId, true, directed);\n this.dfsEdgeList.forEach(function (dfsEdge) {\n var fromNodeId = dfsEdge.fromNode;\n var toNodeId = dfsEdge.toNode;\n var _a = dfsEdge.nodeEdgeNodeLabel,\n nodeLabel1 = _a.nodeLabel1,\n edgeLabel = _a.edgeLabel,\n nodeLabel2 = _a.nodeLabel2;\n if (nodeLabel1 !== VACANT_NODE_LABEL) graph.addNode(fromNodeId, nodeLabel1);\n if (nodeLabel2 !== VACANT_NODE_LABEL) graph.addNode(toNodeId, nodeLabel2);\n graph.addEdge(undefined, fromNodeId, toNodeId, edgeLabel);\n });\n return graph;\n }; // 建立 rightmost path\n\n\n DFScode.prototype.buildRmpath = function () {\n this.rmpath = [];\n var oldFrom = undefined;\n var selfLength = this.dfsEdgeList.length;\n\n for (var i = selfLength - 1; i >= 0; i--) {\n var dfsEdge = this.dfsEdgeList[i];\n var fromNodeIdx = dfsEdge.fromNode;\n var toNodeIdx = dfsEdge.toNode;\n\n if (fromNodeIdx < toNodeIdx && (oldFrom === undefined || toNodeIdx === oldFrom)) {\n this.rmpath.push(i);\n oldFrom = fromNodeIdx;\n }\n }\n\n return this.rmpath;\n };\n\n DFScode.prototype.getNodeNum = function () {\n var nodeMap = {};\n this.dfsEdgeList.forEach(function (dfsEdge) {\n if (!nodeMap[dfsEdge.fromNode]) nodeMap[dfsEdge.fromNode] = true;\n if (!nodeMap[dfsEdge.toNode]) nodeMap[dfsEdge.toNode] = true;\n });\n return Object.keys(nodeMap).length;\n };\n\n return DFScode;\n}();\n\nvar History = function () {\n function History(pdfs) {\n this.his = {};\n this.nodesUsed = {};\n this.edgesUsed = {};\n this.edges = [];\n if (!pdfs) return;\n\n while (pdfs) {\n var e = pdfs.edge;\n this.edges.push(e);\n this.nodesUsed[e.from] = 1;\n this.nodesUsed[e.to] = 1;\n this.edgesUsed[e.id] = 1;\n pdfs = pdfs.preNode;\n } // 倒序\n\n\n this.edges = this.edges.reverse();\n }\n\n History.prototype.hasNode = function (node) {\n return this.nodesUsed[node.id] === 1;\n };\n\n History.prototype.hasEdge = function (edge) {\n return this.edgesUsed[edge.id] === 1;\n };\n\n return History;\n}();\n\nvar GSpan = function () {\n function GSpan(_a) {\n var graphs = _a.graphs,\n _b = _a.minSupport,\n minSupport = _b === void 0 ? 2 : _b,\n _c = _a.minNodeNum,\n minNodeNum = _c === void 0 ? 1 : _c,\n _d = _a.maxNodeNum,\n maxNodeNum = _d === void 0 ? 4 : _d,\n _e = _a.top,\n top = _e === void 0 ? 10 : _e,\n _f = _a.directed,\n directed = _f === void 0 ? false : _f,\n _g = _a.verbose,\n verbose = _g === void 0 ? false : _g; // -------- 第零步,初始化-------\n\n this.graphs = graphs;\n this.dfsCode = new DFScode();\n this.support = 0;\n this.frequentSize1Subgraphs = [];\n this.frequentSubgraphs = [];\n this.minSupport = minSupport;\n this.top = top;\n this.directed = directed;\n this.counter = 0; // TODO? timestamp = {}\n\n this.maxNodeNum = maxNodeNum;\n this.minNodeNum = minNodeNum;\n this.verbose = verbose;\n if (this.maxNodeNum < this.minNodeNum) this.maxNodeNum = this.minNodeNum;\n this.reportDF = []; // matrix\n } // Line 352\n\n\n GSpan.prototype.findForwardRootEdges = function (graph, fromNode) {\n var _this = this;\n\n var result = [];\n var nodeMap = graph.nodeMap;\n fromNode.edges.forEach(function (edge) {\n if (_this.directed || fromNode.label <= nodeMap[edge.to].label) result.push(edge);\n });\n return result;\n };\n\n GSpan.prototype.findBackwardEdge = function (graph, edge1, edge2, history) {\n if (!this.directed && edge1 === edge2) return null;\n var nodeMap = graph.nodeMap;\n var edge2To = nodeMap[edge2.to];\n var edge2ToEdges = edge2To.edges;\n var edgeLength = edge2ToEdges.length;\n\n for (var i = 0; i < edgeLength; i++) {\n var edge = edge2ToEdges[i];\n if (history.hasEdge(edge) || edge.to !== edge1.from) continue;\n\n if (!this.directed) {\n if (edge1.label < edge.label || edge1.label === edge.label && nodeMap[edge1.to].label <= nodeMap[edge2.to].label) {\n return edge;\n }\n } else {\n if (nodeMap[edge1.from].label < nodeMap[edge2.to].label || nodeMap[edge1.from].label === nodeMap[edge2.to].label && edge1.label <= edge.label) {\n return edge;\n }\n }\n }\n\n return null;\n };\n\n GSpan.prototype.findForwardPureEdges = function (graph, rightmostEdge, minNodeLabel, history) {\n var result = [];\n var rightmostEdgeToId = rightmostEdge.to;\n var edges = graph.nodeMap[rightmostEdgeToId].edges;\n var edgeLength = edges.length;\n\n for (var i = 0; i < edgeLength; i++) {\n var edge = edges[i];\n var toNode = graph.nodeMap[edge.to];\n\n if (minNodeLabel <= toNode.label && !history.hasNode(toNode)) {\n result.push(edge);\n }\n }\n\n return result;\n };\n\n GSpan.prototype.findForwardRmpathEdges = function (graph, rightmostEdge, minNodeLabel, history) {\n var result = [];\n var nodeMap = graph.nodeMap;\n var toNodeLabel = nodeMap[rightmostEdge.to].label;\n var fromNode = nodeMap[rightmostEdge.from];\n var edges = fromNode.edges;\n var edgeLength = edges.length;\n\n for (var i = 0; i < edgeLength; i++) {\n var edge = edges[i];\n var newToNodeLabel = nodeMap[edge.to].label;\n\n if (rightmostEdge.to === edge.to || minNodeLabel > newToNodeLabel || history.hasNode(nodeMap[edge.to])) {\n continue;\n }\n\n if (rightmostEdge.label < edge.label || rightmostEdge.label === edge.label && toNodeLabel <= newToNodeLabel) {\n result.push(edge);\n }\n }\n\n return result;\n };\n\n GSpan.prototype.getSupport = function (projected) {\n var graphMap = {};\n projected.forEach(function (pro) {\n if (!graphMap[pro.graphId]) graphMap[pro.graphId] = true;\n });\n return Object.keys(graphMap).length;\n };\n\n GSpan.prototype.findMinLabel = function (obj) {\n var minLabel = undefined;\n Object.keys(obj).forEach(function (nodeEdgeNodeLabel) {\n var _a = obj[nodeEdgeNodeLabel],\n nodeLabel1 = _a.nodeLabel1,\n edgeLabel = _a.edgeLabel,\n nodeLabel2 = _a.nodeLabel2;\n\n if (!minLabel) {\n minLabel = {\n nodeLabel1: nodeLabel1,\n edgeLabel: edgeLabel,\n nodeLabel2: nodeLabel2\n };\n return;\n }\n\n if (nodeLabel1 < minLabel.nodeLabel1 || nodeLabel1 === minLabel.nodeLabel1 && edgeLabel < minLabel.edgeLabel || nodeLabel1 === minLabel.nodeLabel1 && edgeLabel === minLabel.edgeLabel && nodeLabel2 < minLabel.nodeLabel2) {\n minLabel = {\n nodeLabel1: nodeLabel1,\n edgeLabel: edgeLabel,\n nodeLabel2: nodeLabel2\n };\n }\n });\n return minLabel;\n };\n\n GSpan.prototype.isMin = function () {\n var _this = this;\n\n var dfsCode = this.dfsCode;\n if (this.verbose) console.log(\"isMin checking\", dfsCode);\n if (dfsCode.dfsEdgeList.length === 1) return true;\n var directed = this.directed;\n var graph = dfsCode.toGraph(VACANT_GRAPH_ID, directed);\n var nodeMap = graph.nodeMap;\n var dfsCodeMin = new DFScode();\n var root = {};\n graph.nodes.forEach(function (node) {\n var forwardEdges = _this.findForwardRootEdges(graph, node);\n\n forwardEdges.forEach(function (edge) {\n var otherNode = nodeMap[edge.to];\n var nodeEdgeNodeLabel = node.label + \"-\" + edge.label + \"-\" + otherNode.label;\n if (!root[nodeEdgeNodeLabel]) root[nodeEdgeNodeLabel] = {\n projected: [],\n nodeLabel1: node.label,\n edgeLabel: edge.label,\n nodeLabel2: otherNode.label\n };\n var pdfs = {\n graphId: graph.id,\n edge: edge,\n preNode: null\n };\n root[nodeEdgeNodeLabel].projected.push(pdfs);\n });\n }); // 比较 root 中每一项的 nodeEdgeNodeLabel 大小,按照 nodeLabel1、edgeLabe、nodeLabel2 的顺序比较\n\n var minLabel = this.findMinLabel(root); // line 419\n\n dfsCodeMin.dfsEdgeList.push(new DFSedge(0, 1, minLabel.nodeLabel1, minLabel.edgeLabel, minLabel.nodeLabel2)); // line 423\n\n var projectIsMin = function projectIsMin(projected) {\n // right most path\n var rmpath = dfsCodeMin.buildRmpath();\n var minNodeLabel = dfsCodeMin.dfsEdgeList[0].nodeEdgeNodeLabel.nodeLabel1;\n var maxToC = dfsCodeMin.dfsEdgeList[rmpath[0]].toNode; // node id\n\n var backwardRoot = {};\n var flag = false,\n newTo = 0;\n var end = directed ? -1 : 0; // 遍历到 1 还是到 0\n\n var _loop_1 = function _loop_1(i) {\n if (flag) return \"break\"; // line 435\n\n projected.forEach(function (p) {\n var history = new History(p);\n\n var backwardEdge = _this.findBackwardEdge(graph, history.edges[rmpath[i]], history.edges[rmpath[0]], history);\n\n if (backwardEdge) {\n // Line 441\n if (!backwardRoot[backwardEdge.label]) {\n backwardRoot[backwardEdge.label] = {\n projected: [],\n edgeLabel: backwardEdge.label\n };\n }\n\n backwardRoot[backwardEdge.label].projected.push({\n graphId: graph.id,\n edge: backwardRoot,\n preNode: p\n });\n newTo = dfsCodeMin.dfsEdgeList[rmpath[i]].fromNode;\n flag = true;\n }\n });\n };\n\n for (var i = rmpath.length - 1; i > end; i--) {\n var state_1 = _loop_1(i);\n\n if (state_1 === \"break\") break;\n }\n\n if (flag) {\n var minBackwardEdgeLabel = _this.findMinLabel(backwardRoot);\n\n dfsCodeMin.dfsEdgeList.push(new DFSedge(maxToC, newTo, VACANT_NODE_LABEL, minBackwardEdgeLabel.edgeLabel, VACANT_NODE_LABEL));\n var idx_1 = dfsCodeMin.dfsEdgeList.length - 1;\n if (_this.dfsCode.dfsEdgeList[idx_1] !== dfsCodeMin.dfsEdgeList[idx_1]) return false;\n return projectIsMin(backwardRoot[minBackwardEdgeLabel.edgeLabel].projected);\n }\n\n var forwardRoot = {};\n flag = false;\n var newFrom = 0;\n projected.forEach(function (p) {\n var history = new History(p);\n\n var forwardPureEdges = _this.findForwardPureEdges(graph, history.edges[rmpath[0]], minNodeLabel, history);\n\n if (forwardPureEdges.length > 0) {\n flag = true;\n newFrom = maxToC;\n forwardPureEdges.forEach(function (edge) {\n var key = edge.label + \"-\" + nodeMap[edge.to].label;\n if (!forwardRoot[key]) forwardRoot[key] = {\n projected: [],\n edgeLabel: edge.label,\n nodeLabel2: nodeMap[edge.to].label\n };\n forwardRoot[key].projected.push({\n graphId: graph.id,\n edge: edge,\n preNode: p\n });\n });\n }\n });\n var pathLength = rmpath.length;\n\n var _loop_2 = function _loop_2(i) {\n if (flag) return \"break\";\n var value = rmpath[i];\n projected.forEach(function (p) {\n var history = new History(p);\n\n var forwardRmpathEdges = _this.findForwardRmpathEdges(graph, history.edges[value], minNodeLabel, history);\n\n if (forwardRmpathEdges.length > 0) {\n flag = true;\n newFrom = dfsCodeMin.dfsEdgeList[value].fromNode;\n forwardRmpathEdges.forEach(function (edge) {\n var key = edge.label + \"-\" + nodeMap[edge.to].label;\n if (!forwardRoot[key]) forwardRoot[key] = {\n projected: [],\n edgeLabel: edge.label,\n nodeLabel2: nodeMap[edge.to].label\n };\n forwardRoot[key].projected.push({\n graphId: graph.id,\n edge: edge,\n preNode: p\n });\n });\n }\n });\n };\n\n for (var i = 0; i < pathLength; i++) {\n var state_2 = _loop_2(i);\n\n if (state_2 === \"break\") break;\n }\n\n if (!flag) return true;\n\n var forwardMinEdgeNodeLabel = _this.findMinLabel(forwardRoot);\n\n dfsCodeMin.dfsEdgeList.push(new DFSedge(newFrom, maxToC + 1, VACANT_NODE_LABEL, forwardMinEdgeNodeLabel.edgeLabel, forwardMinEdgeNodeLabel.nodeLabel2));\n var idx = dfsCodeMin.dfsEdgeList.length - 1;\n if (dfsCode.dfsEdgeList[idx] !== dfsCodeMin.dfsEdgeList[idx]) return false;\n return projectIsMin(forwardRoot[forwardMinEdgeNodeLabel.edgeLabel + \"-\" + forwardMinEdgeNodeLabel.nodeLabel2].projected);\n };\n\n var key = minLabel.nodeLabel1 + \"-\" + minLabel.edgeLabel + \"-\" + minLabel.nodeLabel2;\n return projectIsMin(root[key].projected);\n };\n\n GSpan.prototype.report = function () {\n if (this.dfsCode.getNodeNum() < this.minNodeNum) return;\n this.counter++;\n var graph = this.dfsCode.toGraph(this.counter, this.directed);\n this.frequentSubgraphs.push(clone(graph));\n };\n\n GSpan.prototype.subGraphMining = function (projected) {\n var _this = this;\n\n var support = this.getSupport(projected);\n if (support < this.minSupport) return;\n if (!this.isMin()) return;\n this.report();\n var nodeNum = this.dfsCode.getNodeNum();\n var rmpath = this.dfsCode.buildRmpath();\n var maxToC = this.dfsCode.dfsEdgeList[rmpath[0]].toNode;\n var minNodeLabel = this.dfsCode.dfsEdgeList[0].nodeEdgeNodeLabel.nodeLabel1;\n var forwardRoot = {};\n var backwardRoot = {};\n projected.forEach(function (p) {\n var graph = _this.graphs[p.graphId];\n var nodeMap = graph.nodeMap;\n var history = new History(p); // backward Line 526\n\n for (var i = rmpath.length - 1; i >= 0; i--) {\n var backwardEdge = _this.findBackwardEdge(graph, history.edges[rmpath[i]], history.edges[rmpath[0]], history);\n\n if (backwardEdge) {\n var key = _this.dfsCode.dfsEdgeList[rmpath[i]].fromNode + \"-\" + backwardEdge.label;\n if (!backwardRoot[key]) backwardRoot[key] = {\n projected: [],\n toNodeId: _this.dfsCode.dfsEdgeList[rmpath[i]].fromNode,\n edgeLabel: backwardEdge.label\n };\n backwardRoot[key].projected.push({\n graphId: p.graphId,\n edge: backwardEdge,\n preNode: p\n });\n }\n } // pure forward\n\n\n if (nodeNum >= _this.maxNodeNum) return;\n\n var forwardPureEdges = _this.findForwardPureEdges(graph, history.edges[rmpath[0]], minNodeLabel, history);\n\n forwardPureEdges.forEach(function (edge) {\n var key = maxToC + \"-\" + edge.label + \"-\" + nodeMap[edge.to].label;\n if (!forwardRoot[key]) forwardRoot[key] = {\n projected: [],\n fromNodeId: maxToC,\n edgeLabel: edge.label,\n nodeLabel2: nodeMap[edge.to].label\n };\n forwardRoot[key].projected.push({\n graphId: p.graphId,\n edge: edge,\n preNode: p\n });\n });\n\n var _loop_3 = function _loop_3(i) {\n var forwardRmpathEdges = _this.findForwardRmpathEdges(graph, history.edges[rmpath[i]], minNodeLabel, history);\n\n forwardRmpathEdges.forEach(function (edge) {\n var key = _this.dfsCode.dfsEdgeList[rmpath[i]].fromNode + \"-\" + edge.label + \"-\" + nodeMap[edge.to].label;\n if (!forwardRoot[key]) forwardRoot[key] = {\n projected: [],\n fromNodeId: _this.dfsCode.dfsEdgeList[rmpath[i]].fromNode,\n edgeLabel: edge.label,\n nodeLabel2: nodeMap[edge.to].label\n };\n forwardRoot[key].projected.push({\n graphId: p.graphId,\n edge: edge,\n preNode: p\n });\n });\n }; // rmpath forward\n\n\n for (var i = 0; i < rmpath.length; i++) {\n _loop_3(i);\n }\n }); // backward\n\n Object.keys(backwardRoot).forEach(function (key) {\n var _a = backwardRoot[key],\n toNodeId = _a.toNodeId,\n edgeLabel = _a.edgeLabel;\n\n _this.dfsCode.dfsEdgeList.push(new DFSedge(maxToC, toNodeId, \"-1\", edgeLabel, \"-1\"));\n\n _this.subGraphMining(backwardRoot[key].projected);\n\n _this.dfsCode.dfsEdgeList.pop();\n }); // forward\n\n Object.keys(forwardRoot).forEach(function (key) {\n var _a = forwardRoot[key],\n fromNodeId = _a.fromNodeId,\n edgeLabel = _a.edgeLabel,\n nodeLabel2 = _a.nodeLabel2;\n\n _this.dfsCode.dfsEdgeList.push(new DFSedge(fromNodeId, maxToC + 1, VACANT_NODE_LABEL, edgeLabel, nodeLabel2));\n\n _this.subGraphMining(forwardRoot[key].projected);\n\n _this.dfsCode.dfsEdgeList.pop();\n });\n };\n\n GSpan.prototype.generate1EdgeFrequentSubGraphs = function () {\n var graphs = this.graphs;\n var directed = this.directed;\n var minSupport = this.minSupport;\n var frequentSize1Subgraphs = this.frequentSize1Subgraphs;\n var nodeLabelCounter = {},\n nodeEdgeNodeCounter = {}; // 保存各个图和各自节点的关系 map,key 格式为 graphKey-node类型\n\n var nodeLableCounted = {}; // 保存各个图和各自边的关系 map,key 格式为 graphKey-fromNode类型-edge类型-toNode类型\n\n var nodeEdgeNodeLabelCounted = {};\n Object.keys(graphs).forEach(function (key) {\n // Line 271\n var graph = graphs[key];\n var nodeMap = graph.nodeMap; // 遍历节点,记录对应图 与 每个节点的 label 到 nodeLableCounted\n\n graph.nodes.forEach(function (node, i) {\n // Line 272\n var nodeLabel = node.label;\n var graphNodeKey = key + \"-\" + nodeLabel;\n\n if (!nodeLableCounted[graphNodeKey]) {\n var counter = nodeLabelCounter[nodeLabel] || 0;\n counter++;\n nodeLabelCounter[nodeLabel] = counter;\n }\n\n nodeLableCounted[graphNodeKey] = {\n graphKey: key,\n label: nodeLabel\n }; // 遍历该节点的所有边,记录各个图和各自边的关系到 nodeEdgeNodeLabelCounted. Line 276\n\n node.edges.forEach(function (edge) {\n var nodeLabel1 = nodeLabel;\n var nodeLabel2 = nodeMap[edge.to].label;\n\n if (!directed && nodeLabel1 > nodeLabel2) {\n var tmp = nodeLabel2;\n nodeLabel2 = nodeLabel1;\n nodeLabel1 = tmp;\n }\n\n var edgeLabel = edge.label;\n var graphNodeEdgeNodeKey = key + \"-\" + nodeLabel1 + \"-\" + edgeLabel + \"-\" + nodeLabel2;\n var nodeEdgeNodeKey = nodeLabel1 + \"-\" + edgeLabel + \"-\" + nodeLabel2;\n\n if (!nodeEdgeNodeCounter[nodeEdgeNodeKey]) {\n var counter = nodeEdgeNodeCounter[nodeEdgeNodeKey] || 0;\n counter++;\n nodeEdgeNodeCounter[nodeEdgeNodeKey] = counter; // Line281\n }\n\n nodeEdgeNodeLabelCounted[graphNodeEdgeNodeKey] = {\n graphId: key,\n nodeLabel1: nodeLabel1,\n edgeLabel: edgeLabel,\n nodeLabel2: nodeLabel2\n };\n });\n });\n }); // 计算频繁的节点\n\n Object.keys(nodeLabelCounter).forEach(function (label) {\n var count = nodeLabelCounter[label];\n if (count < minSupport) return;\n var g = {\n nodes: [],\n edges: []\n };\n g.nodes.push({\n id: \"0\",\n label: label\n });\n frequentSize1Subgraphs.push(g); // if (minNodeNum <= 1) reportSize1 TODO\n });\n return frequentSize1Subgraphs;\n };\n\n GSpan.prototype.run = function () {\n var _this = this; // -------- 第一步, _generate_1edge_frequent_subgraphs:频繁的单个节点-------\n\n\n this.frequentSize1Subgraphs = this.generate1EdgeFrequentSubGraphs();\n if (this.maxNodeNum < 2) return;\n var graphs = this.graphs;\n var directed = this.directed; // PDFS 数组的 map Line 304\n\n var root = {};\n Object.keys(graphs).forEach(function (graphId) {\n var graph = graphs[graphId];\n var nodeMap = graph.nodeMap; // Line 306\n\n graph.nodes.forEach(function (node) {\n var forwardRootEdges = _this.findForwardRootEdges(graph, node); // Line 308\n\n\n forwardRootEdges.forEach(function (edge) {\n var toNode = nodeMap[edge.to];\n var nodeEdgeNodeLabel = node.label + \"-\" + edge.label + \"-\" + toNode.label;\n if (!root[nodeEdgeNodeLabel]) root[nodeEdgeNodeLabel] = {\n projected: [],\n nodeLabel1: node.label,\n edgeLabel: edge.label,\n nodeLabel2: toNode.label\n };\n var pdfs = {\n graphId: graphId,\n edge: edge,\n preNode: null\n };\n root[nodeEdgeNodeLabel].projected.push(pdfs);\n });\n });\n }); // Line 313\n\n Object.keys(root).forEach(function (nodeEdgeNodeLabel) {\n var _a = root[nodeEdgeNodeLabel],\n projected = _a.projected,\n nodeLabel1 = _a.nodeLabel1,\n edgeLabel = _a.edgeLabel,\n nodeLabel2 = _a.nodeLabel2;\n\n _this.dfsCode.dfsEdgeList.push(new DFSedge(0, 1, nodeLabel1, edgeLabel, nodeLabel2));\n\n _this.subGraphMining(projected);\n\n _this.dfsCode.dfsEdgeList.pop();\n });\n };\n\n return GSpan;\n}();\n\nvar formatGraphs = function formatGraphs(graphs, directed, nodeLabelProp, edgeLabelProp) {\n var result = {};\n Object.keys(graphs).forEach(function (key, i) {\n var graph = graphs[key];\n var fGraph = new Graph(i, true, directed);\n var nodeIdxMap = {};\n graph.nodes.forEach(function (node, j) {\n fGraph.addNode(j, node[nodeLabelProp]);\n nodeIdxMap[node.id] = j;\n });\n graph.edges.forEach(function (edge, k) {\n var sourceIdx = nodeIdxMap[edge.source];\n var targetIdx = nodeIdxMap[edge.target];\n fGraph.addEdge(-1, sourceIdx, targetIdx, edge[edgeLabelProp]);\n });\n if (fGraph && fGraph.getNodeNum()) result[fGraph.id] = fGraph;\n });\n return result;\n};\n\nvar toGraphDatas = function toGraphDatas(graphs, nodeLabelProp, edgeLabelProp) {\n var result = [];\n graphs.forEach(function (graph) {\n var graphData = {\n nodes: [],\n edges: []\n };\n graph.nodes.forEach(function (node) {\n var _a;\n\n graphData.nodes.push((_a = {\n id: \"\" + node.id\n }, _a[nodeLabelProp] = node.label, _a));\n });\n graph.edges.forEach(function (edge) {\n var _a;\n\n graphData.edges.push((_a = {\n source: \"\" + edge.from,\n target: \"\" + edge.to\n }, _a[edgeLabelProp] = edge.label, _a));\n });\n result.push(graphData);\n });\n return result;\n};\n\nvar DEFAULT_LABEL_NAME = \"cluster\";\n/**\n * gSpan 频繁子图计算算法(frequent graph mining)\n * @param params 参数\n */\n\nvar gSpan = function gSpan(params) {\n // ------- 将图数据 GraphData 的 map 转换为格式 -------\n var graphs = params.graphs,\n _a = params.directed,\n directed = _a === void 0 ? false : _a,\n _b = params.nodeLabelProp,\n nodeLabelProp = _b === void 0 ? DEFAULT_LABEL_NAME : _b,\n _c = params.edgeLabelProp,\n edgeLabelProp = _c === void 0 ? DEFAULT_LABEL_NAME : _c;\n var formattedGraphs = formatGraphs(graphs, directed, nodeLabelProp, edgeLabelProp);\n var minSupport = params.minSupport,\n maxNodeNum = params.maxNodeNum,\n minNodeNum = params.minNodeNum,\n verbose = params.verbose,\n top = params.top; // ------- 初始化与执行算法 -------\n\n var algoParams = {\n graphs: formattedGraphs,\n minSupport: minSupport,\n maxNodeNum: maxNodeNum,\n minNodeNum: minNodeNum,\n top: top,\n verbose: verbose,\n directed: directed\n };\n var calculator = new GSpan(algoParams);\n calculator.run();\n var result = toGraphDatas(calculator.frequentSubgraphs, nodeLabelProp, edgeLabelProp);\n return result;\n};\n\nexport default gSpan;","import { __spreadArray } from \"tslib\";\nimport floydWarshall from './floydWarshall';\nimport gSpan from './gSpan/gSpan';\nimport dijkstra from './dijkstra';\nimport { uniqueId } from './util';\n/**\n * 为 graphData 中每个节点生成邻居单元数组\n * @param graphData\n * @param spm\n * @param nodeLabelProp\n * @param k k-近邻\n */\n\nvar findKNeighborUnits = function findKNeighborUnits(graphData, spm, nodeLabelProp, k) {\n if (nodeLabelProp === void 0) {\n nodeLabelProp = 'cluster';\n }\n\n if (k === void 0) {\n k = 2;\n }\n\n var units = [];\n var nodes = graphData.nodes;\n spm.forEach(function (row, i) {\n units.push(findKNeighborUnit(nodes, row, i, nodeLabelProp, k));\n });\n return units;\n};\n\nvar findKNeighborUnit = function findKNeighborUnit(nodes, row, i, nodeLabelProp, k) {\n var unitNodeIdxs = [i];\n var neighbors = [];\n var labelCountMap = {};\n row.forEach(function (v, j) {\n if (v <= k && i !== j) {\n unitNodeIdxs.push(j);\n neighbors.push(nodes[j]);\n var label = nodes[j][nodeLabelProp];\n if (!labelCountMap[label]) labelCountMap[label] = {\n count: 1,\n dists: [v]\n };else {\n labelCountMap[label].count++;\n labelCountMap[label].dists.push(v);\n }\n }\n }); // 将 labelCountMap 中的 dists 按照从小到大排序,方便后面使用\n\n Object.keys(labelCountMap).forEach(function (label) {\n labelCountMap[label].dists = labelCountMap[label].dists.sort(function (a, b) {\n return a - b;\n });\n });\n return {\n nodeIdx: i,\n nodeId: nodes[i].id,\n nodeIdxs: unitNodeIdxs,\n neighbors: neighbors,\n neighborNum: unitNodeIdxs.length - 1,\n nodeLabelCountMap: labelCountMap\n };\n};\n/**\n * 随机寻找点对,满足距离小于 k\n * @param k 参数 k,表示 k-近邻\n * @param nodeNum 参数 length\n * @param maxNodePairNum 寻找点对的数量不超过 maxNodePairNum\n * @param spm 最短路径矩阵\n */\n\n\nvar findNodePairsRandomly = function findNodePairsRandomly(k, nodeNum, maxNodePairNum, kNeighborUnits, spm) {\n // 每个节点需要随机找出的点对数\n var nodePairNumEachNode = Math.ceil(maxNodePairNum / nodeNum);\n var nodePairMap = {};\n var foundNodePairCount = 0; // 遍历节点,为每个节点随机找出 nodePairNumEachNode 个点对,满足距离小于 k。找到的点对数量超过 maxNodePairNum 或所有节点遍历结束时终止\n\n kNeighborUnits.forEach(function (unit, i) {\n // 若未达到 nodePairNumEachNode,或循环次数小于最大循环次数(2 * nodeNum),继续循环\n var nodePairForICount = 0;\n var outerLoopCount = 0;\n var neighbors = unit.nodeIdxs; // the first one is the center node\n\n var neighborNum = unit.neighborNum - 1;\n\n while (nodePairForICount < nodePairNumEachNode) {\n // 另一端节点在节点数组中的的 index\n var oidx = neighbors[1 + Math.floor(Math.random() * neighborNum)];\n var innerLoopCount = 0; // 若随机得到的另一端 idx 不符合条件,则继续 random。条件是不是同一个节点、这个点对没有被记录过、距离小于 k\n\n while (nodePairMap[i + \"-\" + oidx] || nodePairMap[oidx + \"-\" + i]) {\n oidx = Math.floor(Math.random() * nodeNum);\n innerLoopCount++;\n if (innerLoopCount > 2 * nodeNum) break; // 循环次数大于最大循环次数(2 * nodeNum)跳出循环,避免死循环\n }\n\n if (innerLoopCount < 2 * nodeNum) {\n // 未达到最大循环次数,说明找到了合适的另一端\n nodePairMap[i + \"-\" + oidx] = {\n start: i,\n end: oidx,\n distance: spm[i][oidx]\n };\n nodePairForICount++;\n foundNodePairCount++; // 如果当前找到的点对数量达到了上限,返回结果\n\n if (foundNodePairCount >= maxNodePairNum) return nodePairMap;\n }\n\n outerLoopCount++;\n if (outerLoopCount > 2 * nodeNum) break; // 循环次数大于最大循环次数(2 * nodeNum)跳出循环,避免死循环\n } // 这个节点没有找到足够 nodePairNumEachNode 的点对。更新 nodePairNumEachNode,让后续节点找更多的点对\n\n\n if (nodePairForICount < nodePairNumEachNode) {\n var gap = nodePairNumEachNode - nodePairForICount;\n nodePairNumEachNode = (nodePairNumEachNode + gap) / (nodeNum - i - 1);\n }\n });\n return nodePairMap;\n};\n/**\n * 计算所有 nodePairMap 中节点对的相交邻居诱导子图\n * @param nodePairMap 节点对 map,key 为 node1.id-node2.id,value 为 { startNodeIdx, endNodeIdx, distance }\n * @param neighborUnits 每个节点的邻居元数组\n * @param graphData 原图数据\n * @param edgeMap 边的 map,方便检索\n * @param cachedInducedGraphMap 缓存的结果,下次进入该函数将继续更新该缓存,若 key 在缓存中存在则不需要重复计算\n */\n\n\nvar getIntersectNeighborInducedGraph = function getIntersectNeighborInducedGraph(nodePairMap, neighborUnits, graphData, cachedInducedGraphMap) {\n var nodes = graphData.nodes;\n if (!cachedInducedGraphMap) cachedInducedGraphMap = {};\n Object.keys(nodePairMap).forEach(function (key) {\n var _a, _b;\n\n if (cachedInducedGraphMap && cachedInducedGraphMap[key]) return;\n cachedInducedGraphMap[key] = {\n nodes: [],\n edges: []\n };\n var pair = nodePairMap[key];\n var startUnitNodeIds = (_a = neighborUnits[pair.start]) === null || _a === void 0 ? void 0 : _a.nodeIdxs;\n var endUnitNodeIds = (_b = neighborUnits[pair.end]) === null || _b === void 0 ? void 0 : _b.nodeIdxs;\n if (!startUnitNodeIds || !endUnitNodeIds) return; // 不存在邻元,返回空图\n\n var endSet = new Set(endUnitNodeIds);\n var intersect = startUnitNodeIds.filter(function (x) {\n return endSet.has(x);\n }); // 可能会爆栈(在 1580 + 6 nodes full-connected 时出现)\n\n if (!intersect || !intersect.length) return; // 没有交集,返回空图\n\n var intersectIdMap = {};\n var intersectLength = intersect.length;\n\n for (var i = 0; i < intersectLength; i++) {\n var node = nodes[intersect[i]];\n cachedInducedGraphMap[key].nodes.push(node); // 将交集中的点加入诱导子图\n\n intersectIdMap[node.id] = true;\n } // 遍历所有边数据,如果边的两端都在交集中,将该边加入诱导子图\n\n\n graphData.edges.forEach(function (edge) {\n if (intersectIdMap[edge.source] && intersectIdMap[edge.target]) cachedInducedGraphMap[key].edges.push(edge);\n });\n });\n return cachedInducedGraphMap;\n};\n/**\n * 计算 strcutre 在 graph 上的匹配数量\n * @param graph 图数据\n * @param structure 目前支持只有两个节点一条边的最简单结构\n * @param nodeLabelProp 节点类型字段名\n * @param edgeLabelProp 边类型字段名\n */\n\n\nvar getMatchedCount = function getMatchedCount(graph, structure, nodeLabelProp, edgeLabelProp) {\n var nodeMap = {};\n graph.nodes.forEach(function (node) {\n nodeMap[node.id] = node;\n });\n var count = 0;\n graph.edges.forEach(function (e) {\n var sourceLabel = nodeMap[e.source][nodeLabelProp];\n var targetLabel = nodeMap[e.target][nodeLabelProp];\n var strNodeLabel1 = structure === null || structure === void 0 ? void 0 : structure.nodes[0][nodeLabelProp];\n var strNodeLabel2 = structure === null || structure === void 0 ? void 0 : structure.nodes[1][nodeLabelProp];\n var strEdgeLabel = structure === null || structure === void 0 ? void 0 : structure.edges[0][edgeLabelProp];\n if (e[edgeLabelProp] !== strEdgeLabel) return;\n\n if (sourceLabel === strNodeLabel1 && targetLabel === strNodeLabel2 || sourceLabel === strNodeLabel2 && targetLabel === strNodeLabel1) {\n count++;\n }\n });\n return count;\n};\n/**\n * structures 中寻找最具有代表性的一个。这个结构是使得 matchedCountMap 的分组方式类内间距最小,类间间距最大\n * @param matchedCountMap 每个 structure 分类后的各图匹配数量,格式 { [strcture.idx]: { [interInducedGraphKey]: count } }\n * @param structureNum strcuture 个数,与 matchedCountMap.length 对应\n * @param structures\n */\n\n\nvar findRepresentStructure = function findRepresentStructure(matchedCountMap, structureNum, structures) {\n var maxOffset = Infinity,\n representClusterType = 0;\n\n var _loop_1 = function _loop_1(i) {\n // 一种分组的 map,key 是 intGraph 的 key,value 是 structures[i] 的匹配个数\n var countMapI = matchedCountMap[i]; // 按照 value 为该组排序,生成 keys 的数组:\n\n var sortedGraphKeys = Object.keys(countMapI).sort(function (a, b) {\n return countMapI[a] - countMapI[b];\n }); // 共 100 个 graphKeys,将 graphKeys 按顺序分为 groupNum 组\n\n var groupNum = 10;\n var clusters = []; // 总共有 groupNum 个项\n\n sortedGraphKeys.forEach(function (key, j) {\n if (!clusters[j % groupNum]) clusters[j % groupNum] = {\n graphs: [],\n totalCount: 0,\n aveCount: 0\n };\n clusters[j % groupNum].graphs.push(key);\n clusters[j % groupNum].totalCount += countMapI[key];\n }); // 计算 cluster 与 cluster 之间的距离 innerDist,每个 cluster 内部的距离 intraDist\n\n var aveIntraDist = 0; // 该类的类内平均值\n\n var aveCounts = []; // 类内平均匹配数量,将用于计算类间距离\n\n clusters.forEach(function (graphsInCluster) {\n // 类内均值\n var aveCount = graphsInCluster.totalCount / graphsInCluster.graphs.length;\n graphsInCluster.aveCount = aveCount;\n aveCounts.push(aveCount); // 对于每类,计算类内间距平均值\n\n var aveIntraPerCluster = 0;\n var graphsNum = graphsInCluster.length;\n graphsInCluster.graphs.forEach(function (graphKey1, j) {\n var graph1Count = countMapI[graphKey1];\n graphsInCluster.graphs.forEach(function (graphKey2, k) {\n if (j === k) return;\n aveIntraPerCluster += Math.abs(graph1Count - countMapI[graphKey2]);\n });\n });\n aveIntraPerCluster /= graphsNum * (graphsNum - 1) / 2;\n aveIntraDist += aveIntraPerCluster;\n });\n aveIntraDist /= clusters.length; // 用类内均值计算类间距\n\n var aveInterDist = 0; // 类间间距平均值\n\n aveCounts.forEach(function (aveCount1, j) {\n aveCounts.forEach(function (aveCount2, k) {\n if (j === k) return;\n aveInterDist += Math.abs(aveCount1 - aveCount2);\n });\n aveInterDist /= aveCounts.length * (aveCounts.length - 1) / 2;\n }); // 寻找 (类间间距均值-类内间距均值) 最大的一种分组方式(对应的 structure 就是最终要找的唯一 DS(G))\n\n var offset = aveInterDist - aveIntraDist;\n\n if (maxOffset < offset) {\n maxOffset = offset;\n representClusterType = i;\n }\n };\n\n for (var i = 0; i < structureNum; i++) {\n _loop_1(i);\n }\n\n return {\n structure: structures[representClusterType],\n structureCountMap: matchedCountMap[representClusterType]\n };\n};\n\nvar getNodeMaps = function getNodeMaps(nodes, nodeLabelProp) {\n var nodeMap = {},\n nodeLabelMap = {};\n nodes.forEach(function (node, i) {\n nodeMap[node.id] = {\n idx: i,\n node: node,\n degree: 0,\n inDegree: 0,\n outDegree: 0\n };\n var label = node[nodeLabelProp];\n if (!nodeLabelMap[label]) nodeLabelMap[label] = [];\n nodeLabelMap[label].push(node);\n });\n return {\n nodeMap: nodeMap,\n nodeLabelMap: nodeLabelMap\n };\n};\n\nvar getEdgeMaps = function getEdgeMaps(edges, edgeLabelProp, nodeMap) {\n var edgeMap = {},\n edgeLabelMap = {};\n edges.forEach(function (edge, i) {\n edgeMap[\"\" + uniqueId] = {\n idx: i,\n edge: edge\n };\n var label = edge[edgeLabelProp];\n if (!edgeLabelMap[label]) edgeLabelMap[label] = [];\n edgeLabelMap[label].push(edge);\n var sourceNode = nodeMap[edge.source];\n\n if (sourceNode) {\n sourceNode.degree++;\n sourceNode.outDegree++;\n }\n\n var targetNode = nodeMap[edge.target];\n\n if (targetNode) {\n targetNode.degree++;\n targetNode.inDegree++;\n }\n });\n return {\n edgeMap: edgeMap,\n edgeLabelMap: edgeLabelMap\n };\n};\n/**\n * 输出最短路径的 map,key 为 sourceNode.id-targetNode.id,value 为这两个节点的最短路径长度\n * @param nodes\n * @param spm\n * @param directed\n */\n\n\nvar getSpmMap = function getSpmMap(nodes, spm, directed) {\n var length = spm.length;\n var map = {};\n spm.forEach(function (row, i) {\n var start = directed ? 0 : i + 1;\n var iId = nodes[i].id;\n\n for (var j = start; j < length; j++) {\n if (i === j) continue;\n var jId = nodes[j].id;\n var dist = row[j];\n map[iId + \"-\" + jId] = dist;\n if (!directed) map[jId + \"-\" + iId] = dist;\n }\n });\n return map;\n};\n/**\n * 计算一对节点(node1,node2)的 NDS 距离\n * @param graph 原图数据\n * @param node1\n * @param node2\n */\n\n\nvar getNDSDist = function getNDSDist(graph, node1, node2, nodeMap, spDist, kNeighborUnits, structure, nodeLabelProp, edgeLabelProp, cachedNDSMap, cachedInterInducedGraph) {\n var _a;\n\n var key = node1.id + \"-\" + node2.id;\n if (cachedNDSMap && cachedNDSMap[key]) return cachedNDSMap[key];\n var interInducedGraph = cachedInterInducedGraph ? cachedInterInducedGraph[key] : undefined; // 若没有缓存相交邻居诱导子图,计算\n\n if (!interInducedGraph) {\n var pairMap = (_a = {}, _a[key] = {\n start: nodeMap[node1.id].idx,\n end: nodeMap[node2.id].idx,\n distance: spDist\n }, _a);\n cachedInterInducedGraph = getIntersectNeighborInducedGraph(pairMap, kNeighborUnits, graph, cachedInterInducedGraph);\n interInducedGraph = cachedInterInducedGraph[key];\n }\n\n return getMatchedCount(interInducedGraph, structure, nodeLabelProp, edgeLabelProp);\n};\n/**\n * 计算 pattern 上绩点的度数并存储到 minPatternNodeLabelDegreeMap\n */\n\n\nvar stashPatternNodeLabelDegreeMap = function stashPatternNodeLabelDegreeMap(minPatternNodeLabelDegreeMap, neighborLabel, patternNodeMap, patternNodeLabelMap) {\n var _a, _b, _c;\n\n var minPatternNodeLabelDegree = (_a = minPatternNodeLabelDegreeMap[neighborLabel]) === null || _a === void 0 ? void 0 : _a.degree;\n var minPatternNodeLabelInDegree = (_b = minPatternNodeLabelDegreeMap[neighborLabel]) === null || _b === void 0 ? void 0 : _b.inDegree;\n var minPatternNodeLabelOutDegree = (_c = minPatternNodeLabelDegreeMap[neighborLabel]) === null || _c === void 0 ? void 0 : _c.outDegree;\n\n if (minPatternNodeLabelDegreeMap[neighborLabel] === undefined) {\n minPatternNodeLabelDegree = Infinity;\n minPatternNodeLabelInDegree = Infinity;\n minPatternNodeLabelOutDegree = Infinity;\n patternNodeLabelMap[neighborLabel].forEach(function (patternNodeWithLabel) {\n var patternNodeDegree = patternNodeMap[patternNodeWithLabel.id].degree;\n if (minPatternNodeLabelDegree > patternNodeDegree) minPatternNodeLabelDegree = patternNodeDegree;\n var patternNodeInDegree = patternNodeMap[patternNodeWithLabel.id].inDegree;\n if (minPatternNodeLabelInDegree > patternNodeInDegree) minPatternNodeLabelInDegree = patternNodeInDegree;\n var patternNodeOutDegree = patternNodeMap[patternNodeWithLabel.id].outDegree;\n if (minPatternNodeLabelOutDegree > patternNodeOutDegree) minPatternNodeLabelOutDegree = patternNodeOutDegree;\n });\n minPatternNodeLabelDegreeMap[neighborLabel] = {\n degree: minPatternNodeLabelDegree,\n inDegree: minPatternNodeLabelInDegree,\n outDegree: minPatternNodeLabelOutDegree\n };\n }\n\n return {\n minPatternNodeLabelDegree: minPatternNodeLabelDegree,\n minPatternNodeLabelInDegree: minPatternNodeLabelInDegree,\n minPatternNodeLabelOutDegree: minPatternNodeLabelOutDegree\n };\n};\n/**\n * GADDI 模式匹配\n * @param graphData 原图数据\n * @param pattern 搜索图(需要在原图上搜索的模式)数据\n * @param directed 是否计算有向图,默认 false\n * @param k 参数 k,表示 k-近邻\n * @param length 参数 length\n * @param nodeLabelProp 节点数据中代表节点标签(分类信息)的属性名。默认为 cluster\n * @param edgeLabelProp 边数据中代表边标签(分类信息)的属性名。默认为 cluster\n */\n\n\nvar GADDI = function GADDI(graphData, pattern, directed, k, length, nodeLabelProp, edgeLabelProp) {\n if (directed === void 0) {\n directed = false;\n }\n\n if (nodeLabelProp === void 0) {\n nodeLabelProp = 'cluster';\n }\n\n if (edgeLabelProp === void 0) {\n edgeLabelProp = 'cluster';\n }\n\n if (!graphData || !graphData.nodes) return; // 分为三步:\n // 0. 预计算:节点/边数,邻接矩阵、最短路径矩阵\n // 1. 处理原图 graphData。再分为 1~5 小步\n // 2. 匹配\n // console.log(\"----- stage-pre: preprocessing -------\");\n // -------- 第零步,预计算:节点/边数,邻接矩阵、最短路径矩阵-------\n\n var nodeNum = graphData.nodes.length;\n if (!nodeNum) return; // console.log(\"----- stage-pre.1: calc shortest path matrix for graph -------\");\n\n var spm = floydWarshall(graphData, directed); // console.log(\n // \"----- stage-pre.2: calc shortest path matrix for pattern -------\"\n // );\n\n var patternSpm = floydWarshall(pattern, directed); // console.log(\n // \"----- stage-pre.3: calc shortest path matrix map for graph -------\"\n // );\n\n var spmMap = getSpmMap(graphData.nodes, spm, directed); // console.log(\n // \"----- stage-pre.4: calc shortest path matrix map for pattern -------\"\n // );\n\n var patternSpmMap = getSpmMap(pattern.nodes, patternSpm, directed); // console.log(\"----- stage-pre.5: establish maps -------\");\n // 节点的 map,以 id 为 id 映射,方便后续快速检索\n\n var _a = getNodeMaps(graphData.nodes, nodeLabelProp),\n nodeMap = _a.nodeMap,\n nodeLabelMap = _a.nodeLabelMap;\n\n var _b = getNodeMaps(pattern.nodes, nodeLabelProp),\n patternNodeMap = _b.nodeMap,\n patternNodeLabelMap = _b.nodeLabelMap; // 计算节点度数\n\n\n getEdgeMaps(graphData.edges, edgeLabelProp, nodeMap);\n var patternEdgeLabelMap = getEdgeMaps(pattern.edges, edgeLabelProp, patternNodeMap).edgeLabelMap; // 若未指定 length,自动计算 pattern 半径(最短路径最大值)\n\n if (!length) length = Math.max.apply(Math, __spreadArray(__spreadArray([], patternSpm[0]), [2]));\n if (!k) k = length; // console.log(\"params\", directed, length, k);\n // console.log(\"----- stage-pre.6: calc k neighbor units -------\");\n // 计算每个节点的 k 邻元集合\n\n var kNeighborUnits = findKNeighborUnits(graphData, spm, nodeLabelProp, k);\n var patternKNeighborUnits = findKNeighborUnits(pattern, patternSpm, nodeLabelProp, k); // console.log(\n // \"----- stage0: going to processing graph and find intersect neighbor induced graphs -------\"\n // );\n // console.log(\"----- stage0.1: going to select random node pairs -------\");\n // -------- 第一步,处理原图 graphData-------\n // 1.1. 随机选择最多 100 个点对,满足距离小于 Length 和 k\n // 当 graphData 少于 20 个节点,则不能找出 100 个点对,只找出不多于 n(n-1)/2 个点对\n\n var maxNodePairNum = Math.min(100, nodeNum * (nodeNum - 1) / 2);\n var nodePairsMap = findNodePairsRandomly(k, nodeNum, maxNodePairNum, patternKNeighborUnits, spm); // console.log(\n // \"----- stage0.2: going to calculate intersect neighbor induced graphs -------\"\n // );\n // 1.2. 生成上面节点对的相应相交邻居诱导子图。格式为 {'beginNodeIdx-endNodeIdx': {nodes: [], edges: []}}\n\n var intGMap = getIntersectNeighborInducedGraph(nodePairsMap, kNeighborUnits, graphData); // 1.3. 使用 gSpan 算法(frequent graph mining)计算 ISIntG 的前 10 个频率最高的子结构(3-4条边)\n\n var top = 10,\n minSupport = 1,\n minNodeNum = 1,\n maxNodeNum = 4;\n var params = {\n graphs: intGMap,\n nodeLabelProp: nodeLabelProp,\n edgeLabelProp: edgeLabelProp,\n minSupport: minSupport,\n minNodeNum: minNodeNum,\n maxNodeNum: maxNodeNum,\n directed: directed\n }; // console.log(\n // \"----- stage1: (gSpan) going to find frequent structure dsG -------\"\n // );\n // console.log(\"----- stage1.1: going to run gSpan -------\");\n // 暂时假设生成的 sub structure 都只有一条边\n\n var freStructures = gSpan(params).slice(0, top); // structureNum 可能小于 top\n\n var structureNum = freStructures.length; // 1.4. 计算上述 10 个子结构在 intGMap 中每个诱导子图的匹配个数\n\n var matchedCountMap = [];\n freStructures.forEach(function (structure, i) {\n matchedCountMap[i] = {};\n Object.keys(intGMap).forEach(function (key) {\n var graph = intGMap[key];\n var subStructureCount = getMatchedCount(graph, structure, nodeLabelProp, edgeLabelProp);\n matchedCountMap[i][key] = subStructureCount;\n });\n }); // console.log(\n // \"----- stage1.1: going to find the most represent strucutre -------\"\n // );\n // 1.5. 对于每个子结构,根据匹配个数为 intGMap 中的诱导子图分组,生成 structureNum 种分组\n // 计算每种分组的类间距和类内间距,找到类间距最大、类内间距最小的一种分组,这种分组对应的子结构被选为唯一代表性子结构 DS(G)\n\n var _c = findRepresentStructure(matchedCountMap, structureNum, freStructures),\n dsG = _c.structure,\n ndsDist = _c.structureCountMap; // -------- 第二步,匹配-------\n // 2.1 从 Q 中的第一个标签的第一个节点开始,寻找 G 中的匹配\n\n\n var beginPNode = pattern.nodes[0];\n var label = beginPNode[nodeLabelProp]; // 2.1.1 找到 G 中标签与之相同的节点\n\n var candidates = nodeLabelMap[label]; // console.log(\"----- stage2: going to find candidates -------\");\n // 全局缓存,避免重复计算\n\n var minPatternNodeLabelDegreeMap = {}; // key 是 label,value 是该 label 节点的最小度数\n\n var patternIntGraphMap = {},\n patternNDSDist = {},\n // key 为 node.id-node.id\n patternNDSDistMap = {}; // key 为 node.id-label2,value nds距离值数组(按从大到小排序,无需关心具体对应哪个 node2)\n // 2.2.2 对于 Q 中的另一个标签的 k 个节点,计算它们到 node 的最短路径以及 NDS 距离\n\n var patternSpDist = {};\n var patternSpDistBack = {};\n Object.keys(patternNodeLabelMap).forEach(function (label2, j) {\n patternSpDist[label2] = [];\n\n if (directed) {\n patternSpDistBack[label2] = [];\n }\n\n var maxDist = -Infinity;\n var patternNodesWithLabel2 = patternNodeLabelMap[label2];\n var patternNodePairMap = {};\n patternNodesWithLabel2.forEach(function (nodeWithLabel2) {\n var dist = patternSpmMap[beginPNode.id + \"-\" + nodeWithLabel2.id];\n dist && patternSpDist[label2].push(dist);\n if (maxDist < dist) maxDist = dist;\n patternNodePairMap[beginPNode.id + \"-\" + nodeWithLabel2.id] = {\n start: 0,\n end: patternNodeMap[nodeWithLabel2.id].idx,\n distance: dist\n };\n\n if (directed) {\n var distBack = patternSpmMap[nodeWithLabel2.id + \"-\" + beginPNode.id];\n distBack && patternSpDistBack[label2].push(distBack);\n }\n }); // spDist[label2] 按照从小到大排序\n\n patternSpDist[label2] = patternSpDist[label2].sort(function (a, b) {\n return a - b;\n });\n if (directed) patternSpDistBack[label2] = patternSpDistBack[label2].sort(function (a, b) {\n return a - b;\n }); // 计算 Q 中所有 label2 节点到 beginPNode 的 NDS 距离\n // 所有 label2 节点到 beginPNode 的邻居相交诱导子图:\n // key: node1.id-node2.id\n\n patternIntGraphMap = getIntersectNeighborInducedGraph(patternNodePairMap, patternKNeighborUnits, pattern, patternIntGraphMap); // pattern 中 beginNode 到当前 label2 节点 的 NDS 距离(数组,无需关心具体对应到哪个节点)\n\n var currentPatternNDSDistArray = [];\n Object.keys(patternNodePairMap).forEach(function (key) {\n if (patternNDSDist[key]) {\n currentPatternNDSDistArray.push(patternNDSDist[key]);\n return; // 缓存过则不需要再次计算\n }\n\n var patternIntGraph = patternIntGraphMap[key];\n patternNDSDist[key] = getMatchedCount(patternIntGraph, dsG, nodeLabelProp, edgeLabelProp);\n currentPatternNDSDistArray.push(patternNDSDist[key]);\n }); // 根据值为 currentPatternNDSDist 从大到小排序\n\n currentPatternNDSDistArray = currentPatternNDSDistArray.sort(function (a, b) {\n return b - a;\n });\n patternNDSDistMap[beginPNode.id + \"-\" + label2] = currentPatternNDSDistArray;\n if (label2 === label) return;\n var candidatesNum = candidates.length;\n\n var _loop_4 = function _loop_4(m) {\n var cNode = candidates[m]; // prune1:若 candidates 中节点 cNode 的 kNeighborUnits 中标签为 label2 的节点个数少于 pattern 中 label2 个数,删去它\n\n var graphNeighborUnit = kNeighborUnits[nodeMap[cNode.id].idx];\n var graphNeighborUnitCountMap = graphNeighborUnit.nodeLabelCountMap[label2];\n var patternLabel2Num = patternNodeLabelMap[label2].length;\n\n if (!graphNeighborUnitCountMap || graphNeighborUnitCountMap.count < patternLabel2Num) {\n candidates.splice(m, 1);\n return \"continue\";\n } // prune2:若 candidates 中节点 cNode 到 kNeighborUnits 中标签为 label2 的节点最短路径大于 patternSpDist[label2],删去它\n // (prune2 规则即:candidate 相关的最短路径的最大 spDist[label2].length 个,按照大小顺序依次和 patternSpDist[label2] 中的值比较,只要遇到一个是 G > Q 的,就删去这个 candidate)\n\n\n var prune2Invalid = false;\n\n for (var n = 0; n < patternLabel2Num; n++) {\n if (graphNeighborUnitCountMap.dists[n] > patternSpDist[label2][n]) {\n prune2Invalid = true;\n break;\n }\n }\n\n if (prune2Invalid) {\n candidates.splice(m, 1);\n return \"continue\";\n } // prune3:若 candidates 中节点 cNode 到 kNeighborUnits 中标签为 label2 的节点 NDS 距离小于 patternNDSDist[beginNode.id-label2],删去它\n // TODO:prune3,currentPatternNDSDistArray 与 currentNDSDist 的比较\n // 计算 G 中所有 label2 节点到 cNode 的 NDS 距离\n // 所有 label2 节点到 cNode 的邻居相交诱导子图:\n\n\n var cNodePairMap = {};\n graphNeighborUnit.neighbors.forEach(function (neighborNode) {\n var dist = spmMap[cNode.id + \"-\" + neighborNode.id];\n cNodePairMap[cNode.id + \"-\" + neighborNode.id] = {\n start: nodeMap[cNode.id].idx,\n end: nodeMap[neighborNode.id].idx,\n distance: dist\n };\n }); // 更新 intGMap\n\n intGMap = getIntersectNeighborInducedGraph(cNodePairMap, kNeighborUnits, graphData, intGMap); // candidate 到它周围 label2 节点的 NDS 距离, key 是 node.id-node.id\n\n var currentNDSDistArray = [];\n Object.keys(cNodePairMap).forEach(function (key) {\n if (ndsDist[key]) {\n currentNDSDistArray.push(ndsDist[key]);\n return; // 缓存过则不需要再次计算\n }\n\n var intGraph = intGMap[key];\n ndsDist[key] = getMatchedCount(intGraph, dsG, nodeLabelProp, edgeLabelProp);\n currentNDSDistArray.push(ndsDist[key]);\n }); // 根据值为 currentNDSDistArray 从大到小排序\n\n currentNDSDistArray = currentNDSDistArray.sort(function (a, b) {\n return b - a;\n });\n var prune3Invalid = false;\n\n for (var n = 0; n < patternLabel2Num; n++) {\n if (currentNDSDistArray[n] < currentPatternNDSDistArray[n]) {\n prune3Invalid = true;\n break;\n }\n }\n\n if (prune3Invalid) {\n candidates.splice(m, 1);\n return \"continue\";\n }\n };\n\n for (var m = candidatesNum - 1; m >= 0; m--) {\n _loop_4(m);\n }\n });\n var candidateGraphs = []; // console.log(\n // \"----- stage3: going to splice neighbors for each candidate graph -------\"\n // );\n // candidates 经过筛选后,以每个 candidate 为中心,生成 Length-neighbor 的邻居诱导子图\n // 并在诱导子图中去除不可能在 Q 上找到匹配的点:在 Q 上不存在的 label,其他 label 到 candidate 的最大最短距离符合 Q、NDS 距离符合 Q\n\n candidates.forEach(function (candidate) {\n var nodeIdx = nodeMap[candidate.id].idx;\n var lengthNeighborUnit = findKNeighborUnit(graphData.nodes, spm[nodeIdx], nodeIdx, nodeLabelProp, length);\n var neighborNodes = lengthNeighborUnit.neighbors; // 删除不可能找到匹配的邻居点\n\n var neighborNum = neighborNodes.length;\n var unmatched = false;\n\n for (var i = neighborNum - 1; i >= 0; i--) {\n // 如果通过裁剪,符合条件的节点数量已过少,说明不能匹配这个 candidate 相关的图\n if (neighborNodes.length + 1 < pattern.nodes.length) {\n unmatched = true;\n return;\n }\n\n var neighborNode = neighborNodes[i];\n var neighborLabel = neighborNode[nodeLabelProp]; // prune1: 若该邻居点的 label 不存在于 pattern 中,移除这个点\n\n if (!patternNodeLabelMap[neighborLabel] || !patternNodeLabelMap[neighborLabel].length) {\n neighborNodes.splice(i, 1);\n continue;\n } // prune2: 若该邻居点到 candidate 的最短路径比和它有相同 label 的节点到 beginPNode 的最大最短路径长度长,移除这个点\n // prune2.1: 如果没有这个标签到 beginPNode 的距离记录,说明 pattern 上(可能 beginPNode 是这个 label)没有其他这个 label 的节点\n\n\n if (!patternSpDist[neighborLabel] || !patternSpDist[neighborLabel].length) {\n neighborNodes.splice(i, 1);\n continue;\n }\n\n var key = candidate.id + \"-\" + neighborNode.id; // prune2.2\n\n var distToCandidate = spmMap[key];\n var idx = patternSpDist[neighborLabel].length - 1;\n var maxDistWithLabelInPattern = patternSpDist[neighborLabel][idx]; // patternSpDist[neighborLabel] 已经按照从小到大排序\n\n if (distToCandidate > maxDistWithLabelInPattern) {\n neighborNodes.splice(i, 1);\n continue;\n }\n\n if (directed) {\n var keyBack = neighborNode.id + \"-\" + candidate.id;\n var distFromCandidate = spmMap[keyBack];\n idx = patternSpDistBack[neighborLabel].length - 1;\n var maxBackDistWithLabelInPattern = patternSpDistBack[neighborLabel][idx];\n\n if (distFromCandidate > maxBackDistWithLabelInPattern) {\n neighborNodes.splice(i, 1);\n continue;\n }\n } // prune3: 若该邻居点到 candidate 的 NDS 距离比和它有相同 label 的节点到 beginPNode 的最小 NDS 距离小,移除这个点\n\n\n var ndsToCandidate = ndsDist[key] ? ndsDist[key] : getNDSDist(graphData, candidate, neighborNode, nodeMap, distToCandidate, kNeighborUnits, dsG, nodeLabelProp, edgeLabelProp, ndsDist, intGMap);\n var patternKey = beginPNode.id + \"-\" + neighborLabel;\n var minNdsWithLabelInPattern = patternNDSDistMap[patternKey][patternNDSDistMap[patternKey].length - 1]; // patternNDSDist[key] 一定存在\n\n if (ndsToCandidate < minNdsWithLabelInPattern) {\n neighborNodes.splice(i, 1);\n continue;\n } // prune4: 若该邻居点的度数小于 pattern 同 label 节点最小度数,删去该点\n\n\n var _a = stashPatternNodeLabelDegreeMap(minPatternNodeLabelDegreeMap, neighborLabel, patternNodeMap, patternNodeLabelMap),\n minPatternNodeLabelDegree = _a.minPatternNodeLabelDegree,\n minPatternNodeLabelInDegree = _a.minPatternNodeLabelInDegree,\n minPatternNodeLabelOutDegree = _a.minPatternNodeLabelOutDegree;\n\n if (nodeMap[neighborNode.id].degree < minPatternNodeLabelDegree) {\n neighborNodes.splice(i, 1);\n continue;\n }\n } // 节点在个数上符合匹配(不少于 pattern 的节点个数),现在筛选相关边\n\n\n if (!unmatched) {\n candidateGraphs.push({\n nodes: [candidate].concat(neighborNodes)\n });\n }\n }); // console.log(\n // \"----- stage4: going to splice edges and neighbors for each candidate graph -------\"\n // );\n\n var undirectedLengthsToBeginPNode = dijkstra(pattern, beginPNode.id, false).length;\n var undirectedLengthsToBeginPNodeLabelMap = {};\n\n if (directed) {\n Object.keys(undirectedLengthsToBeginPNode).forEach(function (nodeId) {\n var nodeLabel = patternNodeMap[nodeId].node[nodeLabelProp];\n if (!undirectedLengthsToBeginPNodeLabelMap[nodeLabel]) undirectedLengthsToBeginPNodeLabelMap[nodeLabel] = [undirectedLengthsToBeginPNode[nodeId]];else undirectedLengthsToBeginPNodeLabelMap[nodeLabel].push(undirectedLengthsToBeginPNode[nodeId]);\n });\n Object.keys(undirectedLengthsToBeginPNodeLabelMap).forEach(function (pLabel) {\n undirectedLengthsToBeginPNodeLabelMap[pLabel].sort(function (a, b) {\n return a - b;\n });\n });\n } else {\n undirectedLengthsToBeginPNodeLabelMap = patternSpDist;\n } // 现在 candidateGraphs 里面只有节点,进行边的筛选\n\n\n var candidateGraphNum = candidateGraphs.length;\n\n var _loop_2 = function _loop_2(i) {\n var candidateGraph = candidateGraphs[i];\n var candidate = candidateGraph.nodes[0];\n var candidateNodeLabelCountMap = {};\n var candidateNodeMap = {};\n candidateGraph.nodes.forEach(function (node, q) {\n candidateNodeMap[node.id] = {\n idx: q,\n node: node,\n degree: 0,\n inDegree: 0,\n outDegree: 0\n };\n var cNodeLabel = node[nodeLabelProp];\n if (!candidateNodeLabelCountMap[cNodeLabel]) candidateNodeLabelCountMap[cNodeLabel] = 1;else candidateNodeLabelCountMap[cNodeLabel]++;\n }); // 根据 candidate 和 neighborNodes 中的节点生成 G 的诱导子图\n // 即,将 graphData 上两端都在 candidateGraph.nodes 中的边放入 candidateEdges\n\n var candidateEdges = [];\n var edgeLabelCountMap = {};\n graphData.edges.forEach(function (edge) {\n if (candidateNodeMap[edge.source] && candidateNodeMap[edge.target]) {\n candidateEdges.push(edge);\n if (!edgeLabelCountMap[edge[edgeLabelProp]]) edgeLabelCountMap[edge[edgeLabelProp]] = 1;else edgeLabelCountMap[edge[edgeLabelProp]]++;\n candidateNodeMap[edge.source].degree++;\n candidateNodeMap[edge.target].degree++;\n candidateNodeMap[edge.source].outDegree++;\n candidateNodeMap[edge.target].inDegree++;\n }\n }); // prune:若有一个 edgeLabel 在 candidateGraph 上的个数少于 pattern,去除该图\n\n var pattenrEdgeLabelNum = Object.keys(patternEdgeLabelMap).length;\n var prunedByEdgeLabel = false;\n\n for (var e = 0; e < pattenrEdgeLabelNum; e++) {\n var label_1 = Object.keys(patternEdgeLabelMap)[e];\n\n if (!edgeLabelCountMap[label_1] || edgeLabelCountMap[label_1] < patternEdgeLabelMap[label_1].length) {\n prunedByEdgeLabel = true;\n break;\n }\n }\n\n if (prunedByEdgeLabel) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n } // 遍历 candidateEdges,进行边的筛选\n\n\n var candidateEdgeNum = candidateEdges.length; // prune:若边数过少,去除该图\n\n if (candidateEdgeNum < pattern.edges.length) {\n candidateGraphs.splice(i, 1);\n return \"break\";\n }\n\n var candidateGraphInvalid = false;\n\n var _loop_5 = function _loop_5(e) {\n var edge = candidateEdges[e];\n var edgeLabel = edge[edgeLabelProp];\n var patternEdgesWithLabel = patternEdgeLabelMap[edgeLabel]; // prune 1: 若边的 label 不存在于 pattern 边 label 中,去除该边\n\n if (!patternEdgesWithLabel || !patternEdgesWithLabel.length) {\n edgeLabelCountMap[edgeLabel]--; // 若这个 label 的 count 减少之后,该 label 的边数不足,去除该图\n\n if (patternEdgesWithLabel && edgeLabelCountMap[edgeLabel] < patternEdgesWithLabel.length) {\n candidateGraphInvalid = true;\n return \"break\";\n }\n\n candidateEdges.splice(e, 1);\n candidateNodeMap[edge.source].degree--;\n candidateNodeMap[edge.target].degree--;\n candidateNodeMap[edge.source].outDegree--;\n candidateNodeMap[edge.target].inDegree--;\n return \"continue\";\n } // prune 2: 若边的 label +两端 label 的三元组关系不能在 pattern 中找到,去除该边\n\n\n var sourceLabel = candidateNodeMap[edge.source].node[nodeLabelProp];\n var targetLabel = candidateNodeMap[edge.target].node[nodeLabelProp];\n var edgeMatched = false;\n patternEdgesWithLabel.forEach(function (patternEdge) {\n var patternSource = patternNodeMap[patternEdge.source].node;\n var patternTarget = patternNodeMap[patternEdge.target].node;\n if (patternSource[nodeLabelProp] === sourceLabel && patternTarget[nodeLabelProp] === targetLabel) edgeMatched = true;\n if (!directed && patternSource[nodeLabelProp] === targetLabel && patternTarget[nodeLabelProp] === sourceLabel) edgeMatched = true;\n });\n\n if (!edgeMatched) {\n edgeLabelCountMap[edgeLabel]--; // 若这个 label 的 count 减少之后,该 label 的边数不足,去除该图\n\n if (patternEdgesWithLabel && edgeLabelCountMap[edgeLabel] < patternEdgesWithLabel.length) {\n candidateGraphInvalid = true;\n return \"break\";\n }\n\n candidateEdges.splice(e, 1);\n candidateNodeMap[edge.source].degree--;\n candidateNodeMap[edge.target].degree--;\n candidateNodeMap[edge.source].outDegree--;\n candidateNodeMap[edge.target].inDegree--;\n return \"continue\";\n }\n };\n\n for (var e = candidateEdgeNum - 1; e >= 0; e--) {\n var state_2 = _loop_5(e);\n\n if (state_2 === \"break\") break;\n } // prune2: 删除边的过程中,发现边数过少/边 label 数过少时,去除该图\n\n\n if (candidateGraphInvalid) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n }\n\n candidateGraph.edges = candidateEdges;\n var lengthsToCandidate = dijkstra(candidateGraph, candidateGraph.nodes[0].id, false).length;\n Object.keys(lengthsToCandidate).reverse().forEach(function (targetId) {\n if (targetId === candidateGraph.nodes[0].id || candidateGraphInvalid) return; // prune4: 通过上述裁剪,可能导致该邻居子图变为不连通。裁剪掉目前在这个邻居子图中和 candidate(第一个节点)不连通的节点\n\n if (lengthsToCandidate[targetId] === Infinity) {\n var targetNodeLabel = candidateNodeMap[targetId].node[nodeLabelProp];\n candidateNodeLabelCountMap[targetNodeLabel]--;\n\n if (candidateNodeLabelCountMap[targetNodeLabel] < patternNodeLabelMap[targetNodeLabel].length) {\n candidateGraphInvalid = true;\n return;\n }\n\n var idx = candidateGraph.nodes.indexOf(candidateNodeMap[targetId].node);\n candidateGraph.nodes.splice(idx, 1);\n candidateNodeMap[targetId] = undefined;\n return;\n } // prune5: 经过边裁剪后,可能又出现了最短路径过长的节点 (比 pattern 中同 label 的节点到 beginNode 最大最短距离远),删去这些节点\n\n\n var nLabel = nodeMap[targetId].node[nodeLabelProp];\n\n if (!undirectedLengthsToBeginPNodeLabelMap[nLabel] || !undirectedLengthsToBeginPNodeLabelMap[nLabel].length || lengthsToCandidate[targetId] > undirectedLengthsToBeginPNodeLabelMap[nLabel][undirectedLengthsToBeginPNodeLabelMap[nLabel].length - 1]) {\n var targetNodeLabel = candidateNodeMap[targetId].node[nodeLabelProp];\n candidateNodeLabelCountMap[targetNodeLabel]--;\n\n if (candidateNodeLabelCountMap[targetNodeLabel] < patternNodeLabelMap[targetNodeLabel].length) {\n candidateGraphInvalid = true;\n return;\n }\n\n var idx = candidateGraph.nodes.indexOf(candidateNodeMap[targetId].node);\n candidateGraph.nodes.splice(idx, 1);\n candidateNodeMap[targetId] = undefined;\n }\n });\n\n if (candidateGraphInvalid) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n }\n\n var degreeChanged = true;\n var loopCount = 0;\n\n while (degreeChanged && !candidateGraphInvalid) {\n degreeChanged = false; // candidate 度数不足,删去该图\n\n var condition = directed ? candidateNodeMap[candidate.id].degree < patternNodeMap[beginPNode.id].degree || candidateNodeMap[candidate.id].inDegree < patternNodeMap[beginPNode.id].inDegree || candidateNodeMap[candidate.id].outDegree < patternNodeMap[beginPNode.id].outDegree : candidateNodeMap[candidate.id].degree < patternNodeMap[beginPNode.id].degree;\n\n if (condition) {\n candidateGraphInvalid = true;\n break;\n } // candidate label 个数不足,删去该图\n\n\n if (candidateNodeLabelCountMap[candidate[nodeLabelProp]] < patternNodeLabelMap[candidate[nodeLabelProp]].length) {\n candidateGraphInvalid = true;\n break;\n } // prune6:去除度数过小的节点\n\n\n var currentCandidateNodeNum = candidateGraph.nodes.length;\n\n for (var o = currentCandidateNodeNum - 1; o >= 0; o--) {\n var cgNode = candidateGraph.nodes[o];\n var nodeDegree = candidateNodeMap[cgNode.id].degree;\n var nodeInDegree = candidateNodeMap[cgNode.id].inDegree;\n var nodeOutDegree = candidateNodeMap[cgNode.id].outDegree;\n var cNodeLabel = cgNode[nodeLabelProp];\n\n var _d = stashPatternNodeLabelDegreeMap(minPatternNodeLabelDegreeMap, cNodeLabel, patternNodeMap, patternNodeLabelMap),\n minPatternNodeLabelDegree = _d.minPatternNodeLabelDegree,\n minPatternNodeLabelInDegree = _d.minPatternNodeLabelInDegree,\n minPatternNodeLabelOutDegree = _d.minPatternNodeLabelOutDegree;\n\n var deleteCondition = directed ? nodeDegree < minPatternNodeLabelDegree || nodeInDegree < minPatternNodeLabelInDegree || nodeOutDegree < minPatternNodeLabelOutDegree : nodeDegree < minPatternNodeLabelDegree;\n\n if (deleteCondition) {\n candidateNodeLabelCountMap[cgNode[nodeLabelProp]]--; // 节点 label 个数不足\n\n if (candidateNodeLabelCountMap[cgNode[nodeLabelProp]] < patternNodeLabelMap[cgNode[nodeLabelProp]].length) {\n candidateGraphInvalid = true;\n break;\n }\n\n candidateGraph.nodes.splice(o, 1);\n candidateNodeMap[cgNode.id] = undefined;\n degreeChanged = true;\n }\n }\n\n if (candidateGraphInvalid || !degreeChanged && loopCount !== 0) break; // 经过 prune5 节点裁剪,删去端点已经不在 candidateGraph 中的边\n\n candidateEdgeNum = candidateEdges.length;\n\n for (var y = candidateEdgeNum - 1; y >= 0; y--) {\n var cedge = candidateEdges[y];\n\n if (!candidateNodeMap[cedge.source] || !candidateNodeMap[cedge.target]) {\n candidateEdges.splice(y, 1);\n var edgeLabel = cedge[edgeLabelProp];\n edgeLabelCountMap[edgeLabel]--;\n\n if (candidateNodeMap[cedge.source]) {\n candidateNodeMap[cedge.source].degree--;\n candidateNodeMap[cedge.source].outDegree--;\n }\n\n if (candidateNodeMap[cedge.target]) {\n candidateNodeMap[cedge.target].degree--;\n candidateNodeMap[cedge.target].inDegree--;\n } // 边 label 数量不足\n\n\n if (patternEdgeLabelMap[edgeLabel] && edgeLabelCountMap[edgeLabel] < patternEdgeLabelMap[edgeLabel].length) {\n candidateGraphInvalid = true;\n break;\n }\n\n degreeChanged = true;\n }\n }\n\n loopCount++;\n }\n\n if (candidateGraphInvalid) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n } // prune: 若节点/边数过少,节点/边 label 过少,去掉这个图\n\n\n if (candidateGraphInvalid || candidateGraph.nodes.length < pattern.nodes.length || candidateEdges.length < pattern.edges.length) {\n candidateGraphs.splice(i, 1);\n return \"continue\";\n }\n };\n\n for (var i = candidateGraphNum - 1; i >= 0; i--) {\n var state_1 = _loop_2(i);\n\n if (state_1 === \"break\") break;\n } // 此时已经生成的多个 candidateGraphs,可能有重复\n // console.log(\n // \"----- stage5: going to splice dulplicated candidate graphs -------\"\n // );\n // 删去 candidateGraphs 中一模一样的子图,通过边的 node-node-edgeLabel 作为 key,这类边个数作为 value,进行匹配\n\n\n var currentLength = candidateGraphs.length;\n\n var _loop_3 = function _loop_3(i) {\n var cg1 = candidateGraphs[i];\n var cg1EdgeMap = {}; // [node1.id-node2.id-edge.label]: count\n\n cg1.edges.forEach(function (edge) {\n var key = edge.source + \"-\" + edge.target + \"-\" + edge.label;\n if (!cg1EdgeMap[key]) cg1EdgeMap[key] = 1;else cg1EdgeMap[key]++;\n });\n\n var _loop_6 = function _loop_6(j) {\n var cg2 = candidateGraphs[j];\n var cg2EdgeMap = {}; // [node1.id-node2.id-edge.label]: count\n\n cg2.edges.forEach(function (edge) {\n var key = edge.source + \"-\" + edge.target + \"-\" + edge.label;\n if (!cg2EdgeMap[key]) cg2EdgeMap[key] = 1;else cg2EdgeMap[key]++;\n });\n var same = true;\n\n if (Object.keys(cg2EdgeMap).length !== Object.keys(cg1EdgeMap).length) {\n same = false;\n } else {\n Object.keys(cg1EdgeMap).forEach(function (key) {\n if (cg2EdgeMap[key] !== cg1EdgeMap[key]) same = false;\n });\n }\n\n if (same) {\n candidateGraphs.splice(j, 1);\n }\n };\n\n for (var j = currentLength - 1; j > i; j--) {\n _loop_6(j);\n }\n\n currentLength = candidateGraphs.length;\n };\n\n for (var i = 0; i <= currentLength - 1; i++) {\n _loop_3(i);\n }\n\n return candidateGraphs;\n};\n\nexport default GADDI;","import LinkedList from './linked-list';\n\nvar Stack = function () {\n function Stack(maxStep) {\n if (maxStep === void 0) {\n maxStep = 10;\n }\n\n this.linkedList = new LinkedList();\n this.maxStep = maxStep;\n }\n\n Object.defineProperty(Stack.prototype, \"length\", {\n get: function get() {\n return this.linkedList.toArray().length;\n },\n enumerable: false,\n configurable: true\n });\n /**\n * 判断栈是否为空,如果链表中没有头部元素,则栈为空\n */\n\n Stack.prototype.isEmpty = function () {\n return !this.linkedList.head;\n };\n /**\n * 是否到定义的栈的最大长度,如果达到最大长度后,不再允许入栈\n */\n\n\n Stack.prototype.isMaxStack = function () {\n return this.toArray().length >= this.maxStep;\n };\n /**\n * 访问顶端元素\n */\n\n\n Stack.prototype.peek = function () {\n if (this.isEmpty()) {\n return null;\n } // 返回头部元素,不删除元素\n\n\n return this.linkedList.head.value;\n };\n\n Stack.prototype.push = function (value) {\n this.linkedList.prepend(value);\n\n if (this.length > this.maxStep) {\n this.linkedList.deleteTail();\n }\n };\n\n Stack.prototype.pop = function () {\n var removeHead = this.linkedList.deleteHead();\n return removeHead ? removeHead.value : null;\n };\n\n Stack.prototype.toArray = function () {\n return this.linkedList.toArray().map(function (node) {\n return node.value;\n });\n };\n\n Stack.prototype.clear = function () {\n while (!this.isEmpty()) {\n this.pop();\n }\n };\n\n return Stack;\n}();\n\nexport default Stack;","import getAdjMatrix from './adjacent-matrix';\nimport breadthFirstSearch from './bfs';\nimport connectedComponent from './connected-component';\nimport getDegree from './degree';\nimport { getInDegree, getOutDegree } from './degree';\nimport detectCycle, { detectAllCycles, detectAllDirectedCycle, detectAllUndirectedCycle } from './detect-cycle';\nimport depthFirstSearch from './dfs';\nimport dijkstra from './dijkstra';\nimport { findAllPath, findShortestPath } from './find-path';\nimport floydWarshall from './floydWarshall';\nimport labelPropagation from './label-propagation';\nimport louvain from './louvain';\nimport minimumSpanningTree from './mts';\nimport pageRank from './pageRank';\nimport GADDI from './gaddi';\nimport Stack from './structs/stack';\nimport { getNeighbors } from './util';\nvar detectDirectedCycle = detectCycle;\nexport { getAdjMatrix, breadthFirstSearch, connectedComponent, getDegree, getInDegree, getOutDegree, detectCycle, detectDirectedCycle, detectAllCycles, detectAllDirectedCycle, detectAllUndirectedCycle, depthFirstSearch, dijkstra, findAllPath, findShortestPath, floydWarshall, labelPropagation, louvain, minimumSpanningTree, pageRank, getNeighbors, Stack, GADDI };\nexport default {\n getAdjMatrix: getAdjMatrix,\n breadthFirstSearch: breadthFirstSearch,\n connectedComponent: connectedComponent,\n getDegree: getDegree,\n getInDegree: getInDegree,\n getOutDegree: getOutDegree,\n detectCycle: detectCycle,\n detectDirectedCycle: detectDirectedCycle,\n detectAllCycles: detectAllCycles,\n detectAllDirectedCycle: detectAllDirectedCycle,\n detectAllUndirectedCycle: detectAllUndirectedCycle,\n depthFirstSearch: depthFirstSearch,\n dijkstra: dijkstra,\n findAllPath: findAllPath,\n findShortestPath: findShortestPath,\n floydWarshall: floydWarshall,\n labelPropagation: labelPropagation,\n louvain: louvain,\n minimumSpanningTree: minimumSpanningTree,\n pageRank: pageRank,\n getNeighbors: getNeighbors,\n Stack: Stack,\n GADDI: GADDI\n};","import { mat3, vec3, ext, vec2 } from '@antv/matrix-util';\nimport { isArray, each } from '@antv/util';\nvar transform = ext.transform;\n/**\n * 对比对象,用于对象数组排序\n * @param {string} attributeName 排序依据的字段名称\n * @param {number} min 最小值\n * @param {number} max 最大值\n * @return {boolean} bool 布尔\n */\n\nexport var compare = function compare(attributeName) {\n return function (m, n) {\n return m[attributeName] - n[attributeName];\n };\n};\n/**\n * 是否在区间内\n * @param {number} value 值\n * @param {number} min 最小值\n * @param {number} max 最大值\n * @return {boolean} bool 布尔\n */\n\nvar isBetween = function isBetween(value, min, max) {\n return value >= min && value <= max;\n};\n/**\n * 获取两条线段的交点\n * @param {Point} p0 第一条线段起点\n * @param {Point} p1 第一条线段终点\n * @param {Point} p2 第二条线段起点\n * @param {Point} p3 第二条线段终点\n * @return {Point} 交点\n */\n\n\nexport var getLineIntersect = function getLineIntersect(p0, p1, p2, p3) {\n var tolerance = 0.0001;\n var E = {\n x: p2.x - p0.x,\n y: p2.y - p0.y\n };\n var D0 = {\n x: p1.x - p0.x,\n y: p1.y - p0.y\n };\n var D1 = {\n x: p3.x - p2.x,\n y: p3.y - p2.y\n };\n var kross = D0.x * D1.y - D0.y * D1.x;\n var sqrKross = kross * kross;\n var invertKross = 1 / kross;\n var sqrLen0 = D0.x * D0.x + D0.y * D0.y;\n var sqrLen1 = D1.x * D1.x + D1.y * D1.y;\n\n if (sqrKross > tolerance * sqrLen0 * sqrLen1) {\n var s = (E.x * D1.y - E.y * D1.x) * invertKross;\n var t = (E.x * D0.y - E.y * D0.x) * invertKross;\n if (!isBetween(s, 0, 1) || !isBetween(t, 0, 1)) return null;\n return {\n x: p0.x + s * D0.x,\n y: p0.y + s * D0.y\n };\n }\n\n return null;\n};\n/**\n * point and rectangular intersection point\n * @param {IRect} rect rect\n * @param {Point} point point\n * @return {PointPoint} rst;\n */\n\nexport var getRectIntersectByPoint = function getRectIntersectByPoint(rect, point) {\n var x = rect.x,\n y = rect.y,\n width = rect.width,\n height = rect.height;\n var cx = x + width / 2;\n var cy = y + height / 2;\n var points = [];\n var center = {\n x: cx,\n y: cy\n };\n points.push({\n x: x,\n y: y\n });\n points.push({\n x: x + width,\n y: y\n });\n points.push({\n x: x + width,\n y: y + height\n });\n points.push({\n x: x,\n y: y + height\n });\n points.push({\n x: x,\n y: y\n });\n var rst = null;\n\n for (var i = 1; i < points.length; i++) {\n rst = getLineIntersect(points[i - 1], points[i], center, point);\n\n if (rst) {\n break;\n }\n }\n\n return rst;\n};\n/**\n * get point and circle inIntersect\n * @param {ICircle} circle 圆点,x,y,r\n * @param {Point} point 点 x,y\n * @return {Point} applied point\n */\n\nexport var getCircleIntersectByPoint = function getCircleIntersectByPoint(circle, point) {\n var cx = circle.x,\n cy = circle.y,\n r = circle.r;\n var x = point.x,\n y = point.y;\n var dx = x - cx;\n var dy = y - cy;\n var d = Math.sqrt(dx * dx + dy * dy);\n\n if (d < r) {\n return null;\n }\n\n var signX = Math.sign(dx);\n var signY = Math.sign(dy);\n var angle = Math.atan(dy / dx);\n return {\n x: cx + Math.abs(r * Math.cos(angle)) * signX,\n y: cy + Math.abs(r * Math.sin(angle)) * signY\n };\n};\n/**\n * get point and ellipse inIntersect\n * @param {Object} ellipse 椭圆 x,y,rx,ry\n * @param {Object} point 点 x,y\n * @return {object} applied point\n */\n\nexport var getEllipseIntersectByPoint = function getEllipseIntersectByPoint(ellipse, point) {\n var a = ellipse.rx;\n var b = ellipse.ry;\n var cx = ellipse.x;\n var cy = ellipse.y;\n var dx = point.x - cx;\n var dy = point.y - cy; // 直接通过 x,y 求夹角,求出来的范围是 -PI, PI\n\n var angle = Math.atan2(dy / b, dx / a);\n\n if (angle < 0) {\n angle += 2 * Math.PI; // 转换到 0,2PI\n }\n\n return {\n x: cx + a * Math.cos(angle),\n y: cy + b * Math.sin(angle)\n };\n};\n/**\n * coordinate matrix transformation\n * @param {number} point coordinate\n * @param {Matrix} matrix matrix\n * @param {number} tag could be 0 or 1\n * @return {Point} transformed point\n */\n\nexport var applyMatrix = function applyMatrix(point, matrix, tag) {\n if (tag === void 0) {\n tag = 1;\n }\n\n var vector = [point.x, point.y, tag];\n\n if (!matrix || isNaN(matrix[0])) {\n matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n vec3.transformMat3(vector, vector, matrix);\n return {\n x: vector[0],\n y: vector[1]\n };\n};\n/**\n * coordinate matrix invert transformation\n * @param {number} point coordinate\n * @param {number} matrix matrix\n * @param {number} tag could be 0 or 1\n * @return {object} transformed point\n */\n\nexport var invertMatrix = function invertMatrix(point, matrix, tag) {\n if (tag === void 0) {\n tag = 1;\n }\n\n if (!matrix || isNaN(matrix[0])) {\n matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n var inversedMatrix = mat3.invert([1, 0, 0, 0, 1, 0, 0, 0, 1], matrix);\n\n if (!inversedMatrix) {\n inversedMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n var vector = [point.x, point.y, tag];\n vec3.transformMat3(vector, vector, inversedMatrix);\n return {\n x: vector[0],\n y: vector[1]\n };\n};\n/**\n *\n * @param p1 First coordinate\n * @param p2 second coordinate\n * @param p3 three coordinate\n */\n\nexport var getCircleCenterByPoints = function getCircleCenterByPoints(p1, p2, p3) {\n var a = p1.x - p2.x;\n var b = p1.y - p2.y;\n var c = p1.x - p3.x;\n var d = p1.y - p3.y;\n var e = (p1.x * p1.x - p2.x * p2.x - p2.y * p2.y + p1.y * p1.y) / 2;\n var f = (p1.x * p1.x - p3.x * p3.x - p3.y * p3.y + p1.y * p1.y) / 2;\n var denominator = b * c - a * d;\n return {\n x: -(d * e - b * f) / denominator,\n y: -(a * f - c * e) / denominator\n };\n};\n/**\n * get distance by two points\n * @param p1 first point\n * @param p2 second point\n */\n\nexport var distance = function distance(p1, p2) {\n var vx = p1.x - p2.x;\n var vy = p1.y - p2.y;\n return Math.sqrt(vx * vx + vy * vy);\n};\n/**\n * scale matrix\n * @param matrix [ [], [], [] ]\n * @param ratio\n */\n\nexport var scaleMatrix = function scaleMatrix(matrix, ratio) {\n var result = [];\n matrix.forEach(function (row) {\n var newRow = [];\n row.forEach(function (v) {\n newRow.push(v * ratio);\n });\n result.push(newRow);\n });\n return result;\n};\n/**\n * Floyd Warshall algorithm for shortest path distances matrix\n * @param {array} adjMatrix adjacency matrix\n * @return {array} distances shortest path distances matrix\n */\n\nexport var floydWarshall = function floydWarshall(adjMatrix) {\n // initialize\n var dist = [];\n var size = adjMatrix.length;\n\n for (var i = 0; i < size; i += 1) {\n dist[i] = [];\n\n for (var j = 0; j < size; j += 1) {\n if (i === j) {\n dist[i][j] = 0;\n } else if (adjMatrix[i][j] === 0 || !adjMatrix[i][j]) {\n dist[i][j] = Infinity;\n } else {\n dist[i][j] = adjMatrix[i][j];\n }\n }\n } // floyd\n\n\n for (var k = 0; k < size; k += 1) {\n for (var i = 0; i < size; i += 1) {\n for (var j = 0; j < size; j += 1) {\n if (dist[i][j] > dist[i][k] + dist[k][j]) {\n dist[i][j] = dist[i][k] + dist[k][j];\n }\n }\n }\n }\n\n return dist;\n};\n/**\n * get adjacency matrix\n * @param data graph data\n * @param directed whether it's a directed graph\n */\n\nexport var getAdjMatrix = function getAdjMatrix(data, directed) {\n var nodes = data.nodes,\n edges = data.edges;\n var matrix = []; // map node with index in data.nodes\n\n var nodeMap = {};\n\n if (!nodes) {\n throw new Error('invalid nodes data!');\n }\n\n if (nodes) {\n nodes.forEach(function (node, i) {\n nodeMap[node.id] = i;\n var row = [];\n matrix.push(row);\n });\n }\n\n if (edges) {\n edges.forEach(function (e) {\n var source = e.source,\n target = e.target;\n var sIndex = nodeMap[source];\n var tIndex = nodeMap[target];\n matrix[sIndex][tIndex] = 1;\n\n if (!directed) {\n matrix[tIndex][sIndex] = 1;\n }\n });\n }\n\n return matrix;\n};\n/**\n * 平移group\n * @param group Group 实例\n * @param vec 移动向量\n */\n\nexport var translate = function translate(group, vec) {\n group.translate(vec.x, vec.y);\n};\n/**\n * 移动到指定坐标点\n * @param group Group 实例\n * @param point 移动到的坐标点\n */\n\nexport var move = function move(group, point, animate, animateCfg) {\n if (animateCfg === void 0) {\n animateCfg = {\n duration: 500\n };\n }\n\n var matrix = group.getMatrix();\n\n if (!matrix) {\n matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n var bbox = group.getCanvasBBox();\n var vx = point.x - bbox.minX;\n var vy = point.y - bbox.minY;\n\n if (animate) {\n var dx_1 = vx * matrix[0];\n var dy_1 = vy * matrix[4];\n var lastX_1 = 0;\n var lastY_1 = 0;\n var newX_1 = 0;\n var newY_1 = 0;\n group.animate(function (ratio) {\n newX_1 = dx_1 * ratio;\n newY_1 = dy_1 * ratio;\n matrix = transform(matrix, [['t', newX_1 - lastX_1, newY_1 - lastY_1]]);\n lastX_1 = newX_1;\n lastY_1 = newY_1;\n return {\n matrix: matrix\n };\n }, animateCfg);\n } else {\n var movedMatrix = transform(matrix, [['t', vx, vy]]);\n group.setMatrix(movedMatrix);\n }\n};\n/**\n * 缩放 group\n * @param group Group 实例\n * @param point 在x 和 y 方向上的缩放比例\n */\n\nexport var scale = function scale(group, ratio) {\n var matrix = group.getMatrix();\n\n if (!matrix) {\n matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n var scaleXY = ratio;\n\n if (!isArray(ratio)) {\n scaleXY = [ratio, ratio];\n }\n\n if (isArray(ratio) && ratio.length === 1) {\n scaleXY = [ratio[0], ratio[0]];\n }\n\n matrix = transform(matrix, [['s', scaleXY[0], scaleXY[1]]]);\n group.setMatrix(matrix);\n};\n/**\n *\n * @param group Group 实例\n * @param ratio 选择角度\n */\n\nexport var rotate = function rotate(group, angle) {\n var matrix = group.getMatrix();\n\n if (!matrix) {\n matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n matrix = transform(matrix, [['r', angle]]);\n group.setMatrix(matrix);\n};\nexport var getDegree = function getDegree(n, nodeIdxMap, edges) {\n var degrees = [];\n\n for (var i = 0; i < n; i++) {\n degrees[i] = 0;\n }\n\n edges.forEach(function (e) {\n if (e.source) {\n degrees[nodeIdxMap[e.source]] += 1;\n }\n\n if (e.target) {\n degrees[nodeIdxMap[e.target]] += 1;\n }\n });\n return degrees;\n}; // 判断点Q是否在p1和p2的线段上\n\nfunction onSegment(p1, p2, q) {\n if ((q[0] - p1[0]) * (p2[1] - p1[1]) === (p2[0] - p1[0]) * (q[1] - p1[1]) && Math.min(p1[0], p2[0]) <= q[0] && q[0] <= Math.max(p1[0], p2[0]) && Math.min(p1[1], p2[1]) <= q[1] && q[1] <= Math.max(p1[1], p2[1])) {\n return true;\n }\n\n return false;\n}\n/**\n * 判断点P在多边形内-射线法. Borrow from https://github.com/antvis/util/blob/master/packages/path-util/src/point-in-polygon.ts\n * @param points\n * @param x\n * @param y\n */\n\n\nexport var isPointInPolygon = function isPointInPolygon(points, x, y) {\n var isHit = false;\n var n = points.length; // 判断两个double在eps精度下的大小关系\n\n var tolerance = 1e-6;\n\n function dcmp(xValue) {\n if (Math.abs(xValue) < tolerance) {\n return 0;\n }\n\n return xValue < 0 ? -1 : 1;\n }\n\n if (n <= 2) {\n // svg 中点小于 3 个时,不显示,也无法被拾取\n return false;\n }\n\n for (var i = 0; i < n; i++) {\n var p1 = points[i];\n var p2 = points[(i + 1) % n];\n\n if (onSegment(p1, p2, [x, y])) {\n // 点在多边形一条边上\n return true;\n } // 前一个判断min(p1[1],p2[1])<P.y<=max(p1[1],p2[1])\n // 后一个判断被测点 在 射线与边交点 的左边\n\n\n if (dcmp(p1[1] - y) > 0 !== dcmp(p2[1] - y) > 0 && dcmp(x - (y - p1[1]) * (p1[0] - p2[0]) / (p1[1] - p2[1]) - p1[0]) < 0) {\n isHit = !isHit;\n }\n }\n\n return isHit;\n}; // 判断两个BBox是否相交\n\nexport var intersectBBox = function intersectBBox(box1, box2) {\n return !(box2.minX > box1.maxX || box2.maxX < box1.minX || box2.minY > box1.maxY || box2.maxY < box1.minY);\n};\n\nvar lineIntersectPolygon = function lineIntersectPolygon(lines, line) {\n var isIntersect = false;\n each(lines, function (l) {\n if (getLineIntersect(l.from, l.to, line.from, line.to)) {\n isIntersect = true;\n return false;\n }\n });\n return isIntersect;\n};\n/**\n * 判断两个polygon是否相交。\n * borrow from @antv/path-util\n * @param points1 polygon1的顶点数组\n * @param points2 polygon2的顶点数组\n */\n\n\nexport var isPolygonsIntersect = function isPolygonsIntersect(points1, points2) {\n var getBBox = function getBBox(points) {\n var xArr = points.map(function (p) {\n return p[0];\n });\n var yArr = points.map(function (p) {\n return p[1];\n });\n return {\n minX: Math.min.apply(null, xArr),\n maxX: Math.max.apply(null, xArr),\n minY: Math.min.apply(null, yArr),\n maxY: Math.max.apply(null, yArr)\n };\n };\n\n var parseToLines = function parseToLines(points) {\n var lines = [];\n var count = points.length;\n\n for (var i = 0; i < count - 1; i++) {\n var point = points[i];\n var next = points[i + 1];\n lines.push({\n from: {\n x: point[0],\n y: point[1]\n },\n to: {\n x: next[0],\n y: next[1]\n }\n });\n }\n\n if (lines.length > 1) {\n var first = points[0];\n var last = points[count - 1];\n lines.push({\n from: {\n x: last[0],\n y: last[1]\n },\n to: {\n x: first[0],\n y: first[1]\n }\n });\n }\n\n return lines;\n }; // 空数组,或者一个点返回 false\n\n\n if (points1.length < 2 || points2.length < 2) {\n return false;\n }\n\n var bbox1 = getBBox(points1);\n var bbox2 = getBBox(points2); // 判定包围盒是否相交,比判定点是否在多边形内要快的多,可以筛选掉大多数情况\n\n if (!intersectBBox(bbox1, bbox2)) {\n return false;\n }\n\n var isIn = false; // 判定点是否在多边形内部,一旦有一个点在另一个多边形内,则返回\n\n each(points2, function (point) {\n if (isPointInPolygon(points1, point[0], point[1])) {\n isIn = true;\n return false;\n }\n });\n\n if (isIn) {\n return true;\n }\n\n each(points1, function (point) {\n if (isPointInPolygon(points2, point[0], point[1])) {\n isIn = true;\n return false;\n }\n });\n\n if (isIn) {\n return true;\n }\n\n var lines1 = parseToLines(points1);\n var lines2 = parseToLines(points2);\n var isIntersect = false;\n each(lines2, function (line) {\n if (lineIntersectPolygon(lines1, line)) {\n isIntersect = true;\n return false;\n }\n });\n return isIntersect;\n};\n\nvar Line = function () {\n function Line(x1, y1, x2, y2) {\n this.x1 = x1;\n this.y1 = y1;\n this.x2 = x2;\n this.y2 = y2;\n }\n\n Line.prototype.getBBox = function () {\n var minX = Math.min(this.x1, this.x2);\n var minY = Math.min(this.y1, this.y2);\n var maxX = Math.max(this.x1, this.x2);\n var maxY = Math.max(this.y1, this.y2);\n var res = {\n x: minX,\n y: minY,\n minX: minX,\n minY: minY,\n maxX: maxX,\n maxY: maxY,\n width: maxX - minX,\n height: maxY - minY\n };\n return res;\n };\n\n return Line;\n}();\n\nexport { Line };\nexport var getBBoxBoundLine = function getBBoxBoundLine(bbox, direction) {\n var bounds = {\n top: [bbox.minX, bbox.minY, bbox.maxX, bbox.minY],\n left: [bbox.minX, bbox.minY, bbox.minX, bbox.maxY],\n bottom: [bbox.minX, bbox.maxY, bbox.maxX, bbox.maxY],\n right: [bbox.maxX, bbox.minY, bbox.maxX, bbox.maxY]\n };\n return bounds[direction];\n};\n/**\n * 计算两条线段相交时,相交点对第一条线段上的分割比例\n */\n\nvar fractionAlongLineA = function fractionAlongLineA(la, lb) {\n var uaT = (lb.x2 - lb.x1) * (la.y1 - lb.y1) - (lb.y2 - lb.y1) * (la.x1 - lb.x1);\n var ubT = (la.x2 - la.x1) * (la.y1 - lb.y1) - (la.y2 - la.y1) * (la.x1 - lb.x1);\n var uB = (lb.y2 - lb.y1) * (la.x2 - la.x1) - (lb.x2 - lb.x1) * (la.y2 - la.y1);\n\n if (uB) {\n var ua = uaT / uB;\n var ub = ubT / uB;\n\n if (ua >= 0 && ua <= 1 && ub >= 0 && ub <= 1) {\n return ua;\n }\n }\n\n return Number.POSITIVE_INFINITY;\n};\n\nexport var itemIntersectByLine = function itemIntersectByLine(item, line) {\n var directions = ['top', 'left', 'bottom', 'right'];\n var bbox = item.getBBox();\n var countIntersections = 0;\n var intersections = [];\n\n for (var i = 0; i < 4; i++) {\n var _a = getBBoxBoundLine(bbox, directions[i]),\n x1 = _a[0],\n y1 = _a[1],\n x2 = _a[2],\n y2 = _a[3];\n\n intersections[i] = getLineIntersect({\n x: line.x1,\n y: line.y1\n }, {\n x: line.x2,\n y: line.y2\n }, {\n x: x1,\n y: y1\n }, {\n x: x2,\n y: y2\n });\n\n if (intersections[i]) {\n countIntersections += 1;\n }\n }\n\n return [intersections, countIntersections];\n};\nexport var fractionToLine = function fractionToLine(item, line) {\n var directions = ['top', 'left', 'bottom', 'right'];\n var bbox = item.getBBox();\n var minDistance = Number.POSITIVE_INFINITY;\n var countIntersections = 0;\n\n for (var i = 0; i < 4; i++) {\n var _a = getBBoxBoundLine(bbox, directions[i]),\n x1 = _a[0],\n y1 = _a[1],\n x2 = _a[2],\n y2 = _a[3];\n\n var testDistance = fractionAlongLineA(line, new Line(x1, y1, x2, y2));\n testDistance = Math.abs(testDistance - 0.5);\n\n if (testDistance >= 0 && testDistance <= 1) {\n countIntersections += 1;\n minDistance = testDistance < minDistance ? testDistance : minDistance;\n }\n }\n\n if (countIntersections === 0) return -1;\n return minDistance;\n};\nexport var getPointsCenter = function getPointsCenter(points) {\n var centerX = 0;\n var centerY = 0;\n\n if (points.length > 0) {\n for (var _i = 0, points_1 = points; _i < points_1.length; _i++) {\n var point = points_1[_i];\n centerX += point.x;\n centerY += point.y;\n }\n\n centerX /= points.length;\n centerY /= points.length;\n }\n\n return {\n x: centerX,\n y: centerY\n };\n};\nexport var squareDist = function squareDist(a, b) {\n return Math.pow(a.x - b.x, 2) + Math.pow(a.y - b.y, 2);\n};\nexport var pointLineSquareDist = function pointLineSquareDist(point, line) {\n var x1 = line.x1;\n var y1 = line.y1;\n var x2 = line.x2 - x1;\n var y2 = line.y2 - y1;\n var px = point.x - x1;\n var py = point.y - y1;\n var dotprod = px * x2 + py * y2;\n var projlenSq;\n\n if (dotprod <= 0) {\n projlenSq = 0;\n } else {\n px = x2 - px;\n py = y2 - py;\n dotprod = px * x2 + py * y2;\n\n if (dotprod <= 0) {\n projlenSq = 0;\n } else {\n projlenSq = dotprod * dotprod / (x2 * x2 + y2 * y2);\n }\n }\n\n var lenSq = px * px + py * py - projlenSq;\n\n if (lenSq < 0) {\n lenSq = 0;\n }\n\n return lenSq;\n};\nexport var isPointsOverlap = function isPointsOverlap(p1, p2, e) {\n if (e === void 0) {\n e = 1e-3;\n }\n\n return Math.pow(p1.x - p2.x, 2) + Math.pow(p1.y - p2.y, 2) < Math.pow(e, 2);\n};\n/**\n * 点到矩形的距离的平方:矩形内部点视作距离为0,外部的点若投影落在矩形边上则为点到矩形边的最近的垂直距离,否则为点到矩形顶点的距离,\n * @param point IPoint\n * @param rect IRect\n */\n\nexport var pointRectSquareDist = function pointRectSquareDist(point, rect) {\n var isLeft = point.x < rect.x;\n var isRight = point.x > rect.x + rect.width;\n var isTop = point.y > rect.y + rect.height;\n var isBottom = point.y < rect.y;\n var isPointOutside = isLeft || isRight || isTop || isBottom;\n\n if (!isPointOutside) {\n return 0;\n }\n\n if (isTop && !isLeft && !isRight) {\n return Math.pow(rect.y + rect.height - point.y, 2);\n }\n\n if (isBottom && !isLeft && !isRight) {\n return Math.pow(point.y - rect.y, 2);\n }\n\n if (isLeft && !isTop && !isBottom) {\n return Math.pow(rect.x - point.x, 2);\n }\n\n if (isRight && !isTop && !isBottom) {\n return Math.pow(rect.x + rect.width - point.x, 2);\n }\n\n var dx = Math.min(Math.abs(rect.x - point.x), Math.abs(rect.x + rect.width - point.x));\n var dy = Math.min(Math.abs(rect.y - point.y), Math.abs(rect.y + rect.height - point.y));\n return dx * dx + dy * dy;\n};\n/**\n * point to line distance\n * @param {array} line 线的四个顶点 [x1, y1, x2, y2]\n * @param {object} point 坐标点 {x, y}\n * @return {Number|NaN} distance\n */\n\nexport var pointLineDistance = function pointLineDistance(line, point) {\n var x1 = line[0],\n y1 = line[1],\n x2 = line[2],\n y2 = line[3];\n var x = point.x,\n y = point.y;\n var d = [x2 - x1, y2 - y1];\n\n if (vec2.exactEquals(d, [0, 0])) {\n return NaN;\n }\n\n var u = [-d[1], d[0]]; // @ts-ignore\n\n vec2.normalize(u, u);\n var a = [x - x1, y - y1]; // @ts-ignore\n\n return Math.abs(vec2.dot(a, u));\n};","var subjectColor = 'rgb(95, 149, 255)';\nvar backColor = 'rgb(255, 255, 255)';\nvar textColor = 'rgb(0, 0, 0)';\nvar activeFill = 'rgb(247, 250, 255)';\nvar nodeMainFill = 'rgb(239, 244, 255)';\nvar comboFill = 'rgb(253, 253, 253)';\nvar disabledFill = 'rgb(250, 250, 250)';\nvar edgeMainStroke = 'rgb(224, 224, 224)';\nvar edgeInactiveStroke = 'rgb(234, 234, 234)';\nvar edgeDisablesStroke = 'rgb(245, 245, 245)';\nvar inactiveStroke = 'rgb(191, 213, 255)';\nvar highlightStroke = '#4572d9';\nvar highlightFill = 'rgb(223, 234, 255)';\nvar colorSet = {\n // for nodes\n mainStroke: subjectColor,\n mainFill: nodeMainFill,\n activeStroke: subjectColor,\n activeFill: activeFill,\n inactiveStroke: inactiveStroke,\n inactiveFill: activeFill,\n selectedStroke: subjectColor,\n selectedFill: backColor,\n highlightStroke: highlightStroke,\n highlightFill: highlightFill,\n disableStroke: edgeMainStroke,\n disableFill: disabledFill,\n // for edges\n edgeMainStroke: edgeMainStroke,\n edgeActiveStroke: subjectColor,\n edgeInactiveStroke: edgeInactiveStroke,\n edgeSelectedStroke: subjectColor,\n edgeHighlightStroke: subjectColor,\n edgeDisableStroke: edgeDisablesStroke,\n // for combos\n comboMainStroke: edgeMainStroke,\n comboMainFill: comboFill,\n comboActiveStroke: subjectColor,\n comboActiveFill: activeFill,\n comboInactiveStroke: edgeMainStroke,\n comboInactiveFill: comboFill,\n comboSelectedStroke: subjectColor,\n comboSelectedFill: comboFill,\n comboHighlightStroke: highlightStroke,\n comboHighlightFill: comboFill,\n comboDisableStroke: edgeInactiveStroke,\n comboDisableFill: disabledFill\n};\nexport default {\n version: '0.3.11',\n rootContainerClassName: 'root-container',\n nodeContainerClassName: 'node-container',\n edgeContainerClassName: 'edge-container',\n comboContainerClassName: 'combo-container',\n delegateContainerClassName: 'delegate-container',\n defaultLoopPosition: 'top',\n nodeLabel: {\n style: {\n fill: '#000',\n fontSize: 12,\n textAlign: 'center',\n textBaseline: 'middle'\n },\n offset: 4 // 节点的默认文本不居中时的偏移量\n\n },\n defaultNode: {\n type: 'circle',\n style: {\n lineWidth: 1,\n stroke: colorSet.mainStroke,\n fill: nodeMainFill\n },\n size: 20,\n color: colorSet.mainStroke,\n linkPoints: {\n size: 8,\n lineWidth: 1,\n fill: colorSet.activeFill,\n stroke: colorSet.activeStroke\n }\n },\n // 节点应用状态后的样式,默认仅提供 active、selected、highlight、inactive、disable,用户可以自己扩展\n nodeStateStyles: {\n active: {\n fill: colorSet.activeFill,\n stroke: colorSet.activeStroke,\n lineWidth: 2,\n shadowColor: colorSet.mainStroke,\n shadowBlur: 10\n },\n selected: {\n fill: colorSet.selectedFill,\n stroke: colorSet.selectedStroke,\n lineWidth: 4,\n shadowColor: colorSet.selectedStroke,\n shadowBlur: 10,\n 'text-shape': {\n fontWeight: 500\n }\n },\n highlight: {\n fill: colorSet.highlightFill,\n stroke: colorSet.highlightStroke,\n lineWidth: 2,\n 'text-shape': {\n fontWeight: 500\n }\n },\n inactive: {\n fill: colorSet.inactiveFill,\n stroke: colorSet.inactiveStroke,\n lineWidth: 1\n },\n disable: {\n fill: colorSet.disableFill,\n stroke: colorSet.disableStroke,\n lineWidth: 1\n }\n },\n edgeLabel: {\n style: {\n fill: textColor,\n textAlign: 'center',\n textBaseline: 'middle',\n fontSize: 12\n }\n },\n defaultEdge: {\n type: 'line',\n size: 1,\n style: {\n stroke: colorSet.edgeMainStroke,\n lineAppendWidth: 2\n },\n color: colorSet.edgeMainStroke\n },\n // 边应用状态后的样式,默认仅提供 active、selected、highlight、inactive、disable,用户可以自己扩展\n edgeStateStyles: {\n active: {\n stroke: colorSet.edgeActiveStroke,\n lineWidth: 1\n },\n selected: {\n stroke: colorSet.edgeSelectedStroke,\n lineWidth: 2,\n shadowColor: colorSet.edgeSelectedStroke,\n shadowBlur: 10,\n 'text-shape': {\n fontWeight: 500\n }\n },\n highlight: {\n stroke: colorSet.edgeHighlightStroke,\n lineWidth: 2,\n 'text-shape': {\n fontWeight: 500\n }\n },\n inactive: {\n stroke: colorSet.edgeInactiveStroke,\n lineWidth: 1\n },\n disable: {\n stroke: colorSet.edgeDisableStroke,\n lineWidth: 1\n }\n },\n comboLabel: {\n style: {\n fill: textColor,\n // textAlign: 'center',\n textBaseline: 'middle',\n fontSize: 12\n },\n refY: 10,\n refX: 10 // Combo 的默认文本不居中时的偏移量\n\n },\n defaultCombo: {\n type: 'circle',\n style: {\n fill: colorSet.comboMainFill,\n lineWidth: 1,\n stroke: colorSet.comboMainStroke,\n r: 5,\n width: 20,\n height: 10\n },\n size: [20, 5],\n color: colorSet.comboMainStroke,\n padding: [25, 20, 15, 20]\n },\n // combo 应用状态后的样式,默认仅提供 active、selected、highlight、inactive、disable,用户可以自己扩展\n comboStateStyles: {\n active: {\n stroke: colorSet.comboActiveStroke,\n lineWidth: 1,\n fill: colorSet.comboActiveFill\n },\n selected: {\n stroke: colorSet.comboSelectedStroke,\n lineWidth: 2,\n fill: colorSet.comboSelectedFill,\n shadowColor: colorSet.comboSelectedStroke,\n shadowBlur: 10,\n 'text-shape': {\n fontWeight: 500\n }\n },\n highlight: {\n stroke: colorSet.comboHighlightStroke,\n lineWidth: 2,\n fill: colorSet.comboHighlightFill,\n 'text-shape': {\n fontWeight: 500\n }\n },\n inactive: {\n stroke: colorSet.comboInactiveStroke,\n fill: colorSet.comboInactiveFill,\n lineWidth: 1\n },\n disable: {\n stroke: colorSet.comboDisableStroke,\n fill: colorSet.comboDisableFill,\n lineWidth: 1\n }\n },\n delegateStyle: {\n fill: '#F3F9FF',\n fillOpacity: 0.5,\n stroke: '#1890FF',\n strokeOpacity: 0.9,\n lineDash: [5, 5]\n }\n};","export default {\n ' ': 0.3329986572265625,\n a: 0.5589996337890625,\n A: 0.6569992065429687,\n b: 0.58599853515625,\n B: 0.6769989013671875,\n c: 0.5469985961914062,\n C: 0.7279998779296875,\n d: 0.58599853515625,\n D: 0.705999755859375,\n e: 0.554998779296875,\n E: 0.63699951171875,\n f: 0.37299957275390627,\n F: 0.5769989013671875,\n g: 0.5909988403320312,\n G: 0.7479995727539063,\n h: 0.555999755859375,\n H: 0.7199996948242188,\n i: 0.255999755859375,\n I: 0.23699951171875,\n j: 0.26699981689453123,\n J: 0.5169998168945312,\n k: 0.5289993286132812,\n K: 0.6899993896484375,\n l: 0.23499908447265624,\n L: 0.5879989624023437,\n m: 0.854998779296875,\n M: 0.8819992065429687,\n n: 0.5589996337890625,\n N: 0.7189987182617188,\n o: 0.58599853515625,\n O: 0.7669998168945312,\n p: 0.58599853515625,\n P: 0.6419998168945312,\n q: 0.58599853515625,\n Q: 0.7669998168945312,\n r: 0.3649993896484375,\n R: 0.6759994506835938,\n s: 0.504998779296875,\n S: 0.6319992065429687,\n t: 0.354998779296875,\n T: 0.6189987182617187,\n u: 0.5599990844726562,\n U: 0.7139999389648437,\n v: 0.48199920654296874,\n V: 0.6389999389648438,\n w: 0.754998779296875,\n W: 0.929998779296875,\n x: 0.5089996337890625,\n X: 0.63699951171875,\n y: 0.4959991455078125,\n Y: 0.66199951171875,\n z: 0.48699951171875,\n Z: 0.6239990234375,\n '0': 0.6,\n '1': 0.40099945068359377,\n '2': 0.6,\n '3': 0.6,\n '4': 0.6,\n '5': 0.6,\n '6': 0.6,\n '7': 0.5469985961914062,\n '8': 0.6,\n '9': 0.6,\n '[': 0.3329986572265625,\n ']': 0.3329986572265625,\n ',': 0.26399993896484375,\n '.': 0.26399993896484375,\n ';': 0.26399993896484375,\n ':': 0.26399993896484375,\n '{': 0.3329986572265625,\n '}': 0.3329986572265625,\n '\\\\': 0.5,\n '|': 0.19499969482421875,\n '=': 0.604998779296875,\n '+': 0.604998779296875,\n '-': 0.604998779296875,\n _: 0.5,\n '`': 0.3329986572265625,\n ' ~': 0.8329986572265625,\n '!': 0.3329986572265625,\n '@': 0.8579986572265625,\n '#': 0.6,\n $: 0.6,\n '%': 0.9699996948242188,\n '^': 0.517999267578125,\n '&': 0.7259994506835937,\n '*': 0.505999755859375,\n '(': 0.3329986572265625,\n ')': 0.3329986572265625,\n '<': 0.604998779296875,\n '>': 0.604998779296875,\n '/': 0.5,\n '?': 0.53699951171875\n};","import { __assign } from \"tslib\";\nimport { vec2 } from '@antv/matrix-util';\nimport Global from '../global';\nimport { applyMatrix } from './math';\nimport letterAspectRatio from './letterAspectRatio';\nimport { isString, clone, isNumber, isObject } from '@antv/util';\nvar PI = Math.PI,\n sin = Math.sin,\n cos = Math.cos; // 一共支持8个方向的自环,每个环占的角度是45度,在计算时再二分,为22.5度\n\nvar SELF_LINK_SIN = sin(PI / 8);\nvar SELF_LINK_COS = cos(PI / 8);\nexport var getBBox = function getBBox(element, group) {\n var bbox = element.getBBox();\n var leftTop = {\n x: bbox.minX,\n y: bbox.minY\n };\n var rightBottom = {\n x: bbox.maxX,\n y: bbox.maxY\n }; // 根据父元素变换矩阵\n\n if (group) {\n var matrix = group.getMatrix();\n\n if (!matrix) {\n matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n leftTop = applyMatrix(leftTop, matrix);\n rightBottom = applyMatrix(rightBottom, matrix);\n }\n\n var lx = leftTop.x,\n ly = leftTop.y;\n var rx = rightBottom.x,\n ry = rightBottom.y;\n return {\n x: lx,\n y: ly,\n minX: lx,\n minY: ly,\n maxX: rx,\n maxY: ry,\n width: rx - lx,\n height: ry - ly\n };\n};\n/**\n * get loop edge config\n * @param cfg edge config\n */\n\nexport var getLoopCfgs = function getLoopCfgs(cfg) {\n var item = cfg.sourceNode || cfg.targetNode;\n var container = item.get('group');\n var containerMatrix = container.getMatrix();\n if (!containerMatrix) containerMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var keyShape = item.getKeyShape();\n var bbox = keyShape.getBBox();\n var loopCfg = cfg.loopCfg || {}; // 距离keyShape边的最高距离\n\n var dist = loopCfg.dist || Math.max(bbox.width, bbox.height) * 2; // 自环边与keyShape的相对位置关系\n\n var position = loopCfg.position || Global.defaultLoopPosition; // 中心取group上真实位置\n\n var center = [containerMatrix[6], containerMatrix[7]];\n var startPoint = [cfg.startPoint.x, cfg.startPoint.y];\n var endPoint = [cfg.endPoint.x, cfg.endPoint.y];\n var rstart = bbox.height / 2;\n var rend = bbox.height / 2;\n var sinDeltaStart = rstart * SELF_LINK_SIN;\n var cosDeltaStart = rstart * SELF_LINK_COS;\n var sinDeltaEnd = rend * SELF_LINK_SIN;\n var cosDeltaEnd = rend * SELF_LINK_COS; // 如果定义了锚点的,直接用锚点坐标,否则,根据自环的 cfg 计算\n\n if (startPoint[0] === endPoint[0] && startPoint[1] === endPoint[1]) {\n switch (position) {\n case 'top':\n startPoint = [center[0] - sinDeltaStart, center[1] - cosDeltaStart];\n endPoint = [center[0] + sinDeltaEnd, center[1] - cosDeltaEnd];\n break;\n\n case 'top-right':\n rstart = bbox.height / 2;\n rend = bbox.width / 2;\n sinDeltaStart = rstart * SELF_LINK_SIN;\n cosDeltaStart = rstart * SELF_LINK_COS;\n sinDeltaEnd = rend * SELF_LINK_SIN;\n cosDeltaEnd = rend * SELF_LINK_COS;\n startPoint = [center[0] + sinDeltaStart, center[1] - cosDeltaStart];\n endPoint = [center[0] + cosDeltaEnd, center[1] - sinDeltaEnd];\n break;\n\n case 'right':\n rstart = bbox.width / 2;\n rend = bbox.width / 2;\n sinDeltaStart = rstart * SELF_LINK_SIN;\n cosDeltaStart = rstart * SELF_LINK_COS;\n sinDeltaEnd = rend * SELF_LINK_SIN;\n cosDeltaEnd = rend * SELF_LINK_COS;\n startPoint = [center[0] + cosDeltaStart, center[1] - sinDeltaStart];\n endPoint = [center[0] + cosDeltaEnd, center[1] + sinDeltaEnd];\n break;\n\n case 'bottom-right':\n rstart = bbox.width / 2;\n rend = bbox.height / 2;\n sinDeltaStart = rstart * SELF_LINK_SIN;\n cosDeltaStart = rstart * SELF_LINK_COS;\n sinDeltaEnd = rend * SELF_LINK_SIN;\n cosDeltaEnd = rend * SELF_LINK_COS;\n startPoint = [center[0] + cosDeltaStart, center[1] + sinDeltaStart];\n endPoint = [center[0] + sinDeltaEnd, center[1] + cosDeltaEnd];\n break;\n\n case 'bottom':\n rstart = bbox.height / 2;\n rend = bbox.height / 2;\n sinDeltaStart = rstart * SELF_LINK_SIN;\n cosDeltaStart = rstart * SELF_LINK_COS;\n sinDeltaEnd = rend * SELF_LINK_SIN;\n cosDeltaEnd = rend * SELF_LINK_COS;\n startPoint = [center[0] + sinDeltaStart, center[1] + cosDeltaStart];\n endPoint = [center[0] - sinDeltaEnd, center[1] + cosDeltaEnd];\n break;\n\n case 'bottom-left':\n rstart = bbox.height / 2;\n rend = bbox.width / 2;\n sinDeltaStart = rstart * SELF_LINK_SIN;\n cosDeltaStart = rstart * SELF_LINK_COS;\n sinDeltaEnd = rend * SELF_LINK_SIN;\n cosDeltaEnd = rend * SELF_LINK_COS;\n startPoint = [center[0] - sinDeltaStart, center[1] + cosDeltaStart];\n endPoint = [center[0] - cosDeltaEnd, center[1] + sinDeltaEnd];\n break;\n\n case 'left':\n rstart = bbox.width / 2;\n rend = bbox.width / 2;\n sinDeltaStart = rstart * SELF_LINK_SIN;\n cosDeltaStart = rstart * SELF_LINK_COS;\n sinDeltaEnd = rend * SELF_LINK_SIN;\n cosDeltaEnd = rend * SELF_LINK_COS;\n startPoint = [center[0] - cosDeltaStart, center[1] + sinDeltaStart];\n endPoint = [center[0] - cosDeltaEnd, center[1] - sinDeltaEnd];\n break;\n\n case 'top-left':\n rstart = bbox.width / 2;\n rend = bbox.height / 2;\n sinDeltaStart = rstart * SELF_LINK_SIN;\n cosDeltaStart = rstart * SELF_LINK_COS;\n sinDeltaEnd = rend * SELF_LINK_SIN;\n cosDeltaEnd = rend * SELF_LINK_COS;\n startPoint = [center[0] - cosDeltaStart, center[1] - sinDeltaStart];\n endPoint = [center[0] - sinDeltaEnd, center[1] - cosDeltaEnd];\n break;\n\n default:\n rstart = bbox.width / 2;\n rend = bbox.width / 2;\n sinDeltaStart = rstart * SELF_LINK_SIN;\n cosDeltaStart = rstart * SELF_LINK_COS;\n sinDeltaEnd = rend * SELF_LINK_SIN;\n cosDeltaEnd = rend * SELF_LINK_COS;\n startPoint = [center[0] - sinDeltaStart, center[1] - cosDeltaStart];\n endPoint = [center[0] + sinDeltaEnd, center[1] - cosDeltaEnd];\n } // 如果逆时针画,交换起点和终点\n\n\n if (loopCfg.clockwise === false) {\n var swap = [startPoint[0], startPoint[1]];\n startPoint = [endPoint[0], endPoint[1]];\n endPoint = [swap[0], swap[1]];\n }\n }\n\n var startVec = [startPoint[0] - center[0], startPoint[1] - center[1]];\n var scaleRateStart = (rstart + dist) / rstart;\n var scaleRateEnd = (rend + dist) / rend;\n\n if (loopCfg.clockwise === false) {\n scaleRateStart = (rend + dist) / rend;\n scaleRateEnd = (rstart + dist) / rstart;\n }\n\n var startExtendVec = vec2.scale([0, 0], startVec, scaleRateStart);\n var controlPoint1 = [center[0] + startExtendVec[0], center[1] + startExtendVec[1]];\n var endVec = [endPoint[0] - center[0], endPoint[1] - center[1]];\n var endExtendVec = vec2.scale([0, 0], endVec, scaleRateEnd);\n var controlPoint2 = [center[0] + endExtendVec[0], center[1] + endExtendVec[1]];\n cfg.startPoint = {\n x: startPoint[0],\n y: startPoint[1]\n };\n cfg.endPoint = {\n x: endPoint[0],\n y: endPoint[1]\n };\n cfg.controlPoints = [{\n x: controlPoint1[0],\n y: controlPoint1[1]\n }, {\n x: controlPoint2[0],\n y: controlPoint2[1]\n }];\n return cfg;\n};\n/**\n * 根据 label 所在线条的位置百分比,计算 label 坐标\n * @param {object} pathShape G 的 path 实例,一般是 Edge 实例的 keyShape\n * @param {number} percent 范围 0 - 1 的线条百分比\n * @param {number} refX x 轴正方向为基准的 label 偏移\n * @param {number} refY y 轴正方向为基准的 label 偏移\n * @param {boolean} rotate 是否根据线条斜率旋转文本\n * @return {object} 文本的 x, y, 文本的旋转角度\n */\n\nexport var getLabelPosition = function getLabelPosition(pathShape, percent, refX, refY, rotate) {\n var TAN_OFFSET = 0.0001;\n var vector = [];\n var point = pathShape === null || pathShape === void 0 ? void 0 : pathShape.getPoint(percent);\n\n if (!point) {\n return {\n x: 0,\n y: 0,\n angle: 0\n };\n } // 头尾最可能,放在最前面,使用 g path 上封装的方法\n\n\n if (percent < TAN_OFFSET) {\n vector = pathShape.getStartTangent().reverse();\n } else if (percent > 1 - TAN_OFFSET) {\n vector = pathShape.getEndTangent();\n } else {\n // 否则取指定位置的点,与少量偏移的点,做微分向量\n var offsetPoint = pathShape === null || pathShape === void 0 ? void 0 : pathShape.getPoint(percent + TAN_OFFSET);\n vector.push([point.x, point.y]);\n vector.push([offsetPoint.x, offsetPoint.y]);\n }\n\n var rad = Math.atan2(vector[1][1] - vector[0][1], vector[1][0] - vector[0][0]);\n\n if (rad < 0) {\n rad += PI * 2;\n }\n\n if (refX) {\n point.x += cos(rad) * refX;\n point.y += sin(rad) * refX;\n }\n\n if (refY) {\n // 默认方向是 x 轴正方向,法线是 求出角度 - 90°\n var normal = rad - PI / 2; // 若法线角度在 y 轴负方向,切到正方向,保证 refY 相对于 y 轴正方向\n\n if (rad > 1 / 2 * PI && rad < 3 * 1 / 2 * PI) {\n normal -= PI;\n }\n\n point.x += cos(normal) * refY;\n point.y += sin(normal) * refY;\n }\n\n var result = {\n x: point.x,\n y: point.y,\n angle: rad\n };\n\n if (rotate) {\n if (rad > 0.5 * PI && rad < 1.5 * PI) {\n rad -= PI;\n }\n\n return __assign({\n rotate: rad\n }, result);\n }\n\n return result;\n};\n/**\n * depth first traverse, from root to leaves, children in inverse order\n * if the fn returns false, terminate the traverse\n */\n\nvar traverse = function traverse(data, fn) {\n if (fn(data) === false) {\n return false;\n }\n\n if (data && data.children) {\n for (var i = data.children.length - 1; i >= 0; i--) {\n if (!traverse(data.children[i], fn)) return false;\n }\n }\n\n return true;\n};\n/**\n * depth first traverse, from leaves to root, children in inverse order\n * if the fn returns false, terminate the traverse\n */\n\n\nvar traverseUp = function traverseUp(data, fn) {\n if (data && data.children) {\n for (var i = data.children.length - 1; i >= 0; i--) {\n if (!traverseUp(data.children[i], fn)) return;\n }\n }\n\n if (fn(data) === false) {\n return false;\n }\n\n return true;\n};\n/**\n * depth first traverse, from root to leaves, children in inverse order\n * if the fn returns false, terminate the traverse\n */\n\n\nexport var traverseTree = function traverseTree(data, fn) {\n if (typeof fn !== 'function') {\n return;\n }\n\n traverse(data, fn);\n};\n/**\n * depth first traverse, from leaves to root, children in inverse order\n * if the fn returns false, terminate the traverse\n */\n\nexport var traverseTreeUp = function traverseTreeUp(data, fn) {\n if (typeof fn !== 'function') {\n return;\n }\n\n traverseUp(data, fn);\n};\n/**\n *\n * @param letter the letter\n * @param fontSize\n * @return the letter's width\n */\n\nexport var getLetterWidth = function getLetterWidth(letter, fontSize) {\n return fontSize * (letterAspectRatio[letter] || 1);\n};\n/**\n *\n * @param text the text\n * @param fontSize\n * @return the text's size\n */\n\nexport var getTextSize = function getTextSize(text, fontSize) {\n var width = 0;\n var pattern = new RegExp(\"[\\u4E00-\\u9FA5]+\");\n text.split('').forEach(function (letter) {\n if (pattern.test(letter)) {\n // 中文字符\n width += fontSize;\n } else {\n width += getLetterWidth(letter, fontSize);\n }\n });\n return [width, fontSize];\n};\n/**\n * construct the trees from combos data\n * @param array the combos array\n * @param nodes the nodes array\n * @return the tree\n */\n\nexport var plainCombosToTrees = function plainCombosToTrees(array, nodes) {\n var result = [];\n var addedMap = {};\n var modelMap = {};\n array.forEach(function (d) {\n modelMap[d.id] = d;\n });\n array.forEach(function (d, i) {\n var cd = clone(d);\n cd.itemType = 'combo';\n cd.children = undefined;\n\n if (cd.parentId === cd.id) {\n console.warn(\"The parentId for combo \" + cd.id + \" can not be the same as the combo's id\");\n delete cd.parentId;\n } else if (cd.parentId && !modelMap[cd.parentId]) {\n console.warn(\"The parent combo for combo \" + cd.id + \" does not exist!\");\n delete cd.parentId;\n }\n\n var mappedObj = addedMap[cd.id];\n\n if (mappedObj) {\n cd.children = mappedObj.children;\n addedMap[cd.id] = cd;\n mappedObj = cd;\n\n if (!mappedObj.parentId) {\n result.push(mappedObj);\n return;\n }\n\n var mappedParent = addedMap[mappedObj.parentId];\n\n if (mappedParent) {\n if (mappedParent.children) mappedParent.children.push(cd);else mappedParent.children = [cd];\n } else {\n var parent_1 = {\n id: mappedObj.parentId,\n children: [mappedObj]\n };\n addedMap[mappedObj.parentId] = parent_1;\n addedMap[cd.id] = cd;\n }\n\n return;\n }\n\n if (isString(d.parentId)) {\n var parent_2 = addedMap[d.parentId];\n\n if (parent_2) {\n if (parent_2.children) parent_2.children.push(cd);else parent_2.children = [cd];\n addedMap[cd.id] = cd;\n } else {\n var pa = {\n id: d.parentId,\n children: [cd]\n };\n addedMap[pa.id] = pa;\n addedMap[cd.id] = cd;\n }\n } else {\n result.push(cd);\n addedMap[cd.id] = cd;\n }\n }); // proccess the nodes\n\n var nodeMap = {};\n (nodes || []).forEach(function (node) {\n nodeMap[node.id] = node;\n var combo = addedMap[node.comboId];\n\n if (combo) {\n var cnode = {\n id: node.id,\n comboId: node.comboId\n };\n if (combo.children) combo.children.push(cnode);else combo.children = [cnode];\n cnode.itemType = 'node';\n addedMap[node.id] = cnode;\n }\n }); // assign the depth for each element\n\n var maxDepth = 0;\n result.forEach(function (tree) {\n tree.depth = maxDepth + 10;\n traverse(tree, function (child) {\n var parent;\n var itemType = addedMap[child.id].itemType;\n\n if (itemType === 'node') {\n parent = addedMap[child.comboId];\n } else {\n parent = addedMap[child.parentId];\n }\n\n if (parent) {\n if (itemType === 'node') child.depth = maxDepth + 1;else child.depth = maxDepth + 10;\n } else {\n child.depth = maxDepth + 10;\n }\n\n if (maxDepth < child.depth) maxDepth = child.depth;\n var oriNodeModel = nodeMap[child.id];\n\n if (oriNodeModel) {\n oriNodeModel.depth = child.depth;\n }\n\n return true;\n });\n });\n return result;\n};\nexport var reconstructTree = function reconstructTree(trees, subtreeId, newParentId) {\n var brothers = trees;\n var subtree;\n var comboChildsMap = {\n root: {\n children: trees\n }\n };\n var foundSubTree = false;\n var oldParentId = 'root';\n (trees || []).forEach(function (tree) {\n if (foundSubTree) return;\n\n if (tree.id === subtreeId) {\n subtree = tree;\n\n if (tree.itemType === 'combo') {\n subtree.parentId = newParentId;\n } else {\n subtree.comboId = newParentId;\n }\n\n foundSubTree = true;\n return;\n }\n\n traverseTree(tree, function (child) {\n comboChildsMap[child.id] = {\n children: child.children\n }; // store the old parent id to delete the subtree from the old parent's children in next recursion\n\n brothers = comboChildsMap[child.parentId || child.comboId || 'root'].children;\n\n if (child && (child.removed || subtreeId === child.id) && brothers) {\n oldParentId = child.parentId || child.comboId || 'root';\n subtree = child; // re-assign the parentId or comboId for the moved subtree\n\n if (child.itemType === 'combo') {\n subtree.parentId = newParentId;\n } else {\n subtree.comboId = newParentId;\n }\n\n foundSubTree = true;\n return false;\n }\n\n return true;\n });\n });\n brothers = comboChildsMap[oldParentId].children;\n var index = brothers ? brothers.indexOf(subtree) : -1;\n if (index > -1) brothers.splice(index, 1); // 如果遍历完整棵树还没有找到,说明之前就不在树中\n\n if (!foundSubTree) {\n subtree = {\n id: subtreeId,\n itemType: 'node',\n comboId: newParentId\n };\n comboChildsMap[subtreeId] = {\n children: undefined\n };\n } // append to new parent\n\n\n if (subtreeId) {\n var found_1 = false; // newParentId is undefined means the subtree will have no parent\n\n if (newParentId) {\n var newParentDepth_1 = 0;\n (trees || []).forEach(function (tree) {\n if (found_1) return; // terminate\n\n traverseTree(tree, function (child) {\n // append subtree to the new parent ans assign the depth to the subtree\n if (newParentId === child.id) {\n found_1 = true;\n if (child.children) child.children.push(subtree);else child.children = [subtree];\n newParentDepth_1 = child.depth;\n if (subtree.itemType === 'node') subtree.depth = newParentDepth_1 + 2;else subtree.depth = newParentDepth_1 + 1;\n return false; // terminate\n }\n\n return true;\n });\n });\n } else if ((!newParentId || !found_1) && subtree.itemType !== 'node') {\n // if the newParentId is undefined or it is not found in the tree, add the subTree to the root\n trees.push(subtree);\n } // update the depth of the subtree and its children from the subtree\n\n\n var currentDepth_1 = subtree.depth;\n traverseTree(subtree, function (child) {\n if (child.itemType === 'node') currentDepth_1 += 2;else currentDepth_1 += 1;\n child.depth = currentDepth_1;\n return true;\n });\n }\n\n return trees;\n};\nexport var getComboBBox = function getComboBBox(children, graph) {\n var comboBBox = {\n minX: Infinity,\n minY: Infinity,\n maxX: -Infinity,\n maxY: -Infinity,\n x: undefined,\n y: undefined,\n width: undefined,\n height: undefined,\n centerX: undefined,\n centerY: undefined\n };\n\n if (!children || children.length === 0) {\n return comboBBox;\n }\n\n children.forEach(function (child) {\n var childItem = graph.findById(child.id);\n if (!childItem || !childItem.isVisible()) return; // ignore hidden children\n\n childItem.set('bboxCanvasCache', undefined);\n var childBBox = childItem.getCanvasBBox();\n if (childBBox.x && comboBBox.minX > childBBox.minX) comboBBox.minX = childBBox.minX;\n if (childBBox.y && comboBBox.minY > childBBox.minY) comboBBox.minY = childBBox.minY;\n if (childBBox.x && comboBBox.maxX < childBBox.maxX) comboBBox.maxX = childBBox.maxX;\n if (childBBox.y && comboBBox.maxY < childBBox.maxY) comboBBox.maxY = childBBox.maxY;\n });\n comboBBox.x = (comboBBox.minX + comboBBox.maxX) / 2;\n comboBBox.y = (comboBBox.minY + comboBBox.maxY) / 2;\n comboBBox.width = comboBBox.maxX - comboBBox.minX;\n comboBBox.height = comboBBox.maxY - comboBBox.minY;\n comboBBox.centerX = (comboBBox.minX + comboBBox.maxX) / 2;\n comboBBox.centerY = (comboBBox.minY + comboBBox.maxY) / 2;\n Object.keys(comboBBox).forEach(function (key) {\n if (comboBBox[key] === Infinity || comboBBox[key] === -Infinity) {\n comboBBox[key] = undefined;\n }\n });\n return comboBBox;\n};\nexport var shouldRefreshEdge = function shouldRefreshEdge(cfg) {\n var refreshEdge = isNumber(cfg.x) || isNumber(cfg.y) || cfg.type || cfg.anchorPoints || cfg.size;\n if (cfg.style) refreshEdge = refreshEdge || isNumber(cfg.style.r) || isNumber(cfg.style.width) || isNumber(cfg.style.height) || isNumber(cfg.style.rx) || isNumber(cfg.style.ry);\n return refreshEdge;\n};\nexport var cloneBesidesImg = function cloneBesidesImg(obj) {\n var clonedObj = {};\n Object.keys(obj).forEach(function (key1) {\n var obj2 = obj[key1];\n\n if (isObject(obj2)) {\n var clonedObj2_1 = {};\n Object.keys(obj2).forEach(function (key2) {\n var v = obj2[key2];\n if (key2 === 'img' && !isString(v)) return;\n clonedObj2_1[key2] = clone(v);\n });\n clonedObj[key1] = clonedObj2_1;\n } else {\n clonedObj[key1] = clone(obj2);\n }\n });\n return clonedObj;\n};","import { __spreadArray } from \"tslib\";\nimport { isString } from '@antv/util';\nimport { traverseTree } from './graphic';\n/**\n * 验证关系图或树图数据的合法性,必须符合以下规则才会渲染图:\n * 1. 必须传入数据\n * 2. 节点的 ID 必须为字符串,暂不支持数字类型,如果支持数字类型,会出现类似 123 与 '123' 是否相等的问题\n * 3. 边的 source 和 target 值必须在节点 ID 中存在\n * @param data 关系图或树图数据\n * @return boolean 全部验证通过返回 true,否则返回 false\n */\n\nexport var dataValidation = function dataValidation(data) {\n // 1. 必须传入数据\n if (!data) {\n console.error('G6 Error Tips: the data must be defined');\n return false;\n } // 2. 节点的 ID 必须为字符串或数字类型\n\n\n var nodes = data.nodes,\n edges = data.edges,\n _a = data.combos,\n combos = _a === void 0 ? [] : _a;\n\n if (!nodes && !edges) {\n var validated_1 = true; // 不存在 nodes 和 edges,则说明是 TreeGraphData,按 TreeGraphData 规则验证\n\n traverseTree(data, function (param) {\n if (!isString(param.id)) {\n validated_1 = false;\n return false;\n }\n\n return true;\n });\n return validated_1;\n }\n\n var nonNode = (nodes || []).find(function (node) {\n return !isString(node.id);\n });\n\n if (nonNode) {\n console.warn(\"G6 Warning Tips: missing 'id' property, or %c\" + nonNode.id + \"%c is not a string.\", 'font-size: 20px; color: red;', '');\n return false;\n } // 3. 边的 source 和 target 必须存在于节点 或 Combo中\n\n\n var nodeIds = (nodes || []).map(function (node) {\n return node.id;\n });\n var comboIds = combos.map(function (combo) {\n return combo.id;\n });\n\n var ids = __spreadArray(__spreadArray([], nodeIds), comboIds);\n\n var nonEdges = (edges || []).find(function (edge) {\n return !ids.includes(edge.source) || !ids.includes(edge.target);\n });\n\n if (nonEdges) {\n console.warn(\"G6 Warning Tips: The source %c\" + nonEdges.source + \"%c or the target %c\" + nonEdges.target + \"%c of the edge do not exist in the nodes or combos.\", 'font-size: 20px; color: red;', '', 'font-size: 20px; color: red;', '');\n return false;\n }\n\n return true;\n};\n/**\n * 验证添加节点、边或从combo时的数据\n * @param type 节点、边或从combo\n * @param data 添加的单条数据\n * @return boolean 全部验证通过返回 true,否则返回 false\n */\n\nexport var singleDataValidation = function singleDataValidation(type, data) {\n if (type === 'node' || type === 'combo') {\n // 必须有 id 字段,且id必须为字符串类型\n if (data.id && !isString(data.id)) {\n console.warn(\"G6 Warning Tips: missing 'id' property, or the 'id' %c\" + data.id + \"%c is not a string.\", 'font-size: 20px; color: red;', '');\n return false;\n }\n } else if (type === 'edge') {\n // 必须有 source 和 target 字段\n if (!data.source || !data.target) {\n console.warn(\"G6 Warning Tips: missing 'source' or 'target' for the edge.\");\n return false;\n }\n }\n\n return true;\n};","import { each, isArray, isString } from '@antv/util';\nimport Behavior from '../../behavior/behavior';\n\nvar ModeController = function () {\n function ModeController(graph) {\n this.graph = graph;\n this.destroyed = false;\n this.modes = graph.get('modes') || {\n default: []\n };\n this.formatModes();\n this.mode = graph.get('defaultMode') || 'default';\n this.currentBehaves = [];\n this.setMode(this.mode);\n }\n\n ModeController.prototype.formatModes = function () {\n var modes = this.modes;\n each(modes, function (mode) {\n each(mode, function (behavior, i) {\n if (isString(behavior)) {\n mode[i] = {\n type: behavior\n };\n }\n });\n });\n };\n\n ModeController.prototype.setBehaviors = function (mode) {\n var graph = this.graph;\n var behaviors = this.modes[mode];\n var behaves = [];\n var behave;\n each(behaviors || [], function (behavior) {\n var BehaviorInstance = Behavior.getBehavior(behavior.type || behavior);\n\n if (!BehaviorInstance) {\n return;\n }\n\n behave = new BehaviorInstance(behavior);\n\n if (behave) {\n behave.bind(graph);\n behaves.push(behave);\n }\n });\n this.currentBehaves = behaves;\n };\n\n ModeController.mergeBehaviors = function (modeBehaviors, behaviors) {\n each(behaviors, function (behavior) {\n if (modeBehaviors.indexOf(behavior) < 0) {\n if (isString(behavior)) {\n behavior = {\n type: behavior\n };\n }\n\n modeBehaviors.push(behavior);\n }\n });\n return modeBehaviors;\n };\n\n ModeController.filterBehaviors = function (modeBehaviors, behaviors) {\n var result = [];\n modeBehaviors.forEach(function (behavior) {\n var type = '';\n\n if (isString(behavior)) {\n type = behavior;\n } else {\n // eslint-disable-next-line prefer-destructuring\n type = behavior.type;\n }\n\n if (behaviors.indexOf(type) < 0) {\n result.push(behavior);\n }\n });\n return result;\n };\n\n ModeController.prototype.setMode = function (mode) {\n var _a = this,\n modes = _a.modes,\n graph = _a.graph;\n\n var current = mode;\n var behaviors = modes[current];\n\n if (!behaviors) {\n return;\n }\n\n graph.emit('beforemodechange', {\n mode: mode\n });\n each(this.currentBehaves, function (behave) {\n if (behave.delegate) behave.delegate.remove();\n behave.unbind(graph);\n });\n this.setBehaviors(current);\n graph.emit('aftermodechange', {\n mode: mode\n });\n this.mode = mode;\n };\n\n ModeController.prototype.getMode = function () {\n return this.mode;\n };\n /**\n * 动态增加或删除 Behavior\n *\n * @param {ModeType[]} behaviors\n * @param {(ModeType[] | ModeType)} modes\n * @param {boolean} isAdd\n * @returns {Mode}\n * @memberof Mode\n */\n\n\n ModeController.prototype.manipulateBehaviors = function (behaviors, modes, isAdd) {\n var _this = this;\n\n var behaves;\n\n if (!isArray(behaviors)) {\n behaves = [behaviors];\n } else {\n behaves = behaviors;\n }\n\n if (isArray(modes)) {\n each(modes, function (mode) {\n if (!_this.modes[mode]) {\n if (isAdd) {\n _this.modes[mode] = behaves;\n }\n } else if (isAdd) {\n _this.modes[mode] = ModeController.mergeBehaviors(_this.modes[mode] || [], behaves);\n } else {\n _this.modes[mode] = ModeController.filterBehaviors(_this.modes[mode] || [], behaves);\n }\n });\n return this;\n }\n\n var currentMode = modes;\n\n if (!modes) {\n currentMode = this.mode; // isString(this.mode) ? this.mode : this.mode.type\n }\n\n if (!this.modes[currentMode]) {\n if (isAdd) {\n this.modes[currentMode] = behaves;\n }\n }\n\n if (isAdd) {\n this.modes[currentMode] = ModeController.mergeBehaviors(this.modes[currentMode] || [], behaves);\n } else {\n this.modes[currentMode] = ModeController.filterBehaviors(this.modes[currentMode] || [], behaves);\n }\n\n this.formatModes();\n this.setMode(this.mode);\n return this;\n };\n /**\n * 更新行为参数\n * @param {string | ModeOption | ModeType} behavior 需要更新的行为\n * @param {string | string[]} modes 指定的模式中的行为,不指定则为 default\n * @return {Graph} Graph\n */\n\n\n ModeController.prototype.updateBehavior = function (behavior, newCfg, mode) {\n if (isString(behavior)) {\n behavior = {\n type: behavior\n };\n }\n\n var behaviorSet = [];\n\n if (!mode || mode === this.mode || mode === 'default') {\n behaviorSet = this.currentBehaves;\n\n if (!behaviorSet || !behaviorSet.length) {\n console.warn('Update behavior failed! There is no behaviors in this mode on the graph.');\n return this;\n }\n\n var length_1 = behaviorSet.length;\n\n for (var i = 0; i < length_1; i++) {\n var behave = behaviorSet[i];\n\n if (behave.type === behavior.type) {\n behave.updateCfg(newCfg);\n return this;\n }\n\n if (i === length_1 - 1) console.warn('Update behavior failed! There is no such behavior in the mode');\n }\n } else {\n behaviorSet = this.modes[mode];\n\n if (!behaviorSet || !behaviorSet.length) {\n console.warn('Update behavior failed! There is no behaviors in this mode on the graph.');\n return this;\n }\n\n var length_2 = behaviorSet.length;\n\n for (var i = 0; i < length_2; i++) {\n var behave = behaviorSet[i];\n\n if (behave.type === behavior.type || behave === behavior.type) {\n if (behave === behavior.type) behave = {\n type: behave\n };\n Object.assign(behave, newCfg);\n behaviorSet[i] = behave;\n return this;\n }\n\n if (i === length_2 - 1) console.warn('Update behavior failed! There is no such behavior in the mode');\n }\n }\n\n return this;\n };\n\n ModeController.prototype.destroy = function () {\n this.graph = null;\n this.modes = null;\n this.currentBehaves = null;\n this.destroyed = true;\n };\n\n return ModeController;\n}();\n\nexport default ModeController;","import { __extends } from \"tslib\";\nimport { Event as GraphEvent } from '@antv/g-base';\n\nvar G6GraphEvent = function (_super) {\n __extends(G6GraphEvent, _super);\n\n function G6GraphEvent(type, event) {\n var _this = _super.call(this, type, event) || this;\n\n _this.item = event.item;\n _this.canvasX = event.canvasX;\n _this.canvasY = event.canvasY;\n _this.wheelDelta = event.wheelDelta;\n _this.detail = event.detail;\n return _this;\n }\n\n return G6GraphEvent;\n}(GraphEvent);\n\nexport { G6GraphEvent };","import { isString, isNumber, isNil, isArray } from '@antv/util';\nimport { G6GraphEvent } from '../interface/behavior';\nexport var uniqueId = function uniqueId(type) {\n return type + \"-\" + Math.random() + Date.now();\n};\n/**\n * turn padding into [top, right, bottom, right]\n * @param {Number|Array} padding input padding\n * @return {array} output\n */\n\nexport var formatPadding = function formatPadding(padding) {\n var top = 0;\n var left = 0;\n var right = 0;\n var bottom = 0;\n\n if (isNumber(padding)) {\n top = left = right = bottom = padding;\n } else if (isString(padding)) {\n var intPadding = parseInt(padding, 10);\n top = left = right = bottom = intPadding;\n } else if (isArray(padding)) {\n top = padding[0];\n right = !isNil(padding[1]) ? padding[1] : padding[0];\n bottom = !isNil(padding[2]) ? padding[2] : padding[0];\n left = !isNil(padding[3]) ? padding[3] : right;\n }\n\n return [top, right, bottom, left];\n};\n/**\n * clone event\n * @param e\n */\n\nexport var cloneEvent = function cloneEvent(e) {\n var event = new G6GraphEvent(e.type, e);\n event.clientX = e.clientX;\n event.clientY = e.clientY;\n event.x = e.x;\n event.y = e.y;\n event.target = e.target;\n event.currentTarget = e.currentTarget;\n event.bubbles = true;\n event.item = e.item;\n return event;\n};\n/**\n * 判断 viewport 是否改变,通过和单位矩阵对比\n * @param matrix Viewport 的 Matrix\n */\n\nexport var isViewportChanged = function isViewportChanged(matrix) {\n // matrix 为 null, 则说明没有变化\n if (!matrix) {\n return false;\n }\n\n var MATRIX_LEN = 9;\n var ORIGIN_MATRIX = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n\n for (var i = 0; i < MATRIX_LEN; i++) {\n if (matrix[i] !== ORIGIN_MATRIX[i]) {\n return true;\n }\n }\n\n return false;\n};\nexport var isNaN = function isNaN(input) {\n return Number.isNaN(Number(input));\n};\n/**\n * 计算一组 Item 的 BBox\n * @param items 选中的一组Item,可以是 node 或 combo\n */\n\nexport var calculationItemsBBox = function calculationItemsBBox(items) {\n var minx = Infinity;\n var maxx = -Infinity;\n var miny = Infinity;\n var maxy = -Infinity; // 获取已节点的所有最大最小x y值\n\n for (var i = 0; i < items.length; i++) {\n var element = items[i];\n var bbox = element.getBBox();\n var minX = bbox.minX,\n minY = bbox.minY,\n maxX = bbox.maxX,\n maxY = bbox.maxY;\n\n if (minX < minx) {\n minx = minX;\n }\n\n if (minY < miny) {\n miny = minY;\n }\n\n if (maxX > maxx) {\n maxx = maxX;\n }\n\n if (maxY > maxy) {\n maxy = maxY;\n }\n }\n\n var x = Math.floor(minx);\n var y = Math.floor(miny);\n var width = Math.ceil(maxx) - Math.floor(minx);\n var height = Math.ceil(maxy) - Math.floor(miny);\n return {\n x: x,\n y: y,\n width: width,\n height: height,\n minX: minx,\n minY: miny,\n maxX: maxx,\n maxY: maxy\n };\n};\n/**\n * 若 edges 中存在两端点相同的边,使用 quadratic 边并自动计算 curveOffset 使它们不相互重叠\n * 文档: https://g6.antv.vision/en/docs/api/Util\n * @param edges 边数据集合\n * @param offsetDiff 相邻两边的 offset 之差\n * @param multiEdgeType\n * @param singleEdgeType\n * @param loopEdgeType\n */\n\nexport var processParallelEdges = function processParallelEdges(edges, offsetDiff, multiEdgeType, singleEdgeType, loopEdgeType) {\n if (offsetDiff === void 0) {\n offsetDiff = 15;\n }\n\n if (multiEdgeType === void 0) {\n multiEdgeType = 'quadratic';\n }\n\n if (singleEdgeType === void 0) {\n singleEdgeType = undefined;\n }\n\n if (loopEdgeType === void 0) {\n loopEdgeType = undefined;\n }\n\n var len = edges.length;\n var cod = offsetDiff * 2;\n var loopPosition = ['top', 'top-right', 'right', 'bottom-right', 'bottom', 'bottom-left', 'left', 'top-left'];\n var edgeMap = {};\n var tags = [];\n var reverses = {};\n\n for (var i = 0; i < len; i++) {\n var edge = edges[i];\n var source = edge.source,\n target = edge.target;\n var sourceTarget = source + \"-\" + target;\n if (tags[i]) continue;\n\n if (!edgeMap[sourceTarget]) {\n edgeMap[sourceTarget] = [];\n }\n\n tags[i] = true;\n edgeMap[sourceTarget].push(edge);\n\n for (var j = 0; j < len; j++) {\n if (i === j) continue;\n var sedge = edges[j];\n var src = sedge.source;\n var dst = sedge.target; // 两个节点之间共同的边\n // 第一条的source = 第二条的target\n // 第一条的target = 第二条的source\n\n if (!tags[j]) {\n if (source === dst && target === src) {\n edgeMap[sourceTarget].push(sedge);\n tags[j] = true;\n reverses[src + \"|\" + dst + \"|\" + (edgeMap[sourceTarget].length - 1)] = true;\n } else if (source === src && target === dst) {\n edgeMap[sourceTarget].push(sedge);\n tags[j] = true;\n }\n }\n }\n }\n\n for (var key in edgeMap) {\n var arcEdges = edgeMap[key];\n var length_1 = arcEdges.length;\n\n for (var k = 0; k < length_1; k++) {\n var current = arcEdges[k];\n\n if (current.source === current.target) {\n if (loopEdgeType) current.type = loopEdgeType; // 超过8条自环边,则需要重新处理\n\n current.loopCfg = {\n position: loopPosition[k % 8],\n dist: Math.floor(k / 8) * 20 + 50\n };\n continue;\n }\n\n if (length_1 === 1 && singleEdgeType && current.source !== current.target) {\n current.type = singleEdgeType;\n continue;\n }\n\n current.type = multiEdgeType;\n var sign = (k % 2 === 0 ? 1 : -1) * (reverses[current.source + \"|\" + current.target + \"|\" + k] ? -1 : 1);\n\n if (length_1 % 2 === 1) {\n current.curveOffset = sign * Math.ceil(k / 2) * cod;\n } else {\n current.curveOffset = sign * (Math.floor(k / 2) * cod + offsetDiff);\n }\n }\n }\n\n return edges;\n};","import { __assign } from \"tslib\";\nimport { isNumber, isString } from '@antv/util';\nimport { formatPadding } from '../../util/base';\nimport { applyMatrix, invertMatrix } from '../../util/math';\n\nvar ViewController = function () {\n function ViewController(graph) {\n this.destroyed = false;\n this.graph = graph;\n this.destroyed = false;\n } // get view center coordinate\n\n\n ViewController.prototype.getViewCenter = function () {\n var padding = this.getFormatPadding();\n var graph = this.graph;\n var width = this.graph.get('width');\n var height = graph.get('height');\n return {\n x: (width - padding[1] - padding[3]) / 2 + padding[3],\n y: (height - padding[0] - padding[2]) / 2 + padding[0]\n };\n };\n\n ViewController.prototype.fitCenter = function () {\n var graph = this.graph;\n var group = graph.get('group');\n group.resetMatrix();\n var bbox = group.getCanvasBBox();\n if (bbox.width === 0 || bbox.height === 0) return;\n var viewCenter = this.getViewCenter();\n var groupCenter = {\n x: bbox.x + bbox.width / 2,\n y: bbox.y + bbox.height / 2\n };\n graph.translate(viewCenter.x - groupCenter.x, viewCenter.y - groupCenter.y);\n }; // fit view graph\n\n\n ViewController.prototype.fitView = function () {\n var graph = this.graph;\n var padding = this.getFormatPadding();\n var width = graph.get('width');\n var height = graph.get('height');\n var group = graph.get('group');\n group.resetMatrix();\n var bbox = group.getCanvasBBox();\n if (bbox.width === 0 || bbox.height === 0) return;\n var viewCenter = this.getViewCenter();\n var groupCenter = {\n x: bbox.x + bbox.width / 2,\n y: bbox.y + bbox.height / 2\n };\n graph.translate(viewCenter.x - groupCenter.x, viewCenter.y - groupCenter.y);\n var w = (width - padding[1] - padding[3]) / bbox.width;\n var h = (height - padding[0] - padding[2]) / bbox.height;\n var ratio = w;\n\n if (w > h) {\n ratio = h;\n }\n\n if (!graph.zoom(ratio, viewCenter)) {\n console.warn('zoom failed, ratio out of range, ratio: %f', ratio);\n }\n };\n\n ViewController.prototype.getFormatPadding = function () {\n var padding = this.graph.get('fitViewPadding');\n return formatPadding(padding);\n };\n\n ViewController.prototype.focusPoint = function (point, animate, animateCfg) {\n var _this = this;\n\n var viewCenter = this.getViewCenter();\n var modelCenter = this.getPointByCanvas(viewCenter.x, viewCenter.y);\n var viewportMatrix = this.graph.get('group').getMatrix();\n if (!viewportMatrix) viewportMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n\n if (animate) {\n var dx_1 = (modelCenter.x - point.x) * viewportMatrix[0];\n var dy_1 = (modelCenter.y - point.y) * viewportMatrix[4];\n var lastX_1 = 0;\n var lastY_1 = 0;\n var newX_1 = 0;\n var newY_1 = 0; // 动画每次平移一点,直到目标位置\n\n this.graph.get('canvas').animate(function (ratio) {\n newX_1 = dx_1 * ratio;\n newY_1 = dy_1 * ratio;\n\n _this.graph.translate(newX_1 - lastX_1, newY_1 - lastY_1);\n\n lastX_1 = newX_1;\n lastY_1 = newY_1;\n }, __assign({}, animateCfg));\n } else {\n this.graph.translate((modelCenter.x - point.x) * viewportMatrix[0], (modelCenter.y - point.y) * viewportMatrix[4]);\n }\n };\n /**\n * 将 Canvas 坐标转成视口坐标\n * @param canvasX canvas x 坐标\n * @param canvasY canvas y 坐标\n */\n\n\n ViewController.prototype.getPointByCanvas = function (canvasX, canvasY) {\n var viewportMatrix = this.graph.get('group').getMatrix();\n\n if (!viewportMatrix) {\n viewportMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n var point = invertMatrix({\n x: canvasX,\n y: canvasY\n }, viewportMatrix);\n return point;\n };\n /**\n * 将页面坐标转成视口坐标\n * @param clientX 页面 x 坐标\n * @param clientY 页面 y 坐标\n */\n\n\n ViewController.prototype.getPointByClient = function (clientX, clientY) {\n var canvas = this.graph.get('canvas');\n var canvasPoint = canvas.getPointByClient(clientX, clientY);\n return this.getPointByCanvas(canvasPoint.x, canvasPoint.y);\n };\n /**\n * 将视口坐标转成页面坐标\n * @param x 视口 x 坐标\n * @param y 视口 y 坐标\n */\n\n\n ViewController.prototype.getClientByPoint = function (x, y) {\n var canvas = this.graph.get('canvas');\n var canvasPoint = this.getCanvasByPoint(x, y);\n var point = canvas.getClientByPoint(canvasPoint.x, canvasPoint.y);\n return {\n x: point.x,\n y: point.y\n };\n };\n /**\n * 将视口坐标转成 Canvas 坐标\n * @param x 视口 x 坐标\n * @param y 视口 y 坐标\n */\n\n\n ViewController.prototype.getCanvasByPoint = function (x, y) {\n var viewportMatrix = this.graph.get('group').getMatrix();\n\n if (!viewportMatrix) {\n viewportMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n return applyMatrix({\n x: x,\n y: y\n }, viewportMatrix);\n };\n /**\n * 将元素移动到画布中心\n * @param item Item 实例或 id\n * @param {boolean} animate 是否带有动画地移动\n * @param {GraphAnimateConfig} animateCfg 若带有动画,动画的配置项\n */\n\n\n ViewController.prototype.focus = function (item, animate, animateCfg) {\n if (isString(item)) {\n item = this.graph.findById(item);\n }\n\n if (item) {\n var x = 0,\n y = 0;\n\n if (item.getType && item.getType() === 'edge') {\n var sourceMatrix = item.getSource().get('group').getMatrix();\n var targetMatrix = item.getTarget().get('group').getMatrix();\n\n if (sourceMatrix && targetMatrix) {\n x = (sourceMatrix[6] + targetMatrix[6]) / 2;\n y = (sourceMatrix[7] + targetMatrix[7]) / 2;\n } else if (sourceMatrix || targetMatrix) {\n x = sourceMatrix ? sourceMatrix[6] : targetMatrix[6];\n y = sourceMatrix ? sourceMatrix[7] : targetMatrix[7];\n }\n } else {\n var group = item.get('group');\n var matrix = group.getMatrix();\n if (!matrix) matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n x = matrix[6];\n y = matrix[7];\n } // 用实际位置而不是model中的x,y,防止由于拖拽等的交互导致model的x,y并不是当前的x,y\n\n\n this.focusPoint({\n x: x,\n y: y\n }, animate, animateCfg);\n }\n };\n /**\n * 改变 canvas 画布的宽度和高度\n * @param width canvas 宽度\n * @param height canvas 高度\n */\n\n\n ViewController.prototype.changeSize = function (width, height) {\n var graph = this.graph;\n\n if (!isNumber(width) || !isNumber(height)) {\n throw Error('invalid canvas width & height, please make sure width & height type is number');\n }\n\n graph.set({\n width: width,\n height: height\n });\n var canvas = graph.get('canvas');\n canvas.changeSize(width, height); // change the size of grid plugin if it exists on graph\n\n var plugins = graph.get('plugins');\n plugins.forEach(function (plugin) {\n if (plugin.get('gridContainer')) {\n // 网格定位信息初始化\n plugin.positionInit();\n }\n });\n };\n\n ViewController.prototype.destroy = function () {\n this.graph = null;\n this.destroyed = false;\n };\n\n return ViewController;\n}();\n\nexport default ViewController;","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * @fileOverview 从xml建立自定义Node,包含update\n * @author xuzhi.mxz@antfin.com\n */\nimport { __assign, __rest } from \"tslib\";\nimport { get } from '@antv/util';\nimport { getTextSize } from '../util/graphic';\n/**\n * 一种更宽松的JSON 解析,如果遇到不符合规范的字段会直接转为字符串\n * @param text json 内容\n */\n\nfunction looseJSONParse(text) {\n if (typeof text !== 'string') {\n return text;\n }\n\n var safeParse = function safeParse(str) {\n if (typeof str !== 'string') {\n return str;\n }\n\n try {\n return JSON.parse(str.trim());\n } catch (e) {\n return str.trim();\n }\n };\n\n var firstAttempt = safeParse(text);\n\n if (typeof firstAttempt !== 'string') {\n return firstAttempt;\n }\n\n var tail = function tail(arr) {\n return arr[arr.length - 1];\n };\n\n var str = text.trim();\n var objectStack = [];\n var syntaxStack = [];\n\n var isLastPair = function isLastPair() {\n var syntaxes = [];\n\n for (var _i = 0; _i < arguments.length; _i++) {\n syntaxes[_i] = arguments[_i];\n }\n\n return syntaxes.some(function (syntax) {\n return tail(syntaxStack) === syntax;\n });\n };\n\n var getValueStore = function getValueStore() {\n return tail(objectStack);\n };\n\n var rst = null;\n var i = 0;\n var temp = '';\n\n while (i < str.length) {\n var nowChar = str[i];\n var isInString = isLastPair('\"', \"'\");\n\n if (!isInString && !nowChar.trim()) {\n i += 1;\n continue;\n }\n\n var isLastTranslate = str[i - 1] === '\\\\';\n var isInObject = isLastPair('}');\n var isInArray = isLastPair(']');\n var isWaitingValue = isLastPair(',');\n var tempArr = getValueStore();\n\n if (isInString) {\n if (tail(syntaxStack) === nowChar && !isLastTranslate) {\n syntaxStack.pop();\n var value = safeParse(temp);\n tempArr.push(value);\n rst = value;\n temp = '';\n } else {\n temp += nowChar;\n }\n } else if (isInArray && nowChar === ',') {\n if (temp) {\n tempArr.push(safeParse(temp));\n temp = '';\n }\n } else if (isInObject && nowChar === ':') {\n syntaxStack.push(',');\n\n if (temp) {\n tempArr.push(temp);\n temp = '';\n }\n } else if (isWaitingValue && nowChar === ',') {\n if (temp) {\n tempArr.push(safeParse(temp));\n temp = '';\n }\n\n syntaxStack.pop();\n } else if (nowChar === '}' && (isInObject || isWaitingValue)) {\n if (temp) {\n tempArr.push(safeParse(temp));\n temp = '';\n }\n\n if (isWaitingValue) {\n syntaxStack.pop();\n }\n\n var obj = {};\n\n for (var c = 1; c < tempArr.length; c += 2) {\n obj[tempArr[c - 1]] = tempArr[c];\n }\n\n objectStack.pop();\n\n if (objectStack.length) {\n tail(objectStack).push(obj);\n }\n\n syntaxStack.pop();\n rst = obj;\n } else if (nowChar === ']' && isInArray) {\n if (temp) {\n tempArr.push(safeParse(temp));\n temp = '';\n }\n\n objectStack.pop();\n\n if (objectStack.length) {\n tail(objectStack).push(tempArr);\n }\n\n syntaxStack.pop();\n rst = tempArr;\n } else if (nowChar === '{') {\n objectStack.push([]);\n syntaxStack.push('}');\n } else if (nowChar === '[') {\n objectStack.push([]);\n syntaxStack.push(']');\n } else if (nowChar === '\"') {\n syntaxStack.push('\"');\n } else if (nowChar === \"'\") {\n syntaxStack.push(\"'\");\n } else {\n temp += nowChar;\n }\n\n i += 1;\n }\n\n return rst || temp;\n}\n\nvar keyConvert = function keyConvert(str) {\n return str.split('-').reduce(function (a, b) {\n return a + b.charAt(0).toUpperCase() + b.slice(1);\n });\n};\n/**\n * 简单的一个{{}}模板渲染,不包含任何复杂语法\n * @param xml\n */\n\n\nexport var xmlDataRenderer = function xmlDataRenderer(xml) {\n return function (data) {\n var len = xml.length;\n var arr = [];\n var i = 0;\n var tmp = '';\n\n while (i < len) {\n if (xml[i] === '{' && xml[i + 1] === '{') {\n arr.push(tmp);\n tmp = '';\n i += 2;\n } else if (xml[i] === '}' && xml[i + 1] === '}') {\n if (arr.length) {\n var last = arr.pop();\n tmp = get(data, tmp, last.endsWith('=') ? \"\\\"{\" + tmp + \"}\\\"\" : tmp);\n arr.push(last + tmp);\n }\n\n i += 2;\n tmp = '';\n } else {\n tmp += xml[i];\n i += 1;\n }\n }\n\n arr.push(tmp);\n return arr.map(function (e, index) {\n return arr[index - 1] && arr[index - 1].endsWith('=') ? \"\\\"{\" + e + \"}\\\"\" : e;\n }).join('');\n };\n};\n/**\n * 解析XML,并转化为相应的JSON结构\n * @param xml xml解析后的节点\n */\n\nexport function parseXML(xml, cfg) {\n var attrs = {};\n var keys = xml.getAttributeNames && xml.getAttributeNames() || [];\n var children = xml.children && Array.from(xml.children).map(function (e) {\n return parseXML(e, cfg);\n });\n var rst = {};\n var tagName = xml.tagName ? xml.tagName.toLowerCase() : 'group';\n\n if (tagName === 'text') {\n attrs.text = xml.innerText;\n }\n\n rst.type = tagName;\n\n if (tagName === 'img') {\n rst.type = 'image';\n }\n\n Array.from(keys).forEach(function (k) {\n var key = keyConvert(k);\n var val = xml.getAttribute(k);\n\n try {\n if (key === 'style' || key === 'attrs') {\n var style = looseJSONParse(val);\n attrs = __assign(__assign({}, attrs), style);\n } else {\n rst[key] = looseJSONParse(val);\n }\n } catch (e) {\n if (key === 'style') {\n throw e;\n }\n\n rst[key] = val;\n }\n });\n rst.attrs = attrs;\n\n if (cfg && cfg.style && rst.name && _typeof(cfg.style[rst.name]) === 'object') {\n rst.attrs = __assign(__assign({}, rst.attrs), cfg.style[rst.name]);\n }\n\n if (cfg && cfg.style && rst.keyshape) {\n rst.attrs = __assign(__assign({}, rst.attrs), cfg.style);\n }\n\n if (children.length) {\n rst.children = children;\n }\n\n return rst;\n}\n/**\n * 根据偏移量和内部节点最终的bounding box来得出该shape最终的bbox\n */\n\nexport function getBBox(node, offset, chilrenBBox) {\n var _a = node.attrs,\n attrs = _a === void 0 ? {} : _a;\n var bbox = {\n x: offset.x || 0,\n y: offset.y || 0,\n width: chilrenBBox.width || 0,\n height: chilrenBBox.height || 0\n };\n var shapeHeight, shapeWidth;\n\n switch (node.type) {\n case 'maker':\n case 'circle':\n if (attrs.r) {\n shapeWidth = 2 * attrs.r;\n shapeHeight = 2 * attrs.r;\n }\n\n break;\n\n case 'text':\n if (attrs.text) {\n shapeWidth = getTextSize(attrs.text, attrs.fontSize || 12)[0];\n shapeHeight = 16;\n bbox.y += shapeHeight;\n bbox.height = shapeHeight;\n bbox.width = shapeWidth;\n node.attrs = __assign({\n fontSize: 12,\n fill: '#000'\n }, attrs);\n }\n\n break;\n\n default:\n if (attrs.width) {\n shapeWidth = attrs.width;\n }\n\n if (attrs.height) {\n shapeHeight = attrs.height;\n }\n\n }\n\n if (shapeHeight >= 0) {\n bbox.height = shapeHeight;\n }\n\n if (shapeWidth >= 0) {\n bbox.width = shapeWidth;\n }\n\n if (attrs.marginTop) {\n bbox.y += attrs.marginTop;\n }\n\n if (attrs.marginLeft) {\n bbox.x += attrs.marginLeft;\n }\n\n return bbox;\n}\n/**\n * 把从xml计算出的结构填上位置信息,补全attrs\n * @param target\n * @param lastOffset\n */\n\nexport function generateTarget(target, lastOffset) {\n var _a;\n\n if (lastOffset === void 0) {\n lastOffset = {\n x: 0,\n y: 0\n };\n }\n\n var defaultBbox = __assign({\n x: 0,\n y: 0,\n width: 0,\n height: 0\n }, lastOffset);\n\n if ((_a = target.children) === null || _a === void 0 ? void 0 : _a.length) {\n var _b = target.attrs,\n attrs = _b === void 0 ? {} : _b;\n var marginTop = attrs.marginTop;\n\n var offset = __assign({}, lastOffset);\n\n if (marginTop) {\n offset.y += marginTop;\n }\n\n for (var index = 0; index < target.children.length; index++) {\n target.children[index].attrs.key = (attrs.key || 'root') + \" -\" + index + \" \";\n var node = generateTarget(target.children[index], offset);\n\n if (node.bbox) {\n var bbox = node.bbox;\n\n if (node.attrs.next === 'inline') {\n offset.x += node.bbox.width;\n } else {\n offset.y += node.bbox.height;\n }\n\n if (bbox.width + bbox.x > defaultBbox.width) {\n defaultBbox.width = bbox.width + bbox.x;\n }\n\n if (bbox.height + bbox.y > defaultBbox.height) {\n defaultBbox.height = bbox.height + bbox.y;\n }\n }\n }\n }\n\n target.bbox = getBBox(target, lastOffset, defaultBbox);\n target.attrs = __assign(__assign({}, target.attrs), target.bbox);\n return target;\n}\n/**\n * 对比前后两个最终计算出来的node,并对比出最小改动,\n * 动作: 'add' 添加节点 | ’delete‘ 删除节点 | ’change‘ 改变节点attrs | 'restructure' 重构节点\n * @param nowTarget\n * @param formerTarget\n */\n\nexport function compareTwoTarget(nowTarget, formerTarget) {\n var _a, _b, _c, _d;\n\n var type = (nowTarget || {}).type;\n var key = ((formerTarget === null || formerTarget === void 0 ? void 0 : formerTarget.attrs) || {}).key;\n\n if (key && nowTarget) {\n nowTarget.attrs.key = key;\n }\n\n if (!nowTarget && formerTarget) {\n return {\n action: 'delete',\n val: formerTarget,\n type: type,\n key: key\n };\n }\n\n if (nowTarget && !formerTarget) {\n return {\n action: 'add',\n val: nowTarget,\n type: type\n };\n }\n\n if (!nowTarget && !formerTarget) {\n return {\n action: 'same',\n type: type\n };\n }\n\n var children = [];\n\n if (((_a = nowTarget.children) === null || _a === void 0 ? void 0 : _a.length) > 0 || ((_b = formerTarget.children) === null || _b === void 0 ? void 0 : _b.length) > 0) {\n var length_1 = Math.max((_c = nowTarget.children) === null || _c === void 0 ? void 0 : _c.length, (_d = formerTarget.children) === null || _d === void 0 ? void 0 : _d.length);\n var formerChilren = formerTarget.children || [];\n var nowChilren = nowTarget.children || [];\n\n for (var index = 0; index < length_1; index += 1) {\n children.push(compareTwoTarget(nowChilren[index], formerChilren[index]));\n }\n }\n\n var formerKeys = Object.keys(formerTarget.attrs);\n var nowKeys = Object.keys(nowTarget.attrs);\n\n if (formerTarget.type !== nowTarget.type) {\n return {\n action: 'restructure',\n nowTarget: nowTarget,\n formerTarget: formerTarget,\n key: key,\n children: children\n };\n }\n\n if (formerKeys.filter(function (e) {\n return e !== 'children';\n }).some(function (e) {\n return nowTarget.attrs[e] !== formerTarget.attrs[e] || !nowKeys.includes(e);\n })) {\n return {\n action: 'change',\n val: nowTarget,\n children: children,\n type: type,\n key: key\n };\n }\n\n return {\n action: 'same',\n children: children,\n type: type,\n key: key\n };\n}\n/**\n * 根据xml或者返回xml的函数构建自定义节点的结构\n * @param gen\n */\n\nexport function createNodeFromXML(gen) {\n var structures = {};\n\n var compileXML = function compileXML(cfg) {\n var rawStr = typeof gen === 'function' ? gen(cfg) : gen;\n var target = xmlDataRenderer(rawStr)(cfg);\n var xmlParser = document.createElement('div');\n xmlParser.innerHTML = target;\n var xml = xmlParser.children[0];\n var result = generateTarget(parseXML(xml, cfg));\n xmlParser.remove();\n return result;\n };\n\n return {\n draw: function draw(cfg, group) {\n var resultTarget = compileXML(cfg);\n var keyshape = group;\n\n var renderTarget = function renderTarget(target) {\n var _a = target.attrs,\n attrs = _a === void 0 ? {} : _a,\n bbox = target.bbox,\n type = target.type,\n children = target.children,\n rest = __rest(target, [\"attrs\", \"bbox\", \"type\", \"children\"]);\n\n if (target.type !== 'group') {\n var shape = group.addShape(target.type, __assign({\n attrs: attrs,\n origin: {\n bbox: bbox,\n type: type,\n children: children\n }\n }, rest));\n\n if (target.keyshape) {\n keyshape = shape;\n }\n }\n\n if (target.children) {\n target.children.forEach(function (n) {\n return renderTarget(n);\n });\n }\n };\n\n renderTarget(resultTarget);\n structures[cfg.id] = [resultTarget];\n return keyshape;\n },\n update: function update(cfg, node) {\n if (!structures[cfg.id]) {\n structures[cfg.id] = [];\n }\n\n var container = node.getContainer();\n var children = container.get('children');\n var newTarget = compileXML(cfg);\n var lastTarget = structures[cfg.id].pop();\n var diffResult = compareTwoTarget(newTarget, lastTarget);\n\n var addShape = function addShape(shape) {\n var _a;\n\n if (shape.type !== 'group') {\n container.addShape(shape.type, {\n attrs: shape.attrs\n });\n }\n\n if ((_a = shape.children) === null || _a === void 0 ? void 0 : _a.length) {\n shape.children.map(function (e) {\n return addShape(e);\n });\n }\n };\n\n var delShape = function delShape(shape) {\n var _a;\n\n var targetShape = children.find(function (e) {\n return e.attrs.key === shape.attrs.key;\n });\n\n if (targetShape) {\n container.removeChild(targetShape);\n }\n\n if ((_a = shape.children) === null || _a === void 0 ? void 0 : _a.length) {\n shape.children.map(function (e) {\n return delShape(e);\n });\n }\n };\n\n var updateTarget = function updateTarget(target) {\n var key = target.key;\n\n if (target.type !== 'group') {\n var targetShape = children.find(function (e) {\n return e.attrs.key === key;\n });\n\n switch (target.action) {\n case 'change':\n if (targetShape) {\n var originAttr = target.val.keyshape ? node.getOriginStyle() : {};\n targetShape.attr(__assign(__assign({}, originAttr), target.val.attrs));\n }\n\n break;\n\n case 'add':\n addShape(target.val);\n break;\n\n case 'delete':\n delShape(target.val);\n break;\n\n case 'restructure':\n delShape(target.formerTarget);\n addShape(target.nowTarget);\n break;\n\n default:\n break;\n }\n }\n\n if (target.children) {\n target.children.forEach(function (n) {\n return updateTarget(n);\n });\n }\n };\n\n updateTarget(diffResult);\n structures[cfg.id].push(newTarget);\n },\n getAnchorPoints: function getAnchorPoints() {\n return [[0, 0.5], [1, 0.5], [0.5, 1], [0.5, 0]];\n }\n };\n}","import { __assign } from \"tslib\";\nimport { upperFirst } from '@antv/util';\nimport { createNodeFromXML } from './xml';\nvar cache = {}; // ucfirst 开销过大,进行缓存\n// 首字母大写\n\nfunction ucfirst(str) {\n if (!cache[str]) {\n cache[str] = upperFirst(str);\n }\n\n return cache[str];\n}\n/**\n * 工厂方法的基类\n * @type Shape.FactoryBase\n */\n\n\nexport var ShapeFactoryBase = {\n /**\n * 默认的形状,当没有指定/匹配 shapeType 时,使用默认的\n * @type {String}\n */\n defaultShapeType: 'defaultType',\n\n /**\n * 形状的 className,用于搜索\n * @type {String}\n */\n className: null,\n\n /**\n * 获取绘制 Shape 的工具类,无状态\n * @param {String} type 类型\n * @return {Shape} 工具类\n */\n getShape: function getShape(type) {\n var self = this;\n var shape = self[type] || self[self.defaultShapeType] || self['simple-circle'];\n return shape;\n },\n\n /**\n * 绘制图形\n * @param {String} type 类型\n * @param {Object} cfg 配置项\n * @param {G.Group} group 图形的分组\n * @return {IShape} 图形对象\n */\n draw: function draw(type, cfg, group) {\n var shape = this.getShape(type);\n var rst = shape.draw(cfg, group);\n\n if (shape.afterDraw) {\n shape.afterDraw(cfg, group, rst);\n }\n\n return rst;\n },\n\n /**\n * 更新\n * @param {String} type 类型\n * @param {Object} cfg 配置项\n * @param {G6.Item} item 节点、边、分组等\n */\n baseUpdate: function baseUpdate(type, cfg, item, updateType) {\n var shape = this.getShape(type);\n\n if (shape.update) {\n // 防止没定义 update 函数\n shape.update(cfg, item, updateType);\n }\n\n if (shape.afterUpdate) {\n shape.afterUpdate(cfg, item);\n }\n },\n\n /**\n * 设置状态\n * @param {String} type 类型\n * @param {String} name 状态名\n * @param {String | Boolean} value 状态值\n * @param {G6.Item} item 节点、边、分组等\n */\n setState: function setState(type, name, value, item) {\n var shape = this.getShape(type); // 调用 shape/shapeBase.ts 中的 setState 方法\n\n shape.setState(name, value, item);\n },\n\n /**\n * 是否允许更新,不重新绘制图形\n * @param {String} type 类型\n * @return {Boolean} 是否允许使用更新\n */\n shouldUpdate: function shouldUpdate(type) {\n var shape = this.getShape(type);\n return !!shape.update;\n },\n getControlPoints: function getControlPoints(type, cfg) {\n var shape = this.getShape(type);\n return shape.getControlPoints(cfg);\n },\n\n /**\n * 获取控制点\n * @param {String} type 节点、边类型\n * @param {Object} cfg 节点、边的配置项\n * @return {Array|null} 控制点的数组,如果为 null,则没有控制点\n */\n getAnchorPoints: function getAnchorPoints(type, cfg) {\n var shape = this.getShape(type);\n return shape.getAnchorPoints(cfg);\n }\n};\n/**\n * 元素的框架\n */\n\nvar ShapeFramework = {\n // 默认样式及配置\n options: {},\n\n /**\n * 绘制\n */\n draw: function draw(cfg, group) {\n return this.drawShape(cfg, group);\n },\n\n /**\n * 绘制\n */\n drawShape: function drawShape() {},\n\n /**\n * 绘制完成后的操作,便于用户继承现有的节点、边\n */\n afterDraw: function afterDraw() {},\n // update(cfg, item) // 默认不定义\n afterUpdate: function afterUpdate() {},\n\n /**\n * 设置节点、边状态\n */\n setState: function setState() {},\n\n /**\n * 获取控制点\n * @param {Object} cfg 节点、边的配置项\n * @return {Array|null} 控制点的数组,如果为 null,则没有控制点\n */\n getControlPoints: function getControlPoints(cfg) {\n return cfg.controlPoints;\n },\n\n /**\n * 获取控制点\n * @param {Object} cfg 节点、边的配置项\n * @return {Array|null} 控制点的数组,如果为 null,则没有控制点\n */\n getAnchorPoints: function getAnchorPoints(cfg) {\n var defaultAnchorPoints = this.options.anchorPoints;\n var anchorPoints = cfg.anchorPoints || defaultAnchorPoints;\n return anchorPoints;\n }\n /* 如果没定义 update 方法,每次都调用 draw 方法\n update(cfg, item) {\n }\n */\n\n};\n\nvar Shape = function () {\n function Shape() {}\n\n Shape.registerFactory = function (factoryType, cfg) {\n var className = ucfirst(factoryType);\n var factoryBase = ShapeFactoryBase;\n\n var shapeFactory = __assign(__assign({}, factoryBase), cfg);\n\n Shape[className] = shapeFactory;\n shapeFactory.className = className;\n return shapeFactory;\n };\n\n Shape.getFactory = function (factoryType) {\n var className = ucfirst(factoryType);\n return Shape[className];\n };\n\n Shape.registerNode = function (shapeType, nodeDefinition, extendShapeType) {\n var shapeFactory = Shape.Node;\n var shapeObj;\n\n if (typeof nodeDefinition === 'string' || typeof nodeDefinition === 'function') {\n var autoNodeDefinition = createNodeFromXML(nodeDefinition);\n shapeObj = __assign(__assign({}, shapeFactory.getShape('single-node')), autoNodeDefinition);\n } else if (nodeDefinition.jsx) {\n var jsx = nodeDefinition.jsx;\n var autoNodeDefinition = createNodeFromXML(jsx);\n shapeObj = __assign(__assign(__assign({}, shapeFactory.getShape('single-node')), autoNodeDefinition), nodeDefinition);\n } else {\n shapeFactory.getShape(extendShapeType);\n var extendShape = extendShapeType ? shapeFactory.getShape(extendShapeType) : ShapeFramework;\n shapeObj = __assign(__assign({}, extendShape), nodeDefinition);\n }\n\n shapeObj.type = shapeType;\n shapeObj.itemType = 'node';\n shapeFactory[shapeType] = shapeObj;\n return shapeObj;\n };\n\n Shape.registerEdge = function (shapeType, edgeDefinition, extendShapeType) {\n var shapeFactory = Shape.Edge;\n var extendShape = extendShapeType ? shapeFactory.getShape(extendShapeType) : ShapeFramework;\n\n var shapeObj = __assign(__assign({}, extendShape), edgeDefinition);\n\n shapeObj.type = shapeType;\n shapeObj.itemType = 'edge';\n shapeFactory[shapeType] = shapeObj;\n return shapeObj;\n };\n\n Shape.registerCombo = function (shapeType, comboDefinition, extendShapeType) {\n var shapeFactory = Shape.Combo;\n var extendShape = extendShapeType ? shapeFactory.getShape(extendShapeType) : ShapeFramework;\n\n var shapeObj = __assign(__assign({}, extendShape), comboDefinition);\n\n shapeObj.type = shapeType;\n shapeObj.itemType = 'combo';\n shapeFactory[shapeType] = shapeObj;\n return shapeObj;\n };\n\n return Shape;\n}();\n\nexport default Shape; // 注册 Node 的工厂方法\n\nShape.registerFactory('node', {\n defaultShapeType: 'circle'\n}); // 注册 Edge 的工厂方法\n\nShape.registerFactory('edge', {\n defaultShapeType: 'line'\n}); // 注册 Combo 的工厂方法\n\nShape.registerFactory('combo', {\n defaultShapeType: 'circle'\n});","import { __assign } from \"tslib\";\nimport { each, isPlainObject, isString, isBoolean, mix, deepMix, clone } from '@antv/util';\nimport Shape from '../element/shape';\nimport { getBBox } from '../util/graphic';\nimport { translate } from '../util/math';\nimport { uniqueId } from '../util/base';\nvar CACHE_BBOX = 'bboxCache';\nvar CACHE_CANVAS_BBOX = 'bboxCanvasCache';\nvar ARROWS = ['startArrow', 'endArrow'];\n\nvar ItemBase = function () {\n function ItemBase(cfg) {\n this._cfg = {};\n this.destroyed = false;\n var defaultCfg = {\n /**\n * id\n * @type {string}\n */\n id: undefined,\n\n /**\n * 类型\n * @type {string}\n */\n type: 'item',\n\n /**\n * data model\n * @type {object}\n */\n model: {},\n\n /**\n * g group\n * @type {G.Group}\n */\n group: undefined,\n\n /**\n * is open animate\n * @type {boolean}\n */\n animate: false,\n\n /**\n * visible - not group visible\n * @type {boolean}\n */\n visible: true,\n\n /**\n * locked - lock node\n * @type {boolean}\n */\n locked: false,\n\n /**\n * capture event\n * @type {boolean}\n */\n event: true,\n\n /**\n * key shape to calculate item's bbox\n * @type object\n */\n keyShape: undefined,\n\n /**\n * item's states, such as selected or active\n * @type Array\n */\n states: []\n };\n this._cfg = Object.assign(defaultCfg, this.getDefaultCfg(), cfg);\n var model = this.get('model');\n var id = model.id;\n var itemType = this.get('type');\n\n if (!id) {\n id = uniqueId(itemType);\n this.get('model').id = id;\n }\n\n this.set('id', id);\n var group = cfg.group;\n\n if (group) {\n group.set('item', this);\n group.set('id', id);\n }\n\n this.init();\n this.draw();\n var shapeType = model.shape || model.type || (itemType === 'edge' ? 'line' : 'circle');\n var shapeFactory = this.get('shapeFactory');\n\n if (shapeFactory && shapeFactory[shapeType]) {\n var options = shapeFactory[shapeType].options; // merge the stateStyles from item and shape\n\n if (options && options.stateStyles) {\n var styles = this.get('styles') || model.stateStyles;\n styles = deepMix({}, options.stateStyles, styles);\n this.set('styles', styles);\n }\n }\n }\n /**\n * 根据 keyshape 计算包围盒\n */\n\n\n ItemBase.prototype.calculateBBox = function () {\n var keyShape = this.get('keyShape');\n var group = this.get('group'); // 因为 group 可能会移动,所以必须通过父元素计算才能计算出正确的包围盒\n\n var bbox = getBBox(keyShape, group);\n bbox.x = bbox.minX;\n bbox.y = bbox.minY;\n bbox.width = bbox.maxX - bbox.minX;\n bbox.height = bbox.maxY - bbox.minY;\n bbox.centerX = (bbox.minX + bbox.maxX) / 2;\n bbox.centerY = (bbox.minY + bbox.maxY) / 2;\n return bbox;\n };\n /**\n * 根据 keyshape 计算包围盒\n */\n\n\n ItemBase.prototype.calculateCanvasBBox = function () {\n var keyShape = this.get('keyShape');\n var group = this.get('group'); // 因为 group 可能会移动,所以必须通过父元素计算才能计算出正确的包围盒\n\n var bbox = getBBox(keyShape, group);\n bbox.x = bbox.minX;\n bbox.y = bbox.minY;\n bbox.width = bbox.maxX - bbox.minX;\n bbox.height = bbox.maxY - bbox.minY;\n bbox.centerX = (bbox.minX + bbox.maxX) / 2;\n bbox.centerY = (bbox.minY + bbox.maxY) / 2;\n return bbox;\n };\n /**\n * draw shape\n */\n\n\n ItemBase.prototype.drawInner = function () {\n var self = this;\n var shapeFactory = self.get('shapeFactory');\n var group = self.get('group');\n var model = self.get('model');\n group.clear();\n var visible = model.visible;\n if (visible !== undefined && !visible) self.changeVisibility(visible);\n\n if (!shapeFactory) {\n return;\n }\n\n self.updatePosition(model);\n var cfg = self.getShapeCfg(model); // 可能会附加额外信息\n\n var shapeType = cfg.type;\n var keyShape = shapeFactory.draw(shapeType, cfg, group);\n\n if (keyShape) {\n self.set('keyShape', keyShape);\n keyShape.set('isKeyShape', true);\n keyShape.set('draggable', true);\n }\n\n this.setOriginStyle(); // 防止由于用户外部修改 model 中的 shape 导致 shape 不更新\n\n this.set('currentShape', shapeType);\n this.restoreStates(shapeFactory, shapeType);\n };\n /**\n * 设置图元素原始样式\n * @param keyShape 图元素 keyShape\n * @param group Group 容器\n */\n\n\n ItemBase.prototype.setOriginStyle = function () {\n var group = this.get('group');\n var children = group.get('children');\n var keyShape = this.getKeyShape();\n var self = this;\n var keyShapeName = keyShape.get('name');\n\n if (!this.get('originStyle')) {\n // 第一次 set originStyle,直接拿首次渲染所有图形的 attrs\n var originStyles_1 = {};\n each(children, function (child) {\n var shapeType = child.get('type');\n var name = child.get('name');\n\n if (name && name !== keyShapeName) {\n originStyles_1[name] = shapeType !== 'image' ? clone(child.attr()) : self.getShapeStyleByName(name); // The text's position and matrix is not allowed to be affected by states\n\n if (originStyles_1[name] && shapeType === 'text') {\n delete originStyles_1[name].x;\n delete originStyles_1[name].y;\n delete originStyles_1[name].matrix;\n }\n } else {\n // !name || name === keyShape\n var keyShapeStyle = self.getShapeStyleByName(); // 可优化,需要去除 child.attr 中其他 shape 名的对象\n\n delete keyShapeStyle.path;\n delete keyShapeStyle.matrix;\n\n if (!keyShapeName) {\n Object.assign(originStyles_1, keyShapeStyle);\n } else {\n // 若 keyShape 有 name 且 !name,这个图形不是 keyShape,给这个图形一个 name\n if (!name) {\n var shapeName = uniqueId('shape');\n child.set('name', shapeName);\n originStyles_1[shapeName] = shapeType !== 'image' ? clone(child.attr()) : self.getShapeStyleByName(name);\n } else {\n originStyles_1[keyShapeName] = keyShapeStyle;\n }\n }\n }\n });\n self.set('originStyle', originStyles_1);\n } else {\n // 第二次 set originStyles,需要找到不是 stateStyles 的样式,更新到 originStyles 中\n // 上一次设置的 originStyle,是初始的 shape attrs\n var styles_1 = this.getOriginStyle(); // let styles: ShapeStyle = {};\n\n if (keyShapeName && !styles_1[keyShapeName]) styles_1[keyShapeName] = {}; // 获取当前状态样式\n\n var currentStatesStyle_1 = this.getCurrentStatesStyle(); // 遍历当前所有图形的 attrs,找到不是 stateStyles 的样式更新到 originStyles 中\n\n each(children, function (child) {\n var name = child.get('name');\n var shapeAttrs = child.attr();\n\n if (name && name !== keyShapeName) {\n // 有 name 的非 keyShape 图形\n var shapeStateStyle_1 = currentStatesStyle_1[name];\n if (!styles_1[name]) styles_1[name] = {};\n\n if (shapeStateStyle_1) {\n Object.keys(shapeAttrs).forEach(function (key) {\n var value = shapeAttrs[key];\n if (value !== shapeStateStyle_1[key]) styles_1[name][key] = value;\n });\n } else {\n styles_1[name] = child.get('type') !== 'image' ? clone(shapeAttrs) : self.getShapeStyleByName(name);\n }\n } else {\n var shapeAttrs_1 = child.attr();\n var keyShapeStateStyles_1 = {};\n Object.keys(currentStatesStyle_1).forEach(function (styleKey) {\n var subStyle = currentStatesStyle_1[styleKey];\n\n if (!isPlainObject(subStyle) || styleKey === keyShapeName) {\n keyShapeStateStyles_1[styleKey] = subStyle;\n }\n });\n Object.keys(shapeAttrs_1).forEach(function (key) {\n var value = shapeAttrs_1[key]; // 如果是对象且不是 arrow,则是其他 shape 的样式\n // if (isPlainObject(value) && ARROWS.indexOf(name) === -1) return;\n\n if (keyShapeStateStyles_1[key] !== value) {\n if (keyShapeName) styles_1[keyShapeName][key] = value;else styles_1[key] = value;\n }\n });\n }\n });\n if (styles_1.path) delete styles_1.path;\n if (styles_1.matrix) delete styles_1.matrix;\n if (styles_1.x) delete styles_1.x;\n if (styles_1.y) delete styles_1.y;\n\n if (styles_1[keyShapeName]) {\n delete styles_1[keyShapeName].x;\n delete styles_1[keyShapeName].y;\n delete styles_1[keyShapeName].matrix;\n delete styles_1[keyShapeName].path;\n }\n\n self.set('originStyle', styles_1);\n }\n };\n /**\n * restore shape states\n * @param shapeFactory\n * @param shapeType\n */\n\n\n ItemBase.prototype.restoreStates = function (shapeFactory, shapeType) {\n var self = this;\n var states = self.get('states');\n each(states, function (state) {\n shapeFactory.setState(shapeType, state, true, self);\n });\n };\n\n ItemBase.prototype.init = function () {\n var shapeFactory = Shape.getFactory(this.get('type'));\n this.set('shapeFactory', shapeFactory);\n };\n /**\n * 获取属性\n * @internal 仅内部类使用\n * @param {String} key 属性名\n * @return {object | string | number} 属性值\n */\n\n\n ItemBase.prototype.get = function (key) {\n return this._cfg[key];\n };\n /**\n * 设置属性\n * @internal 仅内部类使用\n * @param {String|Object} key 属性名,也可以是对象\n * @param {object | string | number} val 属性值\n */\n\n\n ItemBase.prototype.set = function (key, val) {\n if (isPlainObject(key)) {\n this._cfg = __assign(__assign({}, this._cfg), key);\n } else {\n this._cfg[key] = val;\n }\n };\n\n ItemBase.prototype.getDefaultCfg = function () {\n return {};\n };\n /**\n * 更新/刷新等操作后,清除 cache\n */\n\n\n ItemBase.prototype.clearCache = function () {\n this.set(CACHE_BBOX, null);\n this.set(CACHE_CANVAS_BBOX, null);\n };\n /**\n * 渲染前的逻辑,提供给子类复写\n */\n\n\n ItemBase.prototype.beforeDraw = function () {};\n /**\n * 渲染后的逻辑,提供给子类复写\n */\n\n\n ItemBase.prototype.afterDraw = function () {};\n /**\n * 更新后做一些工作\n */\n\n\n ItemBase.prototype.afterUpdate = function () {};\n /**\n * draw shape\n */\n\n\n ItemBase.prototype.draw = function () {\n this.beforeDraw();\n this.drawInner();\n this.afterDraw();\n };\n\n ItemBase.prototype.getShapeStyleByName = function (name) {\n var group = this.get('group');\n var currentShape;\n\n if (name) {\n currentShape = group.find(function (element) {\n return element.get('name') === name;\n });\n } else {\n currentShape = this.getKeyShape();\n }\n\n if (currentShape) {\n var styles_2 = {};\n each(currentShape.attr(), function (val, key) {\n // 修改 img 通过 updateItem 实现\n if (key !== 'img' || isString(val)) {\n styles_2[key] = val;\n }\n });\n return styles_2;\n }\n\n return {};\n };\n\n ItemBase.prototype.getShapeCfg = function (model, updateType) {\n var styles = this.get('styles');\n\n if (styles) {\n // merge graph的item样式与数据模型中的样式\n var newModel = model;\n newModel.style = __assign(__assign({}, styles), model.style);\n return newModel;\n }\n\n return model;\n };\n /**\n * 获取指定状态的样式,去除了全局样式\n * @param state 状态名称\n */\n\n\n ItemBase.prototype.getStateStyle = function (state) {\n var styles = this.get('styles');\n var stateStyle = styles && styles[state];\n return stateStyle;\n };\n /**\n * get keyshape style\n */\n\n\n ItemBase.prototype.getOriginStyle = function () {\n return this.get('originStyle');\n };\n\n ItemBase.prototype.getCurrentStatesStyle = function () {\n var self = this;\n var styles = {};\n var states = self.getStates();\n\n if (!states || !states.length) {\n return this.getOriginStyle();\n }\n\n each(self.getStates(), function (state) {\n styles = Object.assign(styles, self.getStateStyle(state));\n });\n return styles;\n };\n /**\n * 更改元素状态, visible 不属于这个范畴\n * @internal 仅提供内部类 graph 使用\n * @param {String} state 状态名\n * @param {Boolean} value 节点状态值\n */\n\n\n ItemBase.prototype.setState = function (state, value) {\n var states = this.get('states');\n var shapeFactory = this.get('shapeFactory');\n var stateName = state;\n var filterStateName = state;\n\n if (isString(value)) {\n stateName = state + \":\" + value;\n filterStateName = state + \":\";\n }\n\n var newStates = states;\n\n if (isBoolean(value)) {\n var index = states.indexOf(filterStateName);\n\n if (value) {\n if (index > -1) {\n return;\n }\n\n states.push(stateName);\n } else if (index > -1) {\n states.splice(index, 1);\n }\n } else if (isString(value)) {\n // 过滤掉 states 中 filterStateName 相关的状态\n var filterStates = states.filter(function (name) {\n return name.includes(filterStateName);\n });\n\n if (filterStates.length > 0) {\n this.clearStates(filterStates);\n }\n\n newStates = newStates.filter(function (name) {\n return !name.includes(filterStateName);\n });\n newStates.push(stateName);\n this.set('states', newStates);\n }\n\n if (shapeFactory) {\n var model = this.get('model');\n var type = model.type; // 调用 shape/shape.ts 中的 setState\n\n shapeFactory.setState(type, state, value, this);\n }\n };\n /**\n * 清除指定的状态,如果参数为空,则不做任务处理\n * @param states 状态名称\n */\n\n\n ItemBase.prototype.clearStates = function (states) {\n var self = this;\n var originStates = self.getStates();\n var shapeFactory = self.get('shapeFactory');\n var model = self.get('model');\n var shape = model.type;\n\n if (!states) {\n states = originStates;\n }\n\n if (isString(states)) {\n states = [states];\n }\n\n var newStates = originStates.filter(function (state) {\n return states.indexOf(state) === -1;\n });\n self.set('states', newStates);\n states.forEach(function (state) {\n shapeFactory.setState(shape, state, false, self);\n });\n };\n /**\n * 节点的图形容器\n * @return {G.Group} 图形容器\n */\n\n\n ItemBase.prototype.getContainer = function () {\n return this.get('group');\n };\n /**\n * 节点的关键形状,用于计算节点大小,连线截距等\n * @return {IShapeBase} 关键形状\n */\n\n\n ItemBase.prototype.getKeyShape = function () {\n return this.get('keyShape');\n };\n /**\n * 节点数据模型\n * @return {Object} 数据模型\n */\n\n\n ItemBase.prototype.getModel = function () {\n return this.get('model');\n };\n /**\n * 节点类型\n * @return {string} 节点的类型\n */\n\n\n ItemBase.prototype.getType = function () {\n return this.get('type');\n };\n /**\n * 获取 Item 的ID\n */\n\n\n ItemBase.prototype.getID = function () {\n return this.get('id');\n };\n /**\n * 是否是 Item 对象,悬空边情况下进行判定\n */\n\n\n ItemBase.prototype.isItem = function () {\n return true;\n };\n /**\n * 获取当前元素的所有状态\n * @return {Array} 元素的所有状态\n */\n\n\n ItemBase.prototype.getStates = function () {\n return this.get('states');\n };\n /**\n * 当前元素是否处于某状态\n * @param {String} state 状态名\n * @return {Boolean} 是否处于某状态\n */\n\n\n ItemBase.prototype.hasState = function (state) {\n var states = this.getStates();\n return states.indexOf(state) >= 0;\n };\n /**\n * 刷新一般用于处理几种情况\n * 1. item model 在外部被改变\n * 2. 边的节点位置发生改变,需要重新计算边\n *\n * 因为数据从外部被修改无法判断一些属性是否被修改,直接走位置和 shape 的更新\n */\n\n\n ItemBase.prototype.refresh = function (updateType) {\n var model = this.get('model'); // 更新元素位置\n\n this.updatePosition(model); // 更新元素内容,样式\n\n this.updateShape(updateType); // 做一些更新之后的操作\n\n this.afterUpdate(); // 清除缓存\n\n this.clearCache();\n };\n\n ItemBase.prototype.getUpdateType = function (cfg) {\n return undefined;\n };\n /**\n * 将更新应用到 model 上,刷新属性\n * @internal 仅提供给 Graph 使用,外部直接调用 graph.update 接口\n * @param {Object} cfg 配置项,可以是增量信息\n */\n\n\n ItemBase.prototype.update = function (cfg, updateType) {\n if (updateType === void 0) {\n updateType = undefined;\n }\n\n var model = this.get('model'); // 仅仅移动位置时,既不更新,也不重绘\n\n if (updateType === 'move') {\n this.updatePosition(cfg);\n } else {\n var oriVisible = model.visible;\n var cfgVisible = cfg.visible;\n if (oriVisible !== cfgVisible && cfgVisible !== undefined) this.changeVisibility(cfgVisible);\n var originPosition = {\n x: model.x,\n y: model.y\n };\n cfg.x = isNaN(+cfg.x) ? model.x : +cfg.x;\n cfg.y = isNaN(+cfg.y) ? model.y : +cfg.y;\n var styles = this.get('styles');\n\n if (cfg.stateStyles) {\n // 更新 item 时更新 this.get('styles') 中的值\n var stateStyles = cfg.stateStyles;\n mix(styles, stateStyles);\n delete cfg.stateStyles;\n } // 直接将更新合到原数据模型上,可以保证用户在外部修改源数据然后刷新时的样式符合期待。\n\n\n Object.assign(model, cfg); // 如果 x,y 有变化,先重置位置\n\n if (originPosition.x !== cfg.x || originPosition.y !== cfg.y) {\n this.updatePosition(cfg);\n }\n\n this.updateShape();\n }\n\n this.afterUpdate();\n this.clearCache();\n };\n /**\n * 更新元素内容,样式\n */\n\n\n ItemBase.prototype.updateShape = function (updateType) {\n var shapeFactory = this.get('shapeFactory');\n var model = this.get('model');\n var shape = model.type; // 判定是否允许更新\n // 1. 注册的节点允许更新\n // 2. 更新后的 shape 等于原先的 shape\n\n if (shapeFactory.shouldUpdate(shape) && shape === this.get('currentShape')) {\n var updateCfg = this.getShapeCfg(model, updateType);\n shapeFactory.baseUpdate(shape, updateCfg, this, updateType); // 更新完以后重新设置原始样式\n\n if (updateType !== 'move') this.setOriginStyle();\n } else {\n // 如果不满足上面两种状态,重新绘制\n this.draw();\n } // 更新后重置节点状态\n\n\n this.restoreStates(shapeFactory, shape);\n };\n /**\n * 更新位置,避免整体重绘\n * @param {object} cfg 待更新数据\n */\n\n\n ItemBase.prototype.updatePosition = function (cfg) {\n var model = this.get('model');\n var x = isNaN(+cfg.x) ? +model.x : +cfg.x;\n var y = isNaN(+cfg.y) ? +model.y : +cfg.y;\n var group = this.get('group');\n\n if (isNaN(x) || isNaN(y)) {\n return false;\n }\n\n model.x = x;\n model.y = y;\n var matrix = group.getMatrix();\n if (matrix && matrix[6] === x && matrix[7] === y) return false;\n group.resetMatrix(); // G 4.0 element 中移除了矩阵相关方法,详见https://www.yuque.com/antv/blog/kxzk9g#4rMMV\n\n translate(group, {\n x: x,\n y: y\n });\n this.clearCache(); // 位置更新后需要清除缓存\n\n return true;\n };\n /**\n * 获取 item 的包围盒,这个包围盒是相对于 item 自己,不会将 matrix 计算在内\n * @return {Object} 包含 x,y,width,height, centerX, centerY\n */\n\n\n ItemBase.prototype.getBBox = function () {\n // 计算 bbox 开销有些大,缓存\n var bbox = this.get(CACHE_BBOX);\n\n if (!bbox) {\n bbox = this.calculateBBox();\n this.set(CACHE_BBOX, bbox);\n }\n\n return bbox;\n };\n /**\n * 获取 item 相对于画布的包围盒,会将从顶层到当前元素的 matrix 都计算在内\n * @return {Object} 包含 x,y,width,height, centerX, centerY\n */\n\n\n ItemBase.prototype.getCanvasBBox = function () {\n // 计算 bbox 开销有些大,缓存\n var bbox = this.get(CACHE_CANVAS_BBOX);\n\n if (!bbox) {\n bbox = this.calculateCanvasBBox();\n this.set(CACHE_CANVAS_BBOX, bbox);\n }\n\n return bbox;\n };\n /**\n * 将元素放到最前面\n */\n\n\n ItemBase.prototype.toFront = function () {\n var group = this.get('group');\n group.toFront();\n };\n /**\n * 将元素放到最后面\n */\n\n\n ItemBase.prototype.toBack = function () {\n var group = this.get('group');\n group.toBack();\n };\n /**\n * 显示元素\n */\n\n\n ItemBase.prototype.show = function () {\n this.changeVisibility(true);\n };\n /**\n * 隐藏元素\n */\n\n\n ItemBase.prototype.hide = function () {\n this.changeVisibility(false);\n };\n /**\n * 更改是否显示\n * @param {Boolean} visible 是否显示\n */\n\n\n ItemBase.prototype.changeVisibility = function (visible) {\n var group = this.get('group');\n\n if (visible) {\n group.show();\n } else {\n group.hide();\n }\n\n this.set('visible', visible);\n };\n /**\n * 元素是否可见\n * @return {Boolean} 返回该元素是否可见\n */\n\n\n ItemBase.prototype.isVisible = function () {\n return this.get('visible');\n };\n /**\n * 是否拾取及出发该元素的交互事件\n * @param {Boolean} enable 标识位\n */\n\n\n ItemBase.prototype.enableCapture = function (enable) {\n var group = this.get('group');\n\n if (group) {\n group.set('capture', enable);\n }\n };\n\n ItemBase.prototype.destroy = function () {\n if (!this.destroyed) {\n var animate = this.get('animate');\n var group = this.get('group');\n\n if (animate) {\n group.stopAnimate();\n }\n\n this.clearCache();\n group.remove();\n this._cfg = null;\n this.destroyed = true;\n }\n };\n\n return ItemBase;\n}();\n\nexport default ItemBase;","import { __extends } from \"tslib\";\nimport { isString, isPlainObject, isNil, mix } from '@antv/util';\nimport Item from './item';\nvar END_MAP = {\n source: 'start',\n target: 'end'\n};\nvar ITEM_NAME_SUFFIX = 'Node'; // 端点的后缀,如 sourceNode, targetNode\n\nvar POINT_NAME_SUFFIX = 'Point'; // 起点或者结束点的后缀,如 startPoint, endPoint\n\nvar ANCHOR_NAME_SUFFIX = 'Anchor';\n\nvar Edge = function (_super) {\n __extends(Edge, _super);\n\n function Edge() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n\n Edge.prototype.getDefaultCfg = function () {\n return {\n type: 'edge',\n sourceNode: null,\n targetNode: null,\n startPoint: null,\n endPoint: null,\n linkCenter: false\n };\n };\n\n Edge.prototype.setEnd = function (name, value) {\n var pointName = END_MAP[name] + POINT_NAME_SUFFIX;\n var itemName = name + ITEM_NAME_SUFFIX;\n var preItem = this.get(itemName);\n\n if (preItem && !preItem.destroyed) {\n // 如果之前存在节点,则移除掉边\n preItem.removeEdge(this);\n }\n\n if (isPlainObject(value)) {\n // 如果设置成具体的点,则清理节点\n this.set(pointName, value);\n this.set(itemName, null);\n } else if (value) {\n value.addEdge(this);\n this.set(itemName, value);\n this.set(pointName, null);\n }\n };\n /**\n * 获取连接点的坐标\n * @param name source | target\n * @param model 边的数据模型\n * @param controlPoints 控制点\n */\n\n\n Edge.prototype.getLinkPoint = function (name, model, controlPoints) {\n var pointName = END_MAP[name] + POINT_NAME_SUFFIX;\n var itemName = name + ITEM_NAME_SUFFIX;\n var point = this.get(pointName);\n\n if (!point) {\n var item = this.get(itemName);\n var anchorName = name + ANCHOR_NAME_SUFFIX;\n var prePoint = this.getPrePoint(name, controlPoints);\n var anchorIndex = model[anchorName];\n\n if (!isNil(anchorIndex)) {\n // 如果有锚点,则使用锚点索引获取连接点\n point = item.getLinkPointByAnchor(anchorIndex);\n } // 如果锚点没有对应的点或者没有锚点,则直接计算连接点\n\n\n point = point || item.getLinkPoint(prePoint);\n\n if (!isNil(point.index)) {\n this.set(name + \"AnchorIndex\", point.index);\n }\n }\n\n return point;\n };\n /**\n * 获取同端点进行连接的点,计算交汇点\n * @param name\n * @param controlPoints\n */\n\n\n Edge.prototype.getPrePoint = function (name, controlPoints) {\n if (controlPoints && controlPoints.length) {\n var index = name === 'source' ? 0 : controlPoints.length - 1;\n return controlPoints[index];\n }\n\n var oppositeName = name === 'source' ? 'target' : 'source'; // 取另一个节点的位置\n\n return this.getEndPoint(oppositeName);\n };\n /**\n * 获取端点的位置\n * @param name\n */\n\n\n Edge.prototype.getEndPoint = function (name) {\n var itemName = name + ITEM_NAME_SUFFIX;\n var pointName = END_MAP[name] + POINT_NAME_SUFFIX;\n var item = this.get(itemName); // 如果有端点,直接使用 model\n\n if (item) {\n return item.get('model');\n } // 否则直接使用点\n\n\n return this.get(pointName);\n };\n /**\n * 通过端点的中心获取控制点\n * @param model\n */\n\n\n Edge.prototype.getControlPointsByCenter = function (model) {\n var sourcePoint = this.getEndPoint('source');\n var targetPoint = this.getEndPoint('target');\n var shapeFactory = this.get('shapeFactory');\n var type = model.type;\n return shapeFactory.getControlPoints(type, {\n startPoint: sourcePoint,\n endPoint: targetPoint\n });\n };\n\n Edge.prototype.getEndCenter = function (name) {\n var itemName = name + ITEM_NAME_SUFFIX;\n var pointName = END_MAP[name] + POINT_NAME_SUFFIX;\n var item = this.get(itemName); // 如果有端点,直接使用 model\n\n if (item) {\n var bbox = item.getBBox();\n return {\n x: bbox.centerX,\n y: bbox.centerY\n };\n } // 否则直接使用点\n\n\n return this.get(pointName);\n };\n\n Edge.prototype.init = function () {\n _super.prototype.init.call(this); // 初始化两个端点\n\n\n this.setSource(this.get('source'));\n this.setTarget(this.get('target'));\n };\n\n Edge.prototype.getShapeCfg = function (model, updateType) {\n var self = this;\n var linkCenter = self.get('linkCenter'); // 如果连接到中心,忽视锚点、忽视控制点\n\n var cfg = updateType === 'move' ? model : _super.prototype.getShapeCfg.call(this, model);\n\n if (linkCenter) {\n cfg.startPoint = self.getEndCenter('source');\n cfg.endPoint = self.getEndCenter('target');\n } else {\n var controlPoints = cfg.controlPoints || self.getControlPointsByCenter(cfg);\n cfg.startPoint = self.getLinkPoint('source', model, controlPoints);\n cfg.endPoint = self.getLinkPoint('target', model, controlPoints);\n }\n\n cfg.sourceNode = self.get('sourceNode');\n cfg.targetNode = self.get('targetNode');\n return cfg;\n };\n /**\n * 获取边的数据模型\n */\n\n\n Edge.prototype.getModel = function () {\n var out = this.get('model');\n var sourceItem = this.get(\"source\" + ITEM_NAME_SUFFIX);\n var targetItem = this.get(\"target\" + ITEM_NAME_SUFFIX);\n\n if (sourceItem) {\n delete out[\"source\" + ITEM_NAME_SUFFIX];\n } else {\n out.source = this.get(\"start\" + POINT_NAME_SUFFIX);\n }\n\n if (targetItem) {\n delete out[\"target\" + ITEM_NAME_SUFFIX];\n } else {\n out.target = this.get(\"end\" + POINT_NAME_SUFFIX);\n }\n\n if (!isString(out.source) && !isPlainObject(out.source)) {\n out.source = out.source.getID();\n }\n\n if (!isString(out.target) && !isPlainObject(out.target)) {\n out.target = out.target.getID();\n }\n\n return out;\n };\n\n Edge.prototype.setSource = function (source) {\n this.setEnd('source', source);\n this.set('source', source);\n };\n\n Edge.prototype.setTarget = function (target) {\n this.setEnd('target', target);\n this.set('target', target);\n };\n\n Edge.prototype.getSource = function () {\n return this.get('source');\n };\n\n Edge.prototype.getTarget = function () {\n return this.get('target');\n };\n\n Edge.prototype.updatePosition = function () {\n return false;\n };\n /**\n * 边不需要重计算容器位置,直接重新计算 path 位置\n * @param {object} cfg 待更新数据\n */\n\n\n Edge.prototype.update = function (cfg, updateType) {\n if (updateType === void 0) {\n updateType = undefined;\n }\n\n var model = this.get('model');\n var oriVisible = model.visible;\n var cfgVisible = cfg.visible;\n if (oriVisible !== cfgVisible && cfgVisible !== undefined) this.changeVisibility(cfgVisible);\n var styles = this.get('styles');\n\n if (cfg.stateStyles) {\n // 更新 item 时更新 this.get('styles') 中的值\n var stateStyles = cfg.stateStyles;\n mix(styles, stateStyles);\n delete cfg.stateStyles;\n }\n\n Object.assign(model, cfg);\n this.updateShape(updateType);\n this.afterUpdate();\n this.clearCache();\n };\n\n Edge.prototype.destroy = function () {\n var sourceItem = this.get(\"source\" + ITEM_NAME_SUFFIX);\n var targetItem = this.get(\"target\" + ITEM_NAME_SUFFIX);\n\n if (sourceItem && !sourceItem.destroyed) {\n sourceItem.removeEdge(this);\n }\n\n if (targetItem && !targetItem.destroyed) {\n targetItem.removeEdge(this);\n }\n\n _super.prototype.destroy.call(this);\n };\n\n return Edge;\n}(Item);\n\nexport default Edge;","import { __extends } from \"tslib\";\nimport { each, isNil, isNumber } from '@antv/util';\nimport { distance, getCircleIntersectByPoint, getEllipseIntersectByPoint, getRectIntersectByPoint } from '../util/math';\nimport Item from './item';\nvar CACHE_ANCHOR_POINTS = 'anchorPointsCache';\nvar CACHE_BBOX = 'bboxCache';\n\nvar Node = function (_super) {\n __extends(Node, _super);\n\n function Node() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n\n Node.prototype.getNearestPoint = function (points, curPoint) {\n var index = 0;\n var nearestPoint = points[0];\n var minDistance = distance(points[0], curPoint);\n\n for (var i = 0; i < points.length; i++) {\n var point = points[i];\n var dis = distance(point, curPoint);\n\n if (dis < minDistance) {\n nearestPoint = point;\n minDistance = dis;\n index = i;\n }\n }\n\n nearestPoint.anchorIndex = index;\n return nearestPoint;\n };\n\n Node.prototype.getDefaultCfg = function () {\n return {\n type: 'node',\n edges: []\n };\n };\n /**\n * 获取从节点关联的所有边\n */\n\n\n Node.prototype.getEdges = function () {\n return this.get('edges');\n };\n /**\n * 获取所有的入边\n */\n\n\n Node.prototype.getInEdges = function () {\n var self = this;\n return this.get('edges').filter(function (edge) {\n return edge.get('target') === self;\n });\n };\n /**\n * 获取所有的出边\n */\n\n\n Node.prototype.getOutEdges = function () {\n var self = this;\n return this.get('edges').filter(function (edge) {\n return edge.get('source') === self;\n });\n };\n /**\n * 获取节点的邻居节点\n *\n * @returns {INode[]}\n * @memberof Node\n */\n\n\n Node.prototype.getNeighbors = function (type) {\n var _this = this;\n\n var edges = this.get('edges');\n\n if (type === 'target') {\n // 当前节点为 source,它所指向的目标节点\n var neighhborsConverter_1 = function neighhborsConverter_1(edge) {\n return edge.getSource() === _this;\n };\n\n return edges.filter(neighhborsConverter_1).map(function (edge) {\n return edge.getTarget();\n });\n }\n\n if (type === 'source') {\n // 当前节点为 target,它所指向的源节点\n var neighhborsConverter_2 = function neighhborsConverter_2(edge) {\n return edge.getTarget() === _this;\n };\n\n return edges.filter(neighhborsConverter_2).map(function (edge) {\n return edge.getSource();\n });\n } // 若未指定 type ,则返回所有邻居\n\n\n var neighhborsConverter = function neighhborsConverter(edge) {\n return edge.getSource() === _this ? edge.getTarget() : edge.getSource();\n };\n\n return edges.map(neighhborsConverter);\n };\n /**\n * 根据锚点的索引获取连接点\n * @param {Number} index 索引\n */\n\n\n Node.prototype.getLinkPointByAnchor = function (index) {\n var anchorPoints = this.getAnchorPoints();\n return anchorPoints[index];\n };\n /**\n * 获取连接点\n * @param point\n */\n\n\n Node.prototype.getLinkPoint = function (point) {\n var keyShape = this.get('keyShape');\n var type = keyShape.get('type');\n var itemType = this.get('type');\n var centerX;\n var centerY;\n var bbox = this.getBBox();\n\n if (itemType === 'combo') {\n centerX = bbox.centerX || (bbox.maxX + bbox.minX) / 2;\n centerY = bbox.centerY || (bbox.maxY + bbox.minY) / 2;\n } else {\n centerX = bbox.centerX;\n centerY = bbox.centerY;\n }\n\n var anchorPoints = this.getAnchorPoints();\n var intersectPoint;\n\n switch (type) {\n case 'circle':\n intersectPoint = getCircleIntersectByPoint({\n x: centerX,\n y: centerY,\n r: bbox.width / 2\n }, point);\n break;\n\n case 'ellipse':\n intersectPoint = getEllipseIntersectByPoint({\n x: centerX,\n y: centerY,\n rx: bbox.width / 2,\n ry: bbox.height / 2\n }, point);\n break;\n\n default:\n intersectPoint = getRectIntersectByPoint(bbox, point);\n }\n\n var linkPoint = intersectPoint; // 如果存在锚点,则使用交点计算最近的锚点\n\n if (anchorPoints.length) {\n if (!linkPoint) {\n // 如果计算不出交点\n linkPoint = point;\n }\n\n linkPoint = this.getNearestPoint(anchorPoints, linkPoint);\n }\n\n if (!linkPoint) {\n // 如果最终依然没法找到锚点和连接点,直接返回中心点\n linkPoint = {\n x: centerX,\n y: centerY\n };\n }\n\n return linkPoint;\n };\n /**\n * 获取锚点的定义\n * @return {array} anchorPoints\n */\n\n\n Node.prototype.getAnchorPoints = function () {\n var anchorPoints = this.get(CACHE_ANCHOR_POINTS);\n\n if (!anchorPoints) {\n anchorPoints = [];\n var shapeFactory = this.get('shapeFactory');\n var bbox_1 = this.getBBox();\n var model = this.get('model');\n var shapeCfg = this.getShapeCfg(model);\n var type = model.type;\n var points = shapeFactory.getAnchorPoints(type, shapeCfg) || [];\n each(points, function (pointArr, index) {\n var point = {\n x: bbox_1.minX + pointArr[0] * bbox_1.width,\n y: bbox_1.minY + pointArr[1] * bbox_1.height,\n anchorIndex: index\n };\n anchorPoints.push(point);\n });\n this.set(CACHE_ANCHOR_POINTS, anchorPoints);\n }\n\n return anchorPoints;\n };\n /**\n * add edge\n * @param edge Edge instance\n */\n\n\n Node.prototype.addEdge = function (edge) {\n this.get('edges').push(edge);\n };\n /**\n * 锁定节点\n */\n\n\n Node.prototype.lock = function () {\n this.set('locked', true);\n };\n /**\n * 解锁锁定的节点\n */\n\n\n Node.prototype.unlock = function () {\n this.set('locked', false);\n };\n\n Node.prototype.hasLocked = function () {\n return this.get('locked');\n };\n /**\n * 移除边\n * @param {Edge} edge 边\n */\n\n\n Node.prototype.removeEdge = function (edge) {\n var edges = this.getEdges();\n var index = edges.indexOf(edge);\n\n if (index > -1) {\n edges.splice(index, 1);\n }\n };\n\n Node.prototype.clearCache = function () {\n this.set(CACHE_BBOX, null); // 清理缓存的 bbox\n\n this.set(CACHE_ANCHOR_POINTS, null);\n };\n /**\n * 判断更新的种类,move 表示仅移动,bbox 表示大小有变化,style 表示仅与大小无关的参数变化\n * @param cfg 节点数据模型\n */\n\n\n Node.prototype.getUpdateType = function (cfg) {\n var _a, _b, _c, _d, _e;\n\n if (!cfg) {\n return undefined;\n }\n\n var existX = !isNil(cfg.x);\n var existY = !isNil(cfg.y);\n var keys = Object.keys(cfg); // 仅有一个字段,包含 x 或者 包含 y\n // 两个字段,同时有 x,同时有 y\n\n if (keys.length === 1 && (existX || existY) || keys.length === 2 && existX && existY) {\n return 'move';\n }\n\n if (isNumber(cfg.x) || isNumber(cfg.y) || cfg.type || cfg.anchorPoints || cfg.size || (cfg === null || cfg === void 0 ? void 0 : cfg.style) && (((_a = cfg === null || cfg === void 0 ? void 0 : cfg.style) === null || _a === void 0 ? void 0 : _a.r) || ((_b = cfg === null || cfg === void 0 ? void 0 : cfg.style) === null || _b === void 0 ? void 0 : _b.width) || ((_c = cfg === null || cfg === void 0 ? void 0 : cfg.style) === null || _c === void 0 ? void 0 : _c.height) || ((_d = cfg === null || cfg === void 0 ? void 0 : cfg.style) === null || _d === void 0 ? void 0 : _d.rx) || ((_e = cfg === null || cfg === void 0 ? void 0 : cfg.style) === null || _e === void 0 ? void 0 : _e.ry))) {\n return 'bbox';\n }\n\n return 'style';\n };\n\n return Node;\n}(Item);\n\nexport default Node;","import { __assign, __extends } from \"tslib\";\nimport Node from './node';\nimport Global from '../global';\nimport { getBBox } from '../util/graphic';\nimport { isNumber } from '@antv/util';\nvar CACHE_BBOX = 'bboxCache';\nvar CACHE_CANVAS_BBOX = 'bboxCanvasCache';\nvar CACHE_SIZE = 'sizeCache';\nvar CACHE_ANCHOR_POINTS = 'anchorPointsCache';\n\nvar Combo = function (_super) {\n __extends(Combo, _super);\n\n function Combo() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n\n Combo.prototype.getDefaultCfg = function () {\n return {\n type: 'combo',\n nodes: [],\n edges: [],\n combos: []\n };\n };\n\n Combo.prototype.getShapeCfg = function (model) {\n var styles = this.get('styles');\n var bbox = this.get('bbox');\n\n if (styles && bbox) {\n // merge graph的item样式与数据模型中的样式\n var newModel = model;\n var size = {\n r: Math.hypot(bbox.height, bbox.width) / 2 || Global.defaultCombo.size[0] / 2,\n width: bbox.width || Global.defaultCombo.size[0],\n height: bbox.height || Global.defaultCombo.size[1]\n };\n newModel.style = __assign(__assign(__assign({}, styles), model.style), size);\n var padding = model.padding || Global.defaultCombo.padding;\n\n if (isNumber(padding)) {\n size.r += padding;\n size.width += padding * 2;\n size.height += padding * 2;\n } else {\n size.r += padding[0];\n size.width += padding[1] + padding[3] || padding[1] * 2;\n size.height += padding[0] + padding[2] || padding[0] * 2;\n }\n\n this.set(CACHE_SIZE, size);\n return newModel;\n }\n\n return model;\n };\n /**\n * 根据 keyshape 计算包围盒\n */\n\n\n Combo.prototype.calculateCanvasBBox = function () {\n if (this.destroyed) return;\n var keyShape = this.get('keyShape');\n var group = this.get('group'); // 因为 group 可能会移动,所以必须通过父元素计算才能计算出正确的包围盒\n\n var bbox = getBBox(keyShape, group);\n bbox.centerX = (bbox.minX + bbox.maxX) / 2;\n bbox.centerY = (bbox.minY + bbox.maxY) / 2;\n var cacheSize = this.get(CACHE_SIZE);\n var cacheBBox = this.get(CACHE_BBOX) || {};\n var oriX = cacheBBox.x;\n var oriY = cacheBBox.x;\n\n if (cacheSize) {\n cacheSize.width = Math.max(cacheSize.width, bbox.width);\n cacheSize.height = Math.max(cacheSize.height, bbox.height);\n var type = keyShape.get('type');\n\n if (type === 'circle') {\n bbox.width = cacheSize.r * 2;\n bbox.height = cacheSize.r * 2;\n } else {\n bbox.width = cacheSize.width;\n bbox.height = cacheSize.height;\n }\n\n bbox.minX = bbox.centerX - bbox.width / 2;\n bbox.minY = bbox.centerY - bbox.height / 2;\n bbox.maxX = bbox.centerX + bbox.width / 2;\n bbox.maxY = bbox.centerY + bbox.height / 2;\n } else {\n bbox.width = bbox.maxX - bbox.minX;\n bbox.height = bbox.maxY - bbox.minY;\n bbox.centerX = (bbox.minX + bbox.maxX) / 2;\n bbox.centerY = (bbox.minY + bbox.maxY) / 2;\n }\n\n bbox.x = bbox.minX;\n bbox.y = bbox.minY;\n if (bbox.x !== oriX || bbox.y !== oriY) this.set(CACHE_ANCHOR_POINTS, null);\n return bbox;\n };\n /**\n * 获取 Combo 中所有的子元素,包括 Combo、Node 及 Edge\n */\n\n\n Combo.prototype.getChildren = function () {\n var self = this;\n return {\n nodes: self.getNodes(),\n combos: self.getCombos()\n };\n };\n /**\n * 获取 Combo 中所有子节点\n */\n\n\n Combo.prototype.getNodes = function () {\n var self = this;\n return self.get('nodes');\n };\n /**\n * 获取 Combo 中所有子 combo\n */\n\n\n Combo.prototype.getCombos = function () {\n var self = this;\n return self.get('combos');\n };\n /**\n * 向 Combo 中增加子 combo 或 node\n * @param item Combo 或节点实例\n * @return boolean 添加成功返回 true,否则返回 false\n */\n\n\n Combo.prototype.addChild = function (item) {\n var self = this;\n var itemType = item.getType();\n\n switch (itemType) {\n case 'node':\n self.addNode(item);\n break;\n\n case 'combo':\n self.addCombo(item);\n break;\n\n default:\n console.warn('Only node or combo items are allowed to be added into a combo');\n return false;\n }\n\n return true;\n };\n /**\n * 向 Combo 中增加 combo\n * @param combo Combo 实例\n * @return boolean 添加成功返回 true,否则返回 false\n */\n\n\n Combo.prototype.addCombo = function (combo) {\n var self = this;\n self.get('combos').push(combo);\n return true;\n };\n /**\n * 向 Combo 中添加节点\n * @param node 节点实例\n * @return boolean 添加成功返回 true,否则返回 false\n */\n\n\n Combo.prototype.addNode = function (node) {\n var self = this;\n self.get('nodes').push(node);\n return true;\n };\n /**\n * 向 Combo 中增加子 combo 或 node\n * @param item Combo 或节点实例\n * @return boolean 添加成功返回 true,否则返回 false\n */\n\n\n Combo.prototype.removeChild = function (item) {\n var self = this;\n var itemType = item.getType();\n\n switch (itemType) {\n case 'node':\n self.removeNode(item);\n break;\n\n case 'combo':\n self.removeCombo(item);\n break;\n\n default:\n console.warn('Only node or combo items are allowed to be added into a combo');\n return false;\n }\n\n return true;\n };\n /**\n * 从 Combo 中移除指定的 combo\n * @param combo Combo 实例\n * @return boolean 移除成功返回 true,否则返回 false\n */\n\n\n Combo.prototype.removeCombo = function (combo) {\n if (!combo) return;\n var combos = this.getCombos();\n var index = combos.indexOf(combo);\n\n if (index > -1) {\n combos.splice(index, 1);\n return true;\n }\n\n return false;\n };\n /**\n * 向 Combo 中移除指定的节点\n * @param node 节点实例\n * @return boolean 移除成功返回 true,否则返回 false\n */\n\n\n Combo.prototype.removeNode = function (node) {\n if (!node) return;\n var nodes = this.getNodes();\n var index = nodes.indexOf(node);\n\n if (index > -1) {\n nodes.splice(index, 1);\n return true;\n }\n\n return false;\n };\n\n Combo.prototype.getUpdateType = function (cfg) {\n return undefined;\n };\n /**\n * 获取 item 的包围盒,这个包围盒是相对于 item 自己,不会将 matrix 计算在内\n * @return {Object} 包含 x,y,width,height, centerX, centerY\n */\n\n\n Combo.prototype.getBBox = function () {\n this.set(CACHE_CANVAS_BBOX, null);\n var bbox = this.calculateCanvasBBox();\n return bbox;\n };\n\n Combo.prototype.clearCache = function () {\n this.set(CACHE_BBOX, null); // 清理缓存的 bbox\n\n this.set(CACHE_CANVAS_BBOX, null);\n this.set(CACHE_ANCHOR_POINTS, null);\n };\n\n Combo.prototype.destroy = function () {\n if (!this.destroyed) {\n var animate = this.get('animate');\n var group = this.get('group');\n\n if (animate) {\n group.stopAnimate();\n }\n\n this.clearCache();\n this.set(CACHE_SIZE, null);\n this.set('bbox', null);\n group.remove();\n this._cfg = null;\n this.destroyed = true;\n }\n };\n\n return Combo;\n}(Node);\n\nexport default Combo;","import { __assign } from \"tslib\";\nimport { clone, deepMix, each, isArray, isObject, isString, upperFirst, throttle } from '@antv/util';\nimport Edge from '../../item/edge';\nimport Node from '../../item/node';\nimport Combo from '../../item/combo';\nimport { traverseTreeUp, traverseTree, getComboBBox } from '../../util/graphic';\nvar NODE = 'node';\nvar EDGE = 'edge';\nvar VEDGE = 'vedge';\nvar COMBO = 'combo';\nvar CFG_PREFIX = 'default';\nvar MAPPER_SUFFIX = 'Mapper';\nvar STATE_SUFFIX = 'stateStyles';\n\nvar ItemController = function () {\n function ItemController(graph) {\n var _this = this;\n\n this.edgeToBeUpdateMap = {};\n /**\n * 更新边限流,同时可以防止相同的边频繁重复更新\n * */\n\n this.throttleRefresh = throttle(function (_) {\n var _a;\n\n var graph = _this.graph;\n if (!graph || graph.get('destroyed')) return;\n var edgeToBeUpdateMap = _this.edgeToBeUpdateMap;\n if (!edgeToBeUpdateMap || !((_a = Object.keys(edgeToBeUpdateMap)) === null || _a === void 0 ? void 0 : _a.length)) return;\n Object.keys(edgeToBeUpdateMap).forEach(function (eid) {\n var edge = edgeToBeUpdateMap[eid].edge;\n if (!edge || edge.destroyed) return;\n edge.refresh(edgeToBeUpdateMap[eid].updateType);\n });\n _this.edgeToBeUpdateMap = {};\n }, 16, {\n trailing: true,\n leading: true\n });\n this.graph = graph;\n this.destroyed = false;\n }\n /**\n * 增加 Item 实例\n *\n * @param {ITEM_TYPE} type 实例类型,node 或 edge\n * @param {(NodeConfig & EdgeConfig)} model 数据模型\n * @returns {(Item)}\n * @memberof ItemController\n */\n\n\n ItemController.prototype.addItem = function (type, model) {\n var graph = this.graph;\n var vType = type === VEDGE ? EDGE : type;\n var parent = graph.get(vType + \"Group\") || graph.get('group');\n var upperType = upperFirst(vType);\n var item = null; // 获取 this.get('styles') 中的值\n\n var styles = graph.get(vType + upperFirst(STATE_SUFFIX)) || {};\n var defaultModel = graph.get(CFG_PREFIX + upperType);\n\n if (model[STATE_SUFFIX]) {\n // 设置 this.get('styles') 中的值\n styles = model[STATE_SUFFIX];\n }\n\n if (defaultModel) {\n // 很多布局会直接修改原数据模型,所以不能用 merge 的形式,逐个写入原 model 中\n each(defaultModel, function (val, cfg) {\n if (isObject(val) && !isArray(val)) {\n model[cfg] = deepMix({}, val, model[cfg]);\n } else if (isArray(val)) {\n model[cfg] = model[cfg] || clone(defaultModel[cfg]);\n } else {\n model[cfg] = model[cfg] || defaultModel[cfg];\n }\n });\n }\n\n var mapper = graph.get(vType + MAPPER_SUFFIX);\n\n if (mapper) {\n var mappedModel_1 = mapper(model);\n\n if (mappedModel_1[STATE_SUFFIX]) {\n // 设置 this.get('styles') 中的值\n styles = mappedModel_1[STATE_SUFFIX];\n delete mappedModel_1[STATE_SUFFIX];\n } // 如果配置了 defaultEdge 或 defaultNode,则将默认配置的数据也合并进去\n\n\n each(mappedModel_1, function (val, cfg) {\n if (isObject(val) && !isArray(val)) {\n model[cfg] = deepMix({}, model[cfg], val);\n } else {\n model[cfg] = mappedModel_1[cfg] || model[cfg];\n }\n });\n }\n\n graph.emit('beforeadditem', {\n type: type,\n model: model\n });\n\n if (type === EDGE || type === VEDGE) {\n var source = void 0;\n var target = void 0;\n source = model.source; // eslint-disable-line prefer-destructuring\n\n target = model.target; // eslint-disable-line prefer-destructuring\n\n if (source && isString(source)) {\n source = graph.findById(source);\n }\n\n if (target && isString(target)) {\n target = graph.findById(target);\n }\n\n if (!source || !target) {\n console.warn(\"The source or target node of edge \" + model.id + \" does not exist!\");\n return;\n }\n\n if (source.getType && source.getType() === 'combo') {\n model.isComboEdge = true; // graph.updateCombo(source as ICombo);\n }\n\n if (target.getType && target.getType() === 'combo') {\n model.isComboEdge = true; // graph.updateCombo(target as ICombo);\n }\n\n item = new Edge({\n model: model,\n source: source,\n target: target,\n styles: styles,\n linkCenter: graph.get('linkCenter'),\n group: parent.addGroup()\n });\n } else if (type === NODE) {\n item = new Node({\n model: model,\n styles: styles,\n group: parent.addGroup()\n });\n } else if (type === COMBO) {\n var children = model.children;\n var comboBBox = getComboBBox(children, graph);\n if (!isNaN(comboBBox.x)) model.x = comboBBox.x;else if (isNaN(model.x)) model.x = Math.random() * 100;\n if (!isNaN(comboBBox.y)) model.y = comboBBox.y;else if (isNaN(model.y)) model.y = Math.random() * 100;\n var comboGroup = parent.addGroup();\n comboGroup.setZIndex(model.depth);\n item = new Combo({\n model: model,\n styles: styles,\n bbox: model.collapsed ? getComboBBox([], graph) : comboBBox,\n group: comboGroup\n });\n var comboModel_1 = item.getModel();\n (children || []).forEach(function (child) {\n var childItem = graph.findById(child.id);\n item.addChild(childItem);\n child.depth = comboModel_1.depth + 2;\n }); // collapse the combo if the collapsed is true in the model\n\n if (model.collapsed) {\n setTimeout(function () {\n if (!item.destroyed) {\n graph.collapseCombo(item);\n }\n }, 0);\n }\n }\n\n if (item) {\n graph.get(type + \"s\").push(item);\n graph.get('itemMap')[item.get('id')] = item;\n graph.emit('afteradditem', {\n item: item,\n model: model\n }); // eslint-disable-next-line consistent-return\n\n return item;\n }\n };\n /**\n * 更新节点或边\n *\n * @param {Item} item ID 或 实例\n * @param {(EdgeConfig | Partial<NodeConfig>)} cfg 数据模型\n * @returns\n * @memberof ItemController\n */\n\n\n ItemController.prototype.updateItem = function (item, cfg) {\n var _this = this;\n\n var _a, _b;\n\n var graph = this.graph;\n\n if (isString(item)) {\n item = graph.findById(item);\n }\n\n if (!item || item.destroyed) {\n return;\n } // 更新的 item 的类型\n\n\n var type = '';\n if (item.getType) type = item.getType();\n var mapper = graph.get(type + MAPPER_SUFFIX);\n var model = item.getModel();\n var updateType = item.getUpdateType(cfg);\n\n if (mapper) {\n var result = deepMix({}, model, cfg);\n var mappedModel = mapper(result); // 将 update 时候用户传入的参数与mapperModel做deepMix,以便复用之前设置的参数值\n\n var newModel = deepMix({}, model, mappedModel, cfg);\n\n if (mappedModel[STATE_SUFFIX]) {\n item.set('styles', newModel[STATE_SUFFIX]);\n delete newModel[STATE_SUFFIX];\n }\n\n each(newModel, function (val, key) {\n cfg[key] = val;\n });\n } else {\n // merge update传进来的对象参数,model中没有的数据不做处理,对象和字符串值也不做处理,直接替换原来的\n each(cfg, function (val, key) {\n if (model[key]) {\n if (isObject(val) && !isArray(val)) {\n cfg[key] = __assign(__assign({}, model[key]), cfg[key]);\n }\n }\n });\n } // emit beforeupdateitem 事件\n\n\n graph.emit('beforeupdateitem', {\n item: item,\n cfg: cfg\n });\n\n if (type === EDGE) {\n // 若是边要更新source || target, 为了不影响示例内部model,并且重新计算startPoint和endPoint,手动设置\n if (cfg.source) {\n var source = cfg.source;\n\n if (isString(source)) {\n source = graph.findById(source);\n }\n\n item.setSource(source);\n }\n\n if (cfg.target) {\n var target = cfg.target;\n\n if (isString(target)) {\n target = graph.findById(target);\n }\n\n item.setTarget(target);\n }\n\n item.update(cfg);\n } // item.update(cfg);\n\n\n if (type === NODE || type === COMBO) {\n item.update(cfg, updateType);\n var edges_1 = item.getEdges();\n var refreshEdge = updateType === 'bbox' || updateType === 'move';\n\n if (type === NODE) {\n if (updateType === 'move') {\n each(edges_1, function (edge) {\n _this.edgeToBeUpdateMap[edge.getID()] = {\n edge: edge,\n updateType: updateType\n };\n\n _this.throttleRefresh();\n });\n } else if (refreshEdge) {\n each(edges_1, function (edge) {\n edge.refresh();\n });\n }\n } else if (refreshEdge && type === COMBO) {\n var shapeFactory = item.get('shapeFactory');\n var shapeType = model.type || 'circle';\n var comboAnimate = model.animate === undefined || cfg.animate === undefined ? (_b = (_a = shapeFactory[shapeType]) === null || _a === void 0 ? void 0 : _a.options) === null || _b === void 0 ? void 0 : _b.animate : model.animate || cfg.animate;\n\n if (comboAnimate) {\n setTimeout(function () {\n if (!item || item.destroyed) return;\n var keyShape = item.getKeyShape();\n if (!keyShape || keyShape.destroyed) return;\n each(edges_1, function (edge) {\n if (edge && !edge.destroyed) edge.refresh();\n });\n }, 201);\n } else {\n each(edges_1, function (edge) {\n edge.refresh();\n });\n }\n }\n }\n\n graph.emit('afterupdateitem', {\n item: item,\n cfg: cfg\n });\n };\n /**\n * 根据 combo 的子元素更新 combo 的位置及大小\n *\n * @param {ICombo} combo ID 或 实例\n * @returns\n * @memberof ItemController\n */\n\n\n ItemController.prototype.updateCombo = function (combo, children) {\n var _this = this;\n\n var _a, _b;\n\n var graph = this.graph;\n\n if (isString(combo)) {\n combo = graph.findById(combo);\n }\n\n if (!combo || combo.destroyed) {\n return;\n }\n\n var model = combo.getModel();\n var comboBBox = getComboBBox(model.collapsed ? [] : children, graph);\n\n var _c = model.collapsed ? getComboBBox(children, graph) : comboBBox,\n comboX = _c.x,\n comboY = _c.y;\n\n combo.set('bbox', comboBBox);\n combo.update({\n x: comboX,\n y: comboY\n });\n var shapeFactory = combo.get('shapeFactory');\n var shapeType = model.type || 'circle';\n var comboAnimate = model.animate === undefined ? (_b = (_a = shapeFactory[shapeType]) === null || _a === void 0 ? void 0 : _a.options) === null || _b === void 0 ? void 0 : _b.animate : model.animate;\n\n if (comboAnimate) {\n setTimeout(function () {\n if (!combo || combo.destroyed) return;\n var keyShape = combo.getKeyShape();\n if (!keyShape || keyShape.destroyed) return;\n combo.getShapeCfg(model); // 更新 combo 缓存的 size\n\n _this.updateComboEdges(combo);\n }, 201);\n } else {\n this.updateComboEdges(combo);\n }\n };\n\n ItemController.prototype.updateComboEdges = function (combo) {\n var combEdges = combo.getEdges() || [];\n\n for (var i = 0; i < combEdges.length; i++) {\n var edge = combEdges[i];\n\n if (edge && !edge.destroyed) {\n var edgeSF = edge.get('shapeFactory');\n var edgeCfg = edge.getShapeCfg(edge.getModel());\n var edgeGroup = edge.getContainer();\n edgeGroup.clear();\n var keyShape = edgeSF.draw(edgeCfg.type, edgeCfg, edgeGroup);\n edge.set('keyShape', keyShape);\n keyShape.set('isKeyShape', true);\n keyShape.set('draggable', true);\n edge.setOriginStyle();\n }\n }\n };\n /**\n * 收起 combo,隐藏相关元素\n */\n\n\n ItemController.prototype.collapseCombo = function (combo) {\n var graph = this.graph;\n\n if (isString(combo)) {\n combo = graph.findById(combo);\n }\n\n var children = combo.getChildren();\n children.nodes.forEach(function (node) {\n graph.hideItem(node);\n });\n children.combos.forEach(function (c) {\n graph.hideItem(c);\n });\n };\n /**\n * 展开 combo,相关元素出现\n * 若子 combo 原先是收起状态,则保持它的收起状态\n */\n\n\n ItemController.prototype.expandCombo = function (combo) {\n var graph = this.graph;\n\n if (isString(combo)) {\n combo = graph.findById(combo);\n }\n\n var children = combo.getChildren();\n children.nodes.forEach(function (node) {\n graph.showItem(node);\n });\n children.combos.forEach(function (c) {\n if (c.getModel().collapsed) {\n c.show();\n } else {\n graph.showItem(c);\n }\n });\n };\n /**\n * 删除指定的节点或边\n *\n * @param {Item} item item ID 或实例\n * @returns {void}\n * @memberof ItemController\n */\n\n\n ItemController.prototype.removeItem = function (item) {\n var _this = this;\n\n var graph = this.graph;\n\n if (isString(item)) {\n item = graph.findById(item);\n }\n\n if (!item || item.destroyed) {\n return;\n }\n\n var itemModel = clone(item.getModel());\n graph.emit('beforeremoveitem', {\n item: itemModel\n });\n var type = '';\n if (item.getType) type = item.getType();\n var items = graph.get(type + \"s\");\n var index = items.indexOf(item);\n if (index > -1) items.splice(index, 1);\n\n if (type === EDGE) {\n var vitems = graph.get(\"v\" + type + \"s\");\n var vindex = vitems.indexOf(item);\n if (vindex > -1) vitems.splice(vindex, 1);\n }\n\n var itemId = item.get('id');\n var itemMap = graph.get('itemMap');\n delete itemMap[itemId];\n var comboTrees = graph.get('comboTrees');\n var id = item.get('id');\n\n if (type === NODE) {\n var comboId = item.getModel().comboId;\n\n if (comboTrees && comboId) {\n var brothers_1 = comboTrees;\n var found_1 = false; // the flag to terminate the forEach circulation\n // remove the node from the children array of its parent fromt he tree\n\n comboTrees.forEach(function (ctree) {\n if (found_1) return;\n traverseTree(ctree, function (combo) {\n if (combo.id === id && brothers_1) {\n var bidx = brothers_1.indexOf(combo);\n brothers_1.splice(bidx, 1);\n found_1 = true;\n return false; // terminate the traverse\n }\n\n brothers_1 = combo.children;\n return true;\n });\n });\n } // 若移除的是节点,需要将与之相连的边一同删除\n\n\n var edges = item.getEdges();\n\n for (var i = edges.length - 1; i >= 0; i--) {\n graph.removeItem(edges[i], false);\n }\n\n if (comboId) graph.updateCombo(comboId);\n } else if (type === COMBO) {\n var parentId = item.getModel().parentId;\n var comboInTree_1; // find the subtree rooted at the item to be removed\n\n var found_2 = false; // the flag to terminate the forEach circulation\n\n (comboTrees || []).forEach(function (ctree) {\n if (found_2) return;\n traverseTree(ctree, function (combo) {\n if (combo.id === id) {\n comboInTree_1 = combo;\n found_2 = true;\n return false; // terminate the traverse\n }\n\n return true;\n });\n });\n comboInTree_1.removed = true;\n\n if (comboInTree_1 && comboInTree_1.children) {\n comboInTree_1.children.forEach(function (child) {\n _this.removeItem(child.id);\n });\n } // 若移除的是 combo,需要将与之相连的边一同删除\n\n\n var edges = item.getEdges();\n\n for (var i = edges.length; i >= 0; i--) {\n graph.removeItem(edges[i], false);\n }\n\n if (parentId) graph.updateCombo(parentId);\n }\n\n item.destroy();\n graph.emit('afterremoveitem', {\n item: itemModel\n });\n };\n /**\n * 更新 item 状态\n *\n * @param {Item} item Item 实例\n * @param {string} state 状态名称\n * @param {boolean} value 是否启用状态或状态值\n * @returns {void}\n * @memberof ItemController\n */\n\n\n ItemController.prototype.setItemState = function (item, state, value) {\n var graph = this.graph;\n var stateName = state;\n\n if (isString(value)) {\n stateName = state + \":\" + value;\n } // 已经存在要设置的 state,或不存在 state 的样式为 undefined\n\n\n if (item.hasState(stateName) === value && value || isString(value) && item.hasState(stateName)) {\n // 当该状态 value 是字符串,且已经存在该状态,不需要继续\n return;\n }\n\n graph.emit('beforeitemstatechange', {\n item: item,\n state: stateName,\n enabled: value\n });\n item.setState(state, value);\n graph.autoPaint();\n graph.emit('afteritemstatechange', {\n item: item,\n state: stateName,\n enabled: value\n });\n };\n /**\n * 将指定状态的优先级提升为最高优先级\n * @param {Item} item 元素id或元素实例\n * @param state 状态名称\n */\n\n\n ItemController.prototype.priorityState = function (item, state) {\n var graph = this.graph;\n var currentItem = item;\n\n if (isString(item)) {\n currentItem = graph.findById(item);\n } // 先取消已有的 state\n\n\n this.setItemState(currentItem, state, false); // 再设置state,则此时该优先级为最高\n\n this.setItemState(currentItem, state, true);\n };\n /**\n * 清除所有指定的状态\n *\n * @param {Item} item Item 实例\n * @param {string[]} states 状态名称集合\n * @memberof ItemController\n */\n\n\n ItemController.prototype.clearItemStates = function (item, states) {\n var graph = this.graph;\n\n if (isString(item)) {\n item = graph.findById(item);\n }\n\n graph.emit('beforeitemstatesclear', {\n item: item,\n states: states\n });\n item.clearStates(states);\n graph.emit('afteritemstatesclear', {\n item: item,\n states: states\n });\n };\n /**\n * 刷新指定的 Item\n *\n * @param {Item} item Item ID 或 实例\n * @memberof ItemController\n */\n\n\n ItemController.prototype.refreshItem = function (item) {\n var graph = this.graph;\n\n if (isString(item)) {\n item = graph.findById(item);\n }\n\n graph.emit('beforeitemrefresh', {\n item: item\n }); // 调用 Item 的 refresh 方法,实现刷新功能\n\n item.refresh();\n graph.emit('afteritemrefresh', {\n item: item\n });\n };\n /**\n * 根据 graph 上用 combos 数据生成的 comboTree 来增加所有 combos\n *\n * @param {ComboTree[]} comboTrees graph 上用 combos 数据生成的 comboTree\n * @param {ComboConfig[]} comboModels combos 数据\n * @memberof ItemController\n */\n\n\n ItemController.prototype.addCombos = function (comboTrees, comboModels) {\n var _this = this;\n\n var graph = this.graph;\n (comboTrees || []).forEach(function (ctree) {\n traverseTreeUp(ctree, function (child) {\n var comboModel;\n comboModels.forEach(function (model) {\n if (model.id === child.id) {\n model.children = child.children;\n model.depth = child.depth;\n comboModel = model;\n }\n });\n\n if (comboModel) {\n _this.addItem('combo', comboModel);\n }\n\n return true;\n });\n });\n var comboGroup = graph.get('comboGroup');\n if (comboGroup) comboGroup.sort();\n };\n /**\n * 改变Item的显示状态\n *\n * @param {Item} item Item ID 或 实例\n * @param {boolean} visible 是否显示\n * @memberof ItemController\n */\n\n\n ItemController.prototype.changeItemVisibility = function (item, visible) {\n var _this = this;\n\n var graph = this.graph;\n\n if (isString(item)) {\n item = graph.findById(item);\n }\n\n if (!item) {\n console.warn('The item to be shown or hidden does not exist!');\n return;\n }\n\n graph.emit('beforeitemvisibilitychange', {\n item: item,\n visible: visible\n });\n item.changeVisibility(visible);\n\n if (item.getType && item.getType() === NODE) {\n var edges = item.getEdges();\n each(edges, function (edge) {\n // 若隐藏节点,则将与之关联的边也隐藏\n // 若显示节点,则将与之关联的边也显示,但是需要判断边两端的节点都是可见的\n if (visible && !(edge.get('source').isVisible() && edge.get('target').isVisible())) {\n return;\n }\n\n _this.changeItemVisibility(edge, visible);\n });\n } else if (item.getType && item.getType() === COMBO) {\n var comboTrees = graph.get('comboTrees');\n var id_1 = item.get('id');\n var children_1 = [];\n var found_3 = false; // flag the terminate the forEach\n\n (comboTrees || []).forEach(function (ctree) {\n if (found_3) return;\n if (!ctree.children || ctree.children.length === 0) return;\n traverseTree(ctree, function (combo) {\n if (combo.id === id_1) {\n children_1 = combo.children;\n found_3 = true;\n return false; // terminate the traverse\n }\n\n return true;\n });\n });\n\n if (children_1 && (!visible || visible && !item.getModel().collapsed)) {\n children_1.forEach(function (child) {\n var childItem = graph.findById(child.id);\n\n _this.changeItemVisibility(childItem, visible);\n });\n }\n\n var edges = item.getEdges();\n each(edges, function (edge) {\n // 若隐藏 combo,则将与 combo 本身关联的边也隐藏\n // 若显示 combo,则将与 combo 本身关联的边也显示,但是需要判断边两端的节点都是可见的\n if (visible && !(edge.get('source').isVisible() && edge.get('target').isVisible())) {\n return;\n }\n\n _this.changeItemVisibility(edge, visible);\n });\n }\n\n graph.emit('afteritemvisibilitychange', {\n item: item,\n visible: visible\n });\n return item;\n };\n\n ItemController.prototype.destroy = function () {\n this.graph = null;\n this.destroyed = true;\n };\n\n return ItemController;\n}();\n\nexport default ItemController;","import { each, isString } from '@antv/util';\nvar timer = null;\n\nvar StateController = function () {\n function StateController(graph) {\n this.graph = graph;\n /**\n * this.cachedStates = {\n * enabled: {\n * hover: [Node]\n * },\n * disabled: {}\n * }\n */\n\n this.cachedStates = {\n enabled: {},\n disabled: {}\n };\n this.destroyed = false;\n }\n /**\n * 检查 cache 的可用性\n *\n * @private\n * @param {Item} item\n * @param {string} state\n * @param {object} cache\n * @returns\n * @memberof State\n */\n\n\n StateController.checkCache = function (item, state, cache) {\n if (!cache[state]) {\n return;\n }\n\n var index = cache[state].indexOf(item);\n\n if (index >= 0) {\n cache[state].splice(index, 1);\n }\n };\n /**\n * 缓存 state\n *\n * @private\n * @param {Item} item Item 实例\n * @param {string} state 状态名称\n * @param {object} states\n * @memberof State\n */\n\n\n StateController.cacheState = function (item, state, states) {\n if (!states[state]) {\n states[state] = [];\n }\n\n states[state].push(item);\n };\n /**\n * 更新 Item 的状态\n *\n * @param {Item} item Item实例\n * @param {string} state 状态名称\n * @param {boolean} enabled 状态是否可用\n * @memberof State\n */\n\n\n StateController.prototype.updateState = function (item, state, enabled) {\n var _this = this;\n\n var checkCache = StateController.checkCache,\n cacheState = StateController.cacheState;\n\n if (item.destroyed) {\n return;\n }\n\n var cachedStates = this.cachedStates;\n var enabledStates = cachedStates.enabled;\n var disabledStates = cachedStates.disabled;\n\n if (enabled) {\n checkCache(item, state, disabledStates);\n cacheState(item, state, enabledStates);\n } else {\n checkCache(item, state, enabledStates);\n cacheState(item, state, disabledStates);\n }\n\n if (timer) {\n clearTimeout(timer);\n }\n\n timer = setTimeout(function () {\n timer = null;\n\n _this.updateGraphStates();\n }, 16);\n };\n /**\n * 批量更新 states,兼容 updateState,支持更新一个 state\n *\n * @param {Item} item\n * @param {(string | string[])} states\n * @param {boolean} enabled\n * @memberof State\n */\n\n\n StateController.prototype.updateStates = function (item, states, enabled) {\n var _this = this;\n\n if (isString(states)) {\n this.updateState(item, states, enabled);\n } else {\n states.forEach(function (state) {\n _this.updateState(item, state, enabled);\n });\n }\n };\n /**\n * 更新 states\n *\n * @memberof State\n */\n\n\n StateController.prototype.updateGraphStates = function () {\n var states = this.graph.get('states');\n var cachedStates = this.cachedStates;\n each(cachedStates.disabled, function (val, key) {\n if (states[key]) {\n states[key] = states[key].filter(function (item) {\n return val.indexOf(item) < 0 && !val.destroyed;\n });\n }\n });\n each(cachedStates.enabled, function (val, key) {\n if (!states[key]) {\n states[key] = val;\n } else {\n var map_1 = {};\n states[key].forEach(function (item) {\n if (!item.destroyed) {\n map_1[item.get('id')] = true;\n }\n });\n val.forEach(function (item) {\n if (!item.destroyed) {\n var id = item.get('id');\n\n if (!map_1[id]) {\n map_1[id] = true;\n states[key].push(item);\n }\n }\n });\n }\n });\n this.graph.emit('graphstatechange', {\n states: states\n });\n this.cachedStates = {\n enabled: {},\n disabled: {}\n };\n };\n\n StateController.prototype.destroy = function () {\n this.graph = null;\n this.cachedStates = null;\n\n if (timer) {\n clearTimeout(timer);\n }\n\n timer = null;\n this.destroyed = true;\n };\n\n return StateController;\n}();\n\nexport default StateController;","var TAU = Math.PI * 2;\nvar mapToEllipse = function (_a, rx, ry, cosphi, sinphi, centerx, centery) {\n var x = _a.x, y = _a.y;\n x *= rx;\n y *= ry;\n var xp = cosphi * x - sinphi * y;\n var yp = sinphi * x + cosphi * y;\n return {\n x: xp + centerx,\n y: yp + centery\n };\n};\nvar approxUnitArc = function (ang1, ang2) {\n // If 90 degree circular arc, use a constant\n // as derived from http://spencermortensen.com/articles/bezier-circle\n var a = ang2 === 1.5707963267948966\n ? 0.551915024494\n : ang2 === -1.5707963267948966\n ? -0.551915024494\n : 4 / 3 * Math.tan(ang2 / 4);\n var x1 = Math.cos(ang1);\n var y1 = Math.sin(ang1);\n var x2 = Math.cos(ang1 + ang2);\n var y2 = Math.sin(ang1 + ang2);\n return [\n {\n x: x1 - y1 * a,\n y: y1 + x1 * a\n },\n {\n x: x2 + y2 * a,\n y: y2 - x2 * a\n },\n {\n x: x2,\n y: y2\n }\n ];\n};\nvar vectorAngle = function (ux, uy, vx, vy) {\n var sign = (ux * vy - uy * vx < 0) ? -1 : 1;\n var dot = ux * vx + uy * vy;\n if (dot > 1) {\n dot = 1;\n }\n if (dot < -1) {\n dot = -1;\n }\n return sign * Math.acos(dot);\n};\nvar getArcCenter = function (px, py, cx, cy, rx, ry, largeArcFlag, sweepFlag, sinphi, cosphi, pxp, pyp) {\n var rxsq = Math.pow(rx, 2);\n var rysq = Math.pow(ry, 2);\n var pxpsq = Math.pow(pxp, 2);\n var pypsq = Math.pow(pyp, 2);\n var radicant = (rxsq * rysq) - (rxsq * pypsq) - (rysq * pxpsq);\n if (radicant < 0) {\n radicant = 0;\n }\n radicant /= (rxsq * pypsq) + (rysq * pxpsq);\n radicant = Math.sqrt(radicant) * (largeArcFlag === sweepFlag ? -1 : 1);\n var centerxp = radicant * rx / ry * pyp;\n var centeryp = radicant * -ry / rx * pxp;\n var centerx = cosphi * centerxp - sinphi * centeryp + (px + cx) / 2;\n var centery = sinphi * centerxp + cosphi * centeryp + (py + cy) / 2;\n var vx1 = (pxp - centerxp) / rx;\n var vy1 = (pyp - centeryp) / ry;\n var vx2 = (-pxp - centerxp) / rx;\n var vy2 = (-pyp - centeryp) / ry;\n var ang1 = vectorAngle(1, 0, vx1, vy1);\n var ang2 = vectorAngle(vx1, vy1, vx2, vy2);\n if (sweepFlag === 0 && ang2 > 0) {\n ang2 -= TAU;\n }\n if (sweepFlag === 1 && ang2 < 0) {\n ang2 += TAU;\n }\n return [centerx, centery, ang1, ang2];\n};\nvar arcToBezier = function (_a) {\n var px = _a.px, py = _a.py, cx = _a.cx, cy = _a.cy, rx = _a.rx, ry = _a.ry, _b = _a.xAxisRotation, xAxisRotation = _b === void 0 ? 0 : _b, _c = _a.largeArcFlag, largeArcFlag = _c === void 0 ? 0 : _c, _d = _a.sweepFlag, sweepFlag = _d === void 0 ? 0 : _d;\n var curves = [];\n if (rx === 0 || ry === 0) {\n return [{ x1: 0, y1: 0, x2: 0, y2: 0, x: cx, y: cy }];\n }\n var sinphi = Math.sin(xAxisRotation * TAU / 360);\n var cosphi = Math.cos(xAxisRotation * TAU / 360);\n var pxp = cosphi * (px - cx) / 2 + sinphi * (py - cy) / 2;\n var pyp = -sinphi * (px - cx) / 2 + cosphi * (py - cy) / 2;\n if (pxp === 0 && pyp === 0) {\n return [{ x1: 0, y1: 0, x2: 0, y2: 0, x: cx, y: cy }];\n }\n rx = Math.abs(rx);\n ry = Math.abs(ry);\n var lambda = Math.pow(pxp, 2) / Math.pow(rx, 2) +\n Math.pow(pyp, 2) / Math.pow(ry, 2);\n if (lambda > 1) {\n rx *= Math.sqrt(lambda);\n ry *= Math.sqrt(lambda);\n }\n var _e = getArcCenter(px, py, cx, cy, rx, ry, largeArcFlag, sweepFlag, sinphi, cosphi, pxp, pyp), centerx = _e[0], centery = _e[1], ang1 = _e[2], ang2 = _e[3];\n // If 'ang2' == 90.0000000001, then `ratio` will evaluate to\n // 1.0000000001. This causes `segments` to be greater than one, which is an\n // unecessary split, and adds extra points to the bezier curve. To alleviate\n // this issue, we round to 1.0 when the ratio is close to 1.0.\n var ratio = Math.abs(ang2) / (TAU / 4);\n if (Math.abs(1.0 - ratio) < 0.0000001) {\n ratio = 1.0;\n }\n var segments = Math.max(Math.ceil(ratio), 1);\n ang2 /= segments;\n for (var i = 0; i < segments; i++) {\n curves.push(approxUnitArc(ang1, ang2));\n ang1 += ang2;\n }\n return curves.map(function (curve) {\n var _a = mapToEllipse(curve[0], rx, ry, cosphi, sinphi, centerx, centery), x1 = _a.x, y1 = _a.y;\n var _b = mapToEllipse(curve[1], rx, ry, cosphi, sinphi, centerx, centery), x2 = _b.x, y2 = _b.y;\n var _c = mapToEllipse(curve[2], rx, ry, cosphi, sinphi, centerx, centery), x = _c.x, y = _c.y;\n return { x1: x1, y1: y1, x2: x2, y2: y2, x: x, y: y };\n });\n};\nexport function arcToCubic(x1, y1, rx, ry, angle, LAF, SF, x2, y2) {\n var curves = arcToBezier({\n px: x1,\n py: y1,\n cx: x2,\n cy: y2,\n rx: rx,\n ry: ry,\n xAxisRotation: angle,\n largeArcFlag: LAF,\n sweepFlag: SF,\n });\n return curves.reduce(function (prev, cur) {\n var x1 = cur.x1, y1 = cur.y1, x2 = cur.x2, y2 = cur.y2, x = cur.x, y = cur.y;\n prev.push(x1, y1, x2, y2, x, y);\n return prev;\n }, []);\n}\n//# sourceMappingURL=arc-2-cubic.js.map","import { vec2 } from '@antv/matrix-util';\nimport { catmullRom2Bezier } from '@antv/path-util';\n/**\n * 替换字符串中的字段\n * @param {String} str 模版字符串\n * @param {Object} o json data\n */\n\nvar substitute = function substitute(str, o) {\n if (!str || !o) {\n return str;\n }\n\n return str.replace(/\\\\?\\{([^{}]+)\\}/g, function (match, name) {\n if (match.charAt(0) === '\\\\') {\n return match.slice(1);\n }\n\n var res = o[name];\n if (res === 0) res = '0';\n return res || '';\n });\n};\n/**\n * 给定坐标获取三次贝塞尔曲线的 M 及 C 值\n * @param points coordinate set\n */\n\n\nexport var getSpline = function getSpline(points) {\n var data = [];\n\n if (points.length < 2) {\n throw new Error(\"point length must largn than 2, now it's \" + points.length);\n }\n\n for (var _i = 0, points_1 = points; _i < points_1.length; _i++) {\n var point = points_1[_i];\n var x = point.x,\n y = point.y;\n data.push(x);\n data.push(y);\n }\n\n var spliePath = catmullRom2Bezier(data);\n spliePath.unshift(['M', points[0].x, points[0].y]);\n return spliePath;\n};\n/**\n * 根据起始点、相对位置、偏移量计算控制点\n * @param {IPoint} startPoint 起始点,包含 x,y\n * @param {IPoint} endPoint 结束点, 包含 x,y\n * @param {Number} percent 相对位置,范围 0-1\n * @param {Number} offset 偏移量\n * @return {IPoint} 控制点,包含 x,y\n */\n\nexport var getControlPoint = function getControlPoint(startPoint, endPoint, percent, offset) {\n if (percent === void 0) {\n percent = 0;\n }\n\n if (offset === void 0) {\n offset = 0;\n }\n\n var point = {\n x: (1 - percent) * startPoint.x + percent * endPoint.x,\n y: (1 - percent) * startPoint.y + percent * endPoint.y\n };\n var tangent = [0, 0];\n vec2.normalize(tangent, [endPoint.x - startPoint.x, endPoint.y - startPoint.y]);\n\n if (!tangent || !tangent[0] && !tangent[1]) {\n tangent = [0, 0];\n }\n\n var perpendicular = [-tangent[1] * offset, tangent[0] * offset]; // 垂直向量\n\n point.x += perpendicular[0];\n point.y += perpendicular[1];\n return point;\n};\n/**\n * 点集转化为Path多边形\n * @param {Array} points 点集\n * @param {Boolen} z 是否封闭\n * @return {Array} Path\n */\n\nexport var pointsToPolygon = function pointsToPolygon(points, z) {\n var length = points.length;\n\n if (!length) {\n return '';\n }\n\n var path = '';\n var str = '';\n\n for (var i = 0; i < length; i++) {\n var item = points[i];\n\n if (i === 0) {\n str = 'M{x} {y}';\n } else {\n str = 'L{x} {y}';\n }\n\n path += substitute(str, item);\n }\n\n if (z) {\n path += 'Z';\n }\n\n return path;\n};\nexport var pathToPoints = function pathToPoints(path) {\n var points = [];\n path.forEach(function (seg) {\n var command = seg[0];\n\n if (command !== 'A') {\n for (var i = 1; i < seg.length; i = i + 2) {\n points.push([seg[i], seg[i + 1]]);\n }\n } else {\n var length_1 = seg.length;\n points.push([seg[length_1 - 2], seg[length_1 - 1]]);\n }\n });\n return points;\n};\n/**\n * 生成平滑的闭合曲线\n * @param points\n */\n\nexport var getClosedSpline = function getClosedSpline(points) {\n if (points.length < 2) {\n throw new Error(\"point length must largn than 2, now it's \" + points.length);\n }\n\n var first = points[0];\n var second = points[1];\n var last = points[points.length - 1];\n var lastSecond = points[points.length - 2];\n points.unshift(last);\n points.unshift(lastSecond);\n points.push(first);\n points.push(second);\n var closedPath = [];\n\n for (var i = 1; i < points.length - 2; i += 1) {\n var x0 = points[i - 1].x;\n var y0 = points[i - 1].y;\n var x1 = points[i].x;\n var y1 = points[i].y;\n var x2 = points[i + 1].x;\n var y2 = points[i + 1].y;\n var x3 = i !== points.length - 2 ? points[i + 2].x : x2;\n var y3 = i !== points.length - 2 ? points[i + 2].y : y2;\n var cp1x = x1 + (x2 - x0) / 6;\n var cp1y = y1 + (y2 - y0) / 6;\n var cp2x = x2 - (x3 - x1) / 6;\n var cp2y = y2 - (y3 - y1) / 6;\n closedPath.push(['C', cp1x, cp1y, cp2x, cp2y, x2, y2]);\n }\n\n closedPath.unshift(['M', last.x, last.y]);\n return closedPath;\n};\n\nvar vecScaleTo = function vecScaleTo(v, length) {\n // Vector with direction of v with specified length\n return vec2.scale([0, 0], vec2.normalize([0, 0], v), length);\n};\n\nvar unitNormal = function unitNormal(p0, p1) {\n // Returns the unit normal to the line segment from p0 to p1.\n var n = [p0[1] - p1[1], p1[0] - p0[0]];\n var nLength = Math.sqrt(n[0] * n[0] + n[1] * n[1]);\n\n if (nLength === 0) {\n throw new Error('p0 should not be equal to p1');\n }\n\n return [n[0] / nLength, n[1] / nLength];\n};\n\nvar vecFrom = function vecFrom(p0, p1) {\n // Vector from p0 to p1\n return [p1[0] - p0[0], p1[1] - p0[1]];\n};\n/**\n * 传入的节点作为多边形顶点,生成有圆角的多边形\n * @param polyPoints 多边形顶点\n * @param padding 在原多边形基础上增加最终轮廓和原多边形的空白间隔\n */\n\n\nexport function roundedHull(polyPoints, padding) {\n // The rounded hull path around a single point\n var roundedHull1 = function roundedHull1(points) {\n var p1 = [points[0][0], points[0][1] - padding];\n var p2 = [points[0][0], points[0][1] + padding];\n return \"M \" + p1 + \" A \" + padding + \",\" + padding + \",0,0,0,\" + p2 + \" A \" + padding + \",\" + padding + \",0,0,0,\" + p1;\n }; // The rounded hull path around two points\n\n\n var roundedHull2 = function roundedHull2(points) {\n var offsetVector = vec2.scale([0, 0], unitNormal(points[0], points[1]), padding);\n var invOffsetVector = vec2.scale([0, 0], offsetVector, -1);\n var p0 = vec2.add([0, 0], points[0], offsetVector);\n var p1 = vec2.add([0, 0], points[1], offsetVector);\n var p2 = vec2.add([0, 0], points[1], invOffsetVector);\n var p3 = vec2.add([0, 0], points[0], invOffsetVector);\n return \"M \" + p0 + \" L \" + p1 + \" A \" + [padding, padding, '0,0,0', p2].join(',') + \" L \" + p3 + \" A \" + [padding, padding, '0,0,0', p0].join(',');\n }; // 特殊情况处理:节点数小于等于2\n\n\n if (!polyPoints || polyPoints.length < 1) return '';\n if (polyPoints.length === 1) return roundedHull1(polyPoints);\n if (polyPoints.length === 2) return roundedHull2(polyPoints);\n var segments = new Array(polyPoints.length); // Calculate each offset (outwards) segment of the convex hull.\n\n for (var segmentIndex = 0; segmentIndex < segments.length; ++segmentIndex) {\n var p0 = segmentIndex === 0 ? polyPoints[polyPoints.length - 1] : polyPoints[segmentIndex - 1];\n var p1 = polyPoints[segmentIndex]; // Compute the offset vector for the line segment, with length = padding.\n\n var offset = vec2.scale([0, 0], unitNormal(p0, p1), padding);\n segments[segmentIndex] = [vec2.add([0, 0], p0, offset), vec2.add([0, 0], p1, offset)];\n }\n\n var arcData = \"A \" + [padding, padding, '0,0,0,'].join(',');\n segments = segments.map(function (segment, index) {\n var pathFragment = '';\n\n if (index === 0) {\n pathFragment = \"M \" + segments[segments.length - 1][1] + \" \";\n }\n\n pathFragment += arcData + segment[0] + \" L \" + segment[1];\n return pathFragment;\n });\n return segments.join(' ');\n}\n/**\n * 传入的节点作为多边形顶点,生成平滑的闭合多边形\n * @param polyPoints\n * @param padding\n */\n\nexport function paddedHull(polyPoints, padding) {\n var pointCount = polyPoints.length;\n\n var smoothHull1 = function smoothHull1(points) {\n // Returns the path for a circular hull around a single point.\n var p1 = [points[0][0], points[0][1] - padding];\n var p2 = [points[0][0], points[0][1] + padding];\n return \"M \" + p1 + \" A \" + [padding, padding, '0,0,0', p2].join(',') + \" A \" + [padding, padding, '0,0,0', p1].join(',');\n }; // Returns the path for a rounded hull around two points.\n\n\n var smoothHull2 = function smoothHull2(points) {\n var v = vecFrom(points[0], points[1]);\n var extensionVec = vecScaleTo(v, padding);\n var extension0 = vec2.add([0, 0], points[0], vec2.scale([0, 0], extensionVec, -1));\n var extension1 = vec2.add([0, 0], points[1], extensionVec);\n var tangentHalfLength = 1.2 * padding;\n var controlDelta = vecScaleTo(vec2.normalize([0, 0], v), tangentHalfLength);\n var invControlDelta = vec2.scale([0, 0], controlDelta, -1);\n var control0 = vec2.add([0, 0], extension0, invControlDelta);\n var control1 = vec2.add([0, 0], extension1, invControlDelta);\n var control3 = vec2.add([0, 0], extension0, controlDelta); // return [\n // ['M', extension0[0], extension0[1]],\n // ['C', control0, control1, extension1],\n // ['S', control3, extension0],\n // 'Z',\n // ];\n\n return \"M \" + extension0 + \" C \" + [control0, control1, extension1].join(',') + \" S \" + [control3, extension0].join(',') + \" Z\";\n }; // Handle special cases\n\n\n if (!polyPoints || pointCount < 1) return '';\n if (pointCount === 1) return smoothHull1(polyPoints);\n if (pointCount === 2) return smoothHull2(polyPoints);\n var hullPoints = polyPoints.map(function (point, index) {\n var pNext = polyPoints[(index + 1) % pointCount];\n return {\n p: point,\n v: vec2.normalize([0, 0], vecFrom(point, pNext))\n };\n }); // Compute the expanded hull points, and the nearest prior control point for each.\n\n for (var i = 0; i < hullPoints.length; ++i) {\n var priorIndex = i > 0 ? i - 1 : pointCount - 1;\n var extensionVec = vec2.normalize([0, 0], vec2.add([0, 0], hullPoints[priorIndex].v, vec2.scale([0, 0], hullPoints[i].v, -1)));\n hullPoints[i].p = vec2.add([0, 0], hullPoints[i].p, vec2.scale([0, 0], extensionVec, padding));\n }\n\n return hullPoints.map(function (obj) {\n var point = obj.p;\n return {\n x: point[0],\n y: point[1]\n };\n });\n}","/**\n * Use cross product to judge the direction of the turn.\n * Returns a positive value, if OAB makes a clockwise turn,\n * negative for counter-clockwise turn, and zero if the points are collinear.\n */\nexport var cross = function cross(a, b, o) {\n return (a.y - o.y) * (b.x - o.x) - (a.x - o.x) * (b.y - o.y);\n};\n/**\n * Generate a convex hull of given points. Andrew's monotone chain algorithm.\n * @param points An array of [x, y] representing the coordinates of points.\n * @return a list of vertices of the convex hull in counter-clockwise order,\n */\n\nexport var genConvexHull = function genConvexHull(items) {\n var points = items.map(function (item) {\n return {\n x: item.getModel().x,\n y: item.getModel().y\n };\n });\n points.sort(function (a, b) {\n return a.x === b.x ? a.y - b.y : a.x - b.x;\n });\n\n if (points.length === 1) {\n return points;\n } // build the lower hull\n\n\n var lower = [];\n\n for (var i = 0; i < points.length; i++) {\n while (lower.length >= 2 && cross(lower[lower.length - 2], lower[lower.length - 1], points[i]) <= 0) {\n lower.pop();\n }\n\n lower.push(points[i]);\n } // build the upper hull\n\n\n var upper = [];\n\n for (var i = points.length - 1; i >= 0; i--) {\n while (upper.length >= 2 && cross(upper[upper.length - 2], upper[upper.length - 1], points[i]) <= 0) {\n upper.pop();\n }\n\n upper.push(points[i]);\n }\n\n upper.pop();\n lower.pop();\n var strictHull = lower.concat(upper);\n return strictHull;\n};","import { squareDist, pointLineSquareDist, itemIntersectByLine, getPointsCenter, fractionToLine, isPointsOverlap, pointRectSquareDist, Line, isPointInPolygon } from '../../util/math';\nvar defaultOps = {\n maxRoutingIterations: 100,\n maxMarchingIterations: 100,\n pixelGroupSize: 2,\n edgeR0: 10,\n edgeR1: 10,\n nodeR0: 5,\n nodeR1: 10,\n morphBuffer: 5,\n threshold: 0.001,\n skip: 16,\n nodeInfluenceFactor: 1,\n edgeInfluenceFactor: 1,\n negativeNodeInfluenceFactor: -0.5\n};\n/**\n * Marching square algorithm for traching the contour of a pixel group\n * https://www.emanueleferonato.com/2013/03/01/using-marching-squares-algorithm-to-trace-the-contour-of-an-image/\n * @param potentialArea\n * @param threshold\n */\n\nfunction MarchingSquares(contour, potentialArea, threshold) {\n var marched = false;\n\n var getVal = function getVal(x, y) {\n return potentialArea.cells[x + y * potentialArea.width];\n };\n\n var getState = function getState(x, y) {\n var squareVal = 0;\n\n if (getVal(x - 1, y - 1) >= threshold) {\n squareVal += 1;\n }\n\n if (getVal(x, y - 1) > threshold) {\n squareVal += 2;\n }\n\n if (getVal(x - 1, y) > threshold) {\n squareVal += 4;\n }\n\n if (getVal(x, y) > threshold) {\n squareVal += 8;\n }\n\n return squareVal;\n };\n\n var doMarch = function doMarch(xPos, yPos) {\n var x = xPos;\n var y = yPos;\n var prevX;\n var prevY;\n\n for (var i = 0; i < potentialArea.width * potentialArea.height; i++) {\n prevX = x;\n prevY = y;\n\n if (contour.findIndex(function (item) {\n return item.x === x && item.y === y;\n }) > -1) {\n if (contour[0].x !== x || contour[0].y !== y) {// encountered a loop but haven't returned to start: change direction using conditionals and continue back to start\n } else {\n return true;\n }\n } else {\n contour.push({\n x: x,\n y: y\n });\n }\n\n var state = getState(x, y); // assign the move direction according to state of the square\n\n switch (state) {\n case -1:\n console.warn('Marched out of bounds');\n return true;\n\n case 0:\n case 3:\n case 2:\n case 7:\n x++; // go right\n\n break;\n\n case 12:\n case 14:\n case 4:\n x--; // go left\n\n break;\n\n case 6:\n // go left if come from up else go right\n if (prevX === 0) {\n if (prevY === -1) {\n x -= 1;\n } else {\n x += 1;\n }\n }\n\n break;\n\n case 1:\n case 13:\n case 5:\n y--; // go up\n\n break;\n\n case 9:\n // go up if come from right else go down\n if (prevX === 1) {\n if (prevY === 0) {\n y -= 1;\n } else {\n y += 1;\n }\n }\n\n break;\n\n case 10:\n case 8:\n case 11:\n y++; // go down\n\n break;\n\n default:\n console.warn(\"Marching squares invalid state: \" + state);\n return true;\n }\n }\n };\n\n this.march = function () {\n for (var x = 0; x < potentialArea.width && !marched; x += 1) {\n for (var y = 0; y < potentialArea.height && !marched; y += 1) {\n if (getVal(x, y) > threshold && getState(x, y) !== 15) {\n marched = doMarch(x, y);\n }\n }\n }\n\n return marched;\n };\n}\n/**\n * Space partition & assign value to each cell\n * @param points\n */\n\n\nvar initGridCells = function initGridCells(width, height, pixelGroupSize) {\n var scaleWidth = Math.ceil(width / pixelGroupSize);\n var scaleHeight = Math.ceil(height / pixelGroupSize);\n var gridCells = new Float32Array(Math.max(0, scaleWidth * scaleHeight)).fill(0);\n return {\n cells: gridCells,\n width: scaleWidth,\n height: scaleHeight\n };\n};\n/**\n * Find the optimal already visited member to item;\n Optimal: minimize cost(j) = distance(i,j) ∗ countObstacles(i,j)\n * @param item\n * @param visited\n */\n\n\nvar pickBestNeighbor = function pickBestNeighbor(item, visited, nonMembers) {\n var closestNeighbour = null;\n var minCost = Number.POSITIVE_INFINITY;\n visited.forEach(function (neighbourItem) {\n var itemP = {\n x: item.getModel().x,\n y: item.getModel().y\n };\n var neighbourItemP = {\n x: neighbourItem.getModel().x,\n y: neighbourItem.getModel().y\n };\n var dist = squareDist(itemP, neighbourItemP);\n var directLine = new Line(itemP.x, itemP.y, neighbourItemP.x, neighbourItemP.y);\n var numberObstacles = nonMembers.reduce(function (count, _item) {\n if (fractionToLine(_item, directLine) > 0) {\n return count + 1;\n }\n\n return count;\n }, 0);\n\n if (dist * Math.pow(numberObstacles + 1, 2) < minCost) {\n closestNeighbour = neighbourItem;\n minCost = dist * Math.pow(numberObstacles + 1, 2);\n }\n });\n return closestNeighbour;\n};\n/**\n * 返回和线相交的item中,离边的起点最近的item\n * @param items\n * @param line\n */\n\n\nvar getIntersectItem = function getIntersectItem(items, line) {\n var minDistance = Number.POSITIVE_INFINITY;\n var closestItem = null;\n items.forEach(function (item) {\n var distance = fractionToLine(item, line); // find closest intersection\n\n if (distance >= 0 && distance < minDistance) {\n closestItem = item;\n minDistance = distance;\n }\n });\n return closestItem;\n};\n/**\n * Modify the directLine and Route virtual edges around obstacles\n */\n\n\nvar computeRoute = function computeRoute(directLine, nonMembers, maxRoutingIterations, morphBuffer) {\n var checkedLines = [];\n var linesToCheck = [];\n linesToCheck.push(directLine);\n var hasIntersection = true;\n var iterations = 0;\n\n var pointExists = function pointExists(point, lines) {\n var flag = false;\n lines.forEach(function (line) {\n if (flag) return;\n\n if (isPointsOverlap(point, {\n x: line.x1,\n y: line.y1\n }) || isPointsOverlap(point, {\n x: line.x2,\n y: line.y2\n })) {\n flag = true;\n }\n });\n return flag;\n };\n\n var isPointInNonMembers = function isPointInNonMembers(point, _nonMembers) {\n for (var _i = 0, _nonMembers_1 = _nonMembers; _i < _nonMembers_1.length; _i++) {\n var item = _nonMembers_1[_i];\n var bbox = item.getBBox();\n var itemContour = [[bbox.x, bbox.y], [bbox.x + bbox.width, bbox.y], [bbox.x, bbox.y + bbox.height], [bbox.x + bbox.width, bbox.y + bbox.height]];\n\n if (isPointInPolygon(itemContour, point.x, point.y)) {\n return true;\n }\n }\n\n return false;\n }; // outer loop end when no more intersections or out of iterations\n\n\n while (hasIntersection && iterations < maxRoutingIterations) {\n hasIntersection = false;\n\n var _loop_1 = function _loop_1() {\n var line = linesToCheck.pop();\n var closestItem = getIntersectItem(nonMembers, line);\n\n if (closestItem) {\n var _a = itemIntersectByLine(closestItem, line),\n intersections_1 = _a[0],\n countIntersections = _a[1]; // if line passes through item\n\n\n if (countIntersections === 2) {\n var testReroute = function testReroute(isFirst) {\n var tempMorphBuffer = morphBuffer;\n var virtualNode = rerouteLine(closestItem, tempMorphBuffer, intersections_1, isFirst); // test the virtualNode already exists\n\n var exist = pointExists(virtualNode, linesToCheck) || pointExists(virtualNode, checkedLines);\n var pointInside = isPointInNonMembers(virtualNode, nonMembers);\n\n while (!exist && pointInside && tempMorphBuffer >= 1) {\n // try a smaller buffer\n tempMorphBuffer /= 1.5;\n virtualNode = rerouteLine(closestItem, tempMorphBuffer, intersections_1, isFirst);\n exist = pointExists(virtualNode, linesToCheck) || pointExists(virtualNode, checkedLines);\n pointInside = isPointInNonMembers(virtualNode, nonMembers);\n } // 第二次route时不要求pointInside\n\n\n if (virtualNode && !exist && (!isFirst || !pointInside)) {\n // add 2 rerouted lines to check\n linesToCheck.push(new Line(line.x1, line.y1, virtualNode.x, virtualNode.y));\n linesToCheck.push(new Line(virtualNode.x, virtualNode.y, line.x2, line.y2));\n hasIntersection = true;\n }\n };\n\n testReroute(true);\n\n if (!hasIntersection) {\n // if we didn't find a valid point around the first corner, try the second\n testReroute(false);\n }\n }\n } // no intersection found, mark this line as completed\n\n\n if (!hasIntersection) {\n checkedLines.push(line);\n }\n\n iterations += 1;\n }; // inner loop end when out of lines or found an intersection\n\n\n while (!hasIntersection && linesToCheck.length) {\n _loop_1();\n }\n } // 加入剩余的线\n\n\n while (linesToCheck.length) {\n checkedLines.push(linesToCheck.pop());\n }\n\n return checkedLines;\n};\n/**\n * Connect item with visited members using direct line or virtual edges\n */\n\n\nfunction getRoute(item, nonMembers, visited, maxRoutingIterations, morphBuffer) {\n var optimalNeighbor = pickBestNeighbor(item, visited, nonMembers);\n\n if (optimalNeighbor === null) {\n return [];\n } // merge the consecutive lines\n\n\n var mergeLines = function mergeLines(checkedLines) {\n var finalRoute = [];\n\n while (checkedLines.length > 0) {\n var line1 = checkedLines.pop();\n\n if (checkedLines.length === 0) {\n finalRoute.push(line1);\n break;\n }\n\n var line2 = checkedLines.pop();\n var mergeLine = new Line(line1.x1, line1.y1, line2.x2, line2.y2);\n var closestItem = getIntersectItem(nonMembers, mergeLine); // merge most recent line and previous line\n\n if (!closestItem) {\n checkedLines.push(mergeLine);\n } else {\n finalRoute.push(line1);\n checkedLines.push(line2);\n }\n }\n\n return finalRoute;\n };\n\n var directLine = new Line(item.getModel().x, item.getModel().y, optimalNeighbor.getModel().x, optimalNeighbor.getModel().y);\n var checkedLines = computeRoute(directLine, nonMembers, maxRoutingIterations, morphBuffer);\n var finalRoute = mergeLines(checkedLines);\n return finalRoute;\n}\n/**\n * Calculate the countor that includes the selected items and exclues the non-selected items\n * @param graph\n * @param members\n * @param nonMembers\n * @param options\n */\n\n\nexport var genBubbleSet = function genBubbleSet(members, nonMembers, ops) {\n // eslint-disable-next-line no-redeclare\n var options = Object.assign(defaultOps, ops);\n var centroid = getPointsCenter(members.map(function (item) {\n return {\n x: item.getModel().x,\n y: item.getModel().y\n };\n })); // 按照到中心距离远近排序\n\n members = members.sort(function (a, b) {\n return squareDist({\n x: a.getModel().x,\n y: a.getModel().y\n }, centroid) - squareDist({\n x: b.getModel().x,\n y: b.getModel().y\n }, centroid);\n });\n var visited = [];\n var virtualEdges = [];\n members.forEach(function (item) {\n var lines = getRoute(item, nonMembers, visited, options.maxRoutingIterations, options.morphBuffer);\n lines.forEach(function (l) {\n virtualEdges.push(l);\n });\n visited.push(item);\n }); // 由于edge也可以作为member和nonMember传入,暂时不考虑把edges作为参数传入genBubbleSet\n // edges && edges.forEach(e => {\n // virtualEdges.push(new Line(e.getSource().getModel().x, e.getSource().getModel().y, e.getTarget().getModel().x, e.getTarget().getModel().y));\n // });\n\n var activeRegion = getActiveRregion(members, virtualEdges, options.nodeR0);\n var potentialArea = initGridCells(activeRegion.width, activeRegion.height, options.pixelGroupSize); // Use march squares to generate contour\n\n var contour = [];\n var hull = [];\n\n for (var iterations = 0; iterations < options.maxMarchingIterations; iterations++) {\n fillPotentialArea(members, nonMembers, virtualEdges, activeRegion, potentialArea, options);\n contour = [];\n hull = [];\n if (!new MarchingSquares(contour, potentialArea, options.threshold).march()) continue;\n var marchedPath = contour.map(function (point) {\n return {\n x: Math.round(point.x * options.pixelGroupSize + activeRegion.minX),\n y: Math.round(point.y * options.pixelGroupSize + activeRegion.minY)\n };\n }); // const marchedPath = marchingSquares(potentialArea, options.threshold).map(point => ({ x: Math.round(point.x * options.pixelGroupSize + activeRegion.minX), y: Math.round(point.y * options.pixelGroupSize + activeRegion.minY) }))\n\n if (marchedPath) {\n var size = marchedPath.length;\n\n if (options.skip > 1) {\n size = Math.floor(marchedPath.length / options.skip); // if we reduced too much (fewer than three points in reduced surface) reduce skip and try again\n\n while (size < 3 && options.skip > 1) {\n options.skip -= 1;\n size = Math.floor(marchedPath.length / options.skip);\n }\n } // copy hull values\n\n\n for (var i = 0, j = 0; j < size; j += 1, i += options.skip) {\n hull.push({\n x: marchedPath[i].x,\n y: marchedPath[i].y\n });\n }\n }\n\n var isContourValid = function isContourValid() {\n for (var _i = 0, members_1 = members; _i < members_1.length; _i++) {\n var item = members_1[_i];\n var hullPoints = hull.map(function (point) {\n return [point.x, point.y];\n });\n if (!isPointInPolygon(hullPoints, item.getBBox().centerX, item.getBBox().centerY)) return false;\n } // 不强制要求所有nonMembers都没有包含在内\n // for (const item of nonMembers) {\n // if (isPointInPolygon({ x: item.getBBox().centerX, y: item.getBBox().centerY }, contour)) return false\n // }\n\n\n return true;\n };\n\n if (hull && isContourValid()) {\n return hull;\n } // update parameters for next iteraction\n\n\n options.threshold *= 0.9;\n\n if (iterations <= options.maxMarchingIterations * 0.5) {\n options.memberInfluenceFactor *= 1.2;\n options.edgeInfluenceFactor *= 1.2;\n } else if (options.nonMemberInfluenceFactor !== 0 && nonMembers.length > 0) {\n // after half the iterations, start increasing positive energy and lowering the threshold\n options.nonMemberInfluenceFactor *= 0.8;\n } else {\n break;\n }\n }\n\n return hull;\n};\n/**\n * unionboundingbox\n * @param members\n * @param edges\n */\n\nfunction getActiveRregion(members, edges, offset) {\n var activeRegion = {\n minX: Number.POSITIVE_INFINITY,\n minY: Number.POSITIVE_INFINITY,\n maxX: Number.NEGATIVE_INFINITY,\n maxY: Number.NEGATIVE_INFINITY,\n width: 0,\n height: 0,\n x: 0,\n y: 0\n };\n var bboxes = [];\n members.forEach(function (item) {\n bboxes.push(item.getBBox());\n });\n edges.forEach(function (l) {\n bboxes.push(l.getBBox());\n });\n\n for (var _i = 0, bboxes_1 = bboxes; _i < bboxes_1.length; _i++) {\n var bbox = bboxes_1[_i];\n activeRegion.minX = (bbox.minX < activeRegion.minX ? bbox.minX : activeRegion.minX) - offset;\n activeRegion.minY = (bbox.minY < activeRegion.minY ? bbox.minY : activeRegion.minY) - offset;\n activeRegion.maxX = (bbox.maxX > activeRegion.maxX ? bbox.maxX : activeRegion.maxX) + offset;\n activeRegion.maxY = (bbox.maxY > activeRegion.maxY ? bbox.maxY : activeRegion.maxY) + offset;\n }\n\n activeRegion.width = activeRegion.maxX - activeRegion.minX;\n activeRegion.height = activeRegion.maxY - activeRegion.minY;\n activeRegion.x = activeRegion.minX;\n activeRegion.y = activeRegion.minY;\n return activeRegion;\n}\n\nfunction fillPotentialArea(members, nonMembers, edges, activeRegion, potentialArea, options) {\n function pos2GridIx(x, offset) {\n var gridIx = Math.floor((x - offset) / options.pixelGroupSize);\n return gridIx < 0 ? 0 : gridIx;\n }\n\n function gridIx2Pos(x, offset) {\n return x * options.pixelGroupSize + offset;\n } // using inverse a for numerical stability\n\n\n var nodeInfA = (options.nodeR0 - options.nodeR1) * (options.nodeR0 - options.nodeR1);\n var edgeInfA = (options.edgeR0 - options.edgeR1) * (options.edgeR0 - options.edgeR1);\n\n var getAffectedRegion = function getAffectedRegion(bbox, thresholdR) {\n var startX = Math.min(pos2GridIx(bbox.minX, thresholdR + activeRegion.minX), potentialArea.width);\n var startY = Math.min(pos2GridIx(bbox.minY, thresholdR + activeRegion.minY), potentialArea.height);\n var endX = Math.min(pos2GridIx(bbox.maxX, -thresholdR + activeRegion.minX), potentialArea.width);\n var endY = Math.min(pos2GridIx(bbox.maxY, -thresholdR + activeRegion.minY), potentialArea.height);\n return [startX, startY, endX, endY];\n };\n\n var addItemInfluence = function addItemInfluence(item, influenceFactor) {\n var bbox = item.getBBox();\n\n var _a = getAffectedRegion(bbox, options.nodeR1),\n startX = _a[0],\n startY = _a[1],\n endX = _a[2],\n endY = _a[3]; // calculate item influence for each cell\n\n\n for (var y = startY; y < endY; y += 1) {\n for (var x = startX; x < endX; x += 1) {\n if (influenceFactor < 0 && potentialArea[x + y * potentialArea.width] <= 0) {\n continue;\n }\n\n var tempX = gridIx2Pos(x, activeRegion.minX);\n var tempY = gridIx2Pos(y, activeRegion.minY);\n var distanceSq = pointRectSquareDist({\n x: tempX,\n y: tempY\n }, {\n x: bbox.minX,\n y: bbox.minY,\n width: bbox.width,\n height: bbox.height\n });\n\n if (distanceSq < Math.pow(options.nodeR1, 2)) {\n var dr = Math.sqrt(distanceSq) - options.nodeR1;\n potentialArea.cells[x + y * potentialArea.width] += influenceFactor * dr * dr;\n }\n }\n }\n };\n\n var addEdgeInfluence = function addEdgeInfluence(line, influenceFactor) {\n var bbox = line.getBBox();\n\n var _a = getAffectedRegion(bbox, options.edgeR1),\n startX = _a[0],\n startY = _a[1],\n endX = _a[2],\n endY = _a[3]; // for every point in active part of potentialArea, calculate distance to nearest point on line and add influence\n\n\n for (var y = startY; y < endY; y += 1) {\n for (var x = startX; x < endX; x += 1) {\n if (influenceFactor < 0 && potentialArea.cells[x + y * potentialArea.width] <= 0) {\n continue;\n }\n\n var tempX = gridIx2Pos(x, activeRegion.minX);\n var tempY = gridIx2Pos(y, activeRegion.minY);\n var minDistanceSq = pointLineSquareDist({\n x: tempX,\n y: tempY\n }, line); // only influence if less than r1\n\n if (minDistanceSq < Math.pow(options.edgeR1, 2)) {\n var mdr = Math.sqrt(minDistanceSq) - options.edgeR1;\n potentialArea.cells[x + y * potentialArea.width] += influenceFactor * mdr * mdr;\n }\n }\n }\n };\n\n if (options.nodeInfluenceFactor) {\n members.forEach(function (item) {\n addItemInfluence(item, options.nodeInfluenceFactor / nodeInfA);\n });\n }\n\n if (options.edgeInfluenceFactor) {\n edges.forEach(function (edge) {\n addEdgeInfluence(edge, options.edgeInfluenceFactor / edgeInfA);\n });\n }\n\n if (options.negativeNodeInfluenceFactor) {\n nonMembers.forEach(function (item) {\n addItemInfluence(item, options.negativeNodeInfluenceFactor / nodeInfA);\n });\n }\n}\n\nfunction rerouteLine(item, buffer, intersections, wrapNormal) {\n var bbox = item.getBBox();\n var topIntersect = intersections[0],\n leftIntersect = intersections[1],\n bottomIntersect = intersections[2],\n rightIntersect = intersections[3];\n var cornerPos = {\n topLeft: {\n x: bbox.minX - buffer,\n y: bbox.minY - buffer\n },\n topRight: {\n x: bbox.maxX + buffer,\n y: bbox.minY - buffer\n },\n bottomLeft: {\n x: bbox.minX - buffer,\n y: bbox.maxY + buffer\n },\n bottomRight: {\n x: bbox.maxX + buffer,\n y: bbox.maxY + buffer\n }\n };\n var totalArea = bbox.height * bbox.width;\n\n function calcHalfArea(intersect1, intersect2) {\n return bbox.width * ((intersect1.y - bbox.minY + (intersect2.y - bbox.minY)) * 0.5);\n } // 根据线和boundingbox相交的情况,确定control point的位置\n\n\n if (leftIntersect) {\n // 相交区域有三角形\n if (topIntersect) return wrapNormal ? cornerPos.topLeft : cornerPos.bottomRight;\n if (bottomIntersect) return wrapNormal ? cornerPos.bottomLeft : cornerPos.topRight; // 相交区域分成上下两个梯形,比较面积\n\n var topArea = calcHalfArea(leftIntersect, rightIntersect);\n\n if (topArea < totalArea * 0.5) {\n if (leftIntersect.y > rightIntersect.y) return wrapNormal ? cornerPos.topLeft : cornerPos.bottomRight;\n return wrapNormal ? cornerPos.topRight : cornerPos.bottomLeft;\n }\n\n if (leftIntersect.y < rightIntersect.y) return wrapNormal ? cornerPos.bottomLeft : cornerPos.topRight;\n return wrapNormal ? cornerPos.bottomRight : cornerPos.topLeft;\n }\n\n if (rightIntersect) {\n if (topIntersect) return wrapNormal ? cornerPos.topRight : cornerPos.bottomLeft;\n if (bottomIntersect) return wrapNormal ? cornerPos.bottomRight : cornerPos.topLeft;\n } // 相交区域分成左右两个梯形\n\n\n var leftArea = calcHalfArea(topIntersect, bottomIntersect);\n\n if (leftArea < totalArea * 0.5) {\n if (topIntersect.x > bottomIntersect.x) return wrapNormal ? cornerPos.topLeft : cornerPos.bottomRight;\n return wrapNormal ? cornerPos.bottomLeft : cornerPos.topRight;\n }\n\n if (topIntersect.x < bottomIntersect.x) return wrapNormal ? cornerPos.topRight : cornerPos.bottomLeft;\n return wrapNormal ? cornerPos.bottomRight : cornerPos.topLeft;\n}","import { __assign } from \"tslib\";\nimport { deepMix, isString } from '@antv/util';\nimport { parsePathString } from '@antv/path-util';\nimport { pathToPoints, getClosedSpline, roundedHull, paddedHull } from '../util/path';\nimport { isPolygonsIntersect } from '../util/math';\nimport { genConvexHull } from '../element/hull/convexHull';\nimport { genBubbleSet } from '../element/hull/bubbleset';\n/**\n * 用于包裹内部的成员的轮廓。\n * convex hull(凸包):http://geomalgorithms.com/a10-_hull-1.html#Monotone%20Chain\n * bubble: 使用 bubbleset算法,refer: http://vialab.science.uoit.ca/wp-content/papercite-data/pdf/col2009c.pdf\n * 通过配置 padding 可以调节包裹轮廓对节点的松紧程度\n */\n\nvar Hull = function () {\n function Hull(graph, cfg) {\n this.cfg = deepMix(this.getDefaultCfg(), cfg);\n this.graph = graph;\n this.id = this.cfg.id;\n this.group = this.cfg.group;\n this.members = this.cfg.members.map(function (item) {\n return isString(item) ? graph.findById(item) : item;\n });\n this.nonMembers = this.cfg.nonMembers.map(function (item) {\n return isString(item) ? graph.findById(item) : item;\n });\n this.setPadding();\n this.setType();\n this.path = this.calcPath(this.members, this.nonMembers);\n this.render();\n }\n\n Hull.prototype.getDefaultCfg = function () {\n return {\n id: 'g6-hull',\n type: 'round-convex',\n members: [],\n nonMembers: [],\n style: {\n fill: 'lightblue',\n stroke: 'blue',\n opacity: 0.2\n },\n padding: 10\n };\n };\n\n Hull.prototype.setPadding = function () {\n var nodeSize = this.members.length && this.members[0].getKeyShape().getCanvasBBox().width / 2;\n this.padding = this.cfg.padding > 0 ? this.cfg.padding + nodeSize : 10 + nodeSize;\n this.cfg.bubbleCfg = {\n nodeR0: this.padding - nodeSize,\n nodeR1: this.padding - nodeSize,\n morphBuffer: this.padding - nodeSize\n };\n };\n\n Hull.prototype.setType = function () {\n this.type = this.cfg.type;\n\n if (this.members.length < 3) {\n this.type = 'round-convex';\n }\n\n if (this.type !== 'round-convex' && this.type !== 'smooth-convex' && this.type !== 'bubble') {\n console.warn('The hull type should be either round-convex, smooth-convex or bubble, round-convex is used by default.');\n this.type = 'round-convex';\n }\n };\n\n Hull.prototype.calcPath = function (members, nonMembers) {\n var contour, path, hull;\n\n switch (this.type) {\n case 'round-convex':\n contour = genConvexHull(members);\n hull = roundedHull(contour.map(function (p) {\n return [p.x, p.y];\n }), this.padding);\n path = parsePathString(hull);\n break;\n\n case 'smooth-convex':\n contour = genConvexHull(members);\n\n if (contour.length === 2) {\n hull = roundedHull(contour.map(function (p) {\n return [p.x, p.y];\n }), this.padding);\n path = parsePathString(hull);\n } else if (contour.length > 2) {\n hull = paddedHull(contour.map(function (p) {\n return [p.x, p.y];\n }), this.padding);\n path = getClosedSpline(hull);\n }\n\n break;\n\n case 'bubble':\n contour = genBubbleSet(members, nonMembers, this.cfg.bubbleCfg);\n path = contour.length >= 2 && getClosedSpline(contour);\n break;\n\n default:\n }\n\n return path;\n };\n\n Hull.prototype.render = function () {\n this.group.addShape('path', {\n attrs: __assign({\n path: this.path\n }, this.cfg.style),\n id: this.id,\n name: this.cfg.id\n });\n this.group.toBack();\n };\n /**\n * 增加hull的成员,同时如果该成员原先在nonMembers中,则从nonMembers中去掉\n * @param item 节点实例\n * @return boolean 添加成功返回 true,否则返回 false\n */\n\n\n Hull.prototype.addMember = function (item) {\n if (!item) return;\n if (isString(item)) item = this.graph.findById(item);\n this.members.push(item);\n var index = this.nonMembers.indexOf(item);\n\n if (index > -1) {\n this.nonMembers.splice(index, 1);\n }\n\n this.updateData(this.members, this.nonMembers);\n return true;\n };\n /**\n * 增加hull需要排除的节点,同时如果该成员原先在members中,则从members中去掉\n * @param item 节点实例\n * @return boolean 添加成功返回 true,否则返回 false\n */\n\n\n Hull.prototype.addNonMember = function (item) {\n if (!item) return;\n if (isString(item)) item = this.graph.findById(item);\n this.nonMembers.push(item);\n var index = this.members.indexOf(item);\n\n if (index > -1) {\n this.members.splice(index, 1);\n }\n\n this.updateData(this.members, this.nonMembers);\n return true;\n };\n /**\n * 移除hull中的成员\n * @param node 节点实例\n * @return boolean 移除成功返回 true,否则返回 false\n */\n\n\n Hull.prototype.removeMember = function (item) {\n if (!item) return;\n if (isString(item)) item = this.graph.findById(item);\n var index = this.members.indexOf(item);\n\n if (index > -1) {\n this.members.splice(index, 1);\n this.updateData(this.members, this.nonMembers);\n return true;\n }\n\n return false;\n };\n /**\n * @param node 节点实例\n * @return boolean 移除成功返回 true,否则返回 false\n */\n\n\n Hull.prototype.removeNonMember = function (item) {\n if (!item) return;\n if (isString(item)) item = this.graph.findById(item);\n var index = this.nonMembers.indexOf(item);\n\n if (index > -1) {\n this.nonMembers.splice(index, 1);\n this.updateData(this.members, this.nonMembers);\n return true;\n }\n\n return false;\n };\n\n Hull.prototype.updateData = function (members, nonMembers) {\n var _this = this;\n\n this.group.findById(this.id).remove();\n if (members) this.members = members.map(function (item) {\n return isString(item) ? _this.graph.findById(item) : item;\n });\n if (nonMembers) this.nonMembers = nonMembers.map(function (item) {\n return isString(item) ? _this.graph.findById(item) : item;\n });\n this.path = this.calcPath(this.members, this.nonMembers);\n this.render();\n };\n\n Hull.prototype.updateStyle = function (cfg) {\n var path = this.group.findById(this.id);\n path.attr(__assign({}, cfg));\n };\n /**\n * 更新 hull\n * @param cfg hull 配置项\n */\n\n\n Hull.prototype.updateCfg = function (cfg) {\n var _this = this;\n\n this.cfg = deepMix(this.cfg, cfg);\n this.id = this.cfg.id;\n this.group = this.cfg.group;\n\n if (cfg.members) {\n this.members = this.cfg.members.map(function (item) {\n return isString(item) ? _this.graph.findById(item) : item;\n });\n }\n\n if (cfg.nonMembers) {\n this.nonMembers = this.cfg.nonMembers.map(function (item) {\n return isString(item) ? _this.graph.findById(item) : item;\n });\n } // TODO padding 设置太大,会影响到 contain 结果\n\n\n this.setPadding();\n this.setType();\n this.path = this.calcPath(this.members, this.nonMembers);\n this.render();\n };\n /**\n * 判断是否在hull内部\n * @param item\n */\n\n\n Hull.prototype.contain = function (item) {\n var _this = this;\n\n var nodeItem;\n\n if (isString(item)) {\n nodeItem = this.graph.findById(item);\n } else {\n nodeItem = item;\n }\n\n var shapePoints;\n var shape = nodeItem.getKeyShape();\n\n if (nodeItem.get('type') === 'path') {\n shapePoints = pathToPoints(shape.attr('path'));\n } else {\n var shapeBBox = shape.getCanvasBBox();\n shapePoints = [[shapeBBox.minX, shapeBBox.minY], [shapeBBox.maxX, shapeBBox.minY], [shapeBBox.maxX, shapeBBox.maxY], [shapeBBox.minX, shapeBBox.maxY]];\n }\n\n shapePoints = shapePoints.map(function (canvasPoint) {\n var point = _this.graph.getPointByCanvas(canvasPoint[0], canvasPoint[1]);\n\n return [point.x, point.y];\n });\n return isPolygonsIntersect(shapePoints, pathToPoints(this.path));\n };\n\n Hull.prototype.destroy = function () {\n this.group.remove();\n this.cfg = null;\n };\n\n return Hull;\n}();\n\nexport default Hull;","import { __assign, __extends, __spreadArray } from \"tslib\";\nimport EventEmitter from '@antv/event-emitter';\nimport { ext } from '@antv/matrix-util';\nimport { clone, deepMix, each, isPlainObject, isString } from '@antv/util';\nimport { getDegree, getAdjMatrix as getAdjacentMatrix, Stack, floydWarshall } from '@antv/algorithm';\nimport { move } from '../util/math';\nimport { dataValidation, singleDataValidation } from '../util/validation';\nimport Global from '../global';\nimport { ItemController, ModeController, StateController, ViewController } from './controller';\nimport { plainCombosToTrees, traverseTree, reconstructTree, traverseTreeUp } from '../util/graphic';\nimport Hull from '../item/hull';\nvar transform = ext.transform;\nvar NODE = 'node';\n\nvar AbstractGraph = function (_super) {\n __extends(AbstractGraph, _super);\n\n function AbstractGraph(cfg) {\n var _this = _super.call(this) || this;\n\n _this.cfg = deepMix(_this.getDefaultCfg(), cfg);\n\n _this.init();\n\n _this.animating = false;\n _this.destroyed = false; // 启用 stack 后,实例化 undoStack 和 redoStack\n\n if (_this.cfg.enabledStack) {\n // 实例化 undo 和 redo 栈\n _this.undoStack = new Stack(_this.cfg.maxStep);\n _this.redoStack = new Stack(_this.cfg.maxStep);\n }\n\n return _this;\n }\n\n AbstractGraph.prototype.init = function () {\n this.initCanvas(); // instance controller\n\n var viewController = new ViewController(this);\n var modeController = new ModeController(this);\n var itemController = new ItemController(this);\n var stateController = new StateController(this);\n this.set({\n viewController: viewController,\n modeController: modeController,\n itemController: itemController,\n stateController: stateController\n }); // 初始化布局机制\n\n this.initLayoutController(); // 初始化事件机制\n\n this.initEventController();\n this.initGroups();\n /** 初始化插件 */\n\n this.initPlugins();\n }; // 初始化所有 Group\n\n\n AbstractGraph.prototype.initGroups = function () {\n var canvas = this.get('canvas');\n var el = canvas === null || canvas === void 0 ? void 0 : canvas.get('el');\n var id = el.id;\n var group = canvas.addGroup({\n id: id + \"-root\",\n className: Global.rootContainerClassName\n });\n\n if (this.get('groupByTypes')) {\n var edgeGroup = group.addGroup({\n id: id + \"-edge\",\n className: Global.edgeContainerClassName\n });\n var nodeGroup = group.addGroup({\n id: id + \"-node\",\n className: Global.nodeContainerClassName\n });\n var comboGroup = group.addGroup({\n id: id + \"-combo\",\n className: Global.comboContainerClassName\n }); // 用于存储自定义的群组\n\n comboGroup.toBack();\n this.set({\n nodeGroup: nodeGroup,\n edgeGroup: edgeGroup,\n comboGroup: comboGroup\n });\n }\n\n var delegateGroup = group.addGroup({\n id: id + \"-delegate\",\n className: Global.delegateContainerClassName\n });\n this.set({\n delegateGroup: delegateGroup\n });\n this.set('group', group);\n }; // eslint-disable-next-line class-methods-use-this\n\n\n AbstractGraph.prototype.getDefaultCfg = function () {\n return {\n /**\n * Container could be dom object or dom id\n */\n container: undefined,\n\n /**\n * Canvas width\n * unit pixel if undefined force fit width\n */\n width: undefined,\n\n /**\n * Canvas height\n * unit pixel if undefined force fit height\n */\n height: undefined,\n\n /**\n * renderer canvas or svg\n * @type {string}\n */\n renderer: 'canvas',\n\n /**\n * control graph behaviors\n */\n modes: {},\n\n /**\n * 注册插件\n */\n plugins: [],\n\n /**\n * source data\n */\n data: {},\n\n /**\n * Fit view padding (client scale)\n */\n fitViewPadding: 10,\n\n /**\n * Minimum scale size\n */\n minZoom: 0.2,\n\n /**\n * Maxmum scale size\n */\n maxZoom: 10,\n\n /**\n * capture events\n */\n event: true,\n\n /**\n * group node & edges into different graphic groups\n */\n groupByTypes: true,\n\n /**\n * determine if it's a directed graph\n */\n directed: false,\n\n /**\n * when data or shape changed, should canvas draw automatically\n */\n autoPaint: true,\n\n /**\n * store all the node instances\n */\n nodes: [],\n\n /**\n * store all the edge instances\n */\n edges: [],\n\n /**\n * store all the combo instances\n */\n combos: [],\n\n /**\n * store all the edge instances which are virtual edges related to collapsed combo\n */\n vedges: [],\n\n /**\n * all the instances indexed by id\n */\n itemMap: {},\n\n /**\n * 边直接连接到节点的中心,不再考虑锚点\n */\n linkCenter: false,\n\n /**\n * 默认的节点配置,data 上定义的配置会覆盖这些配置。例如:\n * defaultNode: {\n * type: 'rect',\n * size: [60, 40],\n * style: {\n * //... 样式配置项\n * }\n * }\n * 若数据项为 { id: 'node', x: 100, y: 100 }\n * 实际创建的节点模型是 { id: 'node', x: 100, y: 100, type: 'rect', size: [60, 40] }\n * 若数据项为 { id: 'node', x: 100, y: 100, type: 'circle' }\n * 实际创建的节点模型是 { id: 'node', x: 100, y: 100, type: 'circle', size: [60, 40] }\n */\n defaultNode: {},\n\n /**\n * 默认边配置,data 上定义的配置会覆盖这些配置。用法同 defaultNode\n */\n defaultEdge: {},\n\n /**\n * 节点默认样式,也可以添加状态样式\n * 例如:\n * const graph = new G6.Graph({\n * nodeStateStyles: {\n * selected: { fill: '#ccc', stroke: '#666' },\n * active: { lineWidth: 2 }\n * },\n * ...\n * });\n *\n */\n nodeStateStyles: {},\n\n /**\n * 边默认样式,用法同nodeStateStyle\n */\n edgeStateStyles: {},\n\n /**\n * graph 状态\n */\n states: {},\n\n /**\n * 是否启用全局动画\n */\n animate: false,\n\n /**\n * 动画设置,仅在 animate 为 true 时有效\n */\n animateCfg: {\n /**\n * 帧回调函数,用于自定义节点运动路径,为空时线性运动\n */\n onFrame: undefined,\n\n /**\n * 动画时长(ms)\n */\n duration: 500,\n\n /**\n * 指定动画动效\n */\n easing: 'easeLinear'\n },\n callback: undefined,\n // 默认不启用 undo & redo 功能\n enabledStack: false,\n // 只有当 enabledStack 为 true 时才起作用\n maxStep: 10,\n // 存储图上的 tooltip dom,方便销毁\n tooltips: []\n };\n };\n /**\n * 将值设置到 this.cfg 变量上面\n * @param key 键 或 对象值\n * @param val 值\n */\n\n\n AbstractGraph.prototype.set = function (key, val) {\n if (isPlainObject(key)) {\n this.cfg = __assign(__assign({}, this.cfg), key);\n } else {\n this.cfg[key] = val;\n }\n\n return this;\n };\n /**\n * 获取 this.cfg 中的值\n * @param key 键\n */\n\n\n AbstractGraph.prototype.get = function (key) {\n var _a;\n\n return (_a = this.cfg) === null || _a === void 0 ? void 0 : _a[key];\n };\n /**\n * 获取 graph 的根图形分组\n * @return 根 group\n */\n\n\n AbstractGraph.prototype.getGroup = function () {\n return this.get('group');\n };\n /**\n * 获取 graph 的 DOM 容器\n * @return DOM 容器\n */\n\n\n AbstractGraph.prototype.getContainer = function () {\n return this.get('container');\n };\n /**\n * 获取 graph 的最小缩放比例\n * @return minZoom\n */\n\n\n AbstractGraph.prototype.getMinZoom = function () {\n return this.get('minZoom');\n };\n /**\n * 设置 graph 的最小缩放比例\n * @return minZoom\n */\n\n\n AbstractGraph.prototype.setMinZoom = function (ratio) {\n return this.set('minZoom', ratio);\n };\n /**\n * 获取 graph 的最大缩放比例\n * @param maxZoom\n */\n\n\n AbstractGraph.prototype.getMaxZoom = function () {\n return this.get('maxZoom');\n };\n /**\n * 设置 graph 的最大缩放比例\n * @param maxZoom\n */\n\n\n AbstractGraph.prototype.setMaxZoom = function (ratio) {\n return this.set('maxZoom', ratio);\n };\n /**\n * 获取 graph 的宽度\n * @return width\n */\n\n\n AbstractGraph.prototype.getWidth = function () {\n return this.get('width');\n };\n /**\n * 获取 graph 的高度\n * @return width\n */\n\n\n AbstractGraph.prototype.getHeight = function () {\n return this.get('height');\n };\n /**\n * 清理元素多个状态\n * @param {string|Item} item 元素id或元素实例\n * @param {string[]} states 状态\n */\n\n\n AbstractGraph.prototype.clearItemStates = function (item, states) {\n if (isString(item)) {\n item = this.findById(item);\n }\n\n var itemController = this.get('itemController');\n\n if (!states) {\n states = item.get('states');\n }\n\n itemController.clearItemStates(item, states);\n var stateController = this.get('stateController');\n stateController.updateStates(item, states, false);\n };\n /**\n * 设置各个节点样式,以及在各种状态下节点 keyShape 的样式。\n * 若是自定义节点切在各种状态下\n * graph.node(node => {\n * return {\n * type: 'rect',\n * label: node.id,\n * style: { fill: '#666' },\n * stateStyles: {\n * selected: { fill: 'blue' },\n * custom: { fill: 'green' }\n * }\n * }\n * });\n * @param {function} nodeFn 指定每个节点样式\n */\n\n\n AbstractGraph.prototype.node = function (nodeFn) {\n if (typeof nodeFn === 'function') {\n this.set('nodeMapper', nodeFn);\n }\n };\n /**\n * 设置各个边样式\n * @param {function} edgeFn 指定每个边的样式,用法同 node\n */\n\n\n AbstractGraph.prototype.edge = function (edgeFn) {\n if (typeof edgeFn === 'function') {\n this.set('edgeMapper', edgeFn);\n }\n };\n /**\n * 设置各个 combo 的配置\n * @param comboFn\n */\n\n\n AbstractGraph.prototype.combo = function (comboFn) {\n if (typeof comboFn === 'function') {\n this.set('comboMapper', comboFn);\n }\n };\n /**\n * 根据 ID 查询图元素实例\n * @param id 图元素 ID\n */\n\n\n AbstractGraph.prototype.findById = function (id) {\n return this.get('itemMap')[id];\n };\n /**\n * 根据对应规则查找单个元素\n * @param {ITEM_TYPE} type 元素类型(node | edge | group)\n * @param {(item: T, index: number) => T} fn 指定规则\n * @return {T} 元素实例\n */\n\n\n AbstractGraph.prototype.find = function (type, fn) {\n var result;\n var items = this.get(type + \"s\"); // eslint-disable-next-line consistent-return\n\n each(items, function (item, i) {\n if (fn(item, i)) {\n result = item;\n return result;\n }\n });\n return result;\n };\n /**\n * 查找所有满足规则的元素\n * @param {string} type 元素类型(node|edge)\n * @param {string} fn 指定规则\n * @return {array} 元素实例\n */\n\n\n AbstractGraph.prototype.findAll = function (type, fn) {\n var result = [];\n each(this.get(type + \"s\"), function (item, i) {\n if (fn(item, i)) {\n result.push(item);\n }\n });\n return result;\n };\n /**\n * 查找所有处于指定状态的元素\n * @param {string} type 元素类型(node|edge)\n * @param {string} state 状态\n * @return {object} 元素实例\n */\n\n\n AbstractGraph.prototype.findAllByState = function (type, state) {\n return this.findAll(type, function (item) {\n return item.hasState(state);\n });\n };\n /**\n * 平移画布\n * @param dx 水平方向位移\n * @param dy 垂直方向位移\n */\n\n\n AbstractGraph.prototype.translate = function (dx, dy) {\n var group = this.get('group');\n var matrix = clone(group.getMatrix());\n\n if (!matrix) {\n matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n matrix = transform(matrix, [['t', dx, dy]]);\n group.setMatrix(matrix);\n this.emit('viewportchange', {\n action: 'translate',\n matrix: group.getMatrix()\n });\n this.autoPaint();\n };\n /**\n * 平移画布到某点\n * @param {number} x 水平坐标\n * @param {number} y 垂直坐标\n */\n\n\n AbstractGraph.prototype.moveTo = function (x, y, animate, animateCfg) {\n var group = this.get('group');\n move(group, {\n x: x,\n y: y\n }, animate, animateCfg || {\n duration: 500,\n easing: 'easeCubic'\n });\n this.emit('viewportchange', {\n action: 'move',\n matrix: group.getMatrix()\n });\n };\n /**\n * 调整视口适应视图\n * @param {object} padding 四周围边距\n */\n\n\n AbstractGraph.prototype.fitView = function (padding) {\n if (padding) {\n this.set('fitViewPadding', padding);\n }\n\n var viewController = this.get('viewController');\n viewController.fitView();\n this.autoPaint();\n };\n /**\n * 调整视口适应视图,不缩放,仅将图 bbox 中心对齐到画布中心\n */\n\n\n AbstractGraph.prototype.fitCenter = function () {\n var viewController = this.get('viewController');\n viewController.fitCenter();\n this.autoPaint();\n };\n /**\n * 新增行为\n * @param {string | ModeOption | ModeType[]} behaviors 添加的行为\n * @param {string | string[]} modes 添加到对应的模式\n * @return {Graph} Graph\n */\n\n\n AbstractGraph.prototype.addBehaviors = function (behaviors, modes) {\n var modeController = this.get('modeController');\n modeController.manipulateBehaviors(behaviors, modes, true);\n return this;\n };\n /**\n * 移除行为\n * @param {string | ModeOption | ModeType[]} behaviors 移除的行为\n * @param {string | string[]} modes 从指定的模式中移除\n * @return {Graph} Graph\n */\n\n\n AbstractGraph.prototype.removeBehaviors = function (behaviors, modes) {\n var modeController = this.get('modeController');\n modeController.manipulateBehaviors(behaviors, modes, false);\n return this;\n };\n /**\n * 更新行为参数\n * @param {string | ModeOption | ModeType} behavior 需要更新的行为\n * @param {string | string[]} modes 指定的模式中的行为,不指定则为 default\n * @return {Graph} Graph\n */\n\n\n AbstractGraph.prototype.updateBehavior = function (behavior, newCfg, mode) {\n var modeController = this.get('modeController');\n modeController.updateBehavior(behavior, newCfg, mode);\n return this;\n };\n /**\n * 伸缩窗口\n * @param ratio 伸缩比例\n * @param center 以center的x, y坐标为中心缩放\n * @return {boolean} 缩放是否成功\n */\n\n\n AbstractGraph.prototype.zoom = function (ratio, center) {\n var group = this.get('group');\n var matrix = clone(group.getMatrix());\n var minZoom = this.get('minZoom');\n var maxZoom = this.get('maxZoom');\n\n if (!matrix) {\n matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n if (center) {\n matrix = transform(matrix, [['t', -center.x, -center.y], ['s', ratio, ratio], ['t', center.x, center.y]]);\n } else {\n matrix = transform(matrix, [['s', ratio, ratio]]);\n }\n\n if (minZoom && matrix[0] < minZoom || maxZoom && matrix[0] > maxZoom) {\n return false;\n } // matrix = [2, 0, 0, 0, 2, 0, -125, -125, 1];\n\n\n group.setMatrix(matrix);\n this.emit('viewportchange', {\n action: 'zoom',\n matrix: matrix\n });\n this.autoPaint();\n return true;\n };\n /**\n * 伸缩视口到一固定比例\n * @param {number} toRatio 伸缩比例\n * @param {Point} center 以center的x, y坐标为中心缩放\n * @return {boolean} 缩放是否成功\n */\n\n\n AbstractGraph.prototype.zoomTo = function (toRatio, center) {\n var ratio = toRatio / this.getZoom();\n return this.zoom(ratio, center);\n };\n /**\n * 将元素移动到视口中心\n * @param {Item} item 指定元素\n * @param {boolean} animate 是否带有动画地移动\n * @param {GraphAnimateConfig} animateCfg 若带有动画,动画的配置项\n */\n\n\n AbstractGraph.prototype.focusItem = function (item, animate, animateCfg) {\n var viewController = this.get('viewController');\n var isAnimate = false;\n if (animate) isAnimate = true;else if (animate === undefined) isAnimate = this.get('animate');\n var curAniamteCfg = {};\n if (animateCfg) curAniamteCfg = animateCfg;else if (animateCfg === undefined) curAniamteCfg = this.get('animateCfg');\n viewController.focus(item, isAnimate, curAniamteCfg);\n this.autoPaint();\n };\n /**\n * 自动重绘\n * @internal 仅供内部更新机制调用,外部根据需求调用 render 或 paint 接口\n */\n\n\n AbstractGraph.prototype.autoPaint = function () {\n if (this.get('autoPaint')) {\n this.paint();\n }\n };\n /**\n * 仅画布重新绘制\n */\n\n\n AbstractGraph.prototype.paint = function () {\n this.emit('beforepaint');\n this.get('canvas').draw();\n this.emit('afterpaint');\n };\n /**\n * 将屏幕坐标转换为视口坐标\n * @param {number} clientX 屏幕x坐标\n * @param {number} clientY 屏幕y坐标\n * @return {Point} 视口坐标\n */\n\n\n AbstractGraph.prototype.getPointByClient = function (clientX, clientY) {\n var viewController = this.get('viewController');\n return viewController.getPointByClient(clientX, clientY);\n };\n /**\n * 将绘制坐标转换为屏幕坐标\n * @param {number} x 绘制坐标 x\n * @param {number} y 绘制坐标 y\n * @return {Point} 绘制坐标\n */\n\n\n AbstractGraph.prototype.getClientByPoint = function (x, y) {\n var viewController = this.get('viewController');\n return viewController.getClientByPoint(x, y);\n };\n /**\n * 将画布坐标转换为绘制坐标\n * @param {number} canvasX 画布 x 坐标\n * @param {number} canvasY 画布 y 坐标\n * @return {object} 绘制坐标\n */\n\n\n AbstractGraph.prototype.getPointByCanvas = function (canvasX, canvasY) {\n var viewController = this.get('viewController');\n return viewController.getPointByCanvas(canvasX, canvasY);\n };\n /**\n * 将绘制坐标转换为画布坐标\n * @param {number} x 绘制坐标 x\n * @param {number} y 绘制坐标 y\n * @return {object} 画布坐标\n */\n\n\n AbstractGraph.prototype.getCanvasByPoint = function (x, y) {\n var viewController = this.get('viewController');\n return viewController.getCanvasByPoint(x, y);\n };\n /**\n * 获取图内容的中心绘制坐标\n * @return {object} 中心绘制坐标\n */\n\n\n AbstractGraph.prototype.getGraphCenterPoint = function () {\n var bbox = this.get('group').getCanvasBBox();\n return {\n x: (bbox.minX + bbox.maxX) / 2,\n y: (bbox.minY + bbox.maxY) / 2\n };\n };\n /**\n * 获取视口中心绘制坐标\n * @return {object} 视口中心绘制坐标\n */\n\n\n AbstractGraph.prototype.getViewPortCenterPoint = function () {\n return this.getPointByCanvas(this.get('width') / 2, this.get('height') / 2);\n };\n /**\n * 显示元素\n * @param {Item} item 指定元素\n * @param {boolean} stack 本次操作是否入栈,默认为 true\n */\n\n\n AbstractGraph.prototype.showItem = function (item, stack) {\n if (stack === void 0) {\n stack = true;\n }\n\n var itemController = this.get('itemController');\n var object = itemController.changeItemVisibility(item, true);\n\n if (stack && this.get('enabledStack')) {\n var id = object.getID();\n var type = object.getType();\n var before = {};\n var after = {};\n\n switch (type) {\n case 'node':\n before.nodes = [{\n id: id,\n visible: false\n }];\n after.nodes = [{\n id: id,\n visible: true\n }];\n break;\n\n case 'edge':\n before.nodes = [{\n id: id,\n visible: false\n }];\n after.edges = [{\n id: id,\n visible: true\n }];\n break;\n\n case 'combo':\n before.nodes = [{\n id: id,\n visible: false\n }];\n after.combos = [{\n id: id,\n visible: true\n }];\n break;\n\n default:\n break;\n }\n\n this.pushStack('visible', {\n before: before,\n after: after\n });\n }\n };\n /**\n * 隐藏元素\n * @param {Item} item 指定元素\n * @param {boolean} stack 本次操作是否入栈,默认为 true\n */\n\n\n AbstractGraph.prototype.hideItem = function (item, stack) {\n if (stack === void 0) {\n stack = true;\n }\n\n var itemController = this.get('itemController');\n var object = itemController.changeItemVisibility(item, false);\n\n if (stack && this.get('enabledStack')) {\n var id = object.getID();\n var type = object.getType();\n var before = {};\n var after = {};\n\n switch (type) {\n case 'node':\n before.nodes = [{\n id: id,\n visible: true\n }];\n after.nodes = [{\n id: id,\n visible: false\n }];\n break;\n\n case 'edge':\n before.nodes = [{\n id: id,\n visible: true\n }];\n after.edges = [{\n id: id,\n visible: false\n }];\n break;\n\n case 'combo':\n before.nodes = [{\n id: id,\n visible: true\n }];\n after.combos = [{\n id: id,\n visible: false\n }];\n break;\n\n default:\n break;\n }\n\n this.pushStack('visible', {\n before: before,\n after: after\n });\n }\n };\n /**\n * 刷新元素\n * @param {string|object} item 元素id或元素实例\n */\n\n\n AbstractGraph.prototype.refreshItem = function (item) {\n var itemController = this.get('itemController');\n itemController.refreshItem(item);\n };\n /**\n * 设置是否在更新/刷新后自动重绘\n * @param {boolean} auto 自动重绘\n */\n\n\n AbstractGraph.prototype.setAutoPaint = function (auto) {\n var self = this;\n self.set('autoPaint', auto);\n var canvas = self.get('canvas');\n canvas.set('autoDraw', auto);\n };\n /**\n * 删除元素\n * @param {Item} item 元素id或元素实例\n * @param {boolean} stack 本次操作是否入栈,默认为 true\n */\n\n\n AbstractGraph.prototype.remove = function (item, stack) {\n if (stack === void 0) {\n stack = true;\n }\n\n this.removeItem(item, stack);\n };\n /**\n * 删除元素\n * @param {Item} item 元素id或元素实例\n * @param {boolean} stack 本次操作是否入栈,默认为 true\n */\n\n\n AbstractGraph.prototype.removeItem = function (item, stack) {\n if (stack === void 0) {\n stack = true;\n }\n\n var nodeItem = item;\n if (isString(item)) nodeItem = this.findById(item);\n\n if (!nodeItem && isString(item)) {\n console.warn('The item to be removed does not exist!');\n } else if (nodeItem) {\n var type = '';\n if (nodeItem.getType) type = nodeItem.getType(); // 将删除的元素入栈\n\n if (stack && this.get('enabledStack')) {\n var deletedModel = __assign(__assign({}, nodeItem.getModel()), {\n itemType: type\n });\n\n var before = {};\n\n switch (type) {\n case 'node':\n {\n before.nodes = [deletedModel];\n before.edges = [];\n var edges = nodeItem.getEdges();\n\n for (var i = edges.length - 1; i >= 0; i--) {\n before.edges.push(__assign(__assign({}, edges[i].getModel()), {\n itemType: 'edge'\n }));\n }\n\n break;\n }\n\n case 'edge':\n before.edges = [deletedModel];\n break;\n\n case 'combo':\n before.combos = [deletedModel];\n break;\n\n default:\n break;\n }\n\n this.pushStack('delete', {\n before: before,\n after: {}\n });\n }\n\n if (type === 'node') {\n var model = nodeItem.getModel(); // 如果删除的是节点,且该节点存在于某个 Combo 中,则需要先将 node 从 combo 中移除,否则删除节点后,操作 combo 会出错\n\n if (model.comboId) {\n this.updateComboTree(nodeItem, undefined, false);\n }\n }\n\n var itemController = this.get('itemController');\n itemController.removeItem(nodeItem);\n\n if (type === 'combo') {\n var newComboTrees = reconstructTree(this.get('comboTrees'));\n this.set('comboTrees', newComboTrees);\n }\n }\n };\n /**\n * 新增元素\n * @param {ITEM_TYPE} type 元素类型(node | edge)\n * @param {ModelConfig} model 元素数据模型\n * @param {boolean} stack 本次操作是否入栈,默认为 true\n * @param {boolean} sortCombo 本次操作是否需要更新 combo 层级顺序,内部参数,用户在外部使用 addItem 时始终时需要更新\n * @return {Item} 元素实例\n */\n\n\n AbstractGraph.prototype.addItem = function (type, model, stack, sortCombo) {\n if (stack === void 0) {\n stack = true;\n }\n\n if (sortCombo === void 0) {\n sortCombo = true;\n }\n\n var currentComboSorted = this.get('comboSorted');\n this.set('comboSorted', currentComboSorted && !sortCombo);\n var itemController = this.get('itemController'); // 添加节点、边或combo之前,先验证数据是否符合规范\n\n if (!singleDataValidation(type, model)) {\n return false;\n }\n\n if (model.id && this.findById(model.id)) {\n console.warn(\"This item exists already. Be sure the id %c\" + model.id + \"%c is unique.\", 'font-size: 20px; color: red;', '');\n return;\n }\n\n var item;\n var comboTrees = this.get('comboTrees');\n if (!comboTrees) comboTrees = [];\n\n if (type === 'combo') {\n var itemMap_1 = this.get('itemMap');\n var foundParent_1 = false;\n comboTrees.forEach(function (ctree) {\n if (foundParent_1) return; // terminate the forEach after the tree containing the item is done\n\n traverseTreeUp(ctree, function (child) {\n // find the parent\n if (model.parentId === child.id) {\n foundParent_1 = true;\n\n var newCombo = __assign({\n id: model.id,\n depth: child.depth + 2\n }, model);\n\n if (child.children) child.children.push(newCombo);else child.children = [newCombo];\n model.depth = newCombo.depth;\n item = itemController.addItem(type, model);\n }\n\n var childItem = itemMap_1[child.id]; // after the parent is found, update all the ancestors\n\n if (foundParent_1 && childItem && childItem.getType && childItem.getType() === 'combo') {\n itemController.updateCombo(childItem, child.children);\n }\n\n return true;\n });\n }); // if the parent is not found, add it to the root\n\n if (!foundParent_1) {\n var newCombo = __assign({\n id: model.id,\n depth: 0\n }, model);\n\n model.depth = newCombo.depth;\n comboTrees.push(newCombo);\n item = itemController.addItem(type, model);\n }\n\n this.set('comboTrees', comboTrees);\n } else if (type === 'node' && isString(model.comboId) && comboTrees) {\n var parentCombo = this.findById(model.comboId);\n\n if (parentCombo && parentCombo.getType && parentCombo.getType() !== 'combo') {\n console.warn(\"'\" + model.comboId + \"' is not a id of a combo in the graph, the node will be added without combo.\");\n }\n\n item = itemController.addItem(type, model);\n var itemMap_2 = this.get('itemMap');\n var foundParent_2 = false,\n foundNode_1 = false;\n (comboTrees || []).forEach(function (ctree) {\n if (foundNode_1 || foundParent_2) return; // terminate the forEach\n\n traverseTreeUp(ctree, function (child) {\n if (child.id === model.id) {\n // if the item exists in the tree already, terminate\n foundNode_1 = true;\n return false;\n }\n\n if (model.comboId === child.id && !foundNode_1) {\n // found the parent, add the item to the children of its parent in the tree\n foundParent_2 = true;\n var cloneNode = clone(model);\n cloneNode.itemType = 'node';\n if (child.children) child.children.push(cloneNode);else child.children = [cloneNode];\n cloneNode.depth = child.depth + 1;\n } // update the size of all the ancestors\n\n\n if (foundParent_2 && itemMap_2[child.id].getType && itemMap_2[child.id].getType() === 'combo') {\n itemController.updateCombo(itemMap_2[child.id], child.children);\n }\n\n return true;\n });\n });\n } else {\n item = itemController.addItem(type, model);\n }\n\n if (type === 'node' && model.comboId || type === 'combo' && model.parentId) {\n // add the combo to the parent's children array\n var parentCombo = this.findById(model.comboId || model.parentId);\n if (parentCombo && parentCombo.getType && parentCombo.getType() === 'combo') parentCombo.addChild(item);\n }\n\n var combos = this.get('combos');\n\n if (combos && combos.length > 0) {\n this.sortCombos();\n }\n\n this.autoPaint();\n\n if (stack && this.get('enabledStack')) {\n var addedModel = __assign(__assign({}, item.getModel()), {\n itemType: type\n });\n\n var after = {};\n\n switch (type) {\n case 'node':\n after.nodes = [addedModel];\n break;\n\n case 'edge':\n after.edges = [addedModel];\n break;\n\n case 'combo':\n after.combos = [addedModel];\n break;\n\n default:\n break;\n }\n\n this.pushStack('add', {\n before: {},\n after: after\n });\n }\n\n return item;\n };\n /**\n * 新增元素\n * @param {ITEM_TYPE} type 元素类型(node | edge)\n * @param {ModelConfig} model 元素数据模型\n * @param {boolean} stack 本次操作是否入栈,默认为 true\n * @return {Item} 元素实例\n */\n\n\n AbstractGraph.prototype.add = function (type, model, stack, sortCombo) {\n if (stack === void 0) {\n stack = true;\n }\n\n if (sortCombo === void 0) {\n sortCombo = true;\n }\n\n return this.addItem(type, model, stack, sortCombo);\n };\n /**\n * 更新元素\n * @param {Item} item 元素id或元素实例\n * @param {Partial<NodeConfig> | EdgeConfig} cfg 需要更新的数据\n */\n\n\n AbstractGraph.prototype.updateItem = function (item, cfg, stack) {\n var _this = this;\n\n if (stack === void 0) {\n stack = true;\n }\n\n var itemController = this.get('itemController');\n var currentItem;\n\n if (isString(item)) {\n currentItem = this.findById(item);\n } else {\n currentItem = item;\n }\n\n var UnupdateModel = clone(currentItem.getModel());\n var type = '';\n if (currentItem.getType) type = currentItem.getType();\n\n var states = __spreadArray([], currentItem.getStates());\n\n if (type === 'combo') {\n each(states, function (state) {\n return _this.setItemState(currentItem, state, false);\n });\n }\n\n itemController.updateItem(currentItem, cfg);\n\n if (type === 'combo') {\n each(states, function (state) {\n return _this.setItemState(currentItem, state, true);\n });\n }\n\n if (stack && this.get('enabledStack')) {\n var before = {\n nodes: [],\n edges: [],\n combos: []\n };\n var after = {\n nodes: [],\n edges: [],\n combos: []\n };\n\n var afterModel = __assign({\n id: UnupdateModel.id\n }, cfg);\n\n switch (type) {\n case 'node':\n before.nodes.push(UnupdateModel);\n after.nodes.push(afterModel);\n break;\n\n case 'edge':\n before.edges.push(UnupdateModel);\n after.edges.push(afterModel);\n break;\n\n case 'combo':\n before.combos.push(UnupdateModel);\n after.combos.push(afterModel);\n break;\n\n default:\n break;\n }\n\n if (type === 'node') {\n before.nodes.push(UnupdateModel);\n }\n\n this.pushStack('update', {\n before: before,\n after: after\n });\n }\n };\n /**\n * 更新元素\n * @param {Item} item 元素id或元素实例\n * @param {Partial<NodeConfig> | EdgeConfig} cfg 需要更新的数据\n * @param {boolean} stack 本次操作是否入栈,默认为 true\n */\n\n\n AbstractGraph.prototype.update = function (item, cfg, stack) {\n if (stack === void 0) {\n stack = true;\n }\n\n this.updateItem(item, cfg, stack);\n };\n /**\n * 设置元素状态\n * @param {Item} item 元素id或元素实例\n * @param {string} state 状态名称\n * @param {string | boolean} value 是否启用状态 或 状态值\n */\n\n\n AbstractGraph.prototype.setItemState = function (item, state, value) {\n if (isString(item)) {\n item = this.findById(item);\n }\n\n var itemController = this.get('itemController');\n itemController.setItemState(item, state, value);\n var stateController = this.get('stateController');\n\n if (isString(value)) {\n stateController.updateState(item, state + \":\" + value, true);\n } else {\n stateController.updateState(item, state, value);\n }\n };\n /**\n * 将指定状态的优先级提升为最高优先级\n * @param {Item} item 元素id或元素实例\n * @param state 状态名称\n */\n\n\n AbstractGraph.prototype.priorityState = function (item, state) {\n var itemController = this.get('itemController');\n itemController.priorityState(item, state);\n };\n /**\n * 设置视图初始化数据\n * @param {GraphData} data 初始化数据\n */\n\n\n AbstractGraph.prototype.data = function (data) {\n dataValidation(data);\n this.set('data', data);\n };\n /**\n * 根据data接口的数据渲染视图\n */\n\n\n AbstractGraph.prototype.render = function () {\n var self = this;\n this.set('comboSorted', false);\n var data = this.get('data');\n\n if (this.get('enabledStack')) {\n // render 之前清空 redo 和 undo 栈\n this.clearStack();\n }\n\n if (!data) {\n throw new Error('data must be defined first');\n }\n\n var _a = data.nodes,\n nodes = _a === void 0 ? [] : _a,\n _b = data.edges,\n edges = _b === void 0 ? [] : _b,\n _c = data.combos,\n combos = _c === void 0 ? [] : _c;\n this.clear(true);\n this.emit('beforerender');\n each(nodes, function (node) {\n self.add('node', node, false, false);\n }); // process the data to tree structure\n\n if (combos && combos.length !== 0) {\n var comboTrees = plainCombosToTrees(combos, nodes);\n this.set('comboTrees', comboTrees); // add combos\n\n self.addCombos(combos);\n }\n\n each(edges, function (edge) {\n self.add('edge', edge, false, false);\n });\n var animate = self.get('animate');\n\n if (self.get('fitView') || self.get('fitCenter')) {\n self.set('animate', false);\n } // layout\n\n\n var layoutController = self.get('layoutController');\n\n if (layoutController) {\n layoutController.layout(success);\n if (this.destroyed) return;\n } else {\n if (self.get('fitView')) {\n self.fitView();\n }\n\n if (self.get('fitCenter')) {\n self.fitCenter();\n }\n\n self.emit('afterrender');\n self.set('animate', animate);\n } // 将在 onLayoutEnd 中被调用\n\n\n function success() {\n // fitView 与 fitCenter 共存时,fitView 优先,fitCenter 不再执行\n if (self.get('fitView')) {\n self.fitView();\n } else if (self.get('fitCenter')) {\n self.fitCenter();\n }\n\n self.autoPaint();\n self.emit('afterrender');\n\n if (self.get('fitView') || self.get('fitCenter')) {\n self.set('animate', animate);\n }\n }\n\n if (!this.get('groupByTypes')) {\n if (combos && combos.length !== 0) {\n this.sortCombos();\n } else {\n // 为提升性能,选择数量少的进行操作\n if (data.nodes && data.edges && data.nodes.length < data.edges.length) {\n var nodesArr = this.getNodes(); // 遍历节点实例,将所有节点提前。\n\n nodesArr.forEach(function (node) {\n node.toFront();\n });\n } else {\n var edgesArr = this.getEdges(); // 遍历节点实例,将所有节点提前。\n\n edgesArr.forEach(function (edge) {\n edge.toBack();\n });\n }\n }\n }\n\n if (this.get('enabledStack')) {\n this.pushStack('render');\n }\n };\n /**\n * 接收数据进行渲染\n * @Param {Object} data 初始化数据\n */\n\n\n AbstractGraph.prototype.read = function (data) {\n this.data(data);\n this.render();\n }; // 比较item\n\n\n AbstractGraph.prototype.diffItems = function (type, items, models) {\n var self = this;\n var item;\n var itemMap = this.get('itemMap');\n each(models, function (model) {\n item = itemMap[model.id];\n\n if (item) {\n if (self.get('animate') && type === NODE) {\n var containerMatrix = item.getContainer().getMatrix();\n if (!containerMatrix) containerMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n item.set('originAttrs', {\n x: containerMatrix[6],\n y: containerMatrix[7]\n });\n }\n\n self.updateItem(item, model, false);\n } else {\n item = self.addItem(type, model, false);\n }\n\n if (item) items[type + \"s\"].push(item);\n });\n };\n /**\n * 更改源数据,根据新数据重新渲染视图\n * @param {GraphData | TreeGraphData} data 源数据\n * @param {boolean} 是否入栈,默认为true\n * @return {object} this\n */\n\n\n AbstractGraph.prototype.changeData = function (data, stack) {\n if (stack === void 0) {\n stack = true;\n }\n\n var self = this;\n\n if (!dataValidation(data)) {\n return this;\n }\n\n if (stack && this.get('enabledStack')) {\n this.pushStack('changedata', {\n before: self.save(),\n after: data\n });\n }\n\n this.set('comboSorted', false); // 删除 hulls\n\n this.removeHulls(); // 更改数据源后,取消所有状态\n\n this.getNodes().map(function (node) {\n return self.clearItemStates(node);\n });\n this.getEdges().map(function (edge) {\n return self.clearItemStates(edge);\n });\n var canvas = this.get('canvas');\n var localRefresh = canvas.get('localRefresh');\n canvas.set('localRefresh', false);\n\n if (!self.get('data')) {\n self.data(data);\n self.render();\n }\n\n var itemMap = this.get('itemMap');\n var items = {\n nodes: [],\n edges: []\n };\n var combosData = data.combos;\n\n if (combosData) {\n var comboTrees = plainCombosToTrees(combosData, data.nodes);\n this.set('comboTrees', comboTrees);\n } else {\n this.set('comboTrees', []);\n }\n\n this.diffItems('node', items, data.nodes);\n each(itemMap, function (item, id) {\n itemMap[id].getModel().depth = 0;\n if (item.getType && item.getType() === 'edge') return;\n\n if (item.getType && item.getType() === 'combo') {\n delete itemMap[id];\n item.destroy();\n } else if (items.nodes.indexOf(item) < 0) {\n delete itemMap[id];\n self.remove(item, false);\n }\n }); // clear the destroyed combos here to avoid removing sub nodes before removing the parent combo\n\n var comboItems = this.getCombos();\n var combosLength = comboItems.length;\n\n for (var i = combosLength - 1; i >= 0; i--) {\n if (comboItems[i].destroyed) {\n comboItems.splice(i, 1);\n }\n } // process the data to tree structure\n\n\n if (combosData) {\n // add combos\n self.addCombos(combosData);\n\n if (!this.get('groupByTypes')) {\n this.sortCombos();\n }\n }\n\n this.diffItems('edge', items, data.edges);\n each(itemMap, function (item, id) {\n if (item.getType && (item.getType() === 'node' || item.getType() === 'combo')) return;\n\n if (items.edges.indexOf(item) < 0) {\n delete itemMap[id];\n self.remove(item, false);\n }\n });\n this.set({\n nodes: items.nodes,\n edges: items.edges\n });\n var layoutController = this.get('layoutController');\n\n if (layoutController) {\n layoutController.changeData();\n\n if (self.get('animate') && !layoutController.getLayoutType()) {\n // 如果没有指定布局\n self.positionsAnimate();\n } else {\n self.autoPaint();\n }\n }\n\n setTimeout(function () {\n canvas.set('localRefresh', localRefresh);\n }, 16);\n return this;\n };\n /**\n * 私有方法,在 render 和 changeData 的时候批量添加数据中所有平铺的 combos\n * @param {ComboConfig[]} combos 平铺的 combos 数据\n */\n\n\n AbstractGraph.prototype.addCombos = function (combos) {\n var self = this;\n var comboTrees = self.get('comboTrees');\n var itemController = this.get('itemController');\n itemController.addCombos(comboTrees, combos);\n };\n /**\n * 根据已经存在的节点或 combo 创建新的 combo\n * @param combo combo ID 或 Combo 配置\n * @param children 添加到 Combo 中的元素,包括节点和 combo\n */\n\n\n AbstractGraph.prototype.createCombo = function (combo, children) {\n var _this = this;\n\n this.set('comboSorted', false); // step 1: 创建新的 Combo\n\n var comboId = '';\n var comboConfig;\n if (!combo) return;\n\n if (isString(combo)) {\n comboId = combo;\n comboConfig = {\n id: combo\n };\n } else {\n comboId = combo.id;\n\n if (!comboId) {\n console.warn('Create combo failed. Please assign a unique string id for the adding combo.');\n return;\n }\n\n comboConfig = combo;\n } // step2: 更新 children,根据类型添加 comboId 或 parentId\n\n\n var trees = children.map(function (elementId) {\n var item = _this.findById(elementId);\n\n var model = item.getModel();\n var type = '';\n if (item.getType) type = item.getType();\n var cItem = {\n id: item.getID(),\n itemType: type\n };\n\n if (type === 'combo') {\n cItem.parentId = comboId;\n model.parentId = comboId;\n } else if (type === 'node') {\n cItem.comboId = comboId;\n model.comboId = comboId;\n }\n\n return cItem;\n });\n comboConfig.children = trees; // step 3: 添加 Combo,addItem 时会将子将元素添加到 Combo 中\n\n this.addItem('combo', comboConfig, false);\n this.set('comboSorted', false); // step4: 更新 comboTrees 结构\n\n var comboTrees = this.get('comboTrees');\n (comboTrees || []).forEach(function (ctree) {\n traverseTreeUp(ctree, function (child) {\n if (child.id === comboId) {\n child.itemType = 'combo';\n child.children = trees;\n return false;\n }\n\n return true;\n });\n });\n\n if (comboTrees) {\n this.sortCombos();\n }\n };\n /**\n * 解散 combo\n * @param {String | INode | ICombo} combo 需要被解散的 Combo item 或 id\n */\n\n\n AbstractGraph.prototype.uncombo = function (combo) {\n var _this = this;\n\n var self = this;\n var comboItem = combo;\n\n if (isString(combo)) {\n comboItem = this.findById(combo);\n }\n\n if (!comboItem || comboItem.getType && comboItem.getType() !== 'combo') {\n console.warn('The item is not a combo!');\n return;\n }\n\n var parentId = comboItem.getModel().parentId;\n var comboTrees = self.get('comboTrees');\n if (!comboTrees) comboTrees = [];\n var itemMap = this.get('itemMap');\n var comboId = comboItem.get('id');\n var treeToBeUncombo;\n var brothers = [];\n var comboItems = this.get('combos');\n var parentItem = this.findById(parentId);\n comboTrees.forEach(function (ctree) {\n if (treeToBeUncombo) return; // terminate the forEach\n\n traverseTreeUp(ctree, function (subtree) {\n // find the combo to be uncomboed, delete the combo from map and cache\n if (subtree.id === comboId) {\n treeToBeUncombo = subtree; // delete the related edges\n\n var edges = comboItem.getEdges();\n edges.forEach(function (edge) {\n _this.removeItem(edge, false);\n });\n var index = comboItems.indexOf(comboItem);\n comboItems.splice(index, 1);\n delete itemMap[comboId];\n comboItem.destroy();\n\n _this.emit('afterremoveitem', {\n item: comboItem\n });\n } // find the parent to remove the combo from the combo's brothers array and add the combo's children to the combo's brothers array in the tree\n\n\n if (parentId && treeToBeUncombo && subtree.id === parentId) {\n parentItem.removeCombo(comboItem);\n brothers = subtree.children; // the combo's brothers\n // remove the combo from its brothers array\n\n var index = brothers.indexOf(treeToBeUncombo);\n\n if (index !== -1) {\n brothers.splice(index, 1);\n } // append the combo's children to the combo's brothers array\n\n\n treeToBeUncombo.children.forEach(function (child) {\n var item = _this.findById(child.id);\n\n var childModel = item.getModel();\n\n if (item.getType && item.getType() === 'combo') {\n child.parentId = parentId;\n delete child.comboId;\n childModel.parentId = parentId; // update the parentId of the model\n\n delete childModel.comboId;\n } else if (item.getType && item.getType() === 'node') {\n child.comboId = parentId;\n childModel.comboId = parentId; // update the parentId of the model\n }\n\n parentItem.addChild(item);\n brothers.push(child);\n });\n return false;\n }\n\n return true;\n });\n }); // if the parentId is not found, remove the combo from the roots\n\n if (!parentId && treeToBeUncombo) {\n var index = comboTrees.indexOf(treeToBeUncombo);\n comboTrees.splice(index, 1); // modify the parentId of the children\n\n treeToBeUncombo.children.forEach(function (child) {\n child.parentId = undefined;\n\n var childModel = _this.findById(child.id).getModel();\n\n delete childModel.parentId; // update the parentId of the model\n\n delete childModel.comboId; // update the comboId of the model\n\n if (child.itemType !== 'node') comboTrees.push(child);\n });\n }\n };\n /**\n * 根据节点的 bbox 更新所有 combos 的绘制,包括 combos 的位置和范围\n */\n\n\n AbstractGraph.prototype.updateCombos = function () {\n var _this = this;\n\n var self = this;\n var comboTrees = this.get('comboTrees');\n var itemController = self.get('itemController');\n var itemMap = self.get('itemMap');\n (comboTrees || []).forEach(function (ctree) {\n traverseTreeUp(ctree, function (child) {\n if (!child) {\n return true;\n }\n\n var childItem = itemMap[child.id];\n\n if (childItem && childItem.getType && childItem.getType() === 'combo') {\n // 更新具体的 Combo 之前先清除所有的已有状态,以免将 state 中的样式更新为 Combo 的样式\n var states = __spreadArray([], childItem.getStates());\n\n each(states, function (state) {\n return _this.setItemState(childItem, state, false);\n }); // 更新具体的 Combo\n\n itemController.updateCombo(childItem, child.children); // 更新 Combo 后,还原已有的状态\n\n each(states, function (state) {\n return _this.setItemState(childItem, state, true);\n });\n }\n\n return true;\n });\n });\n self.sortCombos();\n };\n /**\n * 根据节点的 bbox 更新 combo 及其祖先 combos 的绘制,包括 combos 的位置和范围\n * @param {String | ICombo} combo 需要被更新的 Combo 或 id,若指定,则该 Combo 及所有祖先 Combod 都会被更新\n */\n\n\n AbstractGraph.prototype.updateCombo = function (combo) {\n var _this = this;\n\n var self = this;\n var comboItem = combo;\n var comboId;\n\n if (isString(combo)) {\n comboItem = this.findById(combo);\n }\n\n if (!comboItem || comboItem.getType && comboItem.getType() !== 'combo') {\n console.warn('The item to be updated is not a combo!');\n return;\n }\n\n comboId = comboItem.get('id');\n var comboTrees = this.get('comboTrees');\n var itemController = self.get('itemController');\n var itemMap = self.get('itemMap');\n (comboTrees || []).forEach(function (ctree) {\n traverseTreeUp(ctree, function (child) {\n if (!child) {\n return true;\n }\n\n var childItem = itemMap[child.id];\n\n if (comboId === child.id && childItem && childItem.getType && childItem.getType() === 'combo') {\n // 更新具体的 Combo 之前先清除所有的已有状态,以免将 state 中的样式更新为 Combo 的样式\n var states = __spreadArray([], childItem.getStates()); // || !item.getStateStyle(stateName)\n\n\n each(states, function (state) {\n if (childItem.getStateStyle(state)) {\n _this.setItemState(childItem, state, false);\n }\n }); // 更新具体的 Combo\n\n itemController.updateCombo(childItem, child.children); // 更新 Combo 后,还原已有的状态\n\n each(states, function (state) {\n if (childItem.getStateStyle(state)) {\n _this.setItemState(childItem, state, true);\n }\n });\n if (comboId) comboId = child.parentId;\n }\n\n return true;\n });\n });\n };\n /**\n * 更新树结构,例如移动子树等\n * @param {String | INode | ICombo} item 需要被更新的 Combo 或 节点 id\n * @param {string | undefined} parentId 新的父 combo id,undefined 代表没有父 combo\n */\n\n\n AbstractGraph.prototype.updateComboTree = function (item, parentId, stack) {\n if (stack === void 0) {\n stack = true;\n }\n\n var self = this;\n this.set('comboSorted', false);\n var uItem;\n\n if (isString(item)) {\n uItem = self.findById(item);\n } else {\n uItem = item;\n }\n\n var model = uItem.getModel();\n var oldParentId = model.comboId || model.parentId;\n var type = '';\n if (uItem.getType) type = uItem.getType(); // 若 item 是 Combo,且 parentId 是其子孙 combo 的 id,则警告并终止\n\n if (parentId && type === 'combo') {\n var comboTrees = this.get('comboTrees');\n var valid_1 = true;\n var itemSubTree_1;\n (comboTrees || []).forEach(function (ctree) {\n if (itemSubTree_1) return;\n traverseTree(ctree, function (subTree) {\n if (itemSubTree_1) return; // 找到从 item 开始的子树\n\n if (subTree.id === uItem.getID()) {\n itemSubTree_1 = subTree;\n }\n\n return true;\n });\n }); // 在以 item 为根的子树中寻找与 parentId 相同的后继元素\n\n traverseTree(itemSubTree_1, function (subTree) {\n if (subTree.id === parentId) {\n valid_1 = false;\n return false;\n }\n\n return true;\n }); // parentId 是 item 的一个后继元素,不能进行更新\n\n if (!valid_1) {\n console.warn('Failed to update the combo tree! The parentId points to a descendant of the combo!');\n return;\n }\n }\n\n if (stack && this.get('enabledStack')) {\n var beforeData = {},\n afterData = {};\n\n if (type === 'combo') {\n beforeData.combos = [{\n id: model.id,\n parentId: model.parentId\n }];\n afterData.combos = [{\n id: model.id,\n parentId: parentId\n }];\n } else if (type === 'node') {\n beforeData.nodes = [{\n id: model.id,\n parentId: model.comboId\n }];\n afterData.nodes = [{\n id: model.id,\n parentId: parentId\n }];\n }\n\n this.pushStack('updateComboTree', {\n before: beforeData,\n after: afterData\n });\n } // 当 combo 存在 parentId 或 comboId 时,才将其移除\n\n\n if (model.parentId || model.comboId) {\n var combo = this.findById(model.parentId || model.comboId);\n\n if (combo) {\n combo.removeChild(uItem);\n }\n }\n\n if (type === 'combo') {\n model.parentId = parentId;\n } else if (type === 'node') {\n model.comboId = parentId;\n } // 只有当移入到指定 combo 时才添加\n\n\n if (parentId) {\n var parentCombo = this.findById(parentId);\n\n if (parentCombo) {\n // 将元素添加到 parentCombo 中\n parentCombo.addChild(uItem);\n }\n } // 如果原先有父亲 combo,则从原父 combo 的子元素数组中删除\n\n\n if (oldParentId) {\n var parentCombo = this.findById(oldParentId);\n\n if (parentCombo) {\n // 将元素从 parentCombo 中移除\n parentCombo.removeChild(uItem);\n }\n }\n\n var newComboTrees = reconstructTree(this.get('comboTrees'), model.id, parentId);\n this.set('comboTrees', newComboTrees);\n this.updateCombos();\n };\n /**\n * 导出图数据\n * @return {object} data\n */\n\n\n AbstractGraph.prototype.save = function () {\n var nodes = [];\n var edges = [];\n var combos = [];\n each(this.get('nodes'), function (node) {\n nodes.push(node.getModel());\n });\n each(this.get('edges'), function (edge) {\n edges.push(edge.getModel());\n });\n each(this.get('combos'), function (combo) {\n combos.push(combo.getModel());\n });\n return {\n nodes: nodes,\n edges: edges,\n combos: combos\n };\n };\n /**\n * 改变画布大小\n * @param {number} width 画布宽度\n * @param {number} height 画布高度\n * @return {object} this\n */\n\n\n AbstractGraph.prototype.changeSize = function (width, height) {\n var viewController = this.get('viewController');\n viewController.changeSize(width, height);\n return this;\n };\n /**\n * 当源数据在外部发生变更时,根据新数据刷新视图。但是不刷新节点位置\n */\n\n\n AbstractGraph.prototype.refresh = function () {\n var self = this;\n self.emit('beforegraphrefresh');\n\n if (self.get('animate')) {\n self.positionsAnimate();\n } else {\n var nodes = self.get('nodes');\n var edges = self.get('edges');\n var vedges = self.get('edges');\n each(nodes, function (node) {\n node.refresh();\n });\n each(edges, function (edge) {\n edge.refresh();\n });\n each(vedges, function (vedge) {\n vedge.refresh();\n });\n }\n\n self.emit('aftergraphrefresh');\n self.autoPaint();\n };\n /**\n * 获取当前图中所有节点的item实例\n * @return {INode} item数组\n */\n\n\n AbstractGraph.prototype.getNodes = function () {\n return this.get('nodes');\n };\n /**\n * 获取当前图中所有边的item实例\n * @return {IEdge} item数组\n */\n\n\n AbstractGraph.prototype.getEdges = function () {\n return this.get('edges');\n };\n /**\n * 获取图中所有的 combo 实例\n */\n\n\n AbstractGraph.prototype.getCombos = function () {\n return this.get('combos');\n };\n /**\n * 获取指定 Combo 中所有的节点\n * @param comboId combo ID\n */\n\n\n AbstractGraph.prototype.getComboChildren = function (combo) {\n if (isString(combo)) {\n combo = this.findById(combo);\n }\n\n if (!combo || combo.getType && combo.getType() !== 'combo') {\n console.warn('The combo does not exist!');\n return;\n }\n\n return combo.getChildren();\n };\n /**\n * 根据 graph 上的 animateCfg 进行视图中节点位置动画接口\n */\n\n\n AbstractGraph.prototype.positionsAnimate = function () {\n var self = this;\n self.emit('beforeanimate');\n var animateCfg = self.get('animateCfg');\n var onFrame = animateCfg.onFrame;\n var nodes = self.getNodes();\n var toNodes = nodes.map(function (node) {\n var model = node.getModel();\n return {\n id: model.id,\n x: model.x,\n y: model.y\n };\n });\n\n if (self.isAnimating()) {\n self.stopAnimate();\n }\n\n var canvas = self.get('canvas');\n canvas.animate(function (ratio) {\n each(toNodes, function (data) {\n var node = self.findById(data.id);\n\n if (!node || node.destroyed) {\n return;\n }\n\n var originAttrs = node.get('originAttrs');\n var model = node.get('model');\n\n if (!originAttrs) {\n var containerMatrix = node.getContainer().getMatrix();\n if (!containerMatrix) containerMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n originAttrs = {\n x: containerMatrix[6],\n y: containerMatrix[7]\n };\n node.set('originAttrs', originAttrs);\n }\n\n if (onFrame) {\n var attrs = onFrame(node, ratio, data, originAttrs);\n node.set('model', Object.assign(model, attrs));\n } else {\n model.x = originAttrs.x + (data.x - originAttrs.x) * ratio;\n model.y = originAttrs.y + (data.y - originAttrs.y) * ratio;\n }\n });\n self.refreshPositions();\n }, {\n duration: animateCfg.duration,\n easing: animateCfg.easing,\n callback: function callback() {\n each(nodes, function (node) {\n node.set('originAttrs', null);\n });\n\n if (animateCfg.callback) {\n animateCfg.callback();\n }\n\n self.emit('afteranimate');\n self.animating = false;\n }\n });\n };\n /**\n * 当节点位置在外部发生改变时,刷新所有节点位置,重计算边\n */\n\n\n AbstractGraph.prototype.refreshPositions = function () {\n var self = this;\n self.emit('beforegraphrefreshposition');\n var nodes = self.get('nodes');\n var edges = self.get('edges');\n var vedges = self.get('vedges');\n var combos = self.get('combos');\n var model;\n var updatedNodes = {};\n each(nodes, function (node) {\n model = node.getModel();\n var originAttrs = node.get('originAttrs');\n\n if (originAttrs && model.x === originAttrs.x && model.y === originAttrs.y) {\n return;\n }\n\n var changed = node.updatePosition({\n x: model.x,\n y: model.y\n });\n updatedNodes[model.id] = changed;\n if (model.comboId) updatedNodes[model.comboId] = updatedNodes[model.comboId] || changed;\n });\n\n if (combos && combos.length !== 0) {\n self.updateCombos();\n }\n\n each(edges, function (edge) {\n var sourceModel = edge.getSource().getModel();\n var target = edge.getTarget(); // 避免 target 是纯对象的情况下调用 getModel 方法\n // 拖动生成边的时候 target 会是纯对象\n\n if (!isPlainObject(target)) {\n var targetModel = target.getModel();\n\n if (updatedNodes[sourceModel.id] || updatedNodes[targetModel.id] || edge.getModel().isComboEdge) {\n edge.refresh();\n }\n }\n });\n each(vedges, function (vedge) {\n vedge.refresh();\n });\n self.emit('aftergraphrefreshposition');\n self.autoPaint();\n };\n\n AbstractGraph.prototype.stopAnimate = function () {\n this.get('canvas').stopAnimate();\n };\n\n AbstractGraph.prototype.isAnimating = function () {\n return this.animating;\n };\n /**\n * 获取当前视口伸缩比例\n * @return {number} 比例\n */\n\n\n AbstractGraph.prototype.getZoom = function () {\n var matrix = this.get('group').getMatrix();\n return matrix ? matrix[0] : 1;\n };\n /**\n * 获取当前的行为模式\n * @return {string} 当前行为模式\n */\n\n\n AbstractGraph.prototype.getCurrentMode = function () {\n var modeController = this.get('modeController');\n return modeController.getMode();\n };\n /**\n * 切换行为模式\n * @param {string} mode 指定模式\n * @return {object} this\n */\n\n\n AbstractGraph.prototype.setMode = function (mode) {\n var modeController = this.get('modeController');\n modeController.setMode(mode);\n return this;\n };\n /**\n * 清除画布元素\n * @return {object} this\n */\n\n\n AbstractGraph.prototype.clear = function (avoidEmit) {\n var _a;\n\n if (avoidEmit === void 0) {\n avoidEmit = false;\n }\n\n (_a = this.get('canvas')) === null || _a === void 0 ? void 0 : _a.clear();\n this.initGroups(); // 清空画布时同时清除数据\n\n this.set({\n itemMap: {},\n nodes: [],\n edges: [],\n groups: [],\n combos: [],\n comboTrees: []\n });\n if (!avoidEmit) this.emit('afterrender');\n return this;\n };\n /**\n * 更换布局配置项\n * @param {object} cfg 新布局配置项\n * @param {'center' | 'begin'} align 对齐方式,可选中心(center)对齐到对齐点,或左上角(begin)对齐到对齐点\n * @param {IPoint} alignPoint 画布上的对齐点,为 Canvas 坐标系(Canvas DOM)\n * 若 cfg 含有 type 字段或为 String 类型,且与现有布局方法不同,则更换布局\n * 若 cfg 不包括 type ,则保持原有布局方法,仅更新布局配置项\n */\n\n\n AbstractGraph.prototype.updateLayout = function (cfg, align, alignPoint) {\n var _this = this;\n\n var layoutController = this.get('layoutController');\n\n if (isString(cfg)) {\n cfg = {\n type: cfg\n };\n } // align the graph after layout\n\n\n if (align) {\n var toPoint_1 = alignPoint;\n\n if (!toPoint_1) {\n if (align === 'begin') toPoint_1 = {\n x: 0,\n y: 0\n };else toPoint_1 = {\n x: this.getWidth() / 2,\n y: this.getHeight() / 2\n };\n } // translate to point coordinate system\n\n\n toPoint_1 = this.getPointByCanvas(toPoint_1.x, toPoint_1.y);\n var forceTypes = ['force', 'gForce', 'fruchterman']; // if it is force layout, only center takes effect, and assign center force\n\n if (forceTypes.includes(cfg.type) || !cfg.type && forceTypes.includes(layoutController === null || layoutController === void 0 ? void 0 : layoutController.layoutType)) {\n cfg.center = [toPoint_1.x, toPoint_1.y];\n } else {\n this.once('afterlayout', function (e) {\n var matrix = _this.getGroup().getMatrix() || [1, 0, 0, 0, 1, 0, 0, 0, 1];\n toPoint_1.x = toPoint_1.x * matrix[0] + matrix[6];\n toPoint_1.y = toPoint_1.y * matrix[0] + matrix[7];\n\n var _a = _this.getGroup().getCanvasBBox(),\n minX = _a.minX,\n maxX = _a.maxX,\n minY = _a.minY,\n maxY = _a.maxY;\n\n var bboxPoint = {\n x: (minX + maxX) / 2,\n y: (minY + maxY) / 2\n };\n\n if (align === 'begin') {\n bboxPoint.x = minX;\n bboxPoint.y = minY;\n }\n\n _this.translate(toPoint_1.x - bboxPoint.x, toPoint_1.y - bboxPoint.y);\n });\n }\n }\n\n var oriLayoutCfg = this.get('layout');\n var layoutCfg = {};\n Object.assign(layoutCfg, oriLayoutCfg, cfg);\n this.set('layout', layoutCfg);\n\n if (layoutController.isLayoutTypeSame(layoutCfg) && layoutCfg.gpuEnabled === oriLayoutCfg.gpuEnabled) {\n // no type or same type, or switch the gpu and cpu, update layout\n layoutController.updateLayoutCfg(layoutCfg);\n } else {\n // has different type, change layout\n layoutController.changeLayout(layoutCfg);\n }\n };\n /**\n * 销毁布局,changeData 时不会再使用原来的布局方法对新数据进行布局\n */\n\n\n AbstractGraph.prototype.destroyLayout = function () {\n var layoutController = this.get('layoutController');\n layoutController.destroyLayout();\n };\n /**\n * 重新以当前示例中配置的属性进行一次布局\n */\n\n\n AbstractGraph.prototype.layout = function () {\n var layoutController = this.get('layoutController');\n var layoutCfg = this.get('layout');\n if (!layoutCfg || !layoutController) return;\n\n if (layoutCfg.workerEnabled) {\n // 如果使用web worker布局\n layoutController.layout();\n return;\n }\n\n if (layoutController.layoutMethod) {\n layoutController.relayout(true);\n } else {\n layoutController.layout();\n }\n };\n /**\n * 收起指定的 combo\n * @param {string | ICombo} combo combo ID 或 combo item\n */\n\n\n AbstractGraph.prototype.collapseCombo = function (combo) {\n var _this = this;\n\n if (isString(combo)) {\n combo = this.findById(combo);\n }\n\n if (!combo) {\n console.warn('The combo to be collapsed does not exist!');\n return;\n }\n\n this.emit('beforecollapseexpandcombo', {\n action: 'expand',\n item: combo\n });\n var comboModel = combo.getModel();\n var itemController = this.get('itemController');\n itemController.collapseCombo(combo);\n comboModel.collapsed = true; // add virtual edges\n\n var edges = this.getEdges().concat(this.get('vedges')); // find all the descendant nodes and combos\n\n var cnodes = [];\n var ccombos = [];\n var comboTrees = this.get('comboTrees');\n var found = false;\n (comboTrees || []).forEach(function (ctree) {\n if (found) return; // if the combo is found, terminate the forEach\n\n traverseTree(ctree, function (subTree) {\n // if the combo is found and it is traversing the other branches, terminate\n if (found && subTree.depth <= comboModel.depth) return false; // if the combo is found\n\n if (comboModel.id === subTree.id) found = true;\n\n if (found) {\n // if the combo is found, concat the descendant nodes and combos\n var item = _this.findById(subTree.id);\n\n if (item && item.getType && item.getType() === 'combo') {\n cnodes = cnodes.concat(item.getNodes());\n ccombos = ccombos.concat(item.getCombos());\n }\n }\n\n return true;\n });\n });\n var edgeWeightMap = {};\n var addedVEdges = [];\n edges.forEach(function (edge) {\n if (edge.isVisible() && !edge.getModel().isVEdge) return;\n var source = edge.getSource();\n var target = edge.getTarget();\n\n if ((cnodes.includes(source) || ccombos.includes(source)) && !cnodes.includes(target) && !ccombos.includes(target) || source.getModel().id === comboModel.id) {\n var edgeModel = edge.getModel();\n\n if (edgeModel.isVEdge) {\n _this.removeItem(edge, false);\n\n return;\n }\n\n var targetModel = target.getModel();\n\n while (!target.isVisible()) {\n target = _this.findById(targetModel.parentId || targetModel.comboId);\n if (!target || !targetModel.parentId && !targetModel.comboId) return; // all the ancestors are hidden, then ignore the edge\n\n targetModel = target.getModel();\n }\n\n var targetId = targetModel.id;\n\n if (edgeWeightMap[comboModel.id + \"-\" + targetId]) {\n edgeWeightMap[comboModel.id + \"-\" + targetId] += edgeModel.size || 1;\n return;\n } // the source is in the combo, the target is not\n\n\n var vedge = _this.addItem('vedge', {\n source: comboModel.id,\n target: targetId,\n isVEdge: true\n }, false);\n\n edgeWeightMap[comboModel.id + \"-\" + targetId] = edgeModel.size || 1;\n addedVEdges.push(vedge);\n } else if (!cnodes.includes(source) && !ccombos.includes(source) && (cnodes.includes(target) || ccombos.includes(target)) || target.getModel().id === comboModel.id) {\n var edgeModel = edge.getModel();\n\n if (edgeModel.isVEdge) {\n _this.removeItem(edge, false);\n\n return;\n }\n\n var sourceModel = source.getModel();\n\n while (!source.isVisible()) {\n source = _this.findById(sourceModel.parentId || sourceModel.comboId);\n if (!source || !sourceModel.parentId && !sourceModel.comboId) return; // all the ancestors are hidden, then ignore the edge\n\n sourceModel = source.getModel();\n }\n\n var sourceId = sourceModel.id;\n\n if (edgeWeightMap[sourceId + \"-\" + comboModel.id]) {\n edgeWeightMap[sourceId + \"-\" + comboModel.id] += edgeModel.size || 1;\n return;\n } // the target is in the combo, the source is not\n\n\n var vedge = _this.addItem('vedge', {\n target: comboModel.id,\n source: sourceId,\n isVEdge: true\n }, false);\n\n edgeWeightMap[sourceId + \"-\" + comboModel.id] = edgeModel.size || 1;\n addedVEdges.push(vedge);\n }\n }); // update the width of the virtual edges, which is the sum of merged actual edges\n // be attention that the actual edges with same endpoints but different directions will be represented by two different virtual edges\n\n addedVEdges.forEach(function (vedge) {\n var vedgeModel = vedge.getModel();\n\n _this.updateItem(vedge, {\n size: edgeWeightMap[vedgeModel.source + \"-\" + vedgeModel.target]\n }, false);\n });\n this.emit('aftercollapseexpandcombo', {\n action: 'collapse',\n item: combo\n });\n };\n /**\n * 展开指定的 combo\n * @param {string | ICombo} combo combo ID 或 combo item\n */\n\n\n AbstractGraph.prototype.expandCombo = function (combo) {\n var _this = this;\n\n if (isString(combo)) {\n combo = this.findById(combo);\n }\n\n if (!combo || combo.getType && combo.getType() !== 'combo') {\n console.warn('The combo to be collapsed does not exist!');\n return;\n }\n\n this.emit('beforecollapseexpandcombo', {\n action: 'expand',\n item: combo\n });\n var comboModel = combo.getModel();\n var itemController = this.get('itemController');\n itemController.expandCombo(combo);\n comboModel.collapsed = false; // add virtual edges\n\n var edges = this.getEdges().concat(this.get('vedges')); // find all the descendant nodes and combos\n\n var cnodes = [];\n var ccombos = [];\n var comboTrees = this.get('comboTrees');\n var found = false;\n (comboTrees || []).forEach(function (ctree) {\n if (found) return; // if the combo is found, terminate\n\n traverseTree(ctree, function (subTree) {\n // if the combo is found and it is traversing the other branches, terminate\n if (found && subTree.depth <= comboModel.depth) return false;\n if (comboModel.id === subTree.id) found = true;\n\n if (found) {\n var item = _this.findById(subTree.id);\n\n if (item && item.getType && item.getType() === 'combo') {\n cnodes = cnodes.concat(item.getNodes());\n ccombos = ccombos.concat(item.getCombos());\n }\n }\n\n return true;\n });\n });\n var edgeWeightMap = {};\n var addedVEdges = {};\n edges.forEach(function (edge) {\n if (edge.isVisible() && !edge.getModel().isVEdge) return;\n var source = edge.getSource();\n var target = edge.getTarget();\n var sourceId = source.get('id');\n var targetId = target.get('id');\n\n if ((cnodes.includes(source) || ccombos.includes(source)) && !cnodes.includes(target) && !ccombos.includes(target) || sourceId === comboModel.id) {\n // the source is in the combo, the target is not\n // ignore the virtual edges\n if (edge.getModel().isVEdge) {\n _this.removeItem(edge, false);\n\n return;\n }\n\n var targetModel = target.getModel(); // find the nearest visible ancestor\n\n while (!target.isVisible()) {\n target = _this.findById(targetModel.comboId || targetModel.parentId);\n\n if (!target || !targetModel.parentId && !targetModel.comboId) {\n return; // if all the ancestors of the oppsite are all hidden, ignore the edge\n }\n\n targetModel = target.getModel();\n }\n\n targetId = targetModel.id;\n var sourceModel = source.getModel(); // find the nearest visible ancestor\n\n while (!source.isVisible()) {\n source = _this.findById(sourceModel.comboId || sourceModel.parentId);\n\n if (!source || !sourceModel.parentId && !sourceModel.comboId) {\n return; // if all the ancestors of the oppsite are all hidden, ignore the edge\n }\n\n if (sourceModel.comboId === comboModel.id || sourceModel.parentId === comboModel.id) {\n break; // if the next ancestor is the combo, break the while\n }\n\n sourceModel = source.getModel();\n }\n\n sourceId = sourceModel.id;\n\n if (targetId) {\n var vedgeId = sourceId + \"-\" + targetId; // update the width of the virtual edges, which is the sum of merged actual edges\n // be attention that the actual edges with same endpoints but different directions will be represented by two different virtual edges\n\n if (edgeWeightMap[vedgeId]) {\n edgeWeightMap[vedgeId] += edge.getModel().size || 1;\n\n _this.updateItem(addedVEdges[vedgeId], {\n size: edgeWeightMap[vedgeId]\n }, false);\n\n return;\n }\n\n var vedge = _this.addItem('vedge', {\n source: sourceId,\n target: targetId,\n isVEdge: true\n }, false);\n\n edgeWeightMap[vedgeId] = edge.getModel().size || 1;\n addedVEdges[vedgeId] = vedge;\n }\n } else if (!cnodes.includes(source) && !ccombos.includes(source) && (cnodes.includes(target) || ccombos.includes(target)) || targetId === comboModel.id) {\n // the target is in the combo, the source is not\n // ignore the virtual edges\n if (edge.getModel().isVEdge) {\n _this.removeItem(edge, false);\n\n return;\n }\n\n var sourceModel = source.getModel(); // find the nearest visible ancestor\n\n while (!source.isVisible()) {\n source = _this.findById(sourceModel.comboId || sourceModel.parentId);\n\n if (!source || !sourceModel.parentId && !sourceModel.comboId) {\n return; // if all the ancestors of the oppsite are all hidden, ignore the edge\n }\n\n sourceModel = source.getModel();\n }\n\n sourceId = sourceModel.id;\n var targetModel = target.getModel(); // find the nearest visible ancestor\n\n while (!target.isVisible()) {\n target = _this.findById(targetModel.comboId || targetModel.parentId);\n\n if (!target || !targetModel.parentId && !targetModel.comboId) {\n return; // if all the ancestors of the oppsite are all hidden, ignore the edge\n }\n\n if (targetModel.comboId === comboModel.id || targetModel.parentId === comboModel.id) {\n break; // if the next ancestor is the combo, break the while\n }\n\n targetModel = target.getModel();\n }\n\n targetId = targetModel.id;\n\n if (sourceId) {\n var vedgeId = sourceId + \"-\" + targetId; // update the width of the virtual edges, which is the sum of merged actual edges\n // be attention that the actual edges with same endpoints but different directions will be represented by two different virtual edges\n\n if (edgeWeightMap[vedgeId]) {\n edgeWeightMap[vedgeId] += edge.getModel().size || 1;\n\n _this.updateItem(addedVEdges[vedgeId], {\n size: edgeWeightMap[vedgeId]\n }, false);\n\n return;\n }\n\n var vedge = _this.addItem('vedge', {\n target: targetId,\n source: sourceId,\n isVEdge: true\n }, false);\n\n edgeWeightMap[vedgeId] = edge.getModel().size || 1;\n addedVEdges[vedgeId] = vedge;\n }\n } else if ((cnodes.includes(source) || ccombos.includes(source)) && (cnodes.includes(target) || ccombos.includes(target))) {\n // both source and target are in the combo, if the target and source are both visible, show the edge\n if (source.isVisible() && target.isVisible()) {\n edge.show();\n }\n }\n });\n this.emit('aftercollapseexpandcombo', {\n action: 'expand',\n item: combo\n });\n };\n\n AbstractGraph.prototype.collapseExpandCombo = function (combo) {\n if (isString(combo)) {\n combo = this.findById(combo);\n }\n\n if (!combo || combo.getType && combo.getType() !== 'combo') return;\n var comboModel = combo.getModel(); // if one ancestor combo of the combo is collapsed, it should not be collapsed or expanded\n\n var parentItem = this.findById(comboModel.parentId);\n\n while (parentItem) {\n var parentModel = parentItem.getModel();\n\n if (parentModel.collapsed) {\n console.warn(\"Fail to expand the combo since it's ancestor combo is collapsed.\");\n parentItem = undefined;\n return;\n }\n\n parentItem = this.findById(parentModel.parentId);\n }\n\n var collapsed = comboModel.collapsed; // 该群组已经处于收起状态,需要展开\n\n if (collapsed) {\n this.expandCombo(combo);\n } else {\n this.collapseCombo(combo);\n }\n\n this.updateCombo(combo);\n };\n /**\n * 根据 comboTree 结构整理 Combo 相关的图形绘制层级,包括 Combo 本身、节点、边\n * @param {GraphData} data 数据\n */\n\n\n AbstractGraph.prototype.sortCombos = function () {\n var _this = this;\n\n var comboSorted = this.get('comboSorted');\n if (comboSorted) return;\n this.set('comboSorted', true);\n var depthMap = [];\n var dataDepthMap = {};\n var comboTrees = this.get('comboTrees');\n (comboTrees || []).forEach(function (cTree) {\n traverseTree(cTree, function (child) {\n if (depthMap[child.depth]) depthMap[child.depth].push(child.id);else depthMap[child.depth] = [child.id];\n dataDepthMap[child.id] = child.depth;\n return true;\n });\n });\n var edges = this.getEdges().concat(this.get('vedges'));\n (edges || []).forEach(function (edgeItem) {\n var edge = edgeItem.getModel();\n var sourceDepth = dataDepthMap[edge.source] || 0;\n var targetDepth = dataDepthMap[edge.target] || 0;\n var depth = Math.max(sourceDepth, targetDepth);\n if (depthMap[depth]) depthMap[depth].push(edge.id);else depthMap[depth] = [edge.id];\n });\n depthMap.forEach(function (array) {\n if (!array || !array.length) return;\n\n for (var i = array.length - 1; i >= 0; i--) {\n var item = _this.findById(array[i]);\n\n if (item) item.toFront();\n }\n });\n };\n /**\n * 获取节点所有的邻居节点\n *\n * @param {(string | INode)} node 节点 ID 或实例\n * @returns {INode[]}\n * @memberof IAbstractGraph\n */\n\n\n AbstractGraph.prototype.getNeighbors = function (node, type) {\n var item = node;\n\n if (isString(node)) {\n item = this.findById(node);\n }\n\n return item.getNeighbors(type);\n };\n /**\n * 获取 node 的度数\n *\n * @param {(string | INode)} node 节点 ID 或实例\n * @param {('in' | 'out' | 'total' | 'all' | undefined)} 度数类型,in 入度,out 出度,total 总度数,all 返回三种类型度数的对象\n * @returns {Number | Object} 该节点的度数\n * @memberof IAbstractGraph\n */\n\n\n AbstractGraph.prototype.getNodeDegree = function (node, type, refresh) {\n if (type === void 0) {\n type = undefined;\n }\n\n if (refresh === void 0) {\n refresh = false;\n }\n\n var item = node;\n\n if (isString(node)) {\n item = this.findById(node);\n }\n\n var degrees = this.get('degrees');\n\n if (!degrees || refresh) {\n degrees = getDegree(this.save());\n this.set('degrees', degrees);\n }\n\n var nodeDegrees = degrees[item.getID()];\n var res = 0; // 如果是通过 addItem 后面新增加的节点,此时它的所有度数都为 0\n\n if (!nodeDegrees) {\n return 0;\n }\n\n switch (type) {\n case 'in':\n res = nodeDegrees.inDegree;\n break;\n\n case 'out':\n res = nodeDegrees.outDegree;\n break;\n\n case 'all':\n res = nodeDegrees;\n break;\n\n default:\n res = nodeDegrees.degree;\n break;\n }\n\n return res;\n };\n\n AbstractGraph.prototype.getUndoStack = function () {\n return this.undoStack;\n };\n\n AbstractGraph.prototype.getRedoStack = function () {\n return this.redoStack;\n };\n /**\n * 获取 undo 和 redo 栈的数据\n */\n\n\n AbstractGraph.prototype.getStackData = function () {\n if (!this.get('enabledStack')) {\n return null;\n }\n\n return {\n undoStack: this.undoStack.toArray(),\n redoStack: this.redoStack.toArray()\n };\n };\n /**\n * 清空 undo stack & redo stack\n */\n\n\n AbstractGraph.prototype.clearStack = function () {\n if (this.get('enabledStack')) {\n this.undoStack.clear();\n this.redoStack.clear();\n }\n };\n /**\n * 将操作类型和操作数据入栈\n * @param action 操作类型\n * @param data 入栈的数据\n * @param stackType 栈的类型\n */\n\n\n AbstractGraph.prototype.pushStack = function (action, data, stackType) {\n if (action === void 0) {\n action = 'update';\n }\n\n if (stackType === void 0) {\n stackType = 'undo';\n }\n\n if (!this.get('enabledStack')) {\n console.warn('请先启用 undo & redo 功能,在实例化 Graph 时候配置 enabledStack: true !');\n return;\n }\n\n var stackData = data ? clone(data) : {\n before: {},\n after: clone(this.save())\n };\n\n if (stackType === 'redo') {\n this.redoStack.push({\n action: action,\n data: stackData\n });\n } else {\n this.undoStack.push({\n action: action,\n data: stackData\n });\n }\n\n this.emit('stackchange', {\n undoStack: this.undoStack,\n redoStack: this.redoStack\n });\n };\n /**\n * 获取邻接矩阵\n *\n * @param {boolean} cache 是否使用缓存的\n * @param {boolean} directed 是否是有向图,默认取 graph.directed\n * @returns {Matrix} 邻接矩阵\n * @memberof IAbstractGraph\n */\n\n\n AbstractGraph.prototype.getAdjMatrix = function (cache, directed) {\n if (cache === void 0) {\n cache = true;\n }\n\n if (directed === undefined) directed = this.get('directed');\n var currentAdjMatrix = this.get('adjMatrix');\n\n if (!currentAdjMatrix || !cache) {\n currentAdjMatrix = getAdjacentMatrix(this.save(), directed);\n this.set('adjMatrix', currentAdjMatrix);\n }\n\n return currentAdjMatrix;\n };\n /**\n * 获取最短路径矩阵\n *\n * @param {boolean} cache 是否使用缓存的\n * @param {boolean} directed 是否是有向图,默认取 graph.directed\n * @returns {Matrix} 最短路径矩阵\n * @memberof IAbstractGraph\n */\n\n\n AbstractGraph.prototype.getShortestPathMatrix = function (cache, directed) {\n if (cache === void 0) {\n cache = true;\n }\n\n if (directed === undefined) directed = this.get('directed');\n var currentAdjMatrix = this.get('adjMatrix');\n var currentShourtestPathMatrix = this.get('shortestPathMatrix');\n\n if (!currentAdjMatrix || !cache) {\n currentAdjMatrix = getAdjacentMatrix(this.save(), directed);\n this.set('adjMatrix', currentAdjMatrix);\n }\n\n if (!currentShourtestPathMatrix || !cache) {\n currentShourtestPathMatrix = floydWarshall(this.save(), directed);\n this.set('shortestPathMatrix', currentShourtestPathMatrix);\n }\n\n return currentShourtestPathMatrix;\n };\n /**\n * 重新定义监听函数,复写参数类型\n */\n\n\n AbstractGraph.prototype.on = function (eventName, callback, once) {\n return _super.prototype.on.call(this, eventName, callback, once);\n };\n /**\n * 销毁画布\n */\n\n\n AbstractGraph.prototype.destroy = function () {\n this.clear(); // 清空栈数据\n\n this.clearStack();\n this.get('itemController').destroy();\n this.get('modeController').destroy();\n this.get('viewController').destroy();\n this.get('stateController').destroy();\n this.get('canvas').destroy();\n this.cfg = null;\n this.destroyed = true;\n this.redoStack = null;\n this.undoStack = null;\n };\n /**\n * 创建凸包或凹包轮廓\n * @param cfg HullCfg 轮廓配置项\n */\n\n\n AbstractGraph.prototype.createHull = function (cfg) {\n if (!cfg.members || cfg.members.length < 1) {\n console.warn('Create hull failed! The members is empty.');\n return;\n }\n\n var parent = this.get('hullGroup');\n var hullMap = this.get('hullMap');\n\n if (!hullMap) {\n hullMap = {};\n this.set('hullMap', hullMap);\n }\n\n if (!parent || parent.get('destroyed')) {\n parent = this.get('group').addGroup({\n id: 'hullGroup'\n });\n parent.toBack();\n this.set('hullGroup', parent);\n }\n\n if (hullMap[cfg.id]) {\n console.warn('Existed hull id.');\n return hullMap[cfg.id];\n }\n\n var group = parent.addGroup({\n id: cfg.id + \"-container\"\n });\n var hull = new Hull(this, __assign(__assign({}, cfg), {\n group: group\n }));\n var hullId = hull.id;\n hullMap[hullId] = hull;\n return hull;\n };\n /**\n * 获取当前 graph 中存在的包裹轮廓\n * @return {[key: string]: Hull} Hull 的 map,hullId 对应的 hull 实例\n */\n\n\n AbstractGraph.prototype.getHulls = function () {\n return this.get('hullMap');\n };\n /**\n * 根据 hullId 获取对应的 hull\n * @return Hull\n */\n\n\n AbstractGraph.prototype.getHullById = function (hullId) {\n return this.get('hullMap')[hullId];\n };\n\n AbstractGraph.prototype.removeHull = function (hull) {\n var hullInstance;\n\n if (isString(hull)) {\n hullInstance = this.getHullById(hull);\n } else {\n hullInstance = hull;\n }\n\n var hullMap = this.get('hullMap');\n delete hullMap[hullInstance.id];\n hullInstance.destroy();\n };\n\n AbstractGraph.prototype.removeHulls = function () {\n var hulls = this.getHulls();\n if (!hulls || !Object.keys(hulls).length) return;\n Object.keys(hulls).forEach(function (key) {\n var hull = hulls[key];\n hull.destroy();\n });\n this.set('hullMap', {});\n };\n\n return AbstractGraph;\n}(EventEmitter);\n\nexport default AbstractGraph;","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nimport { __assign } from \"tslib\";\nimport Global from '../global';\nimport { ext } from '@antv/matrix-util';\nimport { deepMix, each, mix, isBoolean, isPlainObject, clone } from '@antv/util';\nimport { cloneBesidesImg } from '../util/graphic';\nvar transform = ext.transform;\nvar CLS_SHAPE_SUFFIX = '-shape';\nvar CLS_LABEL_SUFFIX = '-label';\nvar ARROWS = ['startArrow', 'endArrow'];\nvar SHAPE_DEFAULT_ATTRS = {\n lineWidth: 1,\n stroke: undefined,\n fill: undefined,\n lineAppendWidth: 1,\n opacity: undefined,\n strokeOpacity: undefined,\n fillOpacity: undefined,\n x: 0,\n y: 0,\n r: 10,\n width: 20,\n height: 20,\n shadowColor: undefined,\n shadowBlur: 0,\n shadowOffsetX: 0,\n shadowOffsetY: 0\n};\nvar PATH_SHAPE_DEFAULT_ATTRS = {\n lineWidth: 1,\n stroke: '#000',\n lineDash: undefined,\n startArrow: false,\n endArrow: false,\n opacity: undefined,\n strokeOpacity: undefined,\n fillOpacity: undefined,\n shadowColor: undefined,\n shadowBlur: 0,\n shadowOffsetX: 0,\n shadowOffsetY: 0\n};\nvar SHAPES_DEFAULT_ATTRS = {\n edge: PATH_SHAPE_DEFAULT_ATTRS,\n node: SHAPE_DEFAULT_ATTRS,\n combo: SHAPE_DEFAULT_ATTRS\n};\nexport var CLS_LABEL_BG_SUFFIX = '-label-bg'; // 单个 shape 带有一个 label,共用这段代码\n\nexport var shapeBase = {\n // 默认样式及配置\n options: {},\n itemType: '',\n\n /**\n * 形状的类型,例如 circle,ellipse,polyline...\n */\n type: '',\n getCustomConfig: function getCustomConfig(cfg) {\n return {};\n },\n getOptions: function getOptions(cfg, updateType) {\n if (updateType === 'move' || updateType === 'bbox') {\n return {};\n }\n\n return deepMix({\n // 解决局部渲染导致的文字移动残影问题\n labelCfg: {\n style: {\n fontFamily: typeof window !== 'undefined' && window.getComputedStyle ? window.getComputedStyle(document.body, null).getPropertyValue('font-family') || 'Arial, sans-serif' : 'Arial, sans-serif'\n }\n },\n descriptionCfg: {\n style: {\n fontFamily: typeof window !== 'undefined' && window.getComputedStyle ? window.getComputedStyle(document.body, null).getPropertyValue('font-family') || 'Arial, sans-serif' : 'Arial, sans-serif'\n }\n }\n }, this.options, this.getCustomConfig(cfg) || {}, cfg);\n },\n\n /**\n * 绘制节点/边,包含文本\n * @override\n * @param {Object} cfg 节点的配置项\n * @param {G.Group} group 节点的容器\n * @return {IShape} 绘制的图形\n */\n draw: function draw(cfg, group) {\n var shape = this.drawShape(cfg, group);\n shape.set('className', this.itemType + CLS_SHAPE_SUFFIX);\n\n if (cfg.label) {\n var label = this.drawLabel(cfg, group);\n label.set('className', this.itemType + CLS_LABEL_SUFFIX);\n }\n\n return shape;\n },\n\n /**\n * 绘制完成后的操作,便于用户继承现有的节点、边\n * @param cfg\n * @param group\n * @param keyShape\n */\n afterDraw: function afterDraw(cfg, group, keyShape) {},\n drawShape: function drawShape(cfg, group) {\n return null;\n },\n drawLabel: function drawLabel(cfg, group) {\n var defaultLabelCfg = this.getOptions(cfg).labelCfg; // image的情况下有可能为null\n\n var labelCfg = defaultLabelCfg || {};\n var labelStyle = this.getLabelStyle(cfg, labelCfg, group);\n var rotate = labelStyle.rotate;\n delete labelStyle.rotate;\n var label = group.addShape('text', {\n attrs: labelStyle,\n draggable: true,\n className: 'text-shape',\n name: 'text-shape'\n });\n\n if (!isNaN(rotate) && rotate !== '') {\n var labelBBox = label.getBBox();\n var labelMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n\n if (labelStyle.rotateCenter) {\n switch (labelStyle.rotateCenter) {\n case 'center':\n labelMatrix = transform(labelMatrix, [['t', -labelBBox.width / 2, -labelBBox.height / 2], ['r', rotate], ['t', labelBBox.width / 2, labelBBox.height / 2]]);\n break;\n\n case 'lefttop':\n labelMatrix = transform(labelMatrix, [['t', -labelStyle.x, -labelStyle.y], ['r', rotate], ['t', labelStyle.x, labelStyle.y]]);\n break;\n\n case 'leftcenter':\n labelMatrix = transform(labelMatrix, [['t', -labelStyle.x, -labelStyle.y - labelBBox.height / 2], ['r', rotate], ['t', labelStyle.x, labelStyle.y + labelBBox.height / 2]]);\n break;\n\n default:\n labelMatrix = transform(labelMatrix, [['t', -labelBBox.width / 2, -labelBBox.height / 2], ['r', rotate], ['t', labelBBox.width / 2, labelBBox.height / 2]]);\n break;\n }\n } else {\n labelMatrix = transform(labelMatrix, [['t', -labelStyle.x, -labelStyle.y - labelBBox.height / 2], ['r', rotate], ['t', labelStyle.x, labelStyle.y + labelBBox.height / 2]]);\n }\n\n label.setMatrix(labelMatrix);\n }\n\n if (labelStyle.background) {\n var rect = this.drawLabelBg(cfg, group, label);\n var labelBgClassname = this.itemType + CLS_LABEL_BG_SUFFIX;\n rect.set('classname', labelBgClassname);\n label.toFront();\n }\n\n return label;\n },\n drawLabelBg: function drawLabelBg(cfg, group, label) {\n var defaultLabelCfg = this.options.labelCfg;\n var labelCfg = mix({}, defaultLabelCfg, cfg.labelCfg);\n var style = this.getLabelBgStyleByPosition(label, cfg, labelCfg, group);\n var rect = group.addShape('rect', {\n name: 'text-bg-shape',\n attrs: style\n });\n return rect;\n },\n getLabelStyleByPosition: function getLabelStyleByPosition(cfg, labelCfg, group) {\n return {\n text: cfg.label\n };\n },\n getLabelBgStyleByPosition: function getLabelBgStyleByPosition(label, cfg, labelCfg, group) {\n return {};\n },\n\n /**\n * 获取文本的配置项\n * @param cfg 节点的配置项\n * @param labelCfg 文本的配置项\n * @param group 父容器,label 的定位可能与图形相关\n */\n getLabelStyle: function getLabelStyle(cfg, labelCfg, group) {\n var calculateStyle = this.getLabelStyleByPosition(cfg, labelCfg, group);\n var attrName = this.itemType + \"Label\"; // 取 nodeLabel,edgeLabel 的配置项\n\n var defaultStyle = Global[attrName] ? Global[attrName].style : null;\n\n var labelStyle = __assign(__assign(__assign({}, defaultStyle), calculateStyle), labelCfg.style);\n\n return labelStyle;\n },\n\n /**\n * 获取图形的配置项\n * @param cfg\n */\n getShapeStyle: function getShapeStyle(cfg) {\n return cfg.style;\n },\n\n /**\n * 更新节点,包含文本\n * @override\n * @param {Object} cfg 节点/边的配置项\n * @param {G6.Item} item 节点/边\n */\n update: function update(cfg, item, updateType) {\n this.updateShapeStyle(cfg, item, updateType);\n this.updateLabel(cfg, item, updateType);\n },\n updateShapeStyle: function updateShapeStyle(cfg, item, updateType) {\n var group = item.getContainer();\n var shape = item.getKeyShape();\n var shapeStyle = mix({}, shape.attr(), cfg.style);\n\n var _loop_1 = function _loop_1(key) {\n var _a;\n\n var style = shapeStyle[key];\n\n if (isPlainObject(style)) {\n // 更新图元素样式,支持更新子元素\n var subShape = group.find(function (element) {\n return element.get('name') === key;\n });\n\n if (subShape) {\n subShape.attr(style);\n }\n } else {\n shape.attr((_a = {}, _a[key] = style, _a));\n }\n };\n\n for (var key in shapeStyle) {\n _loop_1(key);\n }\n },\n updateLabel: function updateLabel(cfg, item, updateType) {\n var group = item.getContainer();\n var defaultLabelCfg = this.getOptions({}, updateType).labelCfg;\n var labelClassName = this.itemType + CLS_LABEL_SUFFIX;\n var label = group.find(function (element) {\n return element.get('className') === labelClassName;\n });\n var labelBgClassname = this.itemType + CLS_LABEL_BG_SUFFIX;\n var labelBg = group.find(function (element) {\n return element.get('classname') === labelBgClassname;\n }); // 防止 cfg.label = \"\" 的情况\n\n if (cfg.label || cfg.label === '') {\n // 若传入的新配置中有 label,(用户没传入但原先有 label,label 也会有值)\n if (!label) {\n // 若原先不存在 label,则绘制一个新的 label\n var newLabel = this.drawLabel(cfg, group);\n newLabel.set('className', labelClassName);\n } else {\n // 若原先存在 label,则更新样式。与 getLabelStyle 不同在于这里需要融合当前 label 的样式\n // 用于融合 style 以外的属性:position, offset, ...\n var currentLabelCfg = {};\n\n if (item.getModel) {\n currentLabelCfg = item.getModel().labelCfg;\n } // 这里不能去掉\n\n\n var labelCfg = deepMix({}, defaultLabelCfg, currentLabelCfg, cfg.labelCfg); // 获取位置信息\n\n var calculateStyle = this.getLabelStyleByPosition(cfg, labelCfg, group); // 取 nodeLabel,edgeLabel 的配置项\n\n var cfgStyle = cfg.labelCfg ? cfg.labelCfg.style : undefined;\n var cfgBgStyle = labelCfg.style && labelCfg.style.background; // 需要融合当前\b label 的样式 label.attr()。不再需要全局/默认样式,因为已经应用在当前的 label 上\n\n var labelStyle = __assign(__assign(__assign({}, label.attr()), calculateStyle), cfgStyle);\n\n var rotate = labelStyle.rotate;\n delete labelStyle.rotate; // 计算 label 的旋转矩阵\n\n if (!isNaN(rotate) && rotate !== '') {\n // if G 4.x define the rotateAtStart, use it directly instead of using the following codes\n var rotateMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n rotateMatrix = transform(rotateMatrix, [['t', -labelStyle.x, -labelStyle.y], ['r', rotate], ['t', labelStyle.x, labelStyle.y]]);\n label.resetMatrix();\n label.attr(__assign(__assign({}, labelStyle), {\n matrix: rotateMatrix\n }));\n } else {\n label.resetMatrix();\n label.attr(labelStyle);\n }\n\n if (!labelBg) {\n if (labelStyle.background) {\n labelBg = this.drawLabelBg(cfg, group, label);\n labelBg.set('classname', labelBgClassname);\n label.toFront();\n }\n } else if (labelStyle.background) {\n var calculateBgStyle = this.getLabelBgStyleByPosition(label, cfg, labelCfg, group);\n\n var labelBgStyle = __assign(__assign({}, calculateBgStyle), cfgBgStyle);\n\n labelBg.resetMatrix();\n\n if (!isNaN(rotate) && rotate !== '') {\n var bgRotateMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n bgRotateMatrix = transform(bgRotateMatrix, [['t', -labelBgStyle.x, -labelBgStyle.y], ['r', rotate], ['t', labelBgStyle.x, labelBgStyle.y]]);\n labelBgStyle.matrix = bgRotateMatrix;\n }\n\n labelBg.attr(labelBgStyle);\n } else {\n group.removeChild(labelBg);\n }\n }\n }\n },\n // update(cfg, item) // 默认不定义\n afterUpdate: function afterUpdate(cfg, item) {},\n\n /**\n * 设置节点的状态,主要是交互状态,业务状态请在 draw 方法中实现\n * 单图形的节点仅考虑 selected、active 状态,有其他状态需求的用户自己复写这个方法\n * @override\n * @param {String} name 状态名称\n * @param {String | Boolean} value 状态值\n * @param {G6.Item} item 节点\n */\n setState: function setState(name, value, item) {\n var _a, _b;\n\n var shape = item.get('keyShape');\n if (!shape || shape.destroyed) return;\n var type = item.getType();\n var stateName = isBoolean(value) ? name : name + \":\" + value;\n var shapeStateStyle = this.getStateStyle(stateName, item);\n var itemStateStyle = item.getStateStyle(stateName); // const originStyle = item.getOriginStyle();\n // 不允许设置一个不存在的状态\n\n if (!itemStateStyle && !shapeStateStyle) {\n return;\n } // 要设置或取消的状态的样式\n // 当没有 state 状态时,默认使用 model.stateStyles 中的样式\n\n\n var styles = mix({}, itemStateStyle || shapeStateStyle);\n var group = item.getContainer(); // 从图元素现有的样式中删除本次要取消的 states 中存在的属性值。使用对象检索更快\n\n var keptAttrs = {\n x: 1,\n y: 1,\n cx: 1,\n cy: 1\n };\n\n if (type === 'combo') {\n keptAttrs.r = 1;\n keptAttrs.width = 1;\n keptAttrs.height = 1;\n }\n\n if (value) {\n var _loop_2 = function _loop_2(key) {\n var _c;\n\n var style = styles[key];\n\n if (isPlainObject(style) && !ARROWS.includes(key)) {\n var subShape = group.find(function (element) {\n return element.get('name') === key;\n });\n\n if (subShape) {\n subShape.attr(style);\n }\n } else {\n // 非纯对象,则认为是设置到 keyShape 上面的\n shape.attr((_c = {}, _c[key] = style, _c));\n }\n }; // style 为要设置的状态的样式\n\n\n for (var key in styles) {\n _loop_2(key);\n }\n } else {\n // 所有生效的 state 的样式\n var enableStatesStyle = cloneBesidesImg(item.getCurrentStatesStyle());\n var model = item.getModel(); // 原始样式\n\n var originStyle_1 = mix({}, model.style, cloneBesidesImg(item.getOriginStyle()));\n var keyShapeName_1 = shape.get('name'); // cloning shape.attr(), keys.forEach to avoid cloning the img attr, which leads to maximum clone heap #2383\n // const keyShapeStyles = clone(shape.attr())\n\n var shapeAttrs_1 = shape.attr();\n var keyShapeStyles_1 = {};\n Object.keys(shapeAttrs_1).forEach(function (key) {\n if (key === 'img') return;\n var attr = shapeAttrs_1[key];\n\n if (attr && _typeof(attr) === 'object') {\n keyShapeStyles_1[key] = clone(attr);\n } else {\n keyShapeStyles_1[key] = attr;\n }\n }); // 已有样式 - 要取消的状态的样式\n\n var filtetDisableStatesStyle = {};\n\n var _loop_3 = function _loop_3(p) {\n var style = styles[p];\n\n if (isPlainObject(style) && !ARROWS.includes(p)) {\n var subShape_1 = group.find(function (element) {\n return element.get('name') === p;\n });\n\n if (subShape_1) {\n var subShapeStyles_1 = cloneBesidesImg(subShape_1.attr());\n each(style, function (v, key) {\n if (p === keyShapeName_1 && keyShapeStyles_1[key] && !keptAttrs[key]) {\n delete keyShapeStyles_1[key];\n var value_1 = originStyle_1[p][key] || SHAPES_DEFAULT_ATTRS[type][key];\n shape.attr(key, value_1);\n } else if (subShapeStyles_1[key] || subShapeStyles_1[key] === 0) {\n delete subShapeStyles_1[key];\n var value_2 = originStyle_1[p][key] || SHAPES_DEFAULT_ATTRS[type][key];\n subShape_1.attr(key, value_2);\n }\n });\n filtetDisableStatesStyle[p] = subShapeStyles_1;\n }\n } else {\n if (keyShapeStyles_1[p] && !keptAttrs[p]) {\n delete keyShapeStyles_1[p];\n var value_3 = originStyle_1[p] || (originStyle_1[keyShapeName_1] ? originStyle_1[keyShapeName_1][p] : undefined) || SHAPES_DEFAULT_ATTRS[type][p];\n shape.attr(p, value_3);\n }\n }\n }; // styles 为要取消的状态的样式\n\n\n for (var p in styles) {\n _loop_3(p);\n } // 从图元素现有的样式中删除本次要取消的 states 中存在的属性值后,\n // 如果 keyShape 有 name 属性,则 filtetDisableStatesStyle 的格式为 { keyShapeName: {} }\n // 否则为普通对象\n\n\n if (!keyShapeName_1) {\n mix(filtetDisableStatesStyle, keyShapeStyles_1);\n } else {\n filtetDisableStatesStyle[keyShapeName_1] = keyShapeStyles_1;\n }\n\n for (var key in enableStatesStyle) {\n if (keptAttrs[key]) continue;\n var enableStyle = enableStatesStyle[key];\n\n if (!isPlainObject(enableStyle) || ARROWS.includes(key)) {\n // 把样式属性merge到keyShape中\n if (!keyShapeName_1) {\n mix(originStyle_1, (_a = {}, _a[key] = enableStyle, _a));\n } else {\n mix(originStyle_1[keyShapeName_1], (_b = {}, _b[key] = enableStyle, _b));\n delete originStyle_1[key];\n }\n\n delete enableStatesStyle[key];\n }\n }\n\n var originstyles = {};\n deepMix(originstyles, originStyle_1, filtetDisableStatesStyle, enableStatesStyle);\n var keyShapeSetted = false;\n\n var _loop_4 = function _loop_4(originKey) {\n var _d, _e;\n\n var style = originstyles[originKey];\n\n if (isPlainObject(style) && !ARROWS.includes(originKey)) {\n var subShape = group.find(function (element) {\n return element.get('name') === originKey;\n });\n\n if (subShape) {\n // The text's position and matrix is not allowed to be affected by states\n if (subShape.get('type') === 'text') {\n delete style.x;\n delete style.y;\n delete style.matrix;\n }\n\n if (originKey === keyShapeName_1) {\n if (type === 'combo') {\n delete style.r;\n delete style.width;\n delete style.height;\n }\n\n keyShapeSetted = true;\n }\n\n subShape.attr(style);\n }\n } else if (!keyShapeSetted) {\n var value_4 = style || SHAPES_DEFAULT_ATTRS[type][originKey]; // 当更新 combo 状态时,当不存在 keyShapeName 时候,则认为是设置到 keyShape 上面的\n\n if (type === 'combo') {\n if (!keyShapeName_1) {\n shape.attr((_d = {}, _d[originKey] = value_4, _d));\n }\n } else {\n shape.attr((_e = {}, _e[originKey] = value_4, _e));\n }\n }\n };\n\n for (var originKey in originstyles) {\n _loop_4(originKey);\n }\n }\n },\n\n /**\n * 获取不同状态下的样式\n *\n * @param {string} name 状态名称\n * @param {Item} item Node或Edge的实例\n * @return {object} 样式\n */\n getStateStyle: function getStateStyle(name, item) {\n var model = item.getModel();\n var type = item.getType();\n\n var _a = this.getOptions(model),\n stateStyles = _a.stateStyles,\n _b = _a.style,\n style = _b === void 0 ? {} : _b;\n\n var modelStateStyle = model.stateStyles ? model.stateStyles[name] : stateStyles && stateStyles[name];\n\n if (type === 'combo') {\n return clone(modelStateStyle);\n }\n\n return mix({}, style, modelStateStyle);\n },\n\n /**\n * 获取控制点\n * @param {Object} cfg 节点、边的配置项\n * @return {Array|null} 控制点的数组,如果为 null,则没有控制点\n */\n getControlPoints: function getControlPoints(cfg) {\n return cfg.controlPoints;\n },\n\n /**\n * 获取控制点\n * @param {Object} cfg 节点、边的配置项\n * @return {Array|null} 锚点的数组,如果为 null,则没有锚点\n */\n getAnchorPoints: function getAnchorPoints(cfg) {\n var _a, _b;\n\n var anchorPoints = (cfg === null || cfg === void 0 ? void 0 : cfg.anchorPoints) || ((_a = this.getCustomConfig(cfg)) === null || _a === void 0 ? void 0 : _a.anchorPoints) || ((_b = this.options) === null || _b === void 0 ? void 0 : _b.anchorPoints);\n return anchorPoints;\n }\n};","import { __assign } from \"tslib\";\nimport { isArray, isNil, mix } from '@antv/util';\nimport { formatPadding } from '../util/base';\nimport Global from '../global';\nimport Shape from './shape';\nimport { shapeBase } from './shapeBase';\nvar singleNode = {\n itemType: 'node',\n // 单个图形的类型\n shapeType: 'single-node',\n\n /**\n * 文本相对图形的位置,默认以中心点\n * 位置包括: top, bottom, left, right, center\n * @type {String}\n */\n labelPosition: 'center',\n\n /**\n * 文本相对偏移,当 labelPosition 不为 center 时有效\n * @type {Number}\n */\n offset: Global.nodeLabel.offset,\n\n /**\n * 获取节点宽高\n * @internal 返回节点的大小,以 [width, height] 的方式维护\n * @param {Object} cfg 节点的配置项\n * @return {Array} 宽高\n */\n getSize: function getSize(cfg) {\n var size = cfg.size || this.getOptions({}).size || Global.defaultNode.size; // size 是数组,但长度为1,则补长度为2\n\n if (isArray(size) && size.length === 1) {\n size = [size[0], size[0]];\n } // size 为数字,则转换为数组\n\n\n if (!isArray(size)) {\n size = [size, size];\n }\n\n return size;\n },\n // 私有方法,不希望扩展的节点复写这个方法\n getLabelStyleByPosition: function getLabelStyleByPosition(cfg, labelCfg) {\n var labelPosition = labelCfg.position || this.labelPosition; // 默认的位置(最可能的情形),所以放在最上面\n\n if (labelPosition === 'center') {\n return {\n x: 0,\n y: 0,\n text: cfg.label\n };\n }\n\n var offset = labelCfg.offset;\n\n if (isNil(offset)) {\n // 考虑 offset = 0 的场景,不用用 labelCfg.offset || Global.nodeLabel.offset\n offset = this.offset; // 不居中时的偏移量\n }\n\n var size = this.getSize(cfg);\n var width = size[0];\n var height = size[1];\n var style;\n\n switch (labelPosition) {\n case 'top':\n style = {\n x: 0,\n y: 0 - height / 2 - offset,\n textBaseline: 'bottom' // 文本在图形的上面\n\n };\n break;\n\n case 'bottom':\n style = {\n x: 0,\n y: height / 2 + offset,\n textBaseline: 'top'\n };\n break;\n\n case 'left':\n style = {\n x: 0 - width / 2 - offset,\n y: 0,\n textAlign: 'right'\n };\n break;\n\n default:\n style = {\n x: width / 2 + offset,\n y: 0,\n textAlign: 'left'\n };\n break;\n }\n\n style.text = cfg.label;\n return style;\n },\n getLabelBgStyleByPosition: function getLabelBgStyleByPosition(label, cfg, labelCfg, group) {\n if (!label) {\n return {};\n }\n\n var bbox = label.getBBox();\n var backgroundStyle = labelCfg.style && labelCfg.style.background;\n\n if (!backgroundStyle) {\n return {};\n }\n\n var padding = formatPadding(backgroundStyle.padding);\n var backgroundWidth = bbox.width + padding[1] + padding[3];\n var backgroundHeight = bbox.height + padding[0] + padding[2];\n var offset = labelCfg.offset;\n\n if (isNil(offset)) {\n // 考虑 offset = 0 的场景,不用用 labelCfg.offset || Global.nodeLabel.offset\n offset = this.offset; // 不居中时的偏移量\n }\n\n var style;\n style = {\n x: bbox.minX - padding[3],\n y: bbox.minY - padding[0]\n };\n style = __assign(__assign(__assign({}, style), backgroundStyle), {\n width: backgroundWidth,\n height: backgroundHeight\n });\n return style;\n },\n drawShape: function drawShape(cfg, group) {\n var shapeType = this.shapeType; // || this.type,都已经加了 shapeType\n\n var style = this.getShapeStyle(cfg);\n var shape = group.addShape(shapeType, {\n attrs: style,\n draggable: true,\n name: 'node-shape'\n });\n return shape;\n },\n\n /**\n * 更新linkPoints\n * @param {Object} cfg 节点数据配置项\n * @param {Group} group Item所在的group\n */\n updateLinkPoints: function updateLinkPoints(cfg, group) {\n var defaultLinkPoints = this.getOptions(cfg).linkPoints;\n var markLeft = group.find(function (element) {\n return element.get('className') === 'link-point-left';\n });\n var markRight = group.find(function (element) {\n return element.get('className') === 'link-point-right';\n });\n var markTop = group.find(function (element) {\n return element.get('className') === 'link-point-top';\n });\n var markBottom = group.find(function (element) {\n return element.get('className') === 'link-point-bottom';\n });\n var currentLinkPoints;\n\n if (markLeft) {\n currentLinkPoints = markLeft.attr();\n }\n\n if (markRight && !currentLinkPoints) {\n currentLinkPoints = markRight.attr();\n }\n\n if (markTop && !currentLinkPoints) {\n currentLinkPoints = markTop.attr();\n }\n\n if (markBottom && !currentLinkPoints) {\n currentLinkPoints = markBottom.attr();\n }\n\n if (!currentLinkPoints) currentLinkPoints = defaultLinkPoints;\n var linkPoints = mix({}, currentLinkPoints, cfg.linkPoints);\n var markFill = linkPoints.fill,\n markStroke = linkPoints.stroke,\n borderWidth = linkPoints.lineWidth;\n var markSize = linkPoints.size / 2;\n if (!markSize) markSize = linkPoints.r;\n\n var _a = cfg.linkPoints ? cfg.linkPoints : {\n left: undefined,\n right: undefined,\n top: undefined,\n bottom: undefined\n },\n left = _a.left,\n right = _a.right,\n top = _a.top,\n bottom = _a.bottom;\n\n var size = this.getSize(cfg);\n var width = size[0];\n var height = size[1];\n var styles = {\n r: markSize,\n fill: markFill,\n stroke: markStroke,\n lineWidth: borderWidth\n };\n\n if (markLeft) {\n if (!left && left !== undefined) {\n markLeft.remove();\n } else {\n markLeft.attr(__assign(__assign({}, styles), {\n x: -width / 2,\n y: 0\n }));\n }\n } else if (left) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: -width / 2,\n y: 0\n }),\n className: 'link-point-left',\n name: 'link-point-left',\n isAnchorPoint: true\n });\n }\n\n if (markRight) {\n if (!right && right !== undefined) {\n markRight.remove();\n }\n\n markRight.attr(__assign(__assign({}, styles), {\n x: width / 2,\n y: 0\n }));\n } else if (right) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: width / 2,\n y: 0\n }),\n className: 'link-point-right',\n name: 'link-point-right',\n isAnchorPoint: true\n });\n }\n\n if (markTop) {\n if (!top && top !== undefined) {\n markTop.remove();\n }\n\n markTop.attr(__assign(__assign({}, styles), {\n x: 0,\n y: -height / 2\n }));\n } else if (top) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: 0,\n y: -height / 2\n }),\n className: 'link-point-top',\n name: 'link-point-top',\n isAnchorPoint: true\n });\n }\n\n if (markBottom) {\n if (!bottom && bottom !== undefined) {\n markBottom.remove();\n } else {\n markBottom.attr(__assign(__assign({}, styles), {\n x: 0,\n y: height / 2\n }));\n }\n } else if (bottom) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: 0,\n y: height / 2\n }),\n className: 'link-point-bottom',\n name: 'link-point-bottom',\n isAnchorPoint: true\n });\n }\n },\n updateShape: function updateShape(cfg, item, keyShapeStyle, hasIcon) {\n var keyShape = item.get('keyShape');\n keyShape.attr(__assign({}, keyShapeStyle));\n this.updateLabel(cfg, item); // special for some types of nodes\n\n if (hasIcon) {\n this.updateIcon(cfg, item);\n }\n },\n updateIcon: function updateIcon(cfg, item) {\n var _this = this;\n\n var group = item.getContainer();\n var icon = this.getOptions(cfg).icon;\n var show = (cfg.icon ? cfg.icon : {\n show: undefined\n }).show;\n var iconShape = group.find(function (element) {\n return element.get('className') === _this.type + \"-icon\";\n });\n\n if (iconShape) {\n // 若原先存在 icon\n if (show || show === undefined) {\n // 若传入 show: true, 或没有设置,则更新原有的 icon 样式\n var iconConfig = mix({}, iconShape.attr(), icon);\n var _a = iconConfig.width,\n w = _a === void 0 ? 20 : _a,\n _b = iconConfig.height,\n h = _b === void 0 ? 20 : _b;\n iconShape.attr(__assign(__assign({}, iconConfig), {\n x: -w / 2,\n y: -h / 2\n }));\n } else {\n // 若传入了 show: false 则删除原先的 icon\n iconShape.remove();\n }\n } else if (show) {\n // 如果原先不存在 icon,但传入了 show: true,则新增 icon\n var w = icon.width,\n h = icon.height;\n group.addShape('image', {\n attrs: __assign(__assign({}, icon), {\n x: -w / 2,\n y: -h / 2\n }),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\"\n }); // to ensure the label is on the top of all the shapes\n\n var labelShape = group.find(function (element) {\n return element.get('className') === \"node-label\";\n });\n\n if (labelShape) {\n labelShape.toFront();\n }\n }\n }\n};\n\nvar singleNodeDef = __assign(__assign({}, shapeBase), singleNode);\n\nShape.registerNode('single-node', singleNodeDef);","/**\n * @fileOverview 自定义边\n * @description 自定义边中有大量逻辑同自定义节点重复,虽然可以提取成为 mixin ,但是考虑到代码的可读性,还是单独实现。\n */\nimport { __assign } from \"tslib\";\nimport { deepMix, mix, each, isNil, isNumber, isArray } from '@antv/util';\nimport { getLabelPosition, getLoopCfgs } from '../util/graphic';\nimport { distance, getCircleCenterByPoints } from '../util/math';\nimport { getControlPoint, getSpline } from '../util/path';\nimport Global from '../global';\nimport Shape from './shape';\nimport { shapeBase, CLS_LABEL_BG_SUFFIX } from './shapeBase';\nvar CLS_SHAPE = 'edge-shape'; // start,end 倒置,center 不变\n\nfunction revertAlign(labelPosition) {\n var textAlign = labelPosition;\n\n if (labelPosition === 'start') {\n textAlign = 'end';\n } else if (labelPosition === 'end') {\n textAlign = 'start';\n }\n\n return textAlign;\n}\n\nvar singleEdge = {\n itemType: 'edge',\n\n /**\n * 文本的位置\n * @type {String}\n */\n labelPosition: 'center',\n\n /**\n * 文本的 x 偏移\n * @type {Number}\n */\n refX: 0,\n\n /**\n * 文本的 y 偏移\n * @type {Number}\n */\n refY: 0,\n\n /**\n * 文本是否跟着线自动旋转,默认 false\n * @type {Boolean}\n */\n labelAutoRotate: false,\n // 自定义边时的配置\n options: {\n size: Global.defaultEdge.size,\n style: {\n x: 0,\n y: 0,\n stroke: Global.defaultEdge.style.stroke,\n lineAppendWidth: Global.defaultEdge.style.lineAppendWidth\n },\n labelCfg: {\n style: {\n fill: Global.edgeLabel.style.fill,\n fontSize: Global.edgeLabel.style.fontSize\n }\n },\n stateStyles: __assign({}, Global.edgeStateStyles)\n },\n\n /**\n * 获取边的 path\n * @internal 供扩展的边覆盖\n * @param {Array} points 构成边的点的集合\n * @return {Array} 构成 path 的数组\n */\n getPath: function getPath(points) {\n var path = [];\n each(points, function (point, index) {\n if (index === 0) {\n path.push(['M', point.x, point.y]);\n } else {\n path.push(['L', point.x, point.y]);\n }\n });\n return path;\n },\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.options.style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = mix({}, defaultStyle, strokeStyle, cfg.style);\n var size = cfg.size || Global.defaultEdge.size;\n cfg = this.getPathPoints(cfg);\n var startPoint = cfg.startPoint,\n endPoint = cfg.endPoint;\n var controlPoints = this.getControlPoints(cfg);\n var points = [startPoint]; // 添加起始点\n // 添加控制点\n\n if (controlPoints) {\n points = points.concat(controlPoints);\n } // 添加结束点\n\n\n points.push(endPoint);\n var path = this.getPath(points);\n var styles = mix({}, Global.defaultEdge.style, {\n stroke: Global.defaultEdge.color,\n lineWidth: size,\n path: path\n }, style);\n return styles;\n },\n updateShapeStyle: function updateShapeStyle(cfg, item, updateType) {\n var _a;\n\n var group = item.getContainer();\n var strokeStyle = {\n stroke: cfg.color\n };\n var shape = ((_a = item.getKeyShape) === null || _a === void 0 ? void 0 : _a.call(item)) || group.find(function (element) {\n return element.get('className') === 'edge-shape';\n });\n var size = cfg.size;\n cfg = this.getPathPoints(cfg);\n var startPoint = cfg.startPoint,\n endPoint = cfg.endPoint;\n var controlPoints = this.getControlPoints(cfg); // || cfg.controlPoints;\n\n var points = [startPoint]; // 添加起始点\n // 添加控制点\n\n if (controlPoints) {\n points = points.concat(controlPoints);\n } // 添加结束点\n\n\n points.push(endPoint);\n var currentAttr = shape.attr();\n var previousStyle = mix({}, strokeStyle, currentAttr, cfg.style);\n var source = cfg.sourceNode;\n var target = cfg.targetNode;\n var routeCfg = {\n radius: previousStyle.radius\n };\n\n if (!controlPoints) {\n routeCfg = {\n source: source,\n target: target,\n offset: previousStyle.offset,\n radius: previousStyle.radius\n };\n }\n\n var path = this.getPath(points, routeCfg);\n var style = {};\n\n if (updateType === 'move') {\n style = {\n path: path\n };\n } else {\n if (currentAttr.endArrow && previousStyle.endArrow === false) {\n cfg.style.endArrow = {\n path: ''\n };\n }\n\n if (currentAttr.startArrow && previousStyle.startArrow === false) {\n cfg.style.startArrow = {\n path: ''\n };\n }\n\n style = mix(strokeStyle, currentAttr, {\n lineWidth: size,\n path: path\n }, cfg.style);\n }\n\n if (shape) {\n shape.attr(style);\n }\n },\n getLabelStyleByPosition: function getLabelStyleByPosition(cfg, labelCfg, group) {\n var labelPosition = labelCfg.position || this.labelPosition; // 文本的位置用户可以传入\n\n var style = {};\n var pathShape = group && group.find(function (element) {\n return element.get('className') === CLS_SHAPE;\n }); // 不对 pathShape 进行判空,如果线不存在,说明有问题了\n\n var pointPercent;\n\n if (labelPosition === 'start') {\n pointPercent = 0;\n } else if (labelPosition === 'end') {\n pointPercent = 1;\n } else {\n pointPercent = 0.5;\n } // 偏移量\n\n\n var offsetX = labelCfg.refX || this.refX;\n var offsetY = labelCfg.refY || this.refY; // 如果两个节点重叠,线就变成了一个点,这时候label的位置,就是这个点 + 绝对偏移\n\n if (cfg.startPoint.x === cfg.endPoint.x && cfg.startPoint.y === cfg.endPoint.y) {\n style.x = cfg.startPoint.x + offsetX;\n style.y = cfg.startPoint.y + offsetY;\n style.text = cfg.label;\n return style;\n }\n\n var autoRotate;\n if (isNil(labelCfg.autoRotate)) autoRotate = this.labelAutoRotate;else autoRotate = labelCfg.autoRotate;\n var offsetStyle = getLabelPosition(pathShape, pointPercent, offsetX, offsetY, autoRotate);\n style.x = offsetStyle.x;\n style.y = offsetStyle.y;\n style.rotate = offsetStyle.rotate;\n style.textAlign = this._getTextAlign(labelPosition, offsetStyle.angle);\n style.text = cfg.label;\n return style;\n },\n getLabelBgStyleByPosition: function getLabelBgStyleByPosition(label, cfg, labelCfg, group) {\n if (!label) {\n return {};\n }\n\n var bbox = label.getBBox();\n var backgroundStyle = labelCfg.style && labelCfg.style.background;\n\n if (!backgroundStyle) {\n return {};\n }\n\n var padding = backgroundStyle.padding;\n var backgroundWidth = bbox.width + padding[1] + padding[3];\n var backgroundHeight = bbox.height + padding[0] + padding[2];\n var labelPosition = labelCfg.position || this.labelPosition;\n\n var style = __assign(__assign({}, backgroundStyle), {\n width: backgroundWidth,\n height: backgroundHeight,\n x: bbox.minX - padding[2],\n y: bbox.minY - padding[0],\n rotate: 0\n });\n\n var autoRotate;\n if (isNil(labelCfg.autoRotate)) autoRotate = this.labelAutoRotate;else autoRotate = labelCfg.autoRotate;\n var pathShape = group && group.find(function (element) {\n return element.get('className') === CLS_SHAPE;\n }); // 不对 pathShape 进行判空,如果线不存在,说明有问题了\n\n var pointPercent;\n\n if (labelPosition === 'start') {\n pointPercent = 0;\n } else if (labelPosition === 'end') {\n pointPercent = 1;\n } else {\n pointPercent = 0.5;\n } // 偏移量\n\n\n var offsetX = labelCfg.refX || this.refX;\n var offsetY = labelCfg.refY || this.refY; // // 如果两个节点重叠,线就变成了一个点,这时候label的位置,就是这个点 + 绝对偏移\n\n if (cfg.startPoint.x === cfg.endPoint.x && cfg.startPoint.y === cfg.endPoint.y) {\n style.x = cfg.startPoint.x + offsetX - backgroundWidth / 2;\n style.y = cfg.startPoint.y + offsetY - backgroundHeight / 2;\n return style;\n }\n\n var bgOffsetX = offsetX - backgroundWidth / 2;\n\n if (labelCfg.position === 'start') {\n bgOffsetX = offsetX - padding[2];\n } else if (labelCfg.position === 'end') {\n bgOffsetX = offsetX - backgroundWidth;\n }\n\n var offsetStyle = getLabelPosition(pathShape, pointPercent, bgOffsetX, offsetY + backgroundHeight / 2, autoRotate);\n\n if (autoRotate) {\n style.x = offsetStyle.x;\n style.y = offsetStyle.y;\n }\n\n style.rotate = offsetStyle.rotate;\n return style;\n },\n // 获取文本对齐方式\n _getTextAlign: function _getTextAlign(labelPosition, angle) {\n var textAlign = 'center';\n\n if (!angle) {\n return labelPosition;\n }\n\n angle = angle % (Math.PI * 2); // 取模\n\n if (labelPosition !== 'center') {\n if (angle >= 0 && angle <= Math.PI / 2 || angle >= 3 / 2 * Math.PI && angle < 2 * Math.PI) {\n textAlign = labelPosition;\n } else {\n textAlign = revertAlign(labelPosition);\n }\n }\n\n return textAlign;\n },\n\n /**\n * @internal 获取边的控制点\n * @param {Object} cfg 边的配置项\n * @return {Array} 控制点的数组\n */\n getControlPoints: function getControlPoints(cfg) {\n return cfg.controlPoints;\n },\n\n /**\n * @internal 处理需要重计算点和边的情况\n * @param {Object} cfg 边的配置项\n * @return {Object} 边的配置项\n */\n getPathPoints: function getPathPoints(cfg) {\n return cfg;\n },\n\n /**\n * 绘制边\n * @override\n * @param {Object} cfg 边的配置项\n * @param {G.Group} group 边的容器\n * @return {IShape} 图形\n */\n drawShape: function drawShape(cfg, group) {\n var shapeStyle = this.getShapeStyle(cfg);\n var shape = group.addShape('path', {\n className: CLS_SHAPE,\n name: CLS_SHAPE,\n attrs: shapeStyle\n });\n return shape;\n },\n drawLabel: function drawLabel(cfg, group) {\n var defaultLabelCfg = this.options.labelCfg;\n var defaultFontFamily;\n if (typeof window !== 'undefined' && typeof window.getComputedStyle !== 'undefined') defaultFontFamily = window.getComputedStyle(document.body, null).getPropertyValue('font-family') || 'Arial, sans-serif';else defaultFontFamily = 'Arial, sans-serif';\n var labelCfg = deepMix({\n fontFamily: defaultFontFamily\n }, defaultLabelCfg, cfg.labelCfg);\n var labelStyle = this.getLabelStyle(cfg, labelCfg, group);\n var rotate = labelStyle.rotate;\n delete labelStyle.rotate;\n var label = group.addShape('text', {\n attrs: labelStyle,\n name: 'text-shape'\n });\n\n if (!isNaN(rotate) && rotate !== '') {\n label.rotateAtStart(rotate);\n }\n\n if (labelStyle.background) {\n var rect = this.drawLabelBg(cfg, group, label, labelStyle, rotate);\n var labelBgClassname = this.itemType + CLS_LABEL_BG_SUFFIX;\n rect.set('classname', labelBgClassname);\n label.toFront();\n }\n\n return label;\n },\n drawLabelBg: function drawLabelBg(cfg, group, label, labelStyle, rotate) {\n var defaultLabelCfg = this.options.labelCfg;\n var labelCfg = deepMix({}, defaultLabelCfg, cfg.labelCfg);\n var style = this.getLabelBgStyleByPosition(label, cfg, labelCfg, group);\n delete style.rotate;\n var rect = group.addShape('rect', {\n name: 'text-bg-shape',\n attrs: style\n });\n if (!isNaN(rotate)) rect.rotateAtStart(rotate);\n return rect;\n }\n};\n\nvar singleEdgeDef = __assign(__assign({}, shapeBase), singleEdge);\n\nShape.registerEdge('single-edge', singleEdgeDef); // 直线, 不支持控制点\n\nShape.registerEdge('line', {\n // 控制点不生效\n getControlPoints: function getControlPoints() {\n return undefined;\n }\n}, 'single-edge'); // 直线\n\nShape.registerEdge('spline', {\n getPath: function getPath(points) {\n var path = getSpline(points);\n return path;\n }\n}, 'single-edge');\nShape.registerEdge('arc', {\n curveOffset: 20,\n clockwise: 1,\n getControlPoints: function getControlPoints(cfg) {\n var startPoint = cfg.startPoint,\n endPoint = cfg.endPoint;\n var midPoint = {\n x: (startPoint.x + endPoint.x) / 2,\n y: (startPoint.y + endPoint.y) / 2\n };\n var center;\n var arcPoint; // 根据给定点计算圆弧\n\n if (cfg.controlPoints !== undefined) {\n arcPoint = cfg.controlPoints[0];\n center = getCircleCenterByPoints(startPoint, arcPoint, endPoint); // 根据控制点和直线关系决定 clockwise值\n\n if (startPoint.x <= endPoint.x && startPoint.y > endPoint.y) {\n this.clockwise = center.x > arcPoint.x ? 0 : 1;\n } else if (startPoint.x <= endPoint.x && startPoint.y < endPoint.y) {\n this.clockwise = center.x > arcPoint.x ? 1 : 0;\n } else if (startPoint.x > endPoint.x && startPoint.y <= endPoint.y) {\n this.clockwise = center.y < arcPoint.y ? 0 : 1;\n } else {\n this.clockwise = center.y < arcPoint.y ? 1 : 0;\n } // 若给定点和两端点共线,无法生成圆弧,绘制直线\n\n\n if ((arcPoint.x - startPoint.x) / (arcPoint.y - startPoint.y) === (endPoint.x - startPoint.x) / (endPoint.y - startPoint.y)) {\n return [];\n }\n } else {\n // 根据直线连线中点的的偏移计算圆弧\n // 若用户给定偏移量则根据其计算,否则按照默认偏移值计算\n if (cfg.curveOffset === undefined) {\n cfg.curveOffset = this.curveOffset;\n }\n\n if (isArray(cfg.curveOffset)) {\n cfg.curveOffset = cfg.curveOffset[0];\n }\n\n if (cfg.curveOffset < 0) {\n this.clockwise = 0;\n } else {\n this.clockwise = 1;\n }\n\n var vec = {\n x: endPoint.x - startPoint.x,\n y: endPoint.y - startPoint.y\n };\n var edgeAngle = Math.atan2(vec.y, vec.x);\n arcPoint = {\n x: cfg.curveOffset * Math.cos(-Math.PI / 2 + edgeAngle) + midPoint.x,\n y: cfg.curveOffset * Math.sin(-Math.PI / 2 + edgeAngle) + midPoint.y\n };\n center = getCircleCenterByPoints(startPoint, arcPoint, endPoint);\n }\n\n var radius = distance(startPoint, center);\n var controlPoints = [{\n x: radius,\n y: radius\n }];\n return controlPoints;\n },\n getPath: function getPath(points) {\n var path = [];\n path.push(['M', points[0].x, points[0].y]); // 控制点与端点共线\n\n if (points.length === 2) {\n path.push(['L', points[1].x, points[1].y]);\n } else {\n path.push(['A', points[1].x, points[1].y, 0, 0, this.clockwise, points[2].x, points[2].y]);\n }\n\n return path;\n }\n}, 'single-edge');\nShape.registerEdge('quadratic', {\n curvePosition: 0.5,\n curveOffset: -20,\n getControlPoints: function getControlPoints(cfg) {\n var controlPoints = cfg.controlPoints; // 指定controlPoints\n\n if (!controlPoints || !controlPoints.length) {\n var startPoint = cfg.startPoint,\n endPoint = cfg.endPoint;\n if (cfg.curveOffset === undefined) cfg.curveOffset = this.curveOffset;\n if (cfg.curvePosition === undefined) cfg.curvePosition = this.curvePosition;\n if (isArray(this.curveOffset)) cfg.curveOffset = cfg.curveOffset[0];\n if (isArray(this.curvePosition)) cfg.curvePosition = cfg.curveOffset[0];\n var innerPoint = getControlPoint(startPoint, endPoint, cfg.curvePosition, cfg.curveOffset);\n controlPoints = [innerPoint];\n }\n\n return controlPoints;\n },\n getPath: function getPath(points) {\n var path = [];\n path.push(['M', points[0].x, points[0].y]);\n path.push(['Q', points[1].x, points[1].y, points[2].x, points[2].y]);\n return path;\n }\n}, 'single-edge');\nShape.registerEdge('cubic', {\n curvePosition: [1 / 2, 1 / 2],\n curveOffset: [-20, 20],\n getControlPoints: function getControlPoints(cfg) {\n var controlPoints = cfg.controlPoints; // 指定 controlPoints\n\n if (cfg.curveOffset === undefined) cfg.curveOffset = this.curveOffset;\n if (cfg.curvePosition === undefined) cfg.curvePosition = this.curvePosition;\n if (isNumber(cfg.curveOffset)) cfg.curveOffset = [cfg.curveOffset, -cfg.curveOffset];\n if (isNumber(cfg.curvePosition)) cfg.curvePosition = [cfg.curvePosition, 1 - cfg.curvePosition];\n\n if (!controlPoints || !controlPoints.length || controlPoints.length < 2) {\n var startPoint = cfg.startPoint,\n endPoint = cfg.endPoint;\n var innerPoint1 = getControlPoint(startPoint, endPoint, cfg.curvePosition[0], cfg.curveOffset[0]);\n var innerPoint2 = getControlPoint(startPoint, endPoint, cfg.curvePosition[1], cfg.curveOffset[1]);\n controlPoints = [innerPoint1, innerPoint2];\n }\n\n return controlPoints;\n },\n getPath: function getPath(points) {\n var path = [];\n path.push(['M', points[0].x, points[0].y]);\n path.push(['C', points[1].x, points[1].y, points[2].x, points[2].y, points[3].x, points[3].y]);\n return path;\n }\n}, 'single-edge'); // 垂直方向的三阶贝塞尔曲线,不再考虑用户外部传入的控制点\n\nShape.registerEdge('cubic-vertical', {\n curvePosition: [1 / 2, 1 / 2],\n minCurveOffset: [0, 0],\n curveOffset: undefined,\n getControlPoints: function getControlPoints(cfg) {\n var startPoint = cfg.startPoint,\n endPoint = cfg.endPoint;\n if (cfg.curvePosition === undefined) cfg.curvePosition = this.curvePosition;\n if (cfg.curveOffset === undefined) cfg.curveOffset = this.curveOffset;\n if (cfg.minCurveOffset === undefined) cfg.minCurveOffset = this.minCurveOffset;\n if (isNumber(cfg.curveOffset)) cfg.curveOffset = [cfg.curveOffset, -cfg.curveOffset];\n if (isNumber(cfg.minCurveOffset)) cfg.minCurveOffset = [cfg.minCurveOffset, -cfg.minCurveOffset];\n if (isNumber(cfg.curvePosition)) cfg.curvePosition = [cfg.curvePosition, 1 - cfg.curvePosition];\n var yDist = endPoint.y - startPoint.y;\n var curveOffset = [0, 0];\n\n if (cfg.curveOffset) {\n curveOffset = cfg.curveOffset;\n } else if (Math.abs(yDist) < Math.abs(cfg.minCurveOffset[0])) {\n curveOffset = cfg.minCurveOffset;\n }\n\n var innerPoint1 = {\n x: startPoint.x,\n y: startPoint.y + yDist * this.curvePosition[0] + curveOffset[0]\n };\n var innerPoint2 = {\n x: endPoint.x,\n y: endPoint.y - yDist * this.curvePosition[1] + curveOffset[1]\n };\n return [innerPoint1, innerPoint2];\n }\n}, 'cubic'); // 水平方向的三阶贝塞尔曲线,不再考虑用户外部传入的控制点\n\nShape.registerEdge('cubic-horizontal', {\n curvePosition: [1 / 2, 1 / 2],\n minCurveOffset: [0, 0],\n curveOffset: undefined,\n getControlPoints: function getControlPoints(cfg) {\n var startPoint = cfg.startPoint,\n endPoint = cfg.endPoint;\n if (cfg.curvePosition === undefined) cfg.curvePosition = this.curvePosition;\n if (cfg.curveOffset === undefined) cfg.curveOffset = this.curveOffset;\n if (cfg.minCurveOffset === undefined) cfg.minCurveOffset = this.minCurveOffset;\n if (isNumber(cfg.curveOffset)) cfg.curveOffset = [cfg.curveOffset, -cfg.curveOffset];\n if (isNumber(cfg.minCurveOffset)) cfg.minCurveOffset = [cfg.minCurveOffset, -cfg.minCurveOffset];\n if (isNumber(cfg.curvePosition)) cfg.curvePosition = [cfg.curvePosition, 1 - cfg.curvePosition];\n var xDist = endPoint.x - startPoint.x;\n var curveOffset = [0, 0];\n\n if (cfg.curveOffset) {\n curveOffset = cfg.curveOffset;\n } else if (Math.abs(xDist) < Math.abs(cfg.minCurveOffset[0])) {\n curveOffset = cfg.minCurveOffset;\n }\n\n var innerPoint1 = {\n x: startPoint.x + xDist * this.curvePosition[0] + curveOffset[0],\n y: startPoint.y\n };\n var innerPoint2 = {\n x: endPoint.x - xDist * this.curvePosition[1] + curveOffset[1],\n y: endPoint.y\n };\n var controlPoints = [innerPoint1, innerPoint2];\n return controlPoints;\n }\n}, 'cubic');\nShape.registerEdge('loop', {\n getPathPoints: function getPathPoints(cfg) {\n return getLoopCfgs(cfg);\n },\n getControlPoints: function getControlPoints(cfg) {\n return cfg.controlPoints;\n },\n afterDraw: function afterDraw(cfg) {\n cfg.controlPoints = undefined;\n },\n afterUpdate: function afterUpdate(cfg) {\n cfg.controlPoints = undefined;\n }\n}, 'cubic');","import { __assign } from \"tslib\";\nimport { isArray, isNil, clone } from '@antv/util';\nimport Global from '../global';\nimport Shape from './shape';\nimport { shapeBase } from './shapeBase';\nvar singleCombo = {\n itemType: 'combo',\n // 单个图形的类型\n shapeType: 'single-combo',\n\n /**\n * Combo 标题文本相对图形的位置,默认为 top\n * 位置包括: top, bottom, left, right, center\n * @type {String}\n */\n labelPosition: 'top',\n\n /**\n * 标题文本相对偏移,当 labelPosition 不为 center 时有效\n * @type {Number}\n */\n refX: Global.comboLabel.refX,\n refY: Global.comboLabel.refY,\n options: {\n style: {\n stroke: Global.defaultCombo.style.stroke,\n fill: Global.defaultCombo.style.fill,\n lineWidth: Global.defaultCombo.style.lineWidth\n },\n labelCfg: {\n style: {\n fill: Global.comboLabel.style.fill,\n fontSize: Global.comboLabel.style.fontSize\n }\n },\n stateStyles: __assign({}, Global.comboStateStyles)\n },\n\n /**\n * 获取 Combo 宽高\n * @internal 返回 Combo 的大小,以 [width, height] 的方式维护\n * @param {Object} cfg Combo 的配置项\n * @return {Array} 宽高\n */\n getSize: function getSize(cfg) {\n var size = clone(cfg.size || this.options.size || Global.defaultCombo.size); // size 是数组,若长度为 1,则补长度为 2\n\n if (isArray(size) && size.length === 1) {\n size = [size[0], size[0]];\n } // size 为数字,则转换为数组\n\n\n if (!isArray(size)) {\n size = [size, size];\n }\n\n return size;\n },\n // 私有方法,不希望扩展的 Combo 复写这个方法\n getLabelStyleByPosition: function getLabelStyleByPosition(cfg, labelCfg) {\n var labelPosition = labelCfg.position || this.labelPosition;\n var cfgStyle = cfg.style;\n var padding = cfg.padding || this.options.padding;\n if (isArray(padding)) padding = padding[0];\n var refX = labelCfg.refX,\n refY = labelCfg.refY; // 考虑 refX 和 refY = 0 的场景,不用用 labelCfg.refX || Global.nodeLabel.refX\n\n if (isNil(refX)) {\n refX = this.refX; // 不居中时的偏移量\n }\n\n if (isNil(refY)) {\n refY = this.refY; // 不居中时的偏移量\n }\n\n var size = this.getSize(cfg);\n var r = Math.max(cfgStyle.r, size[0] / 2) || size[0] / 2;\n var dis = r + padding;\n var style;\n\n switch (labelPosition) {\n case 'top':\n style = {\n x: 0,\n y: -dis - refY,\n textBaseline: 'bottom',\n textAlign: 'center'\n };\n break;\n\n case 'bottom':\n style = {\n x: 0,\n y: dis + refY,\n textBaseline: 'bottom',\n textAlign: 'center'\n };\n break;\n\n case 'left':\n style = {\n x: -dis + refX,\n y: 0,\n textAlign: 'left'\n };\n break;\n\n case 'center':\n style = {\n x: 0,\n y: 0,\n text: cfg.label,\n textAlign: 'center'\n };\n break;\n\n default:\n style = {\n x: dis + refX,\n y: 0,\n textAlign: 'right'\n };\n break;\n }\n\n style.text = cfg.label;\n return style;\n },\n drawShape: function drawShape(cfg, group) {\n var shapeType = this.shapeType; // || this.type,都已经加了 shapeType\n\n var style = this.getShapeStyle(cfg);\n var shape = group.addShape(shapeType, {\n attrs: style,\n draggable: true,\n name: 'combo-shape'\n });\n return shape;\n },\n updateShape: function updateShape(cfg, item, keyShapeStyle) {\n var keyShape = item.get('keyShape');\n var animate = cfg.animate === undefined ? this.options.animate : cfg.animate;\n\n if (animate && keyShape.animate) {\n keyShape.animate(keyShapeStyle, {\n duration: 200,\n easing: 'easeLinear'\n });\n } else {\n keyShape.attr(__assign({}, keyShapeStyle));\n }\n\n this.updateLabel(cfg, item); // special for some types of nodes\n }\n};\n\nvar singleComboDef = __assign(__assign({}, shapeBase), singleCombo);\n\nShape.registerCombo('single-combo', singleComboDef);","import { __assign } from \"tslib\";\nimport Global from '../../global';\nimport Shape from '../shape';\nimport { isNumber, clone, mix, isArray } from '@antv/util'; // 圆形 Combo\n\nShape.registerCombo('circle', {\n // 自定义节点时的配置\n options: {\n size: [Global.defaultCombo.size[0], Global.defaultCombo.size[0]],\n padding: Global.defaultCombo.padding[0],\n animate: true,\n style: {\n stroke: Global.defaultCombo.style.stroke,\n fill: Global.defaultCombo.style.fill,\n lineWidth: Global.defaultCombo.style.lineWidth\n },\n labelCfg: {\n style: {\n fill: Global.comboLabel.style.fill,\n fontSize: Global.comboLabel.style.fontSize\n },\n refX: 0,\n refY: 0\n },\n stateStyles: __assign({}, Global.comboStateStyles)\n },\n shapeType: 'circle',\n // 文本位置\n labelPosition: 'top',\n drawShape: function drawShape(cfg, group) {\n var style = this.getShapeStyle(cfg);\n delete style.height;\n delete style.width;\n var keyShape = group.addShape('circle', {\n attrs: style,\n className: 'circle-combo',\n name: 'circle-combo',\n draggable: true\n });\n return keyShape;\n },\n\n /**\n * 获取 Combo 的样式,供基于该 Combo 自定义时使用\n * @param {Object} cfg Combo 数据模型\n * @return {Object} Combo 的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.options.style;\n var padding = cfg.padding || this.options.padding;\n if (isArray(padding)) padding = padding[0];\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = mix({}, defaultStyle, strokeStyle, cfg.style);\n var r;\n\n if (cfg.fixSize) {\n r = isNumber(cfg.fixSize) ? cfg.fixSize : cfg.fixSize[0];\n } else {\n var size = this.getSize(cfg);\n if (!isNumber(style.r) || isNaN(style.r)) r = size[0] / 2 || Global.defaultCombo.style.r;else r = Math.max(style.r, size[0] / 2) || size[0] / 2;\n }\n\n style.r = r + padding;\n\n var styles = __assign({\n x: 0,\n y: 0\n }, style);\n\n if (cfg.style) cfg.style.r = r;else {\n cfg.style = {\n r: r\n };\n }\n return styles;\n },\n update: function update(cfg, item) {\n var size = this.getSize(cfg);\n var padding = cfg.padding || this.options.padding;\n if (isArray(padding)) padding = padding[0];\n var cfgStyle = clone(cfg.style);\n var r;\n\n if (cfg.fixSize) {\n r = isNumber(cfg.fixSize) ? cfg.fixSize : cfg.fixSize[0];\n } else {\n r = Math.max(cfgStyle.r, size[0] / 2) || size[0] / 2;\n }\n\n cfgStyle.r = r + padding;\n var itemCacheSize = item.get('sizeCache');\n\n if (itemCacheSize) {\n itemCacheSize.r = cfgStyle.r;\n } // 下面这些属性需要覆盖默认样式与目前样式,但若在 cfg 中有指定则应该被 cfg 的相应配置覆盖。\n\n\n var strokeStyle = {\n stroke: cfg.color\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var keyShape = item.get('keyShape');\n var style = mix({}, keyShape.attr(), strokeStyle, cfgStyle);\n if (cfg.style) cfg.style.r = r;else {\n cfg.style = {\n r: r\n };\n }\n this.updateShape(cfg, item, style, true);\n }\n}, 'single-combo');","import { __assign } from \"tslib\";\nimport { mix, isNumber, clone, isNil } from '@antv/util';\nimport Global from '../../global';\nimport Shape from '../shape';\nShape.registerCombo('rect', {\n // 自定义 Combo 时的配置\n options: {\n size: [40, 5],\n padding: [25, 20, 15, 20],\n animate: true,\n style: {\n radius: 0,\n stroke: Global.defaultCombo.style.stroke,\n fill: Global.defaultCombo.style.fill,\n lineWidth: Global.defaultCombo.style.lineWidth\n },\n // 文本样式配置\n labelCfg: {\n style: {\n fill: Global.comboLabel.style.fill,\n fontSize: Global.comboLabel.style.fontSize\n }\n },\n // 连接点,默认为左右\n anchorPoints: [[0, 0.5], [1, 0.5]],\n stateStyles: __assign({}, Global.comboStateStyles)\n },\n shapeType: 'rect',\n labelPosition: 'top',\n drawShape: function drawShape(cfg, group) {\n var style = this.getShapeStyle(cfg);\n var keyShape = group.addShape('rect', {\n attrs: style,\n className: 'rect-combo',\n name: 'rect-combo',\n draggable: true\n });\n return keyShape;\n },\n // 私有方法,不希望扩展的 Combo 复写这个方法\n getLabelStyleByPosition: function getLabelStyleByPosition(cfg, labelCfg) {\n var labelPosition = labelCfg.position || this.labelPosition;\n var cfgStyle = cfg.style;\n var padding = cfg.padding || this.options.padding;\n if (isNumber(padding)) padding = [padding, padding, padding, padding];\n var refX = labelCfg.refX,\n refY = labelCfg.refY; // 考虑 refX 和 refY = 0 的场景,不用用 labelCfg.refX || Global.nodeLabel.refY\n\n if (isNil(refX)) {\n refX = this.refX; // 不居中时的偏移量\n }\n\n if (isNil(refY)) {\n refY = this.refY; // 不居中时的偏移量\n }\n\n var leftDis = cfgStyle.width / 2 + padding[3];\n var topDis = cfgStyle.height / 2 + padding[0];\n var style;\n\n switch (labelPosition) {\n case 'top':\n style = {\n x: 0 - leftDis + refX,\n y: 0 - topDis + refY,\n textBaseline: 'top',\n textAlign: 'left'\n };\n break;\n\n case 'bottom':\n style = {\n x: 0,\n y: topDis + refY,\n textBaseline: 'bottom',\n textAlign: 'center'\n };\n break;\n\n case 'left':\n style = {\n x: 0 - leftDis + refY,\n y: 0,\n textAlign: 'left'\n };\n break;\n\n case 'center':\n style = {\n x: 0,\n y: 0,\n text: cfg.label,\n textAlign: 'center'\n };\n break;\n\n default:\n style = {\n x: leftDis + refX,\n y: 0,\n textAlign: 'right'\n };\n break;\n }\n\n style.text = cfg.label;\n return style;\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.options.style;\n var padding = cfg.padding || this.options.padding;\n if (isNumber(padding)) padding = [padding, padding, padding, padding];\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = mix({}, defaultStyle, strokeStyle, cfg.style);\n var size = this.getSize(cfg);\n var width;\n var height;\n var fixSize = cfg.collapsed && cfg.fixCollapseSize ? cfg.fixCollapseSize : cfg.fixSize;\n\n if (fixSize) {\n if (isNumber(fixSize)) {\n width = fixSize;\n height = fixSize;\n } else {\n width = fixSize[0];\n height = fixSize[1];\n }\n } else {\n if (!isNumber(style.width) || isNaN(style.width)) width = size[0] || Global.defaultCombo.style.width;else width = Math.max(style.width, size[0]) || size[0];\n if (!isNumber(style.height) || isNaN(style.height)) height = size[1] || Global.defaultCombo.style.height;else height = Math.max(style.height, size[1]) || size[1];\n }\n\n var x = -width / 2 - padding[3];\n var y = -height / 2 - padding[0];\n style.width = width + padding[1] + padding[3];\n style.height = height + padding[0] + padding[2];\n\n var styles = __assign({\n x: x,\n y: y\n }, style);\n\n if (!cfg.style) {\n cfg.style = {\n width: width,\n height: height\n };\n } else {\n cfg.style.width = width;\n cfg.style.height = height;\n }\n\n return styles;\n },\n update: function update(cfg, item) {\n var size = this.getSize(cfg);\n var padding = cfg.padding || this.options.padding;\n if (isNumber(padding)) padding = [padding, padding, padding, padding];\n var cfgStyle = clone(cfg.style);\n var width, height;\n var fixSize = cfg.collapsed && cfg.fixCollapseSize ? cfg.fixCollapseSize : cfg.fixSize;\n\n if (fixSize) {\n if (isNumber(fixSize)) {\n width = fixSize;\n height = fixSize;\n } else {\n width = fixSize[0];\n height = fixSize[1];\n }\n } else {\n width = Math.max(cfgStyle.width, size[0]) || size[0];\n height = Math.max(cfgStyle.height, size[1]) || size[1];\n }\n\n cfgStyle.width = width + padding[1] + padding[3];\n cfgStyle.height = height + padding[0] + padding[2];\n var itemCacheSize = item.get('sizeCache');\n\n if (itemCacheSize) {\n itemCacheSize.width = cfgStyle.width;\n itemCacheSize.height = cfgStyle.height;\n }\n\n cfgStyle.x = -width / 2 - padding[3];\n cfgStyle.y = -height / 2 - padding[0]; // 下面这些属性需要覆盖默认样式与目前样式,但若在 cfg 中有指定则应该被 cfg 的相应配置覆盖。\n\n var strokeStyle = {\n stroke: cfg.color\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var keyShape = item.get('keyShape');\n var style = mix({}, keyShape.attr(), strokeStyle, cfgStyle);\n\n if (cfg.style) {\n cfg.style.width = width;\n cfg.style.height = height;\n } else {\n cfg.style = {\n width: width,\n height: height\n };\n }\n\n this.updateShape(cfg, item, style, false);\n },\n updateShape: function updateShape(cfg, item, keyShapeStyle) {\n var keyShape = item.get('keyShape');\n var animate = cfg.animate === undefined ? this.options.animate : cfg.animate;\n\n if (animate && keyShape.animate) {\n keyShape.animate(keyShapeStyle, {\n duration: 200,\n easing: 'easeLinear'\n });\n } else {\n keyShape.attr(__assign({}, keyShapeStyle));\n }\n\n this.updateLabel(cfg, item);\n }\n}, 'single-combo');","import { __assign } from \"tslib\";\nimport { deepMix } from '@antv/util';\nimport Global from '../../global';\nimport Shape from '../shape'; // 带有图标的圆,可用于拓扑图中\n\nShape.registerNode('simple-circle', {\n // 自定义节点时的配置\n options: {\n size: Global.defaultNode.size,\n style: {\n x: 0,\n y: 0,\n stroke: Global.defaultNode.style.stroke,\n fill: Global.defaultNode.style.fill,\n lineWidth: Global.defaultNode.style.lineWidth\n },\n labelCfg: {\n style: {\n fill: Global.nodeLabel.style.fill,\n fontSize: Global.nodeLabel.style.fontSize\n }\n },\n stateStyles: __assign({}, Global.nodeStateStyles)\n },\n shapeType: 'simple-circle',\n // 文本位置\n labelPosition: 'center',\n drawShape: function drawShape(cfg, group) {\n var style = this.getShapeStyle(cfg);\n var keyShape = group.addShape('circle', {\n attrs: style,\n className: this.type + \"-keyShape\",\n draggable: true\n });\n return keyShape;\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = deepMix({}, defaultStyle, strokeStyle);\n var size = this.getSize(cfg);\n var r = size[0] / 2;\n\n var styles = __assign({\n x: 0,\n y: 0,\n r: r\n }, style);\n\n return styles;\n },\n update: function update(cfg, item) {\n var size = this.getSize(cfg); // 下面这些属性需要覆盖默认样式与目前样式,但若在 cfg 中有指定则应该被 cfg 的相应配置覆盖。\n\n var strokeStyle = {\n stroke: cfg.color,\n r: size[0] / 2\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var keyShape = item.get('keyShape');\n var style = deepMix({}, keyShape.attr(), strokeStyle, cfg.style);\n this.updateShape(cfg, item, style, true);\n }\n}, 'single-node');","import { __assign } from \"tslib\";\nimport { mix } from '@antv/util';\nimport Global from '../../global';\nimport Shape from '../shape';\nShape.registerNode('simple-rect', {\n // 自定义节点时的配置\n options: {\n size: [100, 30],\n style: {\n radius: 0,\n stroke: Global.defaultNode.style.stroke,\n fill: Global.defaultNode.style.fill,\n lineWidth: Global.defaultNode.style.lineWidth\n },\n // 文本样式配置\n labelCfg: {\n style: {\n fill: Global.nodeLabel.style.fill,\n fontSize: Global.nodeLabel.style.fontSize\n }\n },\n // 连接点,默认为左右\n // anchorPoints: [{ x: 0, y: 0.5 }, { x: 1, y: 0.5 }]\n anchorPoints: [[0, 0.5], [1, 0.5]],\n stateStyles: __assign({}, Global.nodeStateStyles)\n },\n shapeType: 'simple-rect',\n labelPosition: 'center',\n drawShape: function drawShape(cfg, group) {\n var style = this.getShapeStyle(cfg);\n var keyShape = group.addShape('rect', {\n attrs: style,\n className: this.type + \"-keyShape\",\n name: this.type + \"-keyShape\",\n draggable: true\n });\n return keyShape;\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = mix({}, defaultStyle, strokeStyle);\n var size = this.getSize(cfg);\n var width = style.width || size[0];\n var height = style.height || size[1];\n\n var styles = __assign({\n x: -width / 2,\n y: -height / 2,\n width: width,\n height: height\n }, style);\n\n return styles;\n },\n update: function update(cfg, item) {\n var group = item.getContainer(); // 这里不传 cfg 参数是因为 cfg.style 需要最后覆盖样式\n\n var defaultStyle = this.getOptions({}).style;\n var size = this.getSize(cfg);\n var keyShape = item.get('keyShape');\n\n if (!cfg.size) {\n size[0] = keyShape.attr('width') || defaultStyle.width;\n size[1] = keyShape.attr('height') || defaultStyle.height;\n } // 下面这些属性需要覆盖默认样式与目前样式,但若在 cfg 中有指定则应该被 cfg 的相应配置覆盖。\n\n\n var strokeStyle = {\n stroke: cfg.color,\n x: -size[0] / 2,\n y: -size[1] / 2,\n width: size[0],\n height: size[1]\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var style = mix({}, defaultStyle, keyShape.attr(), strokeStyle);\n style = mix(style, cfg.style);\n this.updateShape(cfg, item, style, false);\n }\n}, 'single-node');","import { __assign } from \"tslib\";\nimport Shape from '../shape';\n/**\n * 基本的图片,可以添加文本,默认文本在图片的下面\n */\n\nShape.registerNode('image', {\n options: {\n img: 'https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*eD7nT6tmYgAAAAAAAAAAAABkARQnAQ',\n size: 200,\n clipCfg: {\n show: false,\n type: 'circle',\n // circle\n r: 50,\n // ellipse\n rx: 50,\n ry: 35,\n // rect\n width: 50,\n height: 35,\n // polygon\n points: [[30, 12], [12, 30], [30, 48], [48, 30]],\n // path\n path: [['M', 25, 25], ['L', 50, 25], ['A', 12.5, 12.5, 0, 1, 1, 50, 50], ['A', 12.5, 12.5, 0, 1, 0, 50, 50], ['L', 25, 75], ['Z']],\n // 坐标\n x: 0,\n y: 0 // clip 的属性样式\n // style: {\n // lineWidth: 1\n // },\n\n }\n },\n shapeType: 'image',\n labelPosition: 'bottom',\n drawShape: function drawShape(cfg, group) {\n var shapeType = this.shapeType; // || this.type,都已经加了 shapeType\n\n var style = this.getShapeStyle(cfg);\n delete style.fill;\n var shape = group.addShape(shapeType, {\n attrs: style,\n className: this.type + \"-keyShape\",\n name: this.type + \"-keyShape\",\n draggable: true\n });\n this.drawClip(cfg, shape);\n return shape;\n },\n drawClip: function drawClip(cfg, shape) {\n var clip = this.getOptions(cfg).clipCfg;\n\n if (!clip.show) {\n return;\n } // 支持 circle、rect、ellipse、Polygon 及自定义 path clip\n\n\n var type = clip.type,\n x = clip.x,\n y = clip.y,\n style = clip.style;\n\n if (type === 'circle') {\n var r = clip.r;\n shape.setClip({\n type: 'circle',\n attrs: __assign({\n r: r,\n x: x,\n y: y\n }, style)\n });\n } else if (type === 'rect') {\n var width = clip.width,\n height = clip.height;\n var rectX = x - width / 2;\n var rectY = y - height / 2;\n shape.setClip({\n type: 'rect',\n attrs: __assign({\n x: rectX,\n y: rectY,\n width: width,\n height: height\n }, style)\n });\n } else if (type === 'ellipse') {\n var rx = clip.rx,\n ry = clip.ry;\n shape.setClip({\n type: 'ellipse',\n attrs: __assign({\n x: x,\n y: y,\n rx: rx,\n ry: ry\n }, style)\n });\n } else if (type === 'polygon') {\n var points = clip.points;\n shape.setClip({\n type: 'polygon',\n attrs: __assign({\n points: points\n }, style)\n });\n } else if (type === 'path') {\n var path = clip.path;\n shape.setClip({\n type: 'path',\n attrs: __assign({\n path: path\n }, style)\n });\n }\n },\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var size = this.getSize(cfg);\n var img = this.getOptions(cfg).img;\n var width = size[0];\n var height = size[1];\n\n if (defaultStyle) {\n width = defaultStyle.width || size[0];\n height = defaultStyle.height || size[1];\n }\n\n var style = __assign({\n x: -width / 2,\n y: -height / 2,\n width: width,\n height: height,\n img: img\n }, defaultStyle);\n\n return style;\n },\n updateShapeStyle: function updateShapeStyle(cfg, item) {\n var group = item.getContainer();\n var shapeClassName = this.itemType + \"-shape\";\n var shape = group.find(function (element) {\n return element.get('className') === shapeClassName;\n }) || item.getKeyShape();\n var shapeStyle = this.getShapeStyle(cfg);\n\n if (shape) {\n shape.attr(shapeStyle);\n }\n }\n}, 'single-node');","export default {\n triangle: function triangle(width, length, d) {\n if (width === void 0) {\n width = 10;\n }\n\n if (length === void 0) {\n length = 15;\n }\n\n if (d === void 0) {\n d = 0;\n }\n\n var begin = d * 2;\n var path = \"M \" + begin + \",0 L \" + (begin + length) + \",-\" + width / 2 + \" L \" + (begin + length) + \",\" + width / 2 + \" Z\";\n return path;\n },\n vee: function vee(width, length, d) {\n if (width === void 0) {\n width = 15;\n }\n\n if (length === void 0) {\n length = 20;\n }\n\n if (d === void 0) {\n d = 0;\n }\n\n var begin = d * 2;\n var path = \"M \" + begin + \",0 L \" + (begin + length) + \",-\" + width / 2 + \"\\n L \" + (begin + 2 * length / 3) + \",0 L \" + (begin + length) + \",\" + width / 2 + \" Z\";\n return path;\n },\n circle: function circle(r, d) {\n if (r === void 0) {\n r = 5;\n }\n\n if (d === void 0) {\n d = 0;\n }\n\n var begin = d * 2;\n var path = \"M \" + begin + \", 0\\n a \" + r + \",\" + r + \" 0 1,0 \" + r * 2 + \",0\\n a \" + r + \",\" + r + \" 0 1,0 \" + -r * 2 + \",0\";\n return path;\n },\n rect: function rect(width, length, d) {\n if (width === void 0) {\n width = 10;\n }\n\n if (length === void 0) {\n length = 10;\n }\n\n if (d === void 0) {\n d = 0;\n }\n\n var begin = d * 2;\n var path = \"M \" + begin + \",\" + -width / 2 + \" \\n L \" + (begin + length) + \",\" + -width / 2 + \" \\n L \" + (begin + length) + \",\" + width / 2 + \" \\n L \" + begin + \",\" + width / 2 + \" Z\";\n return path;\n },\n diamond: function diamond(width, length, d) {\n if (width === void 0) {\n width = 15;\n }\n\n if (length === void 0) {\n length = 15;\n }\n\n if (d === void 0) {\n d = 0;\n }\n\n var begin = d * 2;\n var path = \"M \" + begin + \",0 \\n L \" + (begin + length / 2) + \",\" + -width / 2 + \" \\n L \" + (begin + length) + \",0 \\n L \" + (begin + length / 2) + \",\" + width / 2 + \" Z\";\n return path;\n },\n triangleRect: function triangleRect(tWidth, tLength, rWidth, rLength, gap, d) {\n if (tWidth === void 0) {\n tWidth = 15;\n }\n\n if (tLength === void 0) {\n tLength = 15;\n }\n\n if (rWidth === void 0) {\n rWidth = 15;\n }\n\n if (rLength === void 0) {\n rLength = 3;\n }\n\n if (gap === void 0) {\n gap = 5;\n }\n\n if (d === void 0) {\n d = 0;\n }\n\n var begin = d * 2;\n var rectBegin = begin + tLength + gap;\n var path = \"M \" + begin + \",0 L \" + (begin + tLength) + \",-\" + tWidth / 2 + \" L \" + (begin + tLength) + \",\" + tWidth / 2 + \" Z\\n M \" + rectBegin + \", -\" + rWidth / 2 + \"\\n L \" + (rectBegin + rLength) + \" -\" + rWidth / 2 + \"\\n L \" + (rectBegin + rLength) + \" \" + rWidth / 2 + \"\\n L \" + rectBegin + \" \" + rWidth / 2 + \"\\n Z\";\n return path;\n }\n};","export * from '../interface'; // Behavior type file\n\nexport var G6Event;\n\n(function (G6Event) {\n // common events\n G6Event[\"CLICK\"] = \"click\";\n G6Event[\"DBLCLICK\"] = \"dblclick\";\n G6Event[\"MOUSEDOWN\"] = \"mousedown\";\n G6Event[\"MOUDEUP\"] = \"mouseup\";\n G6Event[\"CONTEXTMENU\"] = \"contextmenu\";\n G6Event[\"MOUSEENTER\"] = \"mouseenter\";\n G6Event[\"MOUSEOUT\"] = \"mouseout\";\n G6Event[\"MOUSEOVER\"] = \"mouseover\";\n G6Event[\"MOUSEMOVE\"] = \"mousemove\";\n G6Event[\"MOUSELEAVE\"] = \"mouseleave\";\n G6Event[\"DRAGSTART\"] = \"dragstart\";\n G6Event[\"DRAGEND\"] = \"dragend\";\n G6Event[\"DRAG\"] = \"drag\";\n G6Event[\"DRAGENTER\"] = \"dragenter\";\n G6Event[\"DRAGLEAVE\"] = \"dragleave\";\n G6Event[\"DRAGOVER\"] = \"dragover\";\n G6Event[\"DRAGOUT\"] = \"dragout\";\n G6Event[\"DDROP\"] = \"drop\";\n G6Event[\"KEYUP\"] = \"keyup\";\n G6Event[\"KEYDOWN\"] = \"keydown\";\n G6Event[\"WHEEL\"] = \"wheel\";\n G6Event[\"FOCUS\"] = \"focus\";\n G6Event[\"BLUR\"] = \"blur\"; // touch events\n\n G6Event[\"TOUCHSTART\"] = \"touchstart\";\n G6Event[\"TOUCHMOVE\"] = \"touchmove\";\n G6Event[\"TOUCHEND\"] = \"touchend\";\n G6Event[\"CANVAS_TOUCHSTART\"] = \"canvas:touchstart\";\n G6Event[\"CANVAS_TOUCHMOVE\"] = \"canvas:touchmove\";\n G6Event[\"CANVAS_TOUCHEND\"] = \"canvas:touchend\";\n G6Event[\"NODE_TOUCHSTART\"] = \"node:touchstart\";\n G6Event[\"NODE_TOUCHMOVE\"] = \"node:touchmove\";\n G6Event[\"NODE_TOUCHEND\"] = \"node:touchend\";\n G6Event[\"COMBO_TOUCHSTART\"] = \"combo:touchstart\";\n G6Event[\"COMBO_TOUCHMOVE\"] = \"combo:touchmove\";\n G6Event[\"COMBO_TOUCHEND\"] = \"combo:touchend\";\n G6Event[\"EDGE_TOUCHSTART\"] = \"edge:touchstart\";\n G6Event[\"EDGE_TOUCHMOVE\"] = \"edge:touchmove\";\n G6Event[\"EDGE_TOUCHEND\"] = \"edge:touchend\"; // node events\n\n G6Event[\"NODE_CONTEXTMENU\"] = \"node:contextmenu\";\n G6Event[\"NODE_CLICK\"] = \"node:click\";\n G6Event[\"NODE_DBLCLICK\"] = \"node:dblclick\";\n G6Event[\"NODE_MOUSEDOWN\"] = \"node:mousedown\";\n G6Event[\"NODE_MOUSEUP\"] = \"node:mouseup\";\n G6Event[\"NODE_MOUSEENTER\"] = \"node:mouseenter\";\n G6Event[\"NODE_MOUSELEAVE\"] = \"node:mouseleave\";\n G6Event[\"NODE_MOUSEMOVE\"] = \"node:mousemove\";\n G6Event[\"NODE_MOUSEOUT\"] = \"node:mouseout\";\n G6Event[\"NODE_MOUSEOVER\"] = \"node:mouseover\";\n G6Event[\"NODE_DROP\"] = \"node:drop\";\n G6Event[\"NODE_DRAGOVER\"] = \"node:dragover\";\n G6Event[\"NODE_DRAGENTER\"] = \"node:dragenter\";\n G6Event[\"NODE_DRAGLEAVE\"] = \"node:dragleave\";\n G6Event[\"NODE_DRAGSTART\"] = \"node:dragstart\";\n G6Event[\"NODE_DRAG\"] = \"node:drag\";\n G6Event[\"NODE_DRAGEND\"] = \"node:dragend\";\n G6Event[\"NODE_TAP\"] = \"node:tap\";\n G6Event[\"NODE_PANSTART\"] = \"node:panstart\";\n G6Event[\"NODE_PANMOVE\"] = \"node:panmove\";\n G6Event[\"NODE_PANEND\"] = \"node:panend\"; // combo, extends from nodes\n\n G6Event[\"COMBO_CONTEXTMENU\"] = \"combo:contextmenu\";\n G6Event[\"COMBO_CLICK\"] = \"combo:click\";\n G6Event[\"COMBO_DBLCLICK\"] = \"combo:dblclick\";\n G6Event[\"COMBO_MOUSEDOWN\"] = \"combo:mousedown\";\n G6Event[\"COMBO_MOUSEUP\"] = \"combo:mouseup\";\n G6Event[\"COMBO_MOUSEENTER\"] = \"combo:mouseenter\";\n G6Event[\"COMBO_MOUSELEAVE\"] = \"combo:mouseleave\";\n G6Event[\"COMBO_MOUSEMOVE\"] = \"combo:mousemove\";\n G6Event[\"COMBO_MOUSEOUT\"] = \"combo:mouseout\";\n G6Event[\"COMBO_MOUSEOVER\"] = \"combo:mouseover\";\n G6Event[\"COMBO_DROP\"] = \"combo:drop\";\n G6Event[\"COMBO_DRAGOVER\"] = \"combo:dragover\";\n G6Event[\"COMBO_DRAGENTER\"] = \"combo:dragenter\";\n G6Event[\"COMBO_DRAGLEAVE\"] = \"combo:dragleave\";\n G6Event[\"COMBO_DRAGSTART\"] = \"combo:dragstart\";\n G6Event[\"COMBO_DRAG\"] = \"combo:drag\";\n G6Event[\"COMBO_DRAGEND\"] = \"combo:dragend\";\n G6Event[\"COMBO_TAP\"] = \"combo:tap\";\n G6Event[\"COMBO_PANSTART\"] = \"combo:panstart\";\n G6Event[\"COMBO_PANMOVE\"] = \"combo:panmove\";\n G6Event[\"COMBO_PANEND\"] = \"combo:panend\"; // edge events\n\n G6Event[\"EDGE_CONTEXTMENU\"] = \"edge:contextmenu\";\n G6Event[\"EDGE_CLICK\"] = \"edge:click\";\n G6Event[\"EDGE_DBLCLICK\"] = \"edge:dblclick\";\n G6Event[\"EDGE_MOUSEDOWN\"] = \"edge:mousedown\";\n G6Event[\"EDGE_MOUSEUP\"] = \"edge:mouseup\";\n G6Event[\"EDGE_MOUSEENTER\"] = \"edge:mouseenter\";\n G6Event[\"EDGE_MOUSELEAVE\"] = \"edge:mouseleave\";\n G6Event[\"EDGE_MOUSEMOVE\"] = \"edge:mousemove\";\n G6Event[\"EDGE_MOUSEOUT\"] = \"edge:mouseout\";\n G6Event[\"EDGE_MOUSEOVER\"] = \"edge:mouseover\";\n G6Event[\"EDGE_DROP\"] = \"edge:drop\";\n G6Event[\"EDGE_DRAGOVER\"] = \"edge:dragover\";\n G6Event[\"EDGE_DRAGENTER\"] = \"edge:dragenter\";\n G6Event[\"EDGE_DRAGLEAVE\"] = \"edge:dragleave\"; // canvas events\n\n G6Event[\"CANVAS_CONTEXTMENU\"] = \"canvas:contextmenu\";\n G6Event[\"CANVAS_CLICK\"] = \"canvas:click\";\n G6Event[\"CANVAS_DBLCLICK\"] = \"canvas:dblclick\";\n G6Event[\"CANVAS_MOUSEDOWN\"] = \"canvas:mousedown\";\n G6Event[\"CANVAS_MOUSEUP\"] = \"canvas:mouseup\";\n G6Event[\"CANVAS_MOUSEENTER\"] = \"canvas:mouseenter\";\n G6Event[\"CANVAS_MOUSELEAVE\"] = \"canvas:mouseleave\";\n G6Event[\"CANVAS_MOUSEMOVE\"] = \"canvas:mousemove\";\n G6Event[\"CANVAS_MOUSEOUT\"] = \"canvas:mouseout\";\n G6Event[\"CANVAS_MOUSEOVER\"] = \"canvas:mouseover\";\n G6Event[\"CANVAS_DROP\"] = \"canvas:drop\";\n G6Event[\"CANVAS_DRAGENTER\"] = \"canvas:dragenter\";\n G6Event[\"CANVAS_DRAGLEAVE\"] = \"canvas:dragleave\";\n G6Event[\"CANVAS_DRAGSTART\"] = \"canvas:dragstart\";\n G6Event[\"CANVAS_DRAG\"] = \"canvas:drag\";\n G6Event[\"CANVAS_DRAGEND\"] = \"canvas:dragend\";\n G6Event[\"CANVAS_TAP\"] = \"canvas:tap\";\n G6Event[\"CANVAS_PANSTART\"] = \"canvas:panstart\";\n G6Event[\"CANVAS_PANMOVE\"] = \"canvas:panmove\";\n G6Event[\"CANVAS_PANEND\"] = \"canvas:panend\"; // timing events\n\n G6Event[\"BEFORERENDER\"] = \"beforerender\";\n G6Event[\"AFTERRENDER\"] = \"afterrender\";\n G6Event[\"BEFOREADDITEM\"] = \"beforeadditem\";\n G6Event[\"AFTERADDITEM\"] = \"afteradditem\";\n G6Event[\"BEFOREREMOVEITEM\"] = \"beforeremoveitem\";\n G6Event[\"AFTERREMOVEITEM\"] = \"afterremoveitem\";\n G6Event[\"BEFOREUPDATEITEM\"] = \"beforeupdateitem\";\n G6Event[\"AFTERUPDATEITEM\"] = \"afterupdateitem\";\n G6Event[\"BEFOREITEMVISIBILITYCHANGE\"] = \"beforeitemvisibilitychange\";\n G6Event[\"AFTERITEMVISIBILITYCHANGE\"] = \"afteritemvisibilitychange\";\n G6Event[\"BEFOREITEMSTATECHANGE\"] = \"beforeitemstatechange\";\n G6Event[\"AFTERITEMSTATECHANGE\"] = \"afteritemstatechange\";\n G6Event[\"BEFOREITEMREFRESH\"] = \"beforeitemrefresh\";\n G6Event[\"AFTERITEMREFRESH\"] = \"afteritemrefresh\";\n G6Event[\"BEFOREITEMSTATESCLEAR\"] = \"beforeitemstatesclear\";\n G6Event[\"AFTERITEMSTATESCLEAR\"] = \"afteritemstatesclear\";\n G6Event[\"BEFOREMODECHANGE\"] = \"beforemodechange\";\n G6Event[\"AFTERMODECHANGE\"] = \"aftermodechange\";\n G6Event[\"BEFORELAYOUT\"] = \"beforelayout\";\n G6Event[\"AFTERLAYOUT\"] = \"afterlayout\";\n G6Event[\"BEFORECREATEEDGE\"] = \"beforecreateedge\";\n G6Event[\"AFTERCREATEEDGE\"] = \"aftercreateedge\";\n G6Event[\"BEFOREGRAPHREFRESHPOSITION\"] = \"beforegraphrefreshposition\";\n G6Event[\"AFTERGRAPHREFRESHPOSITION\"] = \"aftergraphrefreshposition\";\n G6Event[\"BEFOREGRAPHREFRESH\"] = \"beforegraphrefresh\";\n G6Event[\"AFTERGRAPHREFRESH\"] = \"aftergraphrefresh\";\n G6Event[\"BEFOREANIMATE\"] = \"beforeanimate\";\n G6Event[\"AFTERANIMATE\"] = \"afteranimate\";\n G6Event[\"BEFOREPAINT\"] = \"beforepaint\";\n G6Event[\"AFTERPAINT\"] = \"afterpaint\";\n G6Event[\"BEFORECOLLAPSEEXPANDCOMBO\"] = \"beforecollapseexpandcombo\";\n G6Event[\"AFTERCOLLAPSEEXPANDCOMBO\"] = \"aftercollapseexpandcombo\";\n G6Event[\"GRAPHSTATECHANGE\"] = \"graphstatechange\";\n G6Event[\"AFTERACTIVATERELATIONS\"] = \"afteractivaterelations\";\n G6Event[\"NODESELECTCHANGE\"] = \"nodeselectchange\";\n G6Event[\"TOOLTIPCHANGE\"] = \"tooltipchange\";\n G6Event[\"WHEELZOOM\"] = \"wheelzoom\";\n G6Event[\"VIEWPORTCHANGE\"] = \"viewportchange\";\n G6Event[\"DRAGNODEEND\"] = \"dragnodeend\";\n G6Event[\"STACKCHANGE\"] = \"stackchange\"; // Mobile event support\n\n G6Event[\"TAP\"] = \"tap\";\n G6Event[\"PINCHSTART\"] = \"pinchstart\";\n G6Event[\"PINCHMOVE\"] = \"pinchmove\";\n G6Event[\"PANSTART\"] = \"panstart\";\n G6Event[\"PANMOVE\"] = \"panmove\";\n G6Event[\"PANEND\"] = \"panend\";\n})(G6Event || (G6Event = {}));","export default {\n collapse: function collapse(x, y, r) {\n return [['M', x - r, y], ['a', r, r, 0, 1, 0, r * 2, 0], ['a', r, r, 0, 1, 0, -r * 2, 0], ['M', x - r + 4, y], ['L', x + r - 4, y]];\n },\n expand: function expand(x, y, r) {\n return [['M', x - r, y], ['a', r, r, 0, 1, 0, r * 2, 0], ['a', r, r, 0, 1, 0, -r * 2, 0], ['M', x - r + 4, y], ['L', x - r + 2 * r - 4, y], ['M', x - r + r, y - r + 4], ['L', x, y + r - 4]];\n },\n upTriangle: function upTriangle(x, y, r) {\n var l1 = r * Math.cos(Math.PI / 6);\n var l2 = r * Math.sin(Math.PI / 6);\n return [['M', x - l1, y + l2], ['L', x + l1, y + l2], ['L', x, y - r], ['Z']];\n },\n downTriangle: function downTriangle(x, y, r) {\n var l1 = r * Math.cos(Math.PI / 6);\n var l2 = r * Math.sin(Math.PI / 6);\n return [['M', x - l1, y - l2], ['L', x + l1, y - l2], ['L', x, y + r], ['Z']];\n }\n};","import Shape from './shape';\nimport './node';\nimport './edge';\nimport './combo';\nimport './combos';\nimport './nodes';\nexport { default as Arrow } from './arrow';\nexport { default as Marker } from './marker';\nexport default Shape;","export var defaultSubjectColors = ['#5F95FF', '#61DDAA', '#65789B', '#F6BD16', '#7262FD', '#78D3F8', '#9661BC', '#F6903D', '#008685', '#F08BB4'];","import { __assign } from \"tslib\";\nimport * as MathUtil from './math';\nimport * as GraphicUtil from './graphic';\nimport * as PathUtil from './path';\nimport * as BaseUtil from './base';\nimport * as ColorUtil from './color';\nimport { ext, mat3 } from '@antv/matrix-util';\nvar transform = ext.transform;\n\nvar Util = __assign(__assign(__assign(__assign(__assign(__assign({}, BaseUtil), GraphicUtil), PathUtil), MathUtil), ColorUtil), {\n transform: transform,\n mat3: mat3\n});\n\nexport default Util;","import { __assign, __rest } from \"tslib\";\nimport { isFunction, groupBy } from '@antv/util';\nimport { isNaN, calculationItemsBBox } from '../../util/base';\n\nvar LayoutController = function () {\n function LayoutController(graph) {\n this.graph = graph;\n this.layoutCfg = graph.get('layout') || {};\n this.layoutType = this.getLayoutType();\n this.layoutMethods = [];\n this.initLayout();\n } // eslint-disable-next-line class-methods-use-this\n\n\n LayoutController.prototype.initLayout = function () {// no data before rendering\n };\n\n LayoutController.prototype.getLayoutType = function () {\n return this.getLayoutCfgType(this.layoutCfg);\n };\n\n LayoutController.prototype.getLayoutCfgType = function (layoutCfg) {\n var type = layoutCfg.type; // type should be top priority\n\n if (type) {\n return type;\n }\n\n var pipes = layoutCfg.pipes;\n\n if (Array.isArray(pipes)) {\n return pipes.map(function (pipe) {\n return (pipe === null || pipe === void 0 ? void 0 : pipe.type) || '';\n });\n }\n\n return null;\n };\n\n LayoutController.prototype.isLayoutTypeSame = function (cfg) {\n var current = this.getLayoutCfgType(cfg); // already has pipes\n\n if (Array.isArray(this.layoutType)) {\n return this.layoutType.every(function (type, index) {\n return type === current[index];\n });\n }\n\n return (cfg === null || cfg === void 0 ? void 0 : cfg.type) === this.layoutType;\n }; // 绘制\n\n\n LayoutController.prototype.refreshLayout = function () {\n var graph = this.graph;\n if (!graph) return;\n\n if (graph.get('animate')) {\n graph.positionsAnimate();\n } else {\n graph.refreshPositions();\n }\n }; // 更换布局\n\n\n LayoutController.prototype.changeLayout = function (cfg) {\n this.layoutCfg = cfg;\n this.destoryLayoutMethods();\n this.layout();\n }; // 更换数据\n\n\n LayoutController.prototype.changeData = function () {\n this.destoryLayoutMethods();\n this.layout();\n };\n\n LayoutController.prototype.destoryLayoutMethods = function () {\n var layoutMethods = this.layoutMethods;\n layoutMethods === null || layoutMethods === void 0 ? void 0 : layoutMethods.forEach(function (layoutMethod) {\n layoutMethod.destroy();\n });\n this.layoutMethods = [];\n }; // 销毁布局,不能使用 this.destroy,因为 controller 还需要被使用,只是把布局算法销毁\n\n\n LayoutController.prototype.destroyLayout = function () {\n var graph = this.graph;\n this.destoryLayoutMethods();\n graph.set('layout', undefined);\n this.layoutCfg = undefined;\n this.layoutType = undefined;\n this.layoutMethods = undefined;\n }; // 从 this.graph 获取数据\n\n\n LayoutController.prototype.setDataFromGraph = function () {\n var nodes = [];\n var hiddenNodes = [];\n var edges = [];\n var hiddenEdges = [];\n var comboEdges = [];\n var combos = [];\n var hiddenCombos = [];\n var nodeItems = this.graph.getNodes();\n var edgeItems = this.graph.getEdges();\n var comboItems = this.graph.getCombos();\n var nodeLength = nodeItems.length;\n\n for (var i = 0; i < nodeLength; i++) {\n var nodeItem = nodeItems[i];\n if (!nodeItem || nodeItem.destroyed) continue;\n var model = nodeItem.getModel();\n\n if (!nodeItem.isVisible()) {\n hiddenNodes.push(model);\n continue;\n }\n\n nodes.push(model);\n }\n\n var edgeLength = edgeItems.length;\n\n for (var i = 0; i < edgeLength; i++) {\n var edgeItem = edgeItems[i];\n if (!edgeItem || edgeItem.destroyed) continue;\n var model = edgeItem.getModel();\n\n if (!edgeItem.isVisible()) {\n hiddenEdges.push(model);\n continue;\n }\n\n if (!model.isComboEdge) edges.push(model);else comboEdges.push(model);\n }\n\n var comboLength = comboItems.length;\n\n for (var i = 0; i < comboLength; i++) {\n var comboItem = comboItems[i];\n if (comboItem.destroyed) continue;\n var model = comboItem.getModel();\n\n if (!comboItem.isVisible()) {\n hiddenEdges.push(model);\n continue;\n }\n\n combos.push(model);\n }\n\n return {\n nodes: nodes,\n hiddenNodes: hiddenNodes,\n edges: edges,\n hiddenEdges: hiddenEdges,\n combos: combos,\n hiddenCombos: hiddenCombos,\n comboEdges: comboEdges\n };\n };\n\n LayoutController.prototype.reLayoutMethod = function (layoutMethod, layoutCfg) {\n var _this = this;\n\n return new Promise(function (reslove, reject) {\n var graph = _this.graph;\n var layoutType = layoutCfg === null || layoutCfg === void 0 ? void 0 : layoutCfg.type; // 每个布局方法都需要注册\n\n layoutCfg.onLayoutEnd = function () {\n graph.emit('aftersublayout', {\n type: layoutType\n });\n reslove();\n };\n\n layoutMethod.init(_this.data);\n\n if (layoutType === 'force') {\n layoutMethod.ticking = false;\n layoutMethod.forceSimulation.stop();\n }\n\n graph.emit('beforesublayout', {\n type: layoutType\n });\n layoutMethod.execute();\n if (layoutMethod.isCustomLayout && layoutCfg.onLayoutEnd) layoutCfg.onLayoutEnd();\n });\n }; // 重新布局\n\n\n LayoutController.prototype.relayout = function (reloadData) {\n var _this = this;\n\n var _a = this,\n graph = _a.graph,\n layoutMethods = _a.layoutMethods,\n layoutCfg = _a.layoutCfg;\n\n if (reloadData) {\n this.data = this.setDataFromGraph();\n var nodes = this.data.nodes;\n\n if (!nodes) {\n return false;\n }\n\n this.initPositions(layoutCfg.center, nodes);\n }\n\n graph.emit('beforelayout');\n var start = Promise.resolve();\n layoutMethods === null || layoutMethods === void 0 ? void 0 : layoutMethods.forEach(function (layoutMethod, index) {\n var currentCfg = layoutCfg[index];\n start = start.then(function () {\n return _this.reLayoutMethod(layoutMethod, currentCfg);\n });\n });\n start.then(function () {\n if (layoutCfg.onAllLayoutEnd) layoutCfg.onAllLayoutEnd();\n }).catch(function (error) {\n console.warn('relayout failed', error);\n });\n }; // 筛选参与布局的nodes和edges\n\n\n LayoutController.prototype.filterLayoutData = function (data, cfg) {\n var nodes = data.nodes,\n edges = data.edges,\n rest = __rest(data, [\"nodes\", \"edges\"]);\n\n if (!nodes) {\n return data;\n }\n\n var nodesFilter;\n var edegsFilter;\n\n if (isFunction(cfg === null || cfg === void 0 ? void 0 : cfg.nodesFilter)) {\n nodesFilter = cfg.nodesFilter;\n } else {\n nodesFilter = function nodesFilter() {\n return true;\n };\n }\n\n var fNodes = nodes.filter(nodesFilter);\n\n if (isFunction(cfg === null || cfg === void 0 ? void 0 : cfg.edgesFilter)) {\n edegsFilter = cfg.edgesFilter;\n } else {\n var nodesMap_1 = fNodes.reduce(function (acc, cur) {\n acc[cur.id] = true;\n return acc;\n }, {});\n\n edegsFilter = function edegsFilter(edge) {\n return nodesMap_1[edge.source] && nodesMap_1[edge.target];\n };\n }\n\n return __assign({\n nodes: fNodes,\n edges: edges.filter(edegsFilter)\n }, rest);\n };\n\n LayoutController.prototype.getLayoutBBox = function (nodes) {\n var graph = this.graph;\n var graphGroupNodes = groupBy(graph.getNodes(), function (n) {\n return n.getModel().layoutOrder;\n });\n var layoutNodes = Object.values(graphGroupNodes).map(function (value) {\n var bbox = calculationItemsBBox(value);\n bbox.size = [bbox.width, bbox.height];\n return bbox;\n });\n var groupNodes = Object.values(groupBy(nodes, 'layoutOrder'));\n return {\n groupNodes: groupNodes,\n layoutNodes: layoutNodes\n };\n }; // 控制布局动画\n // eslint-disable-next-line class-methods-use-this\n\n\n LayoutController.prototype.layoutAnimate = function () {}; // 将当前节点的平均中心移动到原点\n\n\n LayoutController.prototype.moveToZero = function () {\n var graph = this.graph;\n var data = graph.get('data');\n var nodes = data.nodes;\n\n if (nodes[0].x === undefined || nodes[0].x === null || isNaN(nodes[0].x)) {\n return;\n }\n\n var meanCenter = [0, 0];\n var nodeLength = nodes.length;\n\n for (var i = 0; i < nodeLength; i++) {\n var node = nodes[i];\n meanCenter[0] += node.x;\n meanCenter[1] += node.y;\n }\n\n meanCenter[0] /= nodes.length;\n meanCenter[1] /= nodes.length;\n\n for (var i = 0; i < nodeLength; i++) {\n var node = nodes[i];\n node.x -= meanCenter[0];\n node.y -= meanCenter[1];\n }\n }; // 初始化节点到 center 附近\n\n\n LayoutController.prototype.initPositions = function (center, nodes) {\n var graph = this.graph;\n\n if (!nodes) {\n return false;\n }\n\n var nodeLength = nodes ? nodes.length : 0;\n if (!nodeLength) return;\n var width = graph.get('width') * 0.85;\n var height = graph.get('height') * 0.85;\n var horiNum = Math.ceil(Math.sqrt(nodeLength) * (width / height));\n var vertiNum = Math.ceil(nodeLength / horiNum);\n var horiGap = width / (horiNum - 1);\n var vertiGap = height / (vertiNum - 1);\n if (!isFinite(horiGap) || !horiGap) horiGap = 0;\n if (!isFinite(vertiGap) || !horiGap) vertiGap = 0;\n var beginX = center[0] - width / 2;\n var beginY = center[1] - height / 2;\n var allHavePos = true;\n\n for (var i = 0; i < nodeLength; i++) {\n var node = nodes[i];\n\n if (isNaN(+node.x)) {\n allHavePos = false;\n node.x = i % horiNum * horiGap + beginX;\n }\n\n if (isNaN(+node.y)) {\n allHavePos = false;\n node.y = Math.floor(i / horiNum) * vertiGap + beginY;\n }\n }\n\n return allHavePos;\n };\n\n LayoutController.prototype.destroy = function () {\n this.graph = null;\n this.destoryLayoutMethods();\n this.destroyed = true;\n };\n\n return LayoutController;\n}();\n\nexport default LayoutController;","var EventController = function () {\n function EventController(graph) {\n this.graph = graph;\n this.destroyed = false;\n this.initEvents();\n }\n\n return EventController;\n}();\n\nexport default EventController;","import Behavior from './behavior';\nimport AbstractGraph from './graph/graph';\nimport Shape, { Arrow, Marker } from './element';\nimport Global from './global';\nimport Util from './util'; // 用于 PC 和 Mobile 端分别实现 layout 和 updateLayoutCfg 方法\n\nimport AbstractLayout from './graph/controller/layout';\nimport AbstractEvent from './graph/controller/event';\nimport Node from './item/node';\nimport Edge from './item/edge';\nimport Hull from './item/hull';\nimport Combo from './item/combo';\nvar registerNode = Shape.registerNode;\nvar registerEdge = Shape.registerEdge;\nvar registerCombo = Shape.registerCombo;\nvar registerBehavior = Behavior.registerBehavior;\nvar BaseGlobal = Global;\nexport * from './types';\nexport { Arrow, Shape, Node, Edge, Combo, Hull, Marker, registerNode, registerCombo, AbstractGraph, Util, registerEdge, registerBehavior, AbstractLayout, AbstractEvent, BaseGlobal };\nexport default {\n version: Global.version,\n AbstractGraph: AbstractGraph,\n BaseGlobal: BaseGlobal,\n Util: Util,\n Shape: Shape,\n Node: Node,\n Edge: Edge,\n Combo: Combo,\n Hull: Hull,\n registerNode: Shape.registerNode,\n registerEdge: Shape.registerEdge,\n registerCombo: Shape.registerCombo,\n registerBehavior: Behavior.registerBehavior,\n Arrow: Arrow,\n Marker: Marker,\n AbstractLayout: AbstractLayout,\n AbstractEvent: AbstractEvent\n};","import tinycolor from 'tinycolor2';\n\nvar hueStep = 2; // 色相阶梯\n\nvar saturationStep = 0.16; // 饱和度阶梯,浅色部分\n\nvar saturationStep2 = 0.05; // 饱和度阶梯,深色部分\n\nvar brightnessStep1 = 0.05; // 亮度阶梯,浅色部分\n\nvar brightnessStep2 = 0.15; // 亮度阶梯,深色部分\n\nvar lightColorCount = 5; // 浅色数量,主色上\n\nvar darkColorCount = 4; // 深色数量,主色下\n// 暗色主题颜色映射关系表\n\nvar darkColorMap = [{\n index: 7,\n opacity: 0.15\n}, {\n index: 6,\n opacity: 0.25\n}, {\n index: 5,\n opacity: 0.3\n}, {\n index: 5,\n opacity: 0.45\n}, {\n index: 5,\n opacity: 0.65\n}, {\n index: 5,\n opacity: 0.85\n}, {\n index: 4,\n opacity: 0.9\n}, {\n index: 3,\n opacity: 0.95\n}, {\n index: 2,\n opacity: 0.97\n}, {\n index: 1,\n opacity: 0.98\n}];\n\nfunction getHue(hsv, i, light) {\n var hue; // 根据色相不同,色相转向不同\n\n if (Math.round(hsv.h) >= 60 && Math.round(hsv.h) <= 240) {\n hue = light ? Math.round(hsv.h) - hueStep * i : Math.round(hsv.h) + hueStep * i;\n } else {\n hue = light ? Math.round(hsv.h) + hueStep * i : Math.round(hsv.h) - hueStep * i;\n }\n\n if (hue < 0) {\n hue += 360;\n } else if (hue >= 360) {\n hue -= 360;\n }\n\n return hue;\n}\n\nfunction getSaturation(hsv, i, light) {\n // grey color don't change saturation\n if (hsv.h === 0 && hsv.s === 0) {\n return hsv.s;\n }\n\n var saturation;\n\n if (light) {\n saturation = hsv.s - saturationStep * i;\n } else if (i === darkColorCount) {\n saturation = hsv.s + saturationStep;\n } else {\n saturation = hsv.s + saturationStep2 * i;\n } // 边界值修正\n\n\n if (saturation > 1) {\n saturation = 1;\n } // 第一格的 s 限制在 0.06-0.1 之间\n\n\n if (light && i === lightColorCount && saturation > 0.1) {\n saturation = 0.1;\n }\n\n if (saturation < 0.06) {\n saturation = 0.06;\n }\n\n return Number(saturation.toFixed(2));\n}\n\nfunction getValue(hsv, i, light) {\n var value;\n\n if (light) {\n value = hsv.v + brightnessStep1 * i;\n } else {\n value = hsv.v - brightnessStep2 * i;\n }\n\n if (value > 1) {\n value = 1;\n }\n\n return Number(value.toFixed(2));\n}\n\nfunction generate(color) {\n var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var patterns = [];\n var pColor = tinycolor(color);\n\n for (var i = lightColorCount; i > 0; i -= 1) {\n var hsv = pColor.toHsv();\n var colorString = tinycolor({\n h: getHue(hsv, i, true),\n s: getSaturation(hsv, i, true),\n v: getValue(hsv, i, true)\n }).toHexString();\n patterns.push(colorString);\n }\n\n patterns.push(pColor.toHexString());\n\n for (var _i = 1; _i <= darkColorCount; _i += 1) {\n var _hsv = pColor.toHsv();\n\n var _colorString = tinycolor({\n h: getHue(_hsv, _i),\n s: getSaturation(_hsv, _i),\n v: getValue(_hsv, _i)\n }).toHexString();\n\n patterns.push(_colorString);\n } // dark theme patterns\n\n\n if (opts.theme === 'dark') {\n return darkColorMap.map(function (_ref) {\n var index = _ref.index,\n opacity = _ref.opacity;\n var darkColorString = tinycolor.mix(opts.backgroundColor || '#141414', patterns[index], opacity * 100).toHexString();\n return darkColorString;\n });\n }\n\n return patterns;\n}\n\nvar presetPrimaryColors = {\n red: '#F5222D',\n volcano: '#FA541C',\n orange: '#FA8C16',\n gold: '#FAAD14',\n yellow: '#FADB14',\n lime: '#A0D911',\n green: '#52C41A',\n cyan: '#13C2C2',\n blue: '#1890FF',\n geekblue: '#2F54EB',\n purple: '#722ED1',\n magenta: '#EB2F96',\n grey: '#666666'\n};\nvar presetPalettes = {};\nvar presetDarkPalettes = {};\nObject.keys(presetPrimaryColors).forEach(function (key) {\n presetPalettes[key] = generate(presetPrimaryColors[key]);\n presetPalettes[key].primary = presetPalettes[key][5]; // dark presetPalettes\n\n presetDarkPalettes[key] = generate(presetPrimaryColors[key], {\n theme: 'dark',\n backgroundColor: '#141414'\n });\n presetDarkPalettes[key].primary = presetDarkPalettes[key][5];\n});\nvar red = presetPalettes.red;\nvar volcano = presetPalettes.volcano;\nvar gold = presetPalettes.gold;\nvar orange = presetPalettes.orange;\nvar yellow = presetPalettes.yellow;\nvar lime = presetPalettes.lime;\nvar green = presetPalettes.green;\nvar cyan = presetPalettes.cyan;\nvar blue = presetPalettes.blue;\nvar geekblue = presetPalettes.geekblue;\nvar purple = presetPalettes.purple;\nvar magenta = presetPalettes.magenta;\nvar grey = presetPalettes.grey;\n\nexport { blue, cyan, geekblue, generate, gold, green, grey, lime, magenta, orange, presetDarkPalettes, presetPalettes, presetPrimaryColors, purple, red, volcano, yellow };\n","/**\n * 创建DOM 节点\n * @param {String} str Dom 字符串\n * @return {HTMLElement} DOM 节点\n */\nvar TABLE;\nvar TABLE_TR;\nvar FRAGMENT_REG;\nvar CONTAINERS;\nfunction initConstants() {\n TABLE = document.createElement('table');\n TABLE_TR = document.createElement('tr');\n FRAGMENT_REG = /^\\s*<(\\w+|!)[^>]*>/;\n CONTAINERS = {\n tr: document.createElement('tbody'),\n tbody: TABLE,\n thead: TABLE,\n tfoot: TABLE,\n td: TABLE_TR,\n th: TABLE_TR,\n '*': document.createElement('div'),\n };\n}\nexport default function createDom(str) {\n if (!TABLE) {\n initConstants();\n }\n var name = FRAGMENT_REG.test(str) && RegExp.$1;\n if (!name || !(name in CONTAINERS)) {\n name = '*';\n }\n var container = CONTAINERS[name];\n str = str.replace(/(^\\s*)|(\\s*$)/g, '');\n container.innerHTML = '' + str;\n var dom = container.childNodes[0];\n container.removeChild(dom);\n return dom;\n}\n//# sourceMappingURL=create-dom.js.map","import color from 'color';\nimport { generate } from '@ant-design/colors';\n/**\n * get the mix color of backColor and frontColor with alpah\n * @param backColor background color\n * @param frontColor foreground color\n * @param frontAlpha the opacity of foreground color\n */\n\nexport var mixColor = function mixColor(backColor, frontColor, frontAlpha) {\n var bc = color(backColor);\n var fc = color(frontColor);\n return color([(1 - frontAlpha) * bc.red() + frontAlpha * fc.red(), (1 - frontAlpha) * bc.green() + frontAlpha * fc.green(), (1 - frontAlpha) * bc.blue() + frontAlpha * fc.blue()]).rgb();\n};\n\nvar getColorsWithDefaultTheme = function getColorsWithDefaultTheme(subjectColor, backColor, disableColor) {\n if (backColor === void 0) {\n backColor = '#fff';\n }\n\n if (disableColor === void 0) {\n disableColor = 'rgb(150, 150, 150)';\n }\n\n var subjectColor005 = mixColor(backColor, subjectColor, 0.05).rgb().toString();\n var subjectColor01 = mixColor(backColor, subjectColor, 0.1).rgb().toString();\n var subjectColor02 = mixColor(backColor, subjectColor, 0.2).rgb().toString();\n var subjectColor04 = mixColor(backColor, subjectColor, 0.4).rgb().toString();\n var disableColor002 = mixColor(backColor, disableColor, 0.02).rgb().toString();\n var disableColor005 = mixColor(backColor, disableColor, 0.05).rgb().toString();\n var disableColor01 = mixColor(backColor, disableColor, 0.1).rgb().toString();\n var disableColor02 = mixColor(backColor, disableColor, 0.2).rgb().toString();\n var disableColor03 = mixColor(backColor, disableColor, 0.3).rgb().toString();\n var paletteFromSubject = generate(subjectColor, {\n theme: 'default',\n backgroundColor: backColor\n });\n var subjectHex = color(subjectColor).hex().toLowerCase();\n var subjectIdx = paletteFromSubject.indexOf(subjectHex);\n var deeperSubject = subjectColor;\n\n if (subjectIdx !== -1) {\n deeperSubject = paletteFromSubject[subjectIdx + 1];\n }\n\n return {\n // for nodes\n mainStroke: subjectColor,\n mainFill: subjectColor01,\n activeStroke: subjectColor,\n activeFill: subjectColor005,\n inactiveStroke: subjectColor04,\n inactiveFill: subjectColor005,\n selectedStroke: subjectColor,\n selectedFill: backColor,\n highlightStroke: deeperSubject,\n highlightFill: subjectColor02,\n disableStroke: disableColor03,\n disableFill: disableColor005,\n // for edges\n edgeMainStroke: disableColor03,\n edgeActiveStroke: subjectColor,\n edgeInactiveStroke: disableColor02,\n edgeSelectedStroke: subjectColor,\n edgeHighlightStroke: subjectColor,\n edgeDisableStroke: disableColor01,\n // for combos\n comboMainStroke: disableColor03,\n comboMainFill: disableColor002,\n comboActiveStroke: subjectColor,\n comboActiveFill: subjectColor005,\n comboInactiveStroke: disableColor03,\n comboInactiveFill: disableColor002,\n comboSelectedStroke: subjectColor,\n comboSelectedFill: disableColor002,\n comboHighlightStroke: deeperSubject,\n comboHighlightFill: disableColor002,\n comboDisableStroke: disableColor02,\n comboDisableFill: disableColor005\n };\n};\n\nvar getColorsWithDarkTheme = function getColorsWithDarkTheme(subjectColor, backColor, disableColor) {\n if (backColor === void 0) {\n backColor = '#fff';\n }\n\n if (disableColor === void 0) {\n disableColor = '#777';\n }\n\n var subjectColor02 = mixColor(backColor, subjectColor, 0.2).rgb().toString();\n var subjectColor03 = mixColor(backColor, subjectColor, 0.3).rgb().toString();\n var subjectColor06 = mixColor(backColor, subjectColor, 0.6).rgb().toString();\n var subjectColor08 = mixColor(backColor, subjectColor, 0.8).rgb().toString();\n var disableColor02 = mixColor(backColor, disableColor, 0.2).rgb().toString();\n var disableColor025 = mixColor(backColor, disableColor, 0.25).rgb().toString();\n var disableColor03 = mixColor(backColor, disableColor, 0.3).rgb().toString();\n var disableColor04 = mixColor(backColor, disableColor, 0.4).rgb().toString();\n var disableColor05 = mixColor(backColor, disableColor, 0.5).rgb().toString();\n var paletteFromSubject = generate(subjectColor, {\n theme: 'dark',\n backgroundColor: backColor\n });\n var subjectHex = color(subjectColor).hex().toLowerCase();\n var subjectIdx = paletteFromSubject.indexOf(subjectHex);\n var deeperSubject = subjectColor;\n\n if (subjectIdx !== -1) {\n deeperSubject = paletteFromSubject[subjectIdx + 1];\n }\n\n return {\n // for nodes\n mainStroke: subjectColor08,\n mainFill: subjectColor02,\n activeStroke: subjectColor,\n activeFill: subjectColor03,\n inactiveStroke: subjectColor08,\n inactiveFill: subjectColor02,\n selectedStroke: subjectColor,\n selectedFill: subjectColor02,\n highlightStroke: subjectColor,\n highlightFill: subjectColor06,\n disableStroke: disableColor05,\n disableFill: disableColor025,\n // for edges\n edgeMainStroke: disableColor,\n edgeActiveStroke: subjectColor,\n edgeInactiveStroke: disableColor,\n edgeSelectedStroke: subjectColor,\n edgeHighlightStroke: subjectColor,\n edgeDisableStroke: disableColor03,\n // for combos\n comboMainStroke: disableColor04,\n comboMainFill: disableColor025,\n comboActiveStroke: subjectColor,\n comboActiveFill: disableColor02,\n comboInactiveStroke: disableColor04,\n comboInactiveFill: disableColor025,\n comboSelectedStroke: subjectColor,\n comboSelectedFill: disableColor02,\n comboHighlightStroke: deeperSubject,\n comboHighlightFill: disableColor025,\n comboDisableStroke: disableColor04,\n comboDisableFill: disableColor02\n };\n};\n/**\n * get the set of colors according to the subject color and background color\n * @param subjectColor the subject color\n * @param backColor background color\n * @param disableColor the color for disable state\n */\n\n\nexport var getColorsWithSubjectColor = function getColorsWithSubjectColor(subjectColor, backColor, theme, disableColor) {\n if (backColor === void 0) {\n backColor = '#fff';\n }\n\n if (theme === void 0) {\n theme = 'default';\n }\n\n if (disableColor === void 0) {\n disableColor = 'rgb(150, 150, 150)';\n }\n\n if (theme === 'default') return getColorsWithDefaultTheme(subjectColor, backColor, 'rgb(150, 150, 150)');\n return getColorsWithDarkTheme(subjectColor, backColor, '#777');\n};\nexport var getColorSetsBySubjectColors = function getColorSetsBySubjectColors(subjectColors, backColor, theme, disableColor) {\n if (backColor === void 0) {\n backColor = '#fff';\n }\n\n if (theme === void 0) {\n theme = 'default';\n }\n\n if (disableColor === void 0) {\n disableColor = 'rgb(150, 150, 150)';\n }\n\n var sets = [];\n subjectColors.forEach(function (sColor) {\n sets.push(getColorsWithSubjectColor(sColor, backColor, theme, disableColor));\n });\n return sets;\n};","import { getColorsWithSubjectColor } from './util/color';\nvar subjectColor = 'rgb(95, 149, 255)';\nvar backColor = 'rgb(255, 255, 255)';\nvar textColor = 'rgb(0, 0, 0)';\nvar colorSet = getColorsWithSubjectColor(subjectColor, backColor);\nexport default {\n version: '0.3.11',\n rootContainerClassName: 'root-container',\n nodeContainerClassName: 'node-container',\n edgeContainerClassName: 'edge-container',\n comboContainerClassName: 'combo-container',\n delegateContainerClassName: 'delegate-container',\n defaultLoopPosition: 'top',\n nodeLabel: {\n style: {\n fill: '#000',\n fontSize: 12,\n textAlign: 'center',\n textBaseline: 'middle'\n },\n offset: 4 // 节点的默认文本不居中时的偏移量\n\n },\n defaultNode: {\n type: 'circle',\n style: {\n lineWidth: 1,\n stroke: colorSet.mainStroke,\n fill: colorSet.mainFill\n },\n size: 20,\n color: colorSet.mainStroke,\n linkPoints: {\n size: 8,\n lineWidth: 1,\n fill: colorSet.activeFill,\n stroke: colorSet.activeStroke\n }\n },\n // 节点应用状态后的样式,默认仅提供 active、selected、highlight、inactive、disable,用户可以自己扩展\n nodeStateStyles: {\n active: {\n fill: colorSet.activeFill,\n stroke: colorSet.activeStroke,\n lineWidth: 2,\n shadowColor: colorSet.mainStroke,\n shadowBlur: 10\n },\n selected: {\n fill: colorSet.selectedFill,\n stroke: colorSet.selectedStroke,\n lineWidth: 4,\n shadowColor: colorSet.selectedStroke,\n shadowBlur: 10,\n 'text-shape': {\n fontWeight: 500\n }\n },\n highlight: {\n fill: colorSet.highlightFill,\n stroke: colorSet.highlightStroke,\n lineWidth: 2,\n 'text-shape': {\n fontWeight: 500\n }\n },\n inactive: {\n fill: colorSet.inactiveFill,\n stroke: colorSet.inactiveStroke,\n lineWidth: 1\n },\n disable: {\n fill: colorSet.disableFill,\n stroke: colorSet.disableStroke,\n lineWidth: 1\n }\n },\n edgeLabel: {\n style: {\n fill: textColor,\n textAlign: 'center',\n textBaseline: 'middle',\n fontSize: 12\n }\n },\n defaultEdge: {\n type: 'line',\n size: 1,\n style: {\n stroke: colorSet.edgeMainStroke,\n lineAppendWidth: 2\n },\n color: colorSet.edgeMainStroke\n },\n // 边应用状态后的样式,默认仅提供 active、selected、highlight、inactive、disable,用户可以自己扩展\n edgeStateStyles: {\n active: {\n stroke: colorSet.edgeActiveStroke,\n lineWidth: 1\n },\n selected: {\n stroke: colorSet.edgeSelectedStroke,\n lineWidth: 2,\n shadowColor: colorSet.edgeSelectedStroke,\n shadowBlur: 10,\n 'text-shape': {\n fontWeight: 500\n }\n },\n highlight: {\n stroke: colorSet.edgeHighlightStroke,\n lineWidth: 2,\n 'text-shape': {\n fontWeight: 500\n }\n },\n inactive: {\n stroke: colorSet.edgeInactiveStroke,\n lineWidth: 1\n },\n disable: {\n stroke: colorSet.edgeDisableStroke,\n lineWidth: 1\n }\n },\n comboLabel: {\n style: {\n fill: textColor,\n // textAlign: 'center',\n textBaseline: 'middle',\n fontSize: 12\n },\n refY: 10,\n refX: 10 // Combo 的默认文本不居中时的偏移量\n\n },\n defaultCombo: {\n type: 'circle',\n style: {\n fill: colorSet.comboMainFill,\n lineWidth: 1,\n stroke: colorSet.comboMainStroke,\n r: 5,\n width: 20,\n height: 10\n },\n size: [20, 5],\n color: colorSet.comboMainStroke,\n padding: [25, 20, 15, 20]\n },\n // combo 应用状态后的样式,默认仅提供 active、selected、highlight、inactive、disable,用户可以自己扩展\n comboStateStyles: {\n active: {\n stroke: colorSet.comboActiveStroke,\n lineWidth: 1,\n fill: colorSet.comboActiveFill\n },\n selected: {\n stroke: colorSet.comboSelectedStroke,\n lineWidth: 2,\n fill: colorSet.comboSelectedFill,\n shadowColor: colorSet.comboSelectedStroke,\n shadowBlur: 10,\n 'text-shape': {\n fontWeight: 500\n }\n },\n highlight: {\n stroke: colorSet.comboHighlightStroke,\n lineWidth: 2,\n fill: colorSet.comboHighlightFill,\n 'text-shape': {\n fontWeight: 500\n }\n },\n inactive: {\n stroke: colorSet.comboInactiveStroke,\n fill: colorSet.comboInactiveFill,\n lineWidth: 1\n },\n disable: {\n stroke: colorSet.comboDisableStroke,\n fill: colorSet.comboDisableFill,\n lineWidth: 1\n }\n },\n delegateStyle: {\n fill: '#F3F9FF',\n fillOpacity: 0.5,\n stroke: '#1890FF',\n strokeOpacity: 0.9,\n lineDash: [5, 5]\n },\n // 文本水印默认配置\n textWaterMarkerConfig: {\n width: 150,\n height: 100,\n compatible: false,\n text: {\n x: 0,\n y: 60,\n lineHeight: 20,\n rotate: 20,\n fontSize: 14,\n fontFamily: 'Microsoft YaHei',\n fill: 'rgba(0, 0, 0, 0.1)',\n baseline: 'Middle'\n }\n },\n imageWaterMarkerConfig: {\n width: 150,\n height: 130,\n compatible: false,\n image: {\n x: 0,\n y: 0,\n width: 30,\n height: 20,\n rotate: 0\n }\n },\n waterMarkerImage: 'https://gw.alipayobjects.com/os/s/prod/antv/assets/image/logo-with-text-73b8a.svg'\n};","export default function addEventListener(target, eventType, callback) {\n if (target) {\n if (typeof target.addEventListener === 'function') {\n target.addEventListener(eventType, callback, false);\n return {\n remove: function () {\n target.removeEventListener(eventType, callback, false);\n },\n };\n // @ts-ignore\n }\n if (typeof target.attachEvent === 'function') {\n // @ts-ignore\n target.attachEvent('on' + eventType, callback);\n return {\n remove: function () {\n // @ts-ignore\n target.detachEvent('on' + eventType, callback);\n },\n };\n }\n }\n}\n//# sourceMappingURL=add-event-listener.js.map","export default function modifyCSS(dom, css) {\n if (dom) {\n for (var key in css) {\n if (css.hasOwnProperty(key)) {\n dom.style[key] = css[key];\n }\n }\n }\n return dom;\n}\n//# sourceMappingURL=modify-css.js.map","import { __extends } from \"tslib\";\nimport { addEventListener } from '@antv/dom-util';\nimport { each, isNil, wrapBehavior } from '@antv/util';\nimport { AbstractEvent, Util } from '@antv/g6-core';\nvar cloneEvent = Util.cloneEvent,\n isViewportChanged = Util.isViewportChanged;\n\nvar EventController = function (_super) {\n __extends(EventController, _super);\n\n function EventController(graph) {\n var _this = _super.call(this, graph) || this;\n\n _this.extendEvents = [];\n _this.dragging = false;\n _this.preItem = null;\n _this.graph = graph;\n _this.destroyed = false;\n\n _this.initEvents();\n\n return _this;\n } // 初始化 G6 中的事件\n\n\n EventController.prototype.initEvents = function () {\n var _a = this,\n graph = _a.graph,\n _b = _a.extendEvents,\n extendEvents = _b === void 0 ? [] : _b;\n\n var canvas = graph.get('canvas'); // canvas.set('draggable', true);\n\n var el = canvas.get('el');\n var canvasHandler = wrapBehavior(this, 'onCanvasEvents');\n var originHandler = wrapBehavior(this, 'onExtendEvents');\n var wheelHandler = wrapBehavior(this, 'onWheelEvent'); // each(EVENTS, event => {\n // canvas.off(event).on(event, canvasHandler);\n // });\n\n canvas.off('*').on('*', canvasHandler);\n this.canvasHandler = canvasHandler;\n extendEvents.push(addEventListener(el, 'DOMMouseScroll', wheelHandler));\n extendEvents.push(addEventListener(el, 'mousewheel', wheelHandler));\n\n if (typeof window !== 'undefined') {\n extendEvents.push(addEventListener(window, 'keydown', originHandler));\n extendEvents.push(addEventListener(window, 'keyup', originHandler));\n extendEvents.push(addEventListener(window, 'focus', originHandler));\n }\n }; // 获取 shape 的 item 对象\n\n\n EventController.getItemRoot = function (shape) {\n while (shape && !shape.get('item')) {\n shape = shape.get('parent');\n }\n\n return shape;\n };\n /**\n * 处理 canvas 事件\n * @param evt 事件句柄\n */\n\n\n EventController.prototype.onCanvasEvents = function (evt) {\n var graph = this.graph;\n var canvas = graph.get('canvas');\n var target = evt.target;\n var eventType = evt.type;\n /**\n * (clientX, clientY): 相对于页面的坐标;\n * (canvasX, canvasY): 相对于 <canvas> 左上角的坐标;\n * (x, y): 相对于整个画布的坐标, 与 model 的 x, y 是同一维度的。\n */\n\n evt.canvasX = evt.x;\n evt.canvasY = evt.y;\n var point = {\n x: evt.canvasX,\n y: evt.canvasY\n };\n var group = graph.get('group');\n var matrix = group.getMatrix();\n\n if (!matrix) {\n matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n }\n\n if (isViewportChanged(matrix)) {\n point = graph.getPointByClient(evt.clientX, evt.clientY);\n }\n\n evt.x = point.x;\n evt.y = point.y;\n evt.currentTarget = graph;\n\n if (target === canvas) {\n if (eventType === 'mousemove' || eventType === 'mouseleave') {\n this.handleMouseMove(evt, 'canvas');\n }\n\n evt.target = canvas;\n evt.item = null;\n graph.emit(eventType, evt);\n graph.emit(\"canvas:\" + eventType, evt);\n return;\n }\n\n var itemShape = EventController.getItemRoot(target);\n\n if (!itemShape) {\n graph.emit(eventType, evt);\n return;\n }\n\n var item = itemShape.get('item');\n\n if (item.destroyed) {\n return;\n }\n\n var type = item.getType(); // 事件target是触发事件的Shape实例,item是触发事件的item实例\n\n evt.target = target;\n evt.item = item;\n\n if (evt.canvasX === evt.x && evt.canvasY === evt.y) {\n var canvasPoint = graph.getCanvasByPoint(evt.x, evt.y);\n evt.canvasX = canvasPoint.x;\n evt.canvasY = canvasPoint.y;\n } // emit('click', evt);\n\n\n graph.emit(eventType, evt);\n if (evt.name && !evt.name.includes(':')) graph.emit(type + \":\" + eventType, evt); // emit('node:click', evt)\n else graph.emit(evt.name, evt); // emit('text-shape:click', evt)\n\n if (eventType === 'dragstart') {\n this.dragging = true;\n }\n\n if (eventType === 'dragend') {\n this.dragging = false;\n }\n\n if (eventType === 'mousemove') {\n this.handleMouseMove(evt, type);\n }\n };\n /**\n * 处理扩展事件\n * @param evt 事件句柄\n */\n\n\n EventController.prototype.onExtendEvents = function (evt) {\n this.graph.emit(evt.type, evt);\n };\n /**\n * 处理滚轮事件\n * @param evt 事件句柄\n */\n\n\n EventController.prototype.onWheelEvent = function (evt) {\n if (isNil(evt.wheelDelta)) {\n evt.wheelDelta = -evt.detail;\n }\n\n this.graph.emit('wheel', evt);\n };\n /**\n * 处理鼠标移动的事件\n * @param evt 事件句柄\n * @param type item 类型\n */\n\n\n EventController.prototype.handleMouseMove = function (evt, type) {\n var _a = this,\n graph = _a.graph,\n preItem = _a.preItem;\n\n var canvas = graph.get('canvas');\n var item = evt.target === canvas ? null : evt.item;\n evt = cloneEvent(evt); // 从前一个item直接移动到当前item,触发前一个item的leave事件\n\n if (preItem && preItem !== item && !preItem.destroyed) {\n evt.item = preItem;\n this.emitCustomEvent(preItem.getType(), 'mouseleave', evt);\n\n if (this.dragging) {\n this.emitCustomEvent(preItem.getType(), 'dragleave', evt);\n }\n } // 从一个item或canvas移动到当前item,触发当前item的enter事件\n\n\n if (item && preItem !== item) {\n evt.item = item;\n this.emitCustomEvent(type, 'mouseenter', evt);\n\n if (this.dragging) {\n this.emitCustomEvent(type, 'dragenter', evt);\n }\n }\n\n this.preItem = item;\n };\n /**\n * 在 graph 上面 emit 事件\n * @param itemType item 类型\n * @param eventType 事件类型\n * @param evt 事件句柄\n */\n\n\n EventController.prototype.emitCustomEvent = function (itemType, eventType, evt) {\n evt.type = eventType;\n this.graph.emit(itemType + \":\" + eventType, evt);\n };\n\n EventController.prototype.destroy = function () {\n var _a = this,\n graph = _a.graph,\n canvasHandler = _a.canvasHandler,\n extendEvents = _a.extendEvents;\n\n var canvas = graph.get('canvas'); // each(EVENTS, event => {\n // canvas.off(event, canvasHandler);\n // });\n\n canvas.off('*', canvasHandler);\n each(extendEvents, function (event) {\n event.remove();\n });\n this.dragging = false;\n this.preItem = null;\n this.extendEvents.length = 0;\n this.canvasHandler = null;\n this.destroyed = true;\n };\n\n return EventController;\n}(AbstractEvent);\n\nexport default EventController;","export class Base {\n constructor() {\n this.nodes = [];\n this.edges = [];\n this.combos = [];\n this.positions = [];\n this.destroyed = false;\n this.onLayoutEnd = () => { };\n }\n layout(data) {\n this.init(data);\n return this.execute(true);\n }\n init(data) {\n this.nodes = data.nodes || [];\n this.edges = data.edges || [];\n this.combos = data.combos || [];\n }\n execute(reloadData) { }\n executeWithWorker() { }\n getDefaultCfg() {\n return {};\n }\n updateCfg(cfg) {\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n getType() {\n return 'base';\n }\n destroy() {\n this.nodes = null;\n this.edges = null;\n this.combos = null;\n this.positions = null;\n this.destroyed = true;\n }\n}\n//# sourceMappingURL=base.js.map","export const isString = (val) => typeof val === 'string';\nconst cacheStringFunction = (fn) => {\n const cache = Object.create(null);\n return ((str) => {\n const hit = cache[str];\n return hit || (cache[str] = fn(str));\n });\n};\nconst camelizeRE = /-(\\w)/g;\nexport const camelize = cacheStringFunction((str) => {\n return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : ''));\n});\n// export const capitalize = cacheStringFunction(\n// (str: string) => str.charAt(0).toUpperCase() + str.slice(1),\n// )\n//# sourceMappingURL=string.js.map","export const isArray = Array.isArray;\n//# sourceMappingURL=array.js.map","export const isNumber = (val) => typeof val === 'number';\nexport const isNaN = (num) => Number.isNaN(Number(num));\nexport const toNumber = (val) => {\n const n = parseFloat(val);\n return isNaN(n) ? val : n;\n};\n//# sourceMappingURL=number.js.map","export const isObject = (val) => val !== null && typeof val === 'object';\nexport const clone = (target) => {\n if (target === null) {\n return target;\n }\n if (target instanceof Date) {\n return new Date(target.getTime());\n }\n if (target instanceof Array) {\n const cp = [];\n target.forEach((v) => {\n cp.push(v);\n });\n return cp.map((n) => clone(n));\n }\n if (typeof target === 'object' && target !== {}) {\n const cp = Object.assign({}, target);\n Object.keys(cp).forEach((k) => {\n cp[k] = clone(cp[k]);\n });\n return cp;\n }\n return target;\n};\n//# sourceMappingURL=object.js.map","import { each, isNil } from '@antv/util';\n// 求以a为次幂,结果为b的基数,如 x^^a = b;求x\n// 虽然数学上 b 不支持负数,但是这里需要支持 负数\nexport function calBase(a, b) {\n var e = Math.E;\n var value;\n if (b >= 0) {\n value = Math.pow(e, Math.log(b) / a); // 使用换底公式求底\n }\n else {\n value = Math.pow(e, Math.log(-b) / a) * -1; // 使用换底公式求底\n }\n return value;\n}\nexport function log(a, b) {\n if (a === 1) {\n return 1;\n }\n return Math.log(b) / Math.log(a);\n}\nexport function getLogPositiveMin(values, base, max) {\n if (isNil(max)) {\n max = Math.max.apply(null, values);\n }\n var positiveMin = max;\n each(values, function (value) {\n if (value > 0 && value < positiveMin) {\n positiveMin = value;\n }\n });\n if (positiveMin === max) {\n positiveMin = max / base;\n }\n if (positiveMin > 1) {\n positiveMin = 1;\n }\n return positiveMin;\n}\nfunction digitLength(num) {\n // Get digit length of e\n var eSplit = num.toString().split(/[eE]/);\n var len = (eSplit[0].split('.')[1] || '').length - +(eSplit[1] || 0);\n return len > 0 ? len : 0;\n}\n/**\n * 高精度加法,解决 0.1 + 0.2 !== 0.3 的经典问题\n *\n * @param num1 加数\n * @param num2 被加数\n * @return {number} 返回值\n */\nexport function precisionAdd(num1, num2) {\n var num1Digits = digitLength(num1);\n var num2Digits = digitLength(num2);\n var baseNum = Math.pow(10, Math.max(num1Digits, num2Digits));\n return (num1 * baseNum + num2 * baseNum) / baseNum;\n}\n//# sourceMappingURL=math.js.map","export const isFunction = (val) => typeof val === 'function';\n//# sourceMappingURL=function.js.map","import { Base } from \"../layout/base\";\nimport { isObject } from \"../util\";\nconst map = new Map();\nexport const registerLayout = (name, layoutOverride) => {\n if (map.get(name)) {\n console.warn(`The layout with the name ${name} exists already, it will be overridden`);\n }\n if (isObject(layoutOverride)) {\n // tslint:disable-next-line: max-classes-per-file\n class GLayout extends Base {\n constructor(cfg) {\n super();\n const self = this;\n const props = {};\n const defaultCfg = self.getDefaultCfg();\n Object.assign(props, defaultCfg, layoutOverride, cfg);\n Object.keys(props).forEach((key) => {\n const value = props[key];\n self[key] = value;\n });\n }\n }\n map.set(name, GLayout);\n }\n else {\n map.set(name, layoutOverride);\n }\n};\nexport const unRegisterLayout = (name) => {\n if (map.has(name)) {\n map.delete(name);\n }\n};\nexport const getLayoutByName = (name) => {\n if (map.has(name)) {\n return map.get(name);\n }\n return null;\n};\n//# sourceMappingURL=index.js.map","/**\n * @fileOverview grid layout\n * @author shiwu.wyy@antfin.com\n * this algorithm refers to <cytoscape.js> - https://github.com/cytoscape/cytoscape.js/\n */\nimport { isString, isArray, isNumber, getDegree, isNaN, isObject } from \"../util\";\nimport { Base } from \"./base\";\n/**\n * 网格布局\n */\nexport class GridLayout extends Base {\n constructor(options) {\n super();\n /** 布局起始点 */\n this.begin = [0, 0];\n /** prevents node overlap, may overflow boundingBox if not enough space */\n this.preventOverlap = true;\n /** extra spacing around nodes when preventOverlap: true */\n this.preventOverlapPadding = 10;\n /** uses all available space on false, uses minimal space on true */\n this.condense = false;\n /** a sorting function to order the nodes; e.g. function(a, b){ return a.datapublic ('weight') - b.data('weight') } */\n this.sortBy = \"degree\";\n this.nodeSize = 30;\n this.nodes = [];\n this.edges = [];\n this.width = 300;\n this.height = 300;\n this.row = 0;\n this.col = 0;\n this.cellWidth = 0;\n this.cellHeight = 0;\n this.cellUsed = {};\n this.id2manPos = {};\n /** 迭代结束的回调函数 */\n this.onLayoutEnd = () => { };\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n begin: [0, 0],\n preventOverlap: true,\n preventOverlapPadding: 10,\n condense: false,\n rows: undefined,\n cols: undefined,\n position: undefined,\n sortBy: \"degree\",\n nodeSize: 30\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const n = nodes.length;\n const begin = self.begin;\n if (n === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return {\n nodes,\n edges\n };\n }\n if (n === 1) {\n nodes[0].x = begin[0];\n nodes[0].y = begin[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return {\n nodes,\n edges,\n };\n }\n const layoutNodes = [];\n nodes.forEach((node) => {\n layoutNodes.push(node);\n });\n const nodeIdxMap = {};\n layoutNodes.forEach((node, i) => {\n nodeIdxMap[node.id] = i;\n });\n if (self.sortBy === \"degree\" ||\n !isString(self.sortBy) ||\n layoutNodes[0][self.sortBy] === undefined) {\n self.sortBy = \"degree\";\n if (isNaN(nodes[0].degree)) {\n const values = getDegree(layoutNodes.length, nodeIdxMap, edges);\n layoutNodes.forEach((node, i) => {\n node.degree = values[i];\n });\n }\n }\n // sort nodes by value\n layoutNodes.sort((n1, n2) => n2[self.sortBy] - n1[self.sortBy]);\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n const oRows = self.rows;\n const oCols = self.cols != null ? self.cols : self.columns;\n self.cells = n;\n // if rows or columns were set in self, use those values\n if (oRows != null && oCols != null) {\n self.rows = oRows;\n self.cols = oCols;\n }\n else if (oRows != null && oCols == null) {\n self.rows = oRows;\n self.cols = Math.ceil(self.cells / self.rows);\n }\n else if (oRows == null && oCols != null) {\n self.cols = oCols;\n self.rows = Math.ceil(self.cells / self.cols);\n }\n else {\n // otherwise use the automatic values and adjust accordingly\t // otherwise use the automatic values and adjust accordingly\n // width/height * splits^2 = cells where splits is number of times to split width\n self.splits = Math.sqrt((self.cells * self.height) / self.width);\n self.rows = Math.round(self.splits);\n self.cols = Math.round((self.width / self.height) * self.splits);\n }\n if (self.cols * self.rows > self.cells) {\n // otherwise use the automatic values and adjust accordingly\n // if rounding was up, see if we can reduce rows or columns\n const sm = self.small();\n const lg = self.large();\n // reducing the small side takes away the most cells, so try it first\n if ((sm - 1) * lg >= self.cells) {\n self.small(sm - 1);\n }\n else if ((lg - 1) * sm >= self.cells) {\n self.large(lg - 1);\n }\n }\n else {\n // if rounding was too low, add rows or columns\n while (self.cols * self.rows < self.cells) {\n const sm = self.small();\n const lg = self.large();\n // try to add to larger side first (adds less in multiplication)\n if ((lg + 1) * sm >= self.cells) {\n self.large(lg + 1);\n }\n else {\n self.small(sm + 1);\n }\n }\n }\n self.cellWidth = self.width / self.cols;\n self.cellHeight = self.height / self.rows;\n if (self.condense) {\n self.cellWidth = 0;\n self.cellHeight = 0;\n }\n if (self.preventOverlap) {\n layoutNodes.forEach((node) => {\n if (!node.x || !node.y) {\n // for bb\n node.x = 0;\n node.y = 0;\n }\n let nodew;\n let nodeh;\n if (isArray(node.size)) {\n nodew = node.size[0];\n nodeh = node.size[1];\n }\n else if (isNumber(node.size)) {\n nodew = node.size;\n nodeh = node.size;\n }\n else if (isObject(node.size)) {\n nodew = node.size.width;\n nodeh = node.size.height;\n }\n if (nodew === undefined || nodeh === undefined) {\n if (isArray(self.nodeSize)) {\n nodew = self.nodeSize[0];\n nodeh = self.nodeSize[1];\n }\n else if (isNumber(self.nodeSize)) {\n nodew = self.nodeSize;\n nodeh = self.nodeSize;\n }\n else {\n nodew = 30;\n nodeh = 30;\n }\n }\n const p = self.preventOverlapPadding;\n const w = nodew + p;\n const h = nodeh + p;\n self.cellWidth = Math.max(self.cellWidth, w);\n self.cellHeight = Math.max(self.cellHeight, h);\n });\n }\n self.cellUsed = {}; // e.g. 'c-0-2' => true\n // to keep track of current cell position\n self.row = 0;\n self.col = 0;\n // get a cache of all the manual positions\n self.id2manPos = {};\n for (let i = 0; i < layoutNodes.length; i++) {\n const node = layoutNodes[i];\n let rcPos;\n if (self.position) {\n rcPos = self.position(node);\n }\n if (rcPos && (rcPos.row !== undefined || rcPos.col !== undefined)) {\n // must have at least row or col def'd\n const pos = {\n row: rcPos.row,\n col: rcPos.col\n };\n if (pos.col === undefined) {\n // find unused col\n pos.col = 0;\n while (self.used(pos.row, pos.col)) {\n pos.col++;\n }\n }\n else if (pos.row === undefined) {\n // find unused row\n pos.row = 0;\n while (self.used(pos.row, pos.col)) {\n pos.row++;\n }\n }\n self.id2manPos[node.id] = pos;\n self.use(pos.row, pos.col);\n }\n self.getPos(node);\n }\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return {\n edges,\n nodes: layoutNodes\n };\n }\n small(val) {\n const self = this;\n let res;\n const rows = self.rows || 5;\n const cols = self.cols || 5;\n if (val == null) {\n res = Math.min(rows, cols);\n }\n else {\n const min = Math.min(rows, cols);\n if (min === self.rows) {\n self.rows = val;\n }\n else {\n self.cols = val;\n }\n }\n return res;\n }\n large(val) {\n const self = this;\n let res;\n const rows = self.rows || 5;\n const cols = self.cols || 5;\n if (val == null) {\n res = Math.max(rows, cols);\n }\n else {\n const max = Math.max(rows, cols);\n if (max === self.rows) {\n self.rows = val;\n }\n else {\n self.cols = val;\n }\n }\n return res;\n }\n used(row, col) {\n const self = this;\n return self.cellUsed[`c-${row}-${col}`] || false;\n }\n use(row, col) {\n const self = this;\n self.cellUsed[`c-${row}-${col}`] = true;\n }\n moveToNextCell() {\n const self = this;\n const cols = self.cols || 5;\n self.col++;\n if (self.col >= cols) {\n self.col = 0;\n self.row++;\n }\n }\n getPos(node) {\n const self = this;\n const begin = self.begin;\n const cellWidth = self.cellWidth;\n const cellHeight = self.cellHeight;\n let x;\n let y;\n // see if we have a manual position set\n const rcPos = self.id2manPos[node.id];\n if (rcPos) {\n x = rcPos.col * cellWidth + cellWidth / 2 + begin[0];\n y = rcPos.row * cellHeight + cellHeight / 2 + begin[1];\n }\n else {\n // otherwise set automatically\n while (self.used(self.row, self.col)) {\n self.moveToNextCell();\n }\n x = self.col * cellWidth + cellWidth / 2 + begin[0];\n y = self.row * cellHeight + cellHeight / 2 + begin[1];\n self.use(self.row, self.col);\n self.moveToNextCell();\n }\n node.x = x;\n node.y = y;\n }\n getType() {\n return \"grid\";\n }\n}\n//# sourceMappingURL=grid.js.map","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\nimport { Base } from \"./base\";\n/**\n * 随机布局\n */\nexport class RandomLayout extends Base {\n constructor(options) {\n super();\n /** 布局中心 */\n this.center = [0, 0];\n /** 宽度 */\n this.width = 300;\n /** 高度 */\n this.height = 300;\n this.nodes = [];\n this.edges = [];\n /** 迭代结束的回调函数 */\n this.onLayoutEnd = () => { };\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n center: [0, 0],\n width: 300,\n height: 300\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const nodes = self.nodes;\n const layoutScale = 0.9;\n const center = self.center;\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (nodes) {\n nodes.forEach((node) => {\n node.x = (Math.random() - 0.5) * layoutScale * self.width + center[0];\n node.y = (Math.random() - 0.5) * layoutScale * self.height + center[1];\n });\n }\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return {\n nodes,\n edges: this.edges\n };\n }\n getType() {\n return \"random\";\n }\n}\n//# sourceMappingURL=random.js.map","/**\n * @fileOverview fruchterman layout\n * @author shiwu.wyy@antfin.com\n */\nimport { Base } from \"./base\";\nimport { isNumber, isFunction, isArray, getDegree, isObject, getEdgeTerminal } from \"../util\";\nconst proccessToFunc = (value, defaultV) => {\n let func;\n if (!value) {\n func = (d) => {\n return defaultV || 1;\n };\n }\n else if (isNumber(value)) {\n func = (d) => {\n return value;\n };\n }\n else {\n func = value;\n }\n return func;\n};\n/**\n * graphin 中的 force 布局\n */\nexport class GForceLayout extends Base {\n constructor(options) {\n super();\n /** 停止迭代的最大迭代数 */\n this.maxIteration = 1000;\n /** 弹簧引力系数 */\n this.edgeStrength = 200;\n /** 斥力系数 */\n this.nodeStrength = 1000;\n /** 库伦系数 */\n this.coulombDisScale = 0.005;\n /** 阻尼系数 */\n this.damping = 0.9;\n /** 最大速度 */\n this.maxSpeed = 1000;\n /** 一次迭代的平均移动距离小于该值时停止迭代 */\n this.minMovement = 0.5;\n /** 迭代中衰减 */\n this.interval = 0.02;\n /** 斥力的一个系数 */\n this.factor = 1;\n /** 理想边长 */\n this.linkDistance = 1;\n /** 重力大小 */\n this.gravity = 10;\n /** 是否防止重叠 */\n this.preventOverlap = true;\n /** 每次迭代结束的回调函数 */\n this.tick = () => { };\n this.nodes = [];\n this.edges = [];\n this.width = 300;\n this.height = 300;\n this.nodeMap = {};\n this.nodeIdxMap = {};\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n maxIteration: 500,\n gravity: 10,\n enableTick: true\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const nodes = self.nodes;\n if (self.timeInterval !== undefined && typeof window !== \"undefined\") {\n window.clearInterval(self.timeInterval);\n }\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n const nodeMap = {};\n const nodeIdxMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x))\n node.x = Math.random() * self.width;\n if (!isNumber(node.y))\n node.y = Math.random() * self.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n self.linkDistance = proccessToFunc(self.linkDistance, 1);\n self.nodeStrength = proccessToFunc(self.nodeStrength, 1);\n self.edgeStrength = proccessToFunc(self.edgeStrength, 1);\n // node size function\n const nodeSize = self.nodeSize;\n let nodeSizeFunc;\n if (self.preventOverlap) {\n const nodeSpacing = self.nodeSpacing;\n let nodeSpacingFunc;\n if (isNumber(nodeSpacing)) {\n nodeSpacingFunc = () => nodeSpacing;\n }\n else if (isFunction(nodeSpacing)) {\n nodeSpacingFunc = nodeSpacing;\n }\n else {\n nodeSpacingFunc = () => 0;\n }\n if (!nodeSize) {\n nodeSizeFunc = (d) => {\n if (d.size) {\n if (isArray(d.size)) {\n const res = d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n return res + nodeSpacingFunc(d);\n }\n if (isObject(d.size)) {\n const res = d.size.width > d.size.height ? d.size.width : d.size.height;\n return res + nodeSpacingFunc(d);\n }\n return d.size + nodeSpacingFunc(d);\n }\n return 10 + nodeSpacingFunc(d);\n };\n }\n else if (isArray(nodeSize)) {\n nodeSizeFunc = (d) => {\n const res = nodeSize[0] > nodeSize[1] ? nodeSize[0] : nodeSize[1];\n return res + nodeSpacingFunc(d);\n };\n }\n else {\n nodeSizeFunc = (d) => nodeSize + nodeSpacingFunc(d);\n }\n }\n self.nodeSize = nodeSizeFunc;\n const edges = self.edges;\n self.degrees = getDegree(nodes.length, self.nodeIdxMap, edges);\n if (!self.getMass) {\n self.getMass = (d) => {\n const mass = self.degrees[self.nodeIdxMap[d.id]] || 1;\n return mass;\n };\n }\n // layout\n self.run();\n }\n run() {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const maxIteration = self.maxIteration;\n if (typeof window === \"undefined\")\n return;\n let iter = 0;\n // interval for render the result after each iteration\n this.timeInterval = window.setInterval(() => {\n const accArray = [];\n const velArray = [];\n if (!nodes)\n return;\n nodes.forEach((_, i) => {\n accArray[2 * i] = 0;\n accArray[2 * i + 1] = 0;\n velArray[2 * i] = 0;\n velArray[2 * i + 1] = 0;\n });\n self.calRepulsive(accArray, nodes);\n if (edges)\n self.calAttractive(accArray, edges);\n self.calGravity(accArray, nodes);\n const stepInterval = Math.max(0.02, self.interval - iter * 0.002);\n self.updateVelocity(accArray, velArray, stepInterval, nodes);\n const previousPos = [];\n nodes.forEach((node) => {\n previousPos.push({\n x: node.x,\n y: node.y\n });\n });\n self.updatePosition(velArray, stepInterval, nodes);\n if (self.tick)\n self.tick();\n // whether to stop the iteration\n let movement = 0;\n nodes.forEach((node, j) => {\n const vx = node.x - previousPos[j].x;\n const vy = node.y - previousPos[j].y;\n movement += Math.sqrt(vx * vx + vy * vy);\n });\n movement /= nodes.length;\n if (movement < self.minMovement) {\n window.clearInterval(self.timeInterval);\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n }\n iter++;\n if (iter >= maxIteration) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n window.clearInterval(self.timeInterval);\n }\n }, 0);\n }\n calRepulsive(accArray, nodes) {\n const self = this;\n // const nodes = self.nodes;\n const getMass = self.getMass;\n const nodeStrength = self.nodeStrength;\n const factor = self.factor;\n const coulombDisScale = self.coulombDisScale;\n const preventOverlap = self.preventOverlap;\n const nodeSize = self.nodeSize;\n nodes.forEach((ni, i) => {\n const massi = getMass ? getMass(ni) : 1;\n nodes.forEach((nj, j) => {\n if (i >= j)\n return;\n // if (!accArray[j]) accArray[j] = 0;\n const vecX = ni.x - nj.x;\n const vecY = ni.y - nj.y;\n const vecLength = Math.sqrt(vecX * vecX + vecY * vecY) + 0.01;\n const nVecLength = (vecLength + 0.1) * coulombDisScale;\n const direX = vecX / vecLength;\n const direY = vecY / vecLength;\n const param = (((nodeStrength(ni) + nodeStrength(nj)) / 2) * factor) /\n (nVecLength * nVecLength);\n const massj = getMass ? getMass(nj) : 1;\n accArray[2 * i] += (direX * param);\n accArray[2 * i + 1] += (direY * param);\n accArray[2 * j] -= (direX * param);\n accArray[2 * j + 1] -= (direY * param);\n if (preventOverlap && vecLength < (nodeSize(ni) + nodeSize(nj)) / 2) {\n const paramOverlap = (nodeStrength(ni) + nodeStrength(nj)) / 2 / (vecLength * vecLength);\n accArray[2 * i] += (direX * paramOverlap) / massi;\n accArray[2 * i + 1] += (direY * paramOverlap) / massi;\n accArray[2 * j] -= (direX * paramOverlap) / massj;\n accArray[2 * j + 1] -= (direY * paramOverlap) / massj;\n }\n });\n });\n }\n calAttractive(accArray, edges) {\n const self = this;\n // const edges = self.edges;\n const nodeMap = self.nodeMap;\n const nodeIdxMap = self.nodeIdxMap;\n const linkDistance = self.linkDistance;\n const edgeStrength = self.edgeStrength;\n const getMass = self.getMass;\n edges.forEach((edge, i) => {\n const source = getEdgeTerminal(edge, 'source');\n const target = getEdgeTerminal(edge, 'target');\n const sourceNode = nodeMap[source];\n const targetNode = nodeMap[target];\n const vecX = targetNode.x - sourceNode.x;\n const vecY = targetNode.y - sourceNode.y;\n const vecLength = Math.sqrt(vecX * vecX + vecY * vecY) + 0.01;\n const direX = vecX / vecLength;\n const direY = vecY / vecLength;\n const length = linkDistance(edge) || 1;\n const diff = length - vecLength;\n const param = diff * edgeStrength(edge);\n const sourceIdx = nodeIdxMap[source];\n const targetIdx = nodeIdxMap[target];\n const massSource = getMass ? getMass(sourceNode) : 1;\n const massTarget = getMass ? getMass(targetNode) : 1;\n accArray[2 * sourceIdx] -= (direX * param) / massSource;\n accArray[2 * sourceIdx + 1] -= (direY * param) / massSource;\n accArray[2 * targetIdx] += (direX * param) / massTarget;\n accArray[2 * targetIdx + 1] += (direY * param) / massTarget;\n });\n }\n calGravity(accArray, nodes) {\n const self = this;\n // const nodes = self.nodes;\n const center = self.center;\n const defaultGravity = self.gravity;\n const degrees = self.degrees;\n const nodeLength = nodes.length;\n for (let i = 0; i < nodeLength; i++) {\n const node = nodes[i];\n let vecX = node.x - center[0];\n let vecY = node.y - center[1];\n let gravity = defaultGravity;\n if (self.getCenter) {\n const customCenterOpt = self.getCenter(node, degrees[i]);\n if (customCenterOpt &&\n isNumber(customCenterOpt[0]) &&\n isNumber(customCenterOpt[1]) &&\n isNumber(customCenterOpt[2])) {\n vecX = node.x - customCenterOpt[0];\n vecY = node.y - customCenterOpt[1];\n gravity = customCenterOpt[2];\n }\n }\n if (!gravity)\n continue;\n accArray[2 * i] -= gravity * vecX;\n accArray[2 * i + 1] -= gravity * vecY;\n }\n }\n updateVelocity(accArray, velArray, stepInterval, nodes) {\n const self = this;\n const param = stepInterval * self.damping;\n // const nodes = self.nodes;\n nodes.forEach((node, i) => {\n let vx = accArray[2 * i] * param || 0.01;\n let vy = accArray[2 * i + 1] * param || 0.01;\n const vLength = Math.sqrt(vx * vx + vy * vy);\n if (vLength > self.maxSpeed) {\n const param2 = self.maxSpeed / vLength;\n vx = param2 * vx;\n vy = param2 * vy;\n }\n velArray[2 * i] = vx;\n velArray[2 * i + 1] = vy;\n });\n }\n updatePosition(velArray, stepInterval, nodes) {\n nodes.forEach((node, i) => {\n if (isNumber(node.fx) && isNumber(node.fy)) {\n node.x = node.fx;\n node.y = node.fy;\n return;\n }\n const distX = velArray[2 * i] * stepInterval;\n const distY = velArray[2 * i + 1] * stepInterval;\n node.x += distX;\n node.y += distY;\n });\n }\n stop() {\n if (this.timeInterval && typeof window !== \"undefined\") {\n window.clearInterval(this.timeInterval);\n }\n }\n destroy() {\n const self = this;\n self.stop();\n self.tick = null;\n self.nodes = null;\n self.edges = null;\n self.destroyed = true;\n }\n getType() {\n return \"gForce\";\n }\n}\n//# sourceMappingURL=gForce.js.map","export default function(d) {\n const x = +this._x.call(null, d),\n y = +this._y.call(null, d);\n return add(this.cover(x, y), x, y, d);\n}\n\nfunction add(tree, x, y, d) {\n if (isNaN(x) || isNaN(y)) return tree; // ignore invalid points\n\n var parent,\n node = tree._root,\n leaf = {data: d},\n x0 = tree._x0,\n y0 = tree._y0,\n x1 = tree._x1,\n y1 = tree._y1,\n xm,\n ym,\n xp,\n yp,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return tree._root = leaf, tree;\n\n // Find the existing leaf for the new point, or add it.\n while (node.length) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (parent = node, !(node = node[i = bottom << 1 | right])) return parent[i] = leaf, tree;\n }\n\n // Is the new point is exactly coincident with the existing point?\n xp = +tree._x.call(null, node.data);\n yp = +tree._y.call(null, node.data);\n if (x === xp && y === yp) return leaf.next = node, parent ? parent[i] = leaf : tree._root = leaf, tree;\n\n // Otherwise, split the leaf node until the old and new point are separated.\n do {\n parent = parent ? parent[i] = new Array(4) : tree._root = new Array(4);\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n } while ((i = bottom << 1 | right) === (j = (yp >= ym) << 1 | (xp >= xm)));\n return parent[j] = node, parent[i] = leaf, tree;\n}\n\nexport function addAll(data) {\n var d, i, n = data.length,\n x,\n y,\n xz = new Array(n),\n yz = new Array(n),\n x0 = Infinity,\n y0 = Infinity,\n x1 = -Infinity,\n y1 = -Infinity;\n\n // Compute the points and their extent.\n for (i = 0; i < n; ++i) {\n if (isNaN(x = +this._x.call(null, d = data[i])) || isNaN(y = +this._y.call(null, d))) continue;\n xz[i] = x;\n yz[i] = y;\n if (x < x0) x0 = x;\n if (x > x1) x1 = x;\n if (y < y0) y0 = y;\n if (y > y1) y1 = y;\n }\n\n // If there were no (valid) points, abort.\n if (x0 > x1 || y0 > y1) return this;\n\n // Expand the tree to cover the new points.\n this.cover(x0, y0).cover(x1, y1);\n\n // Add the new points.\n for (i = 0; i < n; ++i) {\n add(this, xz[i], yz[i], data[i]);\n }\n\n return this;\n}\n","export default function(x, y) {\n if (isNaN(x = +x) || isNaN(y = +y)) return this; // ignore invalid points\n\n var x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1;\n\n // If the quadtree has no extent, initialize them.\n // Integer extent are necessary so that if we later double the extent,\n // the existing quadrant boundaries don’t change due to floating point error!\n if (isNaN(x0)) {\n x1 = (x0 = Math.floor(x)) + 1;\n y1 = (y0 = Math.floor(y)) + 1;\n }\n\n // Otherwise, double repeatedly to cover.\n else {\n var z = x1 - x0 || 1,\n node = this._root,\n parent,\n i;\n\n while (x0 > x || x >= x1 || y0 > y || y >= y1) {\n i = (y < y0) << 1 | (x < x0);\n parent = new Array(4), parent[i] = node, node = parent, z *= 2;\n switch (i) {\n case 0: x1 = x0 + z, y1 = y0 + z; break;\n case 1: x0 = x1 - z, y1 = y0 + z; break;\n case 2: x1 = x0 + z, y0 = y1 - z; break;\n case 3: x0 = x1 - z, y0 = y1 - z; break;\n }\n }\n\n if (this._root && this._root.length) this._root = node;\n }\n\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n return this;\n}\n","export default function(node, x0, y0, x1, y1) {\n this.node = node;\n this.x0 = x0;\n this.y0 = y0;\n this.x1 = x1;\n this.y1 = y1;\n}\n","export function defaultX(d) {\n return d[0];\n}\n\nexport default function(_) {\n return arguments.length ? (this._x = _, this) : this._x;\n}\n","export function defaultY(d) {\n return d[1];\n}\n\nexport default function(_) {\n return arguments.length ? (this._y = _, this) : this._y;\n}\n","import tree_add, {addAll as tree_addAll} from \"./add.js\";\nimport tree_cover from \"./cover.js\";\nimport tree_data from \"./data.js\";\nimport tree_extent from \"./extent.js\";\nimport tree_find from \"./find.js\";\nimport tree_remove, {removeAll as tree_removeAll} from \"./remove.js\";\nimport tree_root from \"./root.js\";\nimport tree_size from \"./size.js\";\nimport tree_visit from \"./visit.js\";\nimport tree_visitAfter from \"./visitAfter.js\";\nimport tree_x, {defaultX} from \"./x.js\";\nimport tree_y, {defaultY} from \"./y.js\";\n\nexport default function quadtree(nodes, x, y) {\n var tree = new Quadtree(x == null ? defaultX : x, y == null ? defaultY : y, NaN, NaN, NaN, NaN);\n return nodes == null ? tree : tree.addAll(nodes);\n}\n\nfunction Quadtree(x, y, x0, y0, x1, y1) {\n this._x = x;\n this._y = y;\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n this._root = undefined;\n}\n\nfunction leaf_copy(leaf) {\n var copy = {data: leaf.data}, next = copy;\n while (leaf = leaf.next) next = next.next = {data: leaf.data};\n return copy;\n}\n\nvar treeProto = quadtree.prototype = Quadtree.prototype;\n\ntreeProto.copy = function() {\n var copy = new Quadtree(this._x, this._y, this._x0, this._y0, this._x1, this._y1),\n node = this._root,\n nodes,\n child;\n\n if (!node) return copy;\n\n if (!node.length) return copy._root = leaf_copy(node), copy;\n\n nodes = [{source: node, target: copy._root = new Array(4)}];\n while (node = nodes.pop()) {\n for (var i = 0; i < 4; ++i) {\n if (child = node.source[i]) {\n if (child.length) nodes.push({source: child, target: node.target[i] = new Array(4)});\n else node.target[i] = leaf_copy(child);\n }\n }\n }\n\n return copy;\n};\n\ntreeProto.add = tree_add;\ntreeProto.addAll = tree_addAll;\ntreeProto.cover = tree_cover;\ntreeProto.data = tree_data;\ntreeProto.extent = tree_extent;\ntreeProto.find = tree_find;\ntreeProto.remove = tree_remove;\ntreeProto.removeAll = tree_removeAll;\ntreeProto.root = tree_root;\ntreeProto.size = tree_size;\ntreeProto.visit = tree_visit;\ntreeProto.visitAfter = tree_visitAfter;\ntreeProto.x = tree_x;\ntreeProto.y = tree_y;\n","export default function() {\n var data = [];\n this.visit(function(node) {\n if (!node.length) do data.push(node.data); while (node = node.next)\n });\n return data;\n}\n","export default function(_) {\n return arguments.length\n ? this.cover(+_[0][0], +_[0][1]).cover(+_[1][0], +_[1][1])\n : isNaN(this._x0) ? undefined : [[this._x0, this._y0], [this._x1, this._y1]];\n}\n","import Quad from \"./quad.js\";\n\nexport default function(x, y, radius) {\n var data,\n x0 = this._x0,\n y0 = this._y0,\n x1,\n y1,\n x2,\n y2,\n x3 = this._x1,\n y3 = this._y1,\n quads = [],\n node = this._root,\n q,\n i;\n\n if (node) quads.push(new Quad(node, x0, y0, x3, y3));\n if (radius == null) radius = Infinity;\n else {\n x0 = x - radius, y0 = y - radius;\n x3 = x + radius, y3 = y + radius;\n radius *= radius;\n }\n\n while (q = quads.pop()) {\n\n // Stop searching if this quadrant can’t contain a closer node.\n if (!(node = q.node)\n || (x1 = q.x0) > x3\n || (y1 = q.y0) > y3\n || (x2 = q.x1) < x0\n || (y2 = q.y1) < y0) continue;\n\n // Bisect the current quadrant.\n if (node.length) {\n var xm = (x1 + x2) / 2,\n ym = (y1 + y2) / 2;\n\n quads.push(\n new Quad(node[3], xm, ym, x2, y2),\n new Quad(node[2], x1, ym, xm, y2),\n new Quad(node[1], xm, y1, x2, ym),\n new Quad(node[0], x1, y1, xm, ym)\n );\n\n // Visit the closest quadrant first.\n if (i = (y >= ym) << 1 | (x >= xm)) {\n q = quads[quads.length - 1];\n quads[quads.length - 1] = quads[quads.length - 1 - i];\n quads[quads.length - 1 - i] = q;\n }\n }\n\n // Visit this point. (Visiting coincident points isn’t necessary!)\n else {\n var dx = x - +this._x.call(null, node.data),\n dy = y - +this._y.call(null, node.data),\n d2 = dx * dx + dy * dy;\n if (d2 < radius) {\n var d = Math.sqrt(radius = d2);\n x0 = x - d, y0 = y - d;\n x3 = x + d, y3 = y + d;\n data = node.data;\n }\n }\n }\n\n return data;\n}\n","export default function(d) {\n if (isNaN(x = +this._x.call(null, d)) || isNaN(y = +this._y.call(null, d))) return this; // ignore invalid points\n\n var parent,\n node = this._root,\n retainer,\n previous,\n next,\n x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1,\n x,\n y,\n xm,\n ym,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return this;\n\n // Find the leaf node for the point.\n // While descending, also retain the deepest parent with a non-removed sibling.\n if (node.length) while (true) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (!(parent = node, node = node[i = bottom << 1 | right])) return this;\n if (!node.length) break;\n if (parent[(i + 1) & 3] || parent[(i + 2) & 3] || parent[(i + 3) & 3]) retainer = parent, j = i;\n }\n\n // Find the point to remove.\n while (node.data !== d) if (!(previous = node, node = node.next)) return this;\n if (next = node.next) delete node.next;\n\n // If there are multiple coincident points, remove just the point.\n if (previous) return (next ? previous.next = next : delete previous.next), this;\n\n // If this is the root point, remove it.\n if (!parent) return this._root = next, this;\n\n // Remove this leaf.\n next ? parent[i] = next : delete parent[i];\n\n // If the parent now contains exactly one leaf, collapse superfluous parents.\n if ((node = parent[0] || parent[1] || parent[2] || parent[3])\n && node === (parent[3] || parent[2] || parent[1] || parent[0])\n && !node.length) {\n if (retainer) retainer[j] = node;\n else this._root = node;\n }\n\n return this;\n}\n\nexport function removeAll(data) {\n for (var i = 0, n = data.length; i < n; ++i) this.remove(data[i]);\n return this;\n}\n","export default function() {\n return this._root;\n}\n","export default function() {\n var size = 0;\n this.visit(function(node) {\n if (!node.length) do ++size; while (node = node.next)\n });\n return size;\n}\n","import Quad from \"./quad.js\";\n\nexport default function(callback) {\n var quads = [], q, node = this._root, child, x0, y0, x1, y1;\n if (node) quads.push(new Quad(node, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n if (!callback(node = q.node, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1) && node.length) {\n var xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n }\n }\n return this;\n}\n","import Quad from \"./quad.js\";\n\nexport default function(callback) {\n var quads = [], next = [], q;\n if (this._root) quads.push(new Quad(this._root, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n var node = q.node;\n if (node.length) {\n var child, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1, xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n }\n next.push(q);\n }\n while (q = next.pop()) {\n callback(q.node, q.x0, q.y0, q.x1, q.y1);\n }\n return this;\n}\n","export default function(x) {\n return function() {\n return x;\n };\n}\n","export default function(random) {\n return (random() - 0.5) * 1e-6;\n}\n","var noop = {value: () => {}};\n\nfunction dispatch() {\n for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n if (!(t = arguments[i] + \"\") || (t in _) || /[\\s.]/.test(t)) throw new Error(\"illegal type: \" + t);\n _[t] = [];\n }\n return new Dispatch(_);\n}\n\nfunction Dispatch(_) {\n this._ = _;\n}\n\nfunction parseTypenames(typenames, types) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n return {type: t, name: name};\n });\n}\n\nDispatch.prototype = dispatch.prototype = {\n constructor: Dispatch,\n on: function(typename, callback) {\n var _ = this._,\n T = parseTypenames(typename + \"\", _),\n t,\n i = -1,\n n = T.length;\n\n // If no callback was specified, return the callback of the given type and name.\n if (arguments.length < 2) {\n while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n return;\n }\n\n // If a type was specified, set the callback for the given type and name.\n // Otherwise, if a null callback was specified, remove callbacks of the given name.\n if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n while (++i < n) {\n if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);\n else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);\n }\n\n return this;\n },\n copy: function() {\n var copy = {}, _ = this._;\n for (var t in _) copy[t] = _[t].slice();\n return new Dispatch(copy);\n },\n call: function(type, that) {\n if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n },\n apply: function(type, that, args) {\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n }\n};\n\nfunction get(type, name) {\n for (var i = 0, n = type.length, c; i < n; ++i) {\n if ((c = type[i]).name === name) {\n return c.value;\n }\n }\n}\n\nfunction set(type, name, callback) {\n for (var i = 0, n = type.length; i < n; ++i) {\n if (type[i].name === name) {\n type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));\n break;\n }\n }\n if (callback != null) type.push({name: name, value: callback});\n return type;\n}\n\nexport default dispatch;\n","var frame = 0, // is an animation frame pending?\n timeout = 0, // is a timeout pending?\n interval = 0, // are any timers active?\n pokeDelay = 1000, // how frequently we check for clock skew\n taskHead,\n taskTail,\n clockLast = 0,\n clockNow = 0,\n clockSkew = 0,\n clock = typeof performance === \"object\" && performance.now ? performance : Date,\n setFrame = typeof window === \"object\" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { setTimeout(f, 17); };\n\nexport function now() {\n return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n}\n\nfunction clearNow() {\n clockNow = 0;\n}\n\nexport function Timer() {\n this._call =\n this._time =\n this._next = null;\n}\n\nTimer.prototype = timer.prototype = {\n constructor: Timer,\n restart: function(callback, delay, time) {\n if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n if (!this._next && taskTail !== this) {\n if (taskTail) taskTail._next = this;\n else taskHead = this;\n taskTail = this;\n }\n this._call = callback;\n this._time = time;\n sleep();\n },\n stop: function() {\n if (this._call) {\n this._call = null;\n this._time = Infinity;\n sleep();\n }\n }\n};\n\nexport function timer(callback, delay, time) {\n var t = new Timer;\n t.restart(callback, delay, time);\n return t;\n}\n\nexport function timerFlush() {\n now(); // Get the current time, if not already set.\n ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n var t = taskHead, e;\n while (t) {\n if ((e = clockNow - t._time) >= 0) t._call.call(null, e);\n t = t._next;\n }\n --frame;\n}\n\nfunction wake() {\n clockNow = (clockLast = clock.now()) + clockSkew;\n frame = timeout = 0;\n try {\n timerFlush();\n } finally {\n frame = 0;\n nap();\n clockNow = 0;\n }\n}\n\nfunction poke() {\n var now = clock.now(), delay = now - clockLast;\n if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n}\n\nfunction nap() {\n var t0, t1 = taskHead, t2, time = Infinity;\n while (t1) {\n if (t1._call) {\n if (time > t1._time) time = t1._time;\n t0 = t1, t1 = t1._next;\n } else {\n t2 = t1._next, t1._next = null;\n t1 = t0 ? t0._next = t2 : taskHead = t2;\n }\n }\n taskTail = t0;\n sleep(time);\n}\n\nfunction sleep(time) {\n if (frame) return; // Soonest alarm already set, or will be.\n if (timeout) timeout = clearTimeout(timeout);\n var delay = time - clockNow; // Strictly less than if we recomputed clockNow.\n if (delay > 24) {\n if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);\n if (interval) interval = clearInterval(interval);\n } else {\n if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);\n frame = 1, setFrame(wake);\n }\n}\n","import {dispatch} from \"d3-dispatch\";\nimport {timer} from \"d3-timer\";\nimport lcg from \"./lcg.js\";\n\nexport function x(d) {\n return d.x;\n}\n\nexport function y(d) {\n return d.y;\n}\n\nvar initialRadius = 10,\n initialAngle = Math.PI * (3 - Math.sqrt(5));\n\nexport default function(nodes) {\n var simulation,\n alpha = 1,\n alphaMin = 0.001,\n alphaDecay = 1 - Math.pow(alphaMin, 1 / 300),\n alphaTarget = 0,\n velocityDecay = 0.6,\n forces = new Map(),\n stepper = timer(step),\n event = dispatch(\"tick\", \"end\"),\n random = lcg();\n\n if (nodes == null) nodes = [];\n\n function step() {\n tick();\n event.call(\"tick\", simulation);\n if (alpha < alphaMin) {\n stepper.stop();\n event.call(\"end\", simulation);\n }\n }\n\n function tick(iterations) {\n var i, n = nodes.length, node;\n\n if (iterations === undefined) iterations = 1;\n\n for (var k = 0; k < iterations; ++k) {\n alpha += (alphaTarget - alpha) * alphaDecay;\n\n forces.forEach(function(force) {\n force(alpha);\n });\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n if (node.fx == null) node.x += node.vx *= velocityDecay;\n else node.x = node.fx, node.vx = 0;\n if (node.fy == null) node.y += node.vy *= velocityDecay;\n else node.y = node.fy, node.vy = 0;\n }\n }\n\n return simulation;\n }\n\n function initializeNodes() {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.index = i;\n if (node.fx != null) node.x = node.fx;\n if (node.fy != null) node.y = node.fy;\n if (isNaN(node.x) || isNaN(node.y)) {\n var radius = initialRadius * Math.sqrt(0.5 + i), angle = i * initialAngle;\n node.x = radius * Math.cos(angle);\n node.y = radius * Math.sin(angle);\n }\n if (isNaN(node.vx) || isNaN(node.vy)) {\n node.vx = node.vy = 0;\n }\n }\n }\n\n function initializeForce(force) {\n if (force.initialize) force.initialize(nodes, random);\n return force;\n }\n\n initializeNodes();\n\n return simulation = {\n tick: tick,\n\n restart: function() {\n return stepper.restart(step), simulation;\n },\n\n stop: function() {\n return stepper.stop(), simulation;\n },\n\n nodes: function(_) {\n return arguments.length ? (nodes = _, initializeNodes(), forces.forEach(initializeForce), simulation) : nodes;\n },\n\n alpha: function(_) {\n return arguments.length ? (alpha = +_, simulation) : alpha;\n },\n\n alphaMin: function(_) {\n return arguments.length ? (alphaMin = +_, simulation) : alphaMin;\n },\n\n alphaDecay: function(_) {\n return arguments.length ? (alphaDecay = +_, simulation) : +alphaDecay;\n },\n\n alphaTarget: function(_) {\n return arguments.length ? (alphaTarget = +_, simulation) : alphaTarget;\n },\n\n velocityDecay: function(_) {\n return arguments.length ? (velocityDecay = 1 - _, simulation) : 1 - velocityDecay;\n },\n\n randomSource: function(_) {\n return arguments.length ? (random = _, forces.forEach(initializeForce), simulation) : random;\n },\n\n force: function(name, _) {\n return arguments.length > 1 ? ((_ == null ? forces.delete(name) : forces.set(name, initializeForce(_))), simulation) : forces.get(name);\n },\n\n find: function(x, y, radius) {\n var i = 0,\n n = nodes.length,\n dx,\n dy,\n d2,\n node,\n closest;\n\n if (radius == null) radius = Infinity;\n else radius *= radius;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n dx = x - node.x;\n dy = y - node.y;\n d2 = dx * dx + dy * dy;\n if (d2 < radius) closest = node, radius = d2;\n }\n\n return closest;\n },\n\n on: function(name, _) {\n return arguments.length > 1 ? (event.on(name, _), simulation) : event.on(name);\n }\n };\n}\n","// https://en.wikipedia.org/wiki/Linear_congruential_generator#Parameters_in_common_use\nconst a = 1664525;\nconst c = 1013904223;\nconst m = 4294967296; // 2^32\n\nexport default function() {\n let s = 1;\n return () => (s = (a * s + c) % m) / m;\n}\n","import {quadtree} from \"d3-quadtree\";\nimport constant from \"./constant.js\";\nimport jiggle from \"./jiggle.js\";\nimport {x, y} from \"./simulation.js\";\n\nexport default function() {\n var nodes,\n node,\n random,\n alpha,\n strength = constant(-30),\n strengths,\n distanceMin2 = 1,\n distanceMax2 = Infinity,\n theta2 = 0.81;\n\n function force(_) {\n var i, n = nodes.length, tree = quadtree(nodes, x, y).visitAfter(accumulate);\n for (alpha = _, i = 0; i < n; ++i) node = nodes[i], tree.visit(apply);\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length, node;\n strengths = new Array(n);\n for (i = 0; i < n; ++i) node = nodes[i], strengths[node.index] = +strength(node, i, nodes);\n }\n\n function accumulate(quad) {\n var strength = 0, q, c, weight = 0, x, y, i;\n\n // For internal nodes, accumulate forces from child quadrants.\n if (quad.length) {\n for (x = y = i = 0; i < 4; ++i) {\n if ((q = quad[i]) && (c = Math.abs(q.value))) {\n strength += q.value, weight += c, x += c * q.x, y += c * q.y;\n }\n }\n quad.x = x / weight;\n quad.y = y / weight;\n }\n\n // For leaf nodes, accumulate forces from coincident quadrants.\n else {\n q = quad;\n q.x = q.data.x;\n q.y = q.data.y;\n do strength += strengths[q.data.index];\n while (q = q.next);\n }\n\n quad.value = strength;\n }\n\n function apply(quad, x1, _, x2) {\n if (!quad.value) return true;\n\n var x = quad.x - node.x,\n y = quad.y - node.y,\n w = x2 - x1,\n l = x * x + y * y;\n\n // Apply the Barnes-Hut approximation if possible.\n // Limit forces for very close nodes; randomize direction if coincident.\n if (w * w / theta2 < l) {\n if (l < distanceMax2) {\n if (x === 0) x = jiggle(random), l += x * x;\n if (y === 0) y = jiggle(random), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n node.vx += x * quad.value * alpha / l;\n node.vy += y * quad.value * alpha / l;\n }\n return true;\n }\n\n // Otherwise, process points directly.\n else if (quad.length || l >= distanceMax2) return;\n\n // Limit forces for very close nodes; randomize direction if coincident.\n if (quad.data !== node || quad.next) {\n if (x === 0) x = jiggle(random), l += x * x;\n if (y === 0) y = jiggle(random), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n }\n\n do if (quad.data !== node) {\n w = strengths[quad.data.index] * alpha / l;\n node.vx += x * w;\n node.vy += y * w;\n } while (quad = quad.next);\n }\n\n force.initialize = function(_nodes, _random) {\n nodes = _nodes;\n random = _random;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.distanceMin = function(_) {\n return arguments.length ? (distanceMin2 = _ * _, force) : Math.sqrt(distanceMin2);\n };\n\n force.distanceMax = function(_) {\n return arguments.length ? (distanceMax2 = _ * _, force) : Math.sqrt(distanceMax2);\n };\n\n force.theta = function(_) {\n return arguments.length ? (theta2 = _ * _, force) : Math.sqrt(theta2);\n };\n\n return force;\n}\n","import constant from \"./constant.js\";\nimport jiggle from \"./jiggle.js\";\n\nfunction index(d) {\n return d.index;\n}\n\nfunction find(nodeById, nodeId) {\n var node = nodeById.get(nodeId);\n if (!node) throw new Error(\"node not found: \" + nodeId);\n return node;\n}\n\nexport default function(links) {\n var id = index,\n strength = defaultStrength,\n strengths,\n distance = constant(30),\n distances,\n nodes,\n count,\n bias,\n random,\n iterations = 1;\n\n if (links == null) links = [];\n\n function defaultStrength(link) {\n return 1 / Math.min(count[link.source.index], count[link.target.index]);\n }\n\n function force(alpha) {\n for (var k = 0, n = links.length; k < iterations; ++k) {\n for (var i = 0, link, source, target, x, y, l, b; i < n; ++i) {\n link = links[i], source = link.source, target = link.target;\n x = target.x + target.vx - source.x - source.vx || jiggle(random);\n y = target.y + target.vy - source.y - source.vy || jiggle(random);\n l = Math.sqrt(x * x + y * y);\n l = (l - distances[i]) / l * alpha * strengths[i];\n x *= l, y *= l;\n target.vx -= x * (b = bias[i]);\n target.vy -= y * b;\n source.vx += x * (b = 1 - b);\n source.vy += y * b;\n }\n }\n }\n\n function initialize() {\n if (!nodes) return;\n\n var i,\n n = nodes.length,\n m = links.length,\n nodeById = new Map(nodes.map((d, i) => [id(d, i, nodes), d])),\n link;\n\n for (i = 0, count = new Array(n); i < m; ++i) {\n link = links[i], link.index = i;\n if (typeof link.source !== \"object\") link.source = find(nodeById, link.source);\n if (typeof link.target !== \"object\") link.target = find(nodeById, link.target);\n count[link.source.index] = (count[link.source.index] || 0) + 1;\n count[link.target.index] = (count[link.target.index] || 0) + 1;\n }\n\n for (i = 0, bias = new Array(m); i < m; ++i) {\n link = links[i], bias[i] = count[link.source.index] / (count[link.source.index] + count[link.target.index]);\n }\n\n strengths = new Array(m), initializeStrength();\n distances = new Array(m), initializeDistance();\n }\n\n function initializeStrength() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n strengths[i] = +strength(links[i], i, links);\n }\n }\n\n function initializeDistance() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n distances[i] = +distance(links[i], i, links);\n }\n }\n\n force.initialize = function(_nodes, _random) {\n nodes = _nodes;\n random = _random;\n initialize();\n };\n\n force.links = function(_) {\n return arguments.length ? (links = _, initialize(), force) : links;\n };\n\n force.id = function(_) {\n return arguments.length ? (id = _, force) : id;\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initializeStrength(), force) : strength;\n };\n\n force.distance = function(_) {\n return arguments.length ? (distance = typeof _ === \"function\" ? _ : constant(+_), initializeDistance(), force) : distance;\n };\n\n return force;\n}\n","import {quadtree} from \"d3-quadtree\";\nimport constant from \"./constant.js\";\nimport jiggle from \"./jiggle.js\";\n\nfunction x(d) {\n return d.x + d.vx;\n}\n\nfunction y(d) {\n return d.y + d.vy;\n}\n\nexport default function(radius) {\n var nodes,\n radii,\n random,\n strength = 1,\n iterations = 1;\n\n if (typeof radius !== \"function\") radius = constant(radius == null ? 1 : +radius);\n\n function force() {\n var i, n = nodes.length,\n tree,\n node,\n xi,\n yi,\n ri,\n ri2;\n\n for (var k = 0; k < iterations; ++k) {\n tree = quadtree(nodes, x, y).visitAfter(prepare);\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n ri = radii[node.index], ri2 = ri * ri;\n xi = node.x + node.vx;\n yi = node.y + node.vy;\n tree.visit(apply);\n }\n }\n\n function apply(quad, x0, y0, x1, y1) {\n var data = quad.data, rj = quad.r, r = ri + rj;\n if (data) {\n if (data.index > node.index) {\n var x = xi - data.x - data.vx,\n y = yi - data.y - data.vy,\n l = x * x + y * y;\n if (l < r * r) {\n if (x === 0) x = jiggle(random), l += x * x;\n if (y === 0) y = jiggle(random), l += y * y;\n l = (r - (l = Math.sqrt(l))) / l * strength;\n node.vx += (x *= l) * (r = (rj *= rj) / (ri2 + rj));\n node.vy += (y *= l) * r;\n data.vx -= x * (r = 1 - r);\n data.vy -= y * r;\n }\n }\n return;\n }\n return x0 > xi + r || x1 < xi - r || y0 > yi + r || y1 < yi - r;\n }\n }\n\n function prepare(quad) {\n if (quad.data) return quad.r = radii[quad.data.index];\n for (var i = quad.r = 0; i < 4; ++i) {\n if (quad[i] && quad[i].r > quad.r) {\n quad.r = quad[i].r;\n }\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length, node;\n radii = new Array(n);\n for (i = 0; i < n; ++i) node = nodes[i], radii[node.index] = +radius(node, i, nodes);\n }\n\n force.initialize = function(_nodes, _random) {\n nodes = _nodes;\n random = _random;\n initialize();\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = +_, force) : strength;\n };\n\n force.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : radius;\n };\n\n return force;\n}\n","import * as d3Force from 'd3-force';\nimport { getEdgeTerminal } from '../../util';\n// https://github.com/john-guerra/forceInABox/blob/master/src/forceInABox.js\nexport default function forceInABox() {\n function constant(_) {\n return () => _;\n }\n let groupBy = (d) => {\n return d.cluster;\n };\n let forceNodeSize = constant(1);\n let forceCharge = constant(-1);\n let forceLinkDistance = constant(100);\n let forceLinkStrength = constant(0.1);\n let offset = [0, 0];\n let nodes = [];\n let nodesMap = {};\n let links = [];\n let centerX = 100;\n let centerY = 100;\n let foci = {\n none: {\n x: 0,\n y: 0,\n },\n };\n let templateNodes = [];\n let templateForce;\n let template = 'force';\n let enableGrouping = true;\n let strength = 0.1;\n function force(alpha) {\n if (!enableGrouping) {\n return force;\n }\n templateForce.tick();\n getFocisFromTemplate();\n for (let i = 0, n = nodes.length, node, k = alpha * strength; i < n; ++i) {\n node = nodes[i];\n node.vx += (foci[groupBy(node)].x - node.x) * k;\n node.vy += (foci[groupBy(node)].y - node.y) * k;\n }\n }\n function initialize() {\n if (!nodes)\n return;\n initializeWithForce();\n }\n function initializeWithForce() {\n if (!nodes || !nodes.length) {\n return;\n }\n if (groupBy(nodes[0]) === undefined) {\n throw Error(\"Couldnt find the grouping attribute for the nodes. Make sure to set it up with forceInABox.groupBy('clusterAttr') before calling .links()\");\n }\n // checkLinksAsObjects();\n const net = getGroupsGraph();\n templateForce = d3Force\n .forceSimulation(net.nodes)\n .force('x', d3Force.forceX(centerX).strength(0.1))\n .force('y', d3Force.forceY(centerY).strength(0.1))\n .force('collide', d3Force.forceCollide((d) => d.r).iterations(4))\n .force('charge', d3Force.forceManyBody().strength(forceCharge))\n .force('links', d3Force\n .forceLink(net.nodes.length ? net.links : [])\n .distance(forceLinkDistance)\n .strength(forceLinkStrength));\n templateNodes = templateForce.nodes();\n getFocisFromTemplate();\n }\n function getGroupsGraph() {\n const gnodes = [];\n const glinks = [];\n const dNodes = {};\n let clustersList = [];\n let clustersCounts = {};\n let clustersLinks = [];\n clustersCounts = computeClustersNodeCounts(nodes);\n clustersLinks = computeClustersLinkCounts(links);\n clustersList = Object.keys(clustersCounts);\n clustersList.forEach((key, index) => {\n const val = clustersCounts[key];\n // Uses approx meta-node size\n gnodes.push({\n id: key,\n size: val.count,\n r: Math.sqrt(val.sumforceNodeSize / Math.PI),\n });\n dNodes[key] = index;\n });\n clustersLinks.forEach((l) => {\n const sourceTerminal = getEdgeTerminal(l, 'source');\n const targetTerminal = getEdgeTerminal(l, 'target');\n const source = dNodes[sourceTerminal];\n const target = dNodes[targetTerminal];\n if (source !== undefined && target !== undefined) {\n glinks.push({\n source,\n target,\n count: l.count,\n });\n }\n });\n return {\n nodes: gnodes,\n links: glinks,\n };\n }\n function computeClustersNodeCounts(nodes) {\n const clustersCounts = {};\n nodes.forEach((d) => {\n const key = groupBy(d);\n if (!clustersCounts[key]) {\n clustersCounts[key] = {\n count: 0,\n sumforceNodeSize: 0,\n };\n }\n });\n nodes.forEach((d) => {\n const key = groupBy(d);\n const nodeSize = forceNodeSize(d);\n const tmpCount = clustersCounts[key];\n tmpCount.count = tmpCount.count + 1;\n tmpCount.sumforceNodeSize =\n tmpCount.sumforceNodeSize + Math.PI * (nodeSize * nodeSize) * 1.3;\n clustersCounts[key] = tmpCount;\n });\n return clustersCounts;\n }\n function computeClustersLinkCounts(links) {\n const dClusterLinks = {};\n const clusterLinks = [];\n links.forEach((l) => {\n const key = getLinkKey(l);\n let count = 0;\n if (dClusterLinks[key] !== undefined) {\n count = dClusterLinks[key];\n }\n count += 1;\n dClusterLinks[key] = count;\n });\n const entries = Object.entries(dClusterLinks);\n entries.forEach(([key, count]) => {\n const source = key.split('~')[0];\n const target = key.split('~')[1];\n if (source !== undefined && target !== undefined) {\n clusterLinks.push({\n source,\n target,\n count,\n });\n }\n });\n return clusterLinks;\n }\n function getFocisFromTemplate() {\n foci = {\n none: {\n x: 0,\n y: 0,\n },\n };\n templateNodes.forEach((d) => {\n foci[d.id] = {\n x: d.x - offset[0],\n y: d.y - offset[1],\n };\n });\n return foci;\n }\n function getLinkKey(l) {\n const source = getEdgeTerminal(l, 'source');\n const target = getEdgeTerminal(l, 'target');\n const sourceID = groupBy(nodesMap[source]);\n const targetID = groupBy(nodesMap[target]);\n return sourceID <= targetID\n ? `${sourceID}~${targetID}`\n : `${targetID}~${sourceID}`;\n }\n function genNodesMap(nodes) {\n nodesMap = {};\n nodes.forEach((node) => {\n nodesMap[node.id] = node;\n });\n }\n function setTemplate(x) {\n if (!arguments.length)\n return template;\n template = x;\n initialize();\n return force;\n }\n function setGroupBy(x) {\n if (!arguments.length)\n return groupBy;\n if (typeof x === 'string') {\n groupBy = (d) => {\n return d[x];\n };\n return force;\n }\n groupBy = x;\n return force;\n }\n function setEnableGrouping(x) {\n if (!arguments.length)\n return enableGrouping;\n enableGrouping = x;\n return force;\n }\n function setStrength(x) {\n if (!arguments.length)\n return strength;\n strength = x;\n return force;\n }\n function setCenterX(_) {\n if (arguments.length) {\n centerX = _;\n return force;\n }\n return centerX;\n }\n function setCenterY(_) {\n if (arguments.length) {\n centerY = _;\n return force;\n }\n return centerY;\n }\n function setNodes(_) {\n if (arguments.length) {\n genNodesMap(_ || []);\n nodes = _ || [];\n return force;\n }\n return nodes;\n }\n function setLinks(_) {\n if (arguments.length) {\n links = _ || [];\n initialize();\n return force;\n }\n return links;\n }\n function setForceNodeSize(_) {\n if (arguments.length) {\n if (typeof _ === 'function') {\n forceNodeSize = _;\n }\n else {\n forceNodeSize = constant(+_);\n }\n initialize();\n return force;\n }\n return forceNodeSize;\n }\n function setForceCharge(_) {\n if (arguments.length) {\n if (typeof _ === 'function') {\n forceCharge = _;\n }\n else {\n forceCharge = constant(+_);\n }\n initialize();\n return force;\n }\n return forceCharge;\n }\n function setForceLinkDistance(_) {\n if (arguments.length) {\n if (typeof _ === 'function') {\n forceLinkDistance = _;\n }\n else {\n forceLinkDistance = constant(+_);\n }\n initialize();\n return force;\n }\n return forceLinkDistance;\n }\n function setForceLinkStrength(_) {\n if (arguments.length) {\n if (typeof _ === 'function') {\n forceLinkStrength = _;\n }\n else {\n forceLinkStrength = constant(+_);\n }\n initialize();\n return force;\n }\n return forceLinkStrength;\n }\n function setOffset(_) {\n if (arguments.length) {\n offset = _;\n return force;\n }\n return offset;\n }\n force.initialize = (_) => {\n nodes = _;\n initialize();\n };\n force.template = setTemplate;\n force.groupBy = setGroupBy;\n force.enableGrouping = setEnableGrouping;\n force.strength = setStrength;\n force.centerX = setCenterX;\n force.centerY = setCenterY;\n force.nodes = setNodes;\n force.links = setLinks;\n force.forceNodeSize = setForceNodeSize;\n // Legacy support\n force.nodeSize = force.forceNodeSize;\n force.forceCharge = setForceCharge;\n force.forceLinkDistance = setForceLinkDistance;\n force.forceLinkStrength = setForceLinkStrength;\n force.offset = setOffset;\n force.getFocis = getFocisFromTemplate;\n return force;\n}\n//# sourceMappingURL=force-in-a-box.js.map","import constant from \"./constant.js\";\n\nexport default function(x) {\n var strength = constant(0.1),\n nodes,\n strengths,\n xz;\n\n if (typeof x !== \"function\") x = constant(x == null ? 0 : +x);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vx += (xz[i] - node.x) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n xz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(xz[i] = +x(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : x;\n };\n\n return force;\n}\n","import constant from \"./constant.js\";\n\nexport default function(y) {\n var strength = constant(0.1),\n nodes,\n strengths,\n yz;\n\n if (typeof y !== \"function\") y = constant(y == null ? 0 : +y);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vy += (yz[i] - node.y) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n yz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(yz[i] = +y(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : y;\n };\n\n return force;\n}\n","/** layout message type */\nexport const LAYOUT_MESSAGE = {\n // run layout\n RUN: \"LAYOUT_RUN\",\n // layout ended with success\n END: \"LAYOUT_END\",\n // layout error\n ERROR: \"LAYOUT_ERROR\",\n // layout tick, used in force directed layout\n TICK: \"LAYOUT_TICK\",\n GPURUN: \"GPU_LAYOUT_RUN\",\n GPUEND: \"GPU_LAYOUT_END\"\n};\n//# sourceMappingURL=constants.js.map","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\nimport * as d3Force from \"d3-force\";\nimport forceInABox from \"./force-in-a-box\";\nimport { isArray, isFunction, isNumber, isObject } from \"../../util\";\nimport { Base } from \"../base\";\nimport { LAYOUT_MESSAGE } from \"../constants\";\n/**\n * 经典力导布局 force-directed\n */\nexport class ForceLayout extends Base {\n constructor(options) {\n super();\n /** 向心力作用点 */\n this.center = [0, 0];\n /** 节点作用力 */\n this.nodeStrength = null;\n /** 边的作用力, 默认为根据节点的入度出度自适应 */\n this.edgeStrength = null;\n /** 是否防止节点相互覆盖 */\n this.preventOverlap = false;\n /** 聚类节点作用力 */\n this.clusterNodeStrength = null;\n /** 聚类边作用力 */\n this.clusterEdgeStrength = null;\n /** 聚类边长度 */\n this.clusterEdgeDistance = null;\n /** 聚类节点大小 / 直径,直径越大,越分散 */\n this.clusterNodeSize = null;\n /** 用于 foci 的力 */\n this.clusterFociStrength = null;\n /** 默认边长度 */\n this.linkDistance = 50;\n /** 迭代阈值的衰减率 [0, 1],0.028 对应最大迭代数为 300 */\n this.alphaDecay = 0.028;\n /** 停止迭代的阈值 */\n this.alphaMin = 0.001;\n /** 当前阈值 */\n this.alpha = 0.3;\n /** 防止重叠的力强度 */\n this.collideStrength = 1;\n /** 是否启用web worker。前提是在web worker里执行布局,否则无效\t*/\n this.workerEnabled = false;\n this.tick = () => { };\n /** 布局完成回调 */\n this.onLayoutEnd = () => { };\n /** 是否正在布局 */\n this.ticking = undefined;\n if (options) {\n this.updateCfg(options);\n }\n }\n getDefaultCfg() {\n return {\n center: [0, 0],\n nodeStrength: null,\n edgeStrength: null,\n preventOverlap: false,\n nodeSize: undefined,\n nodeSpacing: undefined,\n linkDistance: 50,\n forceSimulation: null,\n alphaDecay: 0.028,\n alphaMin: 0.001,\n alpha: 0.3,\n collideStrength: 1,\n clustering: false,\n clusterNodeStrength: -1,\n clusterEdgeStrength: 0.1,\n clusterEdgeDistance: 100,\n clusterFociStrength: 0.8,\n clusterNodeSize: 10,\n tick() { },\n onLayoutEnd() { },\n // 是否启用web worker。前提是在web worker里执行布局,否则无效\n workerEnabled: false\n };\n }\n /**\n * 初始化\n * @param {object} data 数据\n */\n init(data) {\n const self = this;\n self.nodes = data.nodes || [];\n const edges = data.edges || [];\n self.edges = edges.map((edge) => {\n const res = {};\n const expectKeys = [\"targetNode\", \"sourceNode\", \"startPoint\", \"endPoint\"];\n Object.keys(edge).forEach((key) => {\n if (!(expectKeys.indexOf(key) > -1)) {\n res[key] = edge[key];\n }\n });\n return res;\n });\n self.ticking = false;\n }\n /**\n * 执行布局\n */\n execute(reloadData) {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n // 如果正在布局,忽略布局请求\n if (self.ticking) {\n return;\n }\n let simulation = self.forceSimulation;\n const alphaMin = self.alphaMin;\n const alphaDecay = self.alphaDecay;\n const alpha = self.alpha;\n if (!simulation) {\n try {\n // 定义节点的力\n const nodeForce = d3Force.forceManyBody();\n if (self.nodeStrength) {\n nodeForce.strength(self.nodeStrength);\n }\n simulation = d3Force.forceSimulation().nodes(nodes);\n if (self.clustering) {\n const clusterForce = forceInABox();\n clusterForce\n .centerX(self.center[0])\n .centerY(self.center[1])\n .template(\"force\")\n .strength(self.clusterFociStrength);\n if (edges) {\n clusterForce.links(edges);\n }\n if (nodes) {\n clusterForce.nodes(nodes);\n }\n clusterForce\n .forceLinkDistance(self.clusterEdgeDistance)\n .forceLinkStrength(self.clusterEdgeStrength)\n .forceCharge(self.clusterNodeStrength)\n .forceNodeSize(self.clusterNodeSize);\n self.clusterForce = clusterForce;\n simulation.force(\"group\", clusterForce);\n }\n simulation\n .force(\"center\", d3Force.forceCenter(self.center[0], self.center[1]))\n .force(\"charge\", nodeForce)\n .alpha(alpha)\n .alphaDecay(alphaDecay)\n .alphaMin(alphaMin);\n if (self.preventOverlap) {\n self.overlapProcess(simulation);\n }\n // 如果有边,定义边的力\n if (edges) {\n // d3 的 forceLayout 会重新生成边的数据模型,为了避免污染源数据\n const edgeForce = d3Force\n .forceLink()\n .id((d) => d.id)\n .links(edges);\n if (self.edgeStrength) {\n edgeForce.strength(self.edgeStrength);\n }\n if (self.linkDistance) {\n edgeForce.distance(self.linkDistance);\n }\n self.edgeForce = edgeForce;\n simulation.force(\"link\", edgeForce);\n }\n if (self.workerEnabled && !isInWorker()) {\n // 如果不是运行在web worker里,不用web worker布局\n self.workerEnabled = false;\n console.warn(\"workerEnabled option is only supported when running in web worker.\");\n }\n if (!self.workerEnabled) {\n simulation\n .on(\"tick\", () => {\n self.tick();\n })\n .on(\"end\", () => {\n self.ticking = false;\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n });\n self.ticking = true;\n }\n else {\n // worker is enabled\n simulation.stop();\n const totalTicks = getSimulationTicks(simulation);\n for (let currentTick = 1; currentTick <= totalTicks; currentTick++) {\n simulation.tick();\n // currentTick starts from 1.\n postMessage({\n nodes,\n currentTick,\n totalTicks,\n type: LAYOUT_MESSAGE.TICK\n }, undefined);\n }\n self.ticking = false;\n }\n self.forceSimulation = simulation;\n self.ticking = true;\n }\n catch (e) {\n self.ticking = false;\n console.warn(e);\n }\n }\n else {\n if (reloadData) {\n if (self.clustering && self.clusterForce) {\n self.clusterForce.nodes(nodes);\n self.clusterForce.links(edges);\n }\n simulation.nodes(nodes);\n if (edges && self.edgeForce)\n self.edgeForce.links(edges);\n else if (edges && !self.edgeForce) {\n // d3 的 forceLayout 会重新生成边的数据模型,为了避免污染源数据\n const edgeForce = d3Force\n .forceLink()\n .id((d) => d.id)\n .links(edges);\n if (self.edgeStrength) {\n edgeForce.strength(self.edgeStrength);\n }\n if (self.linkDistance) {\n edgeForce.distance(self.linkDistance);\n }\n self.edgeForce = edgeForce;\n simulation.force(\"link\", edgeForce);\n }\n }\n if (self.preventOverlap) {\n self.overlapProcess(simulation);\n }\n simulation.alpha(alpha).restart();\n this.ticking = true;\n }\n }\n /**\n * 防止重叠\n * @param {object} simulation 力模拟模型\n */\n overlapProcess(simulation) {\n const self = this;\n const nodeSize = self.nodeSize;\n const nodeSpacing = self.nodeSpacing;\n let nodeSizeFunc;\n let nodeSpacingFunc;\n const collideStrength = self.collideStrength;\n if (isNumber(nodeSpacing)) {\n nodeSpacingFunc = () => nodeSpacing;\n }\n else if (isFunction(nodeSpacing)) {\n nodeSpacingFunc = nodeSpacing;\n }\n else {\n nodeSpacingFunc = () => 0;\n }\n if (!nodeSize) {\n nodeSizeFunc = (d) => {\n if (d.size) {\n if (isArray(d.size)) {\n const res = d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n return res / 2 + nodeSpacingFunc(d);\n }\n if (isObject(d.size)) {\n const res = d.size.width > d.size.height ? d.size.width : d.size.height;\n return res / 2 + nodeSpacingFunc(d);\n }\n return d.size / 2 + nodeSpacingFunc(d);\n }\n return 10 + nodeSpacingFunc(d);\n };\n }\n else if (isFunction(nodeSize)) {\n nodeSizeFunc = (d) => {\n const size = nodeSize(d);\n return size + nodeSpacingFunc(d);\n };\n }\n else if (isArray(nodeSize)) {\n const larger = nodeSize[0] > nodeSize[1] ? nodeSize[0] : nodeSize[1];\n const radius = larger / 2;\n nodeSizeFunc = (d) => radius + nodeSpacingFunc(d);\n }\n else if (isNumber(nodeSize)) {\n const radius = nodeSize / 2;\n nodeSizeFunc = (d) => radius + nodeSpacingFunc(d);\n }\n else {\n nodeSizeFunc = () => 10;\n }\n // forceCollide's parameter is a radius\n simulation.force(\"collisionForce\", d3Force.forceCollide(nodeSizeFunc).strength(collideStrength));\n }\n /**\n * 更新布局配置,但不执行布局\n * @param {object} cfg 需要更新的配置项\n */\n updateCfg(cfg) {\n const self = this;\n if (self.ticking) {\n self.forceSimulation.stop();\n self.ticking = false;\n }\n self.forceSimulation = null;\n Object.assign(self, cfg);\n }\n destroy() {\n const self = this;\n if (self.ticking) {\n self.forceSimulation.stop();\n self.ticking = false;\n }\n self.nodes = null;\n self.edges = null;\n self.destroyed = true;\n }\n}\n// Return total ticks of d3-force simulation\nfunction getSimulationTicks(simulation) {\n const alphaMin = simulation.alphaMin();\n const alphaTarget = simulation.alphaTarget();\n const alpha = simulation.alpha();\n const totalTicksFloat = Math.log((alphaMin - alphaTarget) / (alpha - alphaTarget)) /\n Math.log(1 - simulation.alphaDecay());\n const totalTicks = Math.ceil(totalTicksFloat);\n return totalTicks;\n}\n// 判断是否运行在web worker里\nfunction isInWorker() {\n // eslint-disable-next-line no-undef\n return (typeof WorkerGlobalScope !== \"undefined\" &&\n self instanceof WorkerGlobalScope);\n}\n//# sourceMappingURL=force.js.map","export default function(x, y) {\n var nodes, strength = 1;\n\n if (x == null) x = 0;\n if (y == null) y = 0;\n\n function force() {\n var i,\n n = nodes.length,\n node,\n sx = 0,\n sy = 0;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i], sx += node.x, sy += node.y;\n }\n\n for (sx = (sx / n - x) * strength, sy = (sy / n - y) * strength, i = 0; i < n; ++i) {\n node = nodes[i], node.x -= sx, node.y -= sy;\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = +_, force) : x;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = +_, force) : y;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = +_, force) : strength;\n };\n\n return force;\n}\n","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\nimport { Base } from \"./base\";\nimport { getDegree, clone, getEdgeTerminal } from \"../util\";\nfunction initHierarchy(nodes, edges, nodeMap, directed) {\n nodes.forEach((_, i) => {\n nodes[i].children = [];\n nodes[i].parent = [];\n });\n if (directed) {\n edges.forEach((e) => {\n const source = getEdgeTerminal(e, 'source');\n const target = getEdgeTerminal(e, 'target');\n let sourceIdx = 0;\n if (source) {\n sourceIdx = nodeMap[source];\n }\n let targetIdx = 0;\n if (target) {\n targetIdx = nodeMap[target];\n }\n const child = nodes[sourceIdx].children;\n const parent = nodes[targetIdx].parent;\n child.push(nodes[targetIdx].id);\n parent.push(nodes[sourceIdx].id);\n });\n }\n else {\n edges.forEach((e) => {\n const source = getEdgeTerminal(e, 'source');\n const target = getEdgeTerminal(e, 'target');\n let sourceIdx = 0;\n if (source) {\n sourceIdx = nodeMap[source];\n }\n let targetIdx = 0;\n if (target) {\n targetIdx = nodeMap[target];\n }\n const sourceChildren = nodes[sourceIdx].children;\n const targetChildren = nodes[targetIdx].children;\n sourceChildren.push(nodes[targetIdx].id);\n targetChildren.push(nodes[sourceIdx].id);\n });\n }\n}\nfunction connect(a, b, edges) {\n const m = edges.length;\n for (let i = 0; i < m; i++) {\n const source = getEdgeTerminal(edges[i], 'source');\n const target = getEdgeTerminal(edges[i], 'target');\n if ((a.id === source && b.id === target) ||\n (b.id === source && a.id === target)) {\n return true;\n }\n }\n return false;\n}\nfunction compareDegree(a, b) {\n const aDegree = a.degree;\n const bDegree = b.degree;\n if (aDegree < bDegree) {\n return -1;\n }\n if (aDegree > bDegree) {\n return 1;\n }\n return 0;\n}\n/**\n * 圆形布局\n */\nexport class CircularLayout extends Base {\n constructor(options) {\n super();\n /** 固定半径,若设置了 radius,则 startRadius 与 endRadius 不起效 */\n this.radius = null;\n /** 起始半径 */\n this.startRadius = null;\n /** 终止半径 */\n this.endRadius = null;\n /** 起始角度 */\n this.startAngle = 0;\n /** 终止角度 */\n this.endAngle = 2 * Math.PI;\n /** 是否顺时针 */\n this.clockwise = true;\n /** 节点在环上分成段数(几个段将均匀分布),在 endRadius - startRadius != 0 时生效 */\n this.divisions = 1;\n /** 节点在环上排序的依据,可选: 'topology', 'degree', 'null' */\n this.ordering = null;\n /** how many 2*pi from first to last nodes */\n this.angleRatio = 1;\n this.nodes = [];\n this.edges = [];\n this.nodeMap = {};\n this.degrees = [];\n this.width = 300;\n this.height = 300;\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n radius: null,\n startRadius: null,\n endRadius: null,\n startAngle: 0,\n endAngle: 2 * Math.PI,\n clockwise: true,\n divisions: 1,\n ordering: null,\n angleRatio: 1\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const n = nodes.length;\n if (n === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n if (n === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n let radius = self.radius;\n let startRadius = self.startRadius;\n let endRadius = self.endRadius;\n const divisions = self.divisions;\n const startAngle = self.startAngle;\n const endAngle = self.endAngle;\n const angleStep = (endAngle - startAngle) / n;\n // layout\n const nodeMap = {};\n nodes.forEach((node, i) => {\n nodeMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n const degrees = getDegree(nodes.length, nodeMap, edges);\n self.degrees = degrees;\n if (!radius && !startRadius && !endRadius) {\n radius = self.height > self.width ? self.width / 2 : self.height / 2;\n }\n else if (!startRadius && endRadius) {\n startRadius = endRadius;\n }\n else if (startRadius && !endRadius) {\n endRadius = startRadius;\n }\n const angleRatio = self.angleRatio;\n const astep = angleStep * angleRatio;\n const ordering = self.ordering;\n let layoutNodes = [];\n if (ordering === \"topology\") {\n // layout according to the topology\n layoutNodes = self.topologyOrdering();\n }\n else if (ordering === \"topology-directed\") {\n // layout according to the topology\n layoutNodes = self.topologyOrdering(true);\n }\n else if (ordering === \"degree\") {\n // layout according to the descent order of degrees\n layoutNodes = self.degreeOrdering();\n }\n else {\n // layout according to the original order in the data.nodes\n layoutNodes = nodes;\n }\n const clockwise = self.clockwise;\n const divN = Math.ceil(n / divisions); // node number in each division\n for (let i = 0; i < n; ++i) {\n let r = radius;\n if (!r && startRadius !== null && endRadius !== null) {\n r = startRadius + (i * (endRadius - startRadius)) / (n - 1);\n }\n if (!r) {\n r = 10 + (i * 100) / (n - 1);\n }\n let angle = startAngle +\n (i % divN) * astep +\n ((2 * Math.PI) / divisions) * Math.floor(i / divN);\n if (!clockwise) {\n angle =\n endAngle -\n (i % divN) * astep -\n ((2 * Math.PI) / divisions) * Math.floor(i / divN);\n }\n layoutNodes[i].x = center[0] + Math.cos(angle) * r;\n layoutNodes[i].y = center[1] + Math.sin(angle) * r;\n layoutNodes[i].weight = degrees[i];\n }\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return {\n nodes: layoutNodes,\n edges: this.edges\n };\n }\n /**\n * 根据节点的拓扑结构排序\n * @return {array} orderedNodes 排序后的结果\n */\n topologyOrdering(directed = false) {\n const self = this;\n const degrees = self.degrees;\n const edges = self.edges;\n const nodes = self.nodes;\n const cnodes = clone(nodes);\n const nodeMap = self.nodeMap;\n const orderedCNodes = [cnodes[0]];\n const resNodes = [nodes[0]];\n const pickFlags = [];\n const n = nodes.length;\n pickFlags[0] = true;\n initHierarchy(cnodes, edges, nodeMap, directed);\n let k = 0;\n cnodes.forEach((cnode, i) => {\n if (i !== 0) {\n if ((i === n - 1 ||\n degrees[i] !== degrees[i + 1] ||\n connect(orderedCNodes[k], cnode, edges)) &&\n !pickFlags[i]) {\n orderedCNodes.push(cnode);\n resNodes.push(nodes[nodeMap[cnode.id]]);\n pickFlags[i] = true;\n k++;\n }\n else {\n const children = orderedCNodes[k].children;\n let foundChild = false;\n for (let j = 0; j < children.length; j++) {\n const childIdx = nodeMap[children[j]];\n if (degrees[childIdx] === degrees[i] && !pickFlags[childIdx]) {\n orderedCNodes.push(cnodes[childIdx]);\n resNodes.push(nodes[nodeMap[cnodes[childIdx].id]]);\n pickFlags[childIdx] = true;\n foundChild = true;\n break;\n }\n }\n let ii = 0;\n while (!foundChild) {\n if (!pickFlags[ii]) {\n orderedCNodes.push(cnodes[ii]);\n resNodes.push(nodes[nodeMap[cnodes[ii].id]]);\n pickFlags[ii] = true;\n foundChild = true;\n }\n ii++;\n if (ii === n) {\n break;\n }\n }\n }\n }\n });\n return resNodes;\n }\n /**\n * 根据节点度数大小排序\n * @return {array} orderedNodes 排序后的结果\n */\n degreeOrdering() {\n const self = this;\n const nodes = self.nodes;\n const orderedNodes = [];\n const degrees = self.degrees;\n nodes.forEach((node, i) => {\n node.degree = degrees[i];\n orderedNodes.push(node);\n });\n orderedNodes.sort(compareDegree);\n return orderedNodes;\n }\n getType() {\n return \"circular\";\n }\n}\n//# sourceMappingURL=circular.js.map","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\nimport dagre from \"dagre\";\nimport { isArray, isNumber, isObject, getEdgeTerminal } from \"../util\";\nimport { Base } from \"./base\";\n/**\n * 层次布局\n */\nexport class DagreLayout extends Base {\n constructor(options) {\n super();\n /** layout 方向, 可选 TB, BT, LR, RL */\n this.rankdir = \"TB\";\n /** 节点水平间距(px) */\n this.nodesep = 50;\n /** 每一层节点之间间距 */\n this.ranksep = 50;\n /** 是否保留布局连线的控制点 */\n this.controlPoints = false;\n /** 每层节点是否根据节点数据中的 comboId 进行排序,以防止同层 combo 重叠 */\n this.sortByCombo = false;\n this.nodes = [];\n this.edges = [];\n /** 迭代结束的回调函数 */\n this.onLayoutEnd = () => { };\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n rankdir: \"TB\",\n align: undefined,\n nodeSize: undefined,\n nodesepFunc: undefined,\n ranksepFunc: undefined,\n nodesep: 50,\n ranksep: 50,\n controlPoints: false, // 是否保留布局连线的控制点\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const { nodes, nodeSize, rankdir, combos } = self;\n if (!nodes)\n return;\n const edges = self.edges || [];\n const g = new dagre.graphlib.Graph({\n multigraph: true,\n compound: true,\n });\n let nodeSizeFunc;\n if (!nodeSize) {\n nodeSizeFunc = (d) => {\n if (d.size) {\n if (isArray(d.size)) {\n return d.size;\n }\n if (isObject(d.size)) {\n return [d.size.width || 40, d.size.height || 40];\n }\n return [d.size, d.size];\n }\n return [40, 40];\n };\n }\n else if (isArray(nodeSize)) {\n nodeSizeFunc = () => nodeSize;\n }\n else {\n nodeSizeFunc = () => [nodeSize, nodeSize];\n }\n let horisep = getFunc(self.nodesepFunc, self.nodesep, 50);\n let vertisep = getFunc(self.ranksepFunc, self.ranksep, 50);\n if (rankdir === \"LR\" || rankdir === \"RL\") {\n horisep = getFunc(self.ranksepFunc, self.ranksep, 50);\n vertisep = getFunc(self.nodesepFunc, self.nodesep, 50);\n }\n g.setDefaultEdgeLabel(() => ({}));\n g.setGraph(self);\n const comboMap = {};\n nodes.filter((node) => node.layout !== false).forEach((node) => {\n const size = nodeSizeFunc(node);\n const verti = vertisep(node);\n const hori = horisep(node);\n const width = size[0] + 2 * hori;\n const height = size[1] + 2 * verti;\n g.setNode(node.id, { width, height });\n if (this.sortByCombo && node.comboId) {\n if (!comboMap[node.comboId]) {\n comboMap[node.comboId] = true;\n g.setNode(node.comboId, {});\n }\n g.setParent(node.id, node.comboId);\n }\n });\n if (this.sortByCombo && combos) {\n combos.forEach((combo) => {\n if (!combo.parentId)\n return;\n if (!comboMap[combo.parentId]) {\n comboMap[combo.parentId] = true;\n g.setNode(combo.parentId, {});\n }\n g.setParent(combo.id, combo.parentId);\n });\n }\n edges.forEach((edge) => {\n // dagrejs Wiki https://github.com/dagrejs/dagre/wiki#configuring-the-layout\n const source = getEdgeTerminal(edge, 'source');\n const target = getEdgeTerminal(edge, 'target');\n g.setEdge(source, target, {\n weight: edge.weight || 1,\n });\n });\n dagre.layout(g);\n let coord;\n g.nodes().forEach((node) => {\n coord = g.node(node);\n const i = nodes.findIndex((it) => it.id === node);\n if (!nodes[i])\n return;\n nodes[i].x = coord.x;\n nodes[i].y = coord.y;\n });\n g.edges().forEach((edge) => {\n coord = g.edge(edge);\n const i = edges.findIndex((it) => {\n const source = getEdgeTerminal(it, 'source');\n const target = getEdgeTerminal(it, 'target');\n return source === edge.v && target === edge.w;\n });\n if (self.controlPoints && edges[i].type !== \"loop\") {\n edges[i].controlPoints = coord.points.slice(1, coord.points.length - 1);\n }\n });\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return {\n nodes,\n edges,\n };\n }\n getType() {\n return \"dagre\";\n }\n}\nfunction getFunc(func, value, defaultValue) {\n let resultFunc;\n if (func) {\n resultFunc = func;\n }\n else if (isNumber(value)) {\n resultFunc = () => value;\n }\n else {\n resultFunc = () => defaultValue;\n }\n return resultFunc;\n}\n//# sourceMappingURL=dagre.js.map","const toString = Object.prototype.toString;\r\n\r\nexport default function isAnyArray(object) {\r\n return toString.call(object).endsWith('Array]');\r\n}\r\n","import isArray from 'is-any-array';\n\nfunction max(input) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!isArray(input)) {\n throw new TypeError('input must be an array');\n }\n\n if (input.length === 0) {\n throw new TypeError('input must not be empty');\n }\n\n var _options$fromIndex = options.fromIndex,\n fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n _options$toIndex = options.toIndex,\n toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n throw new Error('fromIndex must be a positive integer smaller than length');\n }\n\n if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n }\n\n var maxValue = input[fromIndex];\n\n for (var i = fromIndex + 1; i < toIndex; i++) {\n if (input[i] > maxValue) maxValue = input[i];\n }\n\n return maxValue;\n}\n\nexport default max;\n","import isArray from 'is-any-array';\n\nfunction min(input) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!isArray(input)) {\n throw new TypeError('input must be an array');\n }\n\n if (input.length === 0) {\n throw new TypeError('input must not be empty');\n }\n\n var _options$fromIndex = options.fromIndex,\n fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n _options$toIndex = options.toIndex,\n toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n throw new Error('fromIndex must be a positive integer smaller than length');\n }\n\n if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n }\n\n var minValue = input[fromIndex];\n\n for (var i = fromIndex + 1; i < toIndex; i++) {\n if (input[i] < minValue) minValue = input[i];\n }\n\n return minValue;\n}\n\nexport default min;\n","import isArray from 'is-any-array';\nimport max from 'ml-array-max';\nimport min from 'ml-array-min';\n\nfunction rescale(input) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!isArray(input)) {\n throw new TypeError('input must be an array');\n } else if (input.length === 0) {\n throw new TypeError('input must not be empty');\n }\n\n var output;\n\n if (options.output !== undefined) {\n if (!isArray(options.output)) {\n throw new TypeError('output option must be an array if specified');\n }\n\n output = options.output;\n } else {\n output = new Array(input.length);\n }\n\n var currentMin = min(input);\n var currentMax = max(input);\n\n if (currentMin === currentMax) {\n throw new RangeError('minimum and maximum input values are equal. Cannot rescale a constant array');\n }\n\n var _options$min = options.min,\n minValue = _options$min === void 0 ? options.autoMinMax ? currentMin : 0 : _options$min,\n _options$max = options.max,\n maxValue = _options$max === void 0 ? options.autoMinMax ? currentMax : 1 : _options$max;\n\n if (minValue >= maxValue) {\n throw new RangeError('min option must be smaller than max option');\n }\n\n var factor = (maxValue - minValue) / (currentMax - currentMin);\n\n for (var i = 0; i < input.length; i++) {\n output[i] = (input[i] - currentMin) * factor + minValue;\n }\n\n return output;\n}\n\nexport default rescale;\n","const indent = ' '.repeat(2);\nconst indentData = ' '.repeat(4);\n\nexport function inspectMatrix() {\n return inspectMatrixWithOptions(this);\n}\n\nexport function inspectMatrixWithOptions(matrix, options = {}) {\n const { maxRows = 15, maxColumns = 10, maxNumSize = 8 } = options;\n return `${matrix.constructor.name} {\n${indent}[\n${indentData}${inspectData(matrix, maxRows, maxColumns, maxNumSize)}\n${indent}]\n${indent}rows: ${matrix.rows}\n${indent}columns: ${matrix.columns}\n}`;\n}\n\nfunction inspectData(matrix, maxRows, maxColumns, maxNumSize) {\n const { rows, columns } = matrix;\n const maxI = Math.min(rows, maxRows);\n const maxJ = Math.min(columns, maxColumns);\n const result = [];\n for (let i = 0; i < maxI; i++) {\n let line = [];\n for (let j = 0; j < maxJ; j++) {\n line.push(formatNumber(matrix.get(i, j), maxNumSize));\n }\n result.push(`${line.join(' ')}`);\n }\n if (maxJ !== columns) {\n result[result.length - 1] += ` ... ${columns - maxColumns} more columns`;\n }\n if (maxI !== rows) {\n result.push(`... ${rows - maxRows} more rows`);\n }\n return result.join(`\\n${indentData}`);\n}\n\nfunction formatNumber(num, maxNumSize) {\n const numStr = String(num);\n if (numStr.length <= maxNumSize) {\n return numStr.padEnd(maxNumSize, ' ');\n }\n const precise = num.toPrecision(maxNumSize - 2);\n if (precise.length <= maxNumSize) {\n return precise;\n }\n const exponential = num.toExponential(maxNumSize - 2);\n const eIndex = exponential.indexOf('e');\n const e = exponential.slice(eIndex);\n return exponential.slice(0, maxNumSize - e.length) + e;\n}\n","/**\n * @private\n * Check that a row index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nexport function checkRowIndex(matrix, index, outer) {\n let max = outer ? matrix.rows : matrix.rows - 1;\n if (index < 0 || index > max) {\n throw new RangeError('Row index out of range');\n }\n}\n\n/**\n * @private\n * Check that a column index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nexport function checkColumnIndex(matrix, index, outer) {\n let max = outer ? matrix.columns : matrix.columns - 1;\n if (index < 0 || index > max) {\n throw new RangeError('Column index out of range');\n }\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nexport function checkRowVector(matrix, vector) {\n if (vector.to1DArray) {\n vector = vector.to1DArray();\n }\n if (vector.length !== matrix.columns) {\n throw new RangeError(\n 'vector size must be the same as the number of columns',\n );\n }\n return vector;\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nexport function checkColumnVector(matrix, vector) {\n if (vector.to1DArray) {\n vector = vector.to1DArray();\n }\n if (vector.length !== matrix.rows) {\n throw new RangeError('vector size must be the same as the number of rows');\n }\n return vector;\n}\n\nexport function checkIndices(matrix, rowIndices, columnIndices) {\n return {\n row: checkRowIndices(matrix, rowIndices),\n column: checkColumnIndices(matrix, columnIndices),\n };\n}\n\nexport function checkRowIndices(matrix, rowIndices) {\n if (typeof rowIndices !== 'object') {\n throw new TypeError('unexpected type for row indices');\n }\n\n let rowOut = rowIndices.some((r) => {\n return r < 0 || r >= matrix.rows;\n });\n\n if (rowOut) {\n throw new RangeError('row indices are out of range');\n }\n\n if (!Array.isArray(rowIndices)) rowIndices = Array.from(rowIndices);\n\n return rowIndices;\n}\n\nexport function checkColumnIndices(matrix, columnIndices) {\n if (typeof columnIndices !== 'object') {\n throw new TypeError('unexpected type for column indices');\n }\n\n let columnOut = columnIndices.some((c) => {\n return c < 0 || c >= matrix.columns;\n });\n\n if (columnOut) {\n throw new RangeError('column indices are out of range');\n }\n if (!Array.isArray(columnIndices)) columnIndices = Array.from(columnIndices);\n\n return columnIndices;\n}\n\nexport function checkRange(matrix, startRow, endRow, startColumn, endColumn) {\n if (arguments.length !== 5) {\n throw new RangeError('expected 4 arguments');\n }\n checkNumber('startRow', startRow);\n checkNumber('endRow', endRow);\n checkNumber('startColumn', startColumn);\n checkNumber('endColumn', endColumn);\n if (\n startRow > endRow ||\n startColumn > endColumn ||\n startRow < 0 ||\n startRow >= matrix.rows ||\n endRow < 0 ||\n endRow >= matrix.rows ||\n startColumn < 0 ||\n startColumn >= matrix.columns ||\n endColumn < 0 ||\n endColumn >= matrix.columns\n ) {\n throw new RangeError('Submatrix indices are out of range');\n }\n}\n\nexport function newArray(length, value = 0) {\n let array = [];\n for (let i = 0; i < length; i++) {\n array.push(value);\n }\n return array;\n}\n\nfunction checkNumber(name, value) {\n if (typeof value !== 'number') {\n throw new TypeError(`${name} must be a number`);\n }\n}\n\nexport function checkNonEmpty(matrix) {\n if (matrix.isEmpty()) {\n throw new Error('Empty matrix has no elements to index');\n }\n}\n","import { newArray } from './util';\n\nexport function sumByRow(matrix) {\n let sum = newArray(matrix.rows);\n for (let i = 0; i < matrix.rows; ++i) {\n for (let j = 0; j < matrix.columns; ++j) {\n sum[i] += matrix.get(i, j);\n }\n }\n return sum;\n}\n\nexport function sumByColumn(matrix) {\n let sum = newArray(matrix.columns);\n for (let i = 0; i < matrix.rows; ++i) {\n for (let j = 0; j < matrix.columns; ++j) {\n sum[j] += matrix.get(i, j);\n }\n }\n return sum;\n}\n\nexport function sumAll(matrix) {\n let v = 0;\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n v += matrix.get(i, j);\n }\n }\n return v;\n}\n\nexport function productByRow(matrix) {\n let sum = newArray(matrix.rows, 1);\n for (let i = 0; i < matrix.rows; ++i) {\n for (let j = 0; j < matrix.columns; ++j) {\n sum[i] *= matrix.get(i, j);\n }\n }\n return sum;\n}\n\nexport function productByColumn(matrix) {\n let sum = newArray(matrix.columns, 1);\n for (let i = 0; i < matrix.rows; ++i) {\n for (let j = 0; j < matrix.columns; ++j) {\n sum[j] *= matrix.get(i, j);\n }\n }\n return sum;\n}\n\nexport function productAll(matrix) {\n let v = 1;\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n v *= matrix.get(i, j);\n }\n }\n return v;\n}\n\nexport function varianceByRow(matrix, unbiased, mean) {\n const rows = matrix.rows;\n const cols = matrix.columns;\n const variance = [];\n\n for (let i = 0; i < rows; i++) {\n let sum1 = 0;\n let sum2 = 0;\n let x = 0;\n for (let j = 0; j < cols; j++) {\n x = matrix.get(i, j) - mean[i];\n sum1 += x;\n sum2 += x * x;\n }\n if (unbiased) {\n variance.push((sum2 - (sum1 * sum1) / cols) / (cols - 1));\n } else {\n variance.push((sum2 - (sum1 * sum1) / cols) / cols);\n }\n }\n return variance;\n}\n\nexport function varianceByColumn(matrix, unbiased, mean) {\n const rows = matrix.rows;\n const cols = matrix.columns;\n const variance = [];\n\n for (let j = 0; j < cols; j++) {\n let sum1 = 0;\n let sum2 = 0;\n let x = 0;\n for (let i = 0; i < rows; i++) {\n x = matrix.get(i, j) - mean[j];\n sum1 += x;\n sum2 += x * x;\n }\n if (unbiased) {\n variance.push((sum2 - (sum1 * sum1) / rows) / (rows - 1));\n } else {\n variance.push((sum2 - (sum1 * sum1) / rows) / rows);\n }\n }\n return variance;\n}\n\nexport function varianceAll(matrix, unbiased, mean) {\n const rows = matrix.rows;\n const cols = matrix.columns;\n const size = rows * cols;\n\n let sum1 = 0;\n let sum2 = 0;\n let x = 0;\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < cols; j++) {\n x = matrix.get(i, j) - mean;\n sum1 += x;\n sum2 += x * x;\n }\n }\n if (unbiased) {\n return (sum2 - (sum1 * sum1) / size) / (size - 1);\n } else {\n return (sum2 - (sum1 * sum1) / size) / size;\n }\n}\n\nexport function centerByRow(matrix, mean) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) - mean[i]);\n }\n }\n}\n\nexport function centerByColumn(matrix, mean) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) - mean[j]);\n }\n }\n}\n\nexport function centerAll(matrix, mean) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) - mean);\n }\n }\n}\n\nexport function getScaleByRow(matrix) {\n const scale = [];\n for (let i = 0; i < matrix.rows; i++) {\n let sum = 0;\n for (let j = 0; j < matrix.columns; j++) {\n sum += Math.pow(matrix.get(i, j), 2) / (matrix.columns - 1);\n }\n scale.push(Math.sqrt(sum));\n }\n return scale;\n}\n\nexport function scaleByRow(matrix, scale) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) / scale[i]);\n }\n }\n}\n\nexport function getScaleByColumn(matrix) {\n const scale = [];\n for (let j = 0; j < matrix.columns; j++) {\n let sum = 0;\n for (let i = 0; i < matrix.rows; i++) {\n sum += Math.pow(matrix.get(i, j), 2) / (matrix.rows - 1);\n }\n scale.push(Math.sqrt(sum));\n }\n return scale;\n}\n\nexport function scaleByColumn(matrix, scale) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) / scale[j]);\n }\n }\n}\n\nexport function getScaleAll(matrix) {\n const divider = matrix.size - 1;\n let sum = 0;\n for (let j = 0; j < matrix.columns; j++) {\n for (let i = 0; i < matrix.rows; i++) {\n sum += Math.pow(matrix.get(i, j), 2) / divider;\n }\n }\n return Math.sqrt(sum);\n}\n\nexport function scaleAll(matrix, scale) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) / scale);\n }\n }\n}\n","import rescale from 'ml-array-rescale';\n\nimport { inspectMatrix, inspectMatrixWithOptions } from './inspect';\nimport { installMathOperations } from './mathOperations';\nimport {\n sumByRow,\n sumByColumn,\n sumAll,\n productByRow,\n productByColumn,\n productAll,\n varianceByRow,\n varianceByColumn,\n varianceAll,\n centerByRow,\n centerByColumn,\n centerAll,\n scaleByRow,\n scaleByColumn,\n scaleAll,\n getScaleByRow,\n getScaleByColumn,\n getScaleAll,\n} from './stat';\nimport {\n checkRowVector,\n checkRowIndex,\n checkColumnIndex,\n checkColumnVector,\n checkRange,\n checkIndices,\n checkNonEmpty,\n} from './util';\n\nexport class AbstractMatrix {\n static from1DArray(newRows, newColumns, newData) {\n let length = newRows * newColumns;\n if (length !== newData.length) {\n throw new RangeError('data length does not match given dimensions');\n }\n let newMatrix = new Matrix(newRows, newColumns);\n for (let row = 0; row < newRows; row++) {\n for (let column = 0; column < newColumns; column++) {\n newMatrix.set(row, column, newData[row * newColumns + column]);\n }\n }\n return newMatrix;\n }\n\n static rowVector(newData) {\n let vector = new Matrix(1, newData.length);\n for (let i = 0; i < newData.length; i++) {\n vector.set(0, i, newData[i]);\n }\n return vector;\n }\n\n static columnVector(newData) {\n let vector = new Matrix(newData.length, 1);\n for (let i = 0; i < newData.length; i++) {\n vector.set(i, 0, newData[i]);\n }\n return vector;\n }\n\n static zeros(rows, columns) {\n return new Matrix(rows, columns);\n }\n\n static ones(rows, columns) {\n return new Matrix(rows, columns).fill(1);\n }\n\n static rand(rows, columns, options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { random = Math.random } = options;\n let matrix = new Matrix(rows, columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n matrix.set(i, j, random());\n }\n }\n return matrix;\n }\n\n static randInt(rows, columns, options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { min = 0, max = 1000, random = Math.random } = options;\n if (!Number.isInteger(min)) throw new TypeError('min must be an integer');\n if (!Number.isInteger(max)) throw new TypeError('max must be an integer');\n if (min >= max) throw new RangeError('min must be smaller than max');\n let interval = max - min;\n let matrix = new Matrix(rows, columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n let value = min + Math.round(random() * interval);\n matrix.set(i, j, value);\n }\n }\n return matrix;\n }\n\n static eye(rows, columns, value) {\n if (columns === undefined) columns = rows;\n if (value === undefined) value = 1;\n let min = Math.min(rows, columns);\n let matrix = this.zeros(rows, columns);\n for (let i = 0; i < min; i++) {\n matrix.set(i, i, value);\n }\n return matrix;\n }\n\n static diag(data, rows, columns) {\n let l = data.length;\n if (rows === undefined) rows = l;\n if (columns === undefined) columns = rows;\n let min = Math.min(l, rows, columns);\n let matrix = this.zeros(rows, columns);\n for (let i = 0; i < min; i++) {\n matrix.set(i, i, data[i]);\n }\n return matrix;\n }\n\n static min(matrix1, matrix2) {\n matrix1 = this.checkMatrix(matrix1);\n matrix2 = this.checkMatrix(matrix2);\n let rows = matrix1.rows;\n let columns = matrix1.columns;\n let result = new Matrix(rows, columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n result.set(i, j, Math.min(matrix1.get(i, j), matrix2.get(i, j)));\n }\n }\n return result;\n }\n\n static max(matrix1, matrix2) {\n matrix1 = this.checkMatrix(matrix1);\n matrix2 = this.checkMatrix(matrix2);\n let rows = matrix1.rows;\n let columns = matrix1.columns;\n let result = new this(rows, columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n result.set(i, j, Math.max(matrix1.get(i, j), matrix2.get(i, j)));\n }\n }\n return result;\n }\n\n static checkMatrix(value) {\n return AbstractMatrix.isMatrix(value) ? value : new Matrix(value);\n }\n\n static isMatrix(value) {\n return value != null && value.klass === 'Matrix';\n }\n\n get size() {\n return this.rows * this.columns;\n }\n\n apply(callback) {\n if (typeof callback !== 'function') {\n throw new TypeError('callback must be a function');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n callback.call(this, i, j);\n }\n }\n return this;\n }\n\n to1DArray() {\n let array = [];\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n array.push(this.get(i, j));\n }\n }\n return array;\n }\n\n to2DArray() {\n let copy = [];\n for (let i = 0; i < this.rows; i++) {\n copy.push([]);\n for (let j = 0; j < this.columns; j++) {\n copy[i].push(this.get(i, j));\n }\n }\n return copy;\n }\n\n toJSON() {\n return this.to2DArray();\n }\n\n isRowVector() {\n return this.rows === 1;\n }\n\n isColumnVector() {\n return this.columns === 1;\n }\n\n isVector() {\n return this.rows === 1 || this.columns === 1;\n }\n\n isSquare() {\n return this.rows === this.columns;\n }\n\n isEmpty() {\n return this.rows === 0 || this.columns === 0;\n }\n\n isSymmetric() {\n if (this.isSquare()) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j <= i; j++) {\n if (this.get(i, j) !== this.get(j, i)) {\n return false;\n }\n }\n }\n return true;\n }\n return false;\n }\n\n isEchelonForm() {\n let i = 0;\n let j = 0;\n let previousColumn = -1;\n let isEchelonForm = true;\n let checked = false;\n while (i < this.rows && isEchelonForm) {\n j = 0;\n checked = false;\n while (j < this.columns && checked === false) {\n if (this.get(i, j) === 0) {\n j++;\n } else if (this.get(i, j) === 1 && j > previousColumn) {\n checked = true;\n previousColumn = j;\n } else {\n isEchelonForm = false;\n checked = true;\n }\n }\n i++;\n }\n return isEchelonForm;\n }\n\n isReducedEchelonForm() {\n let i = 0;\n let j = 0;\n let previousColumn = -1;\n let isReducedEchelonForm = true;\n let checked = false;\n while (i < this.rows && isReducedEchelonForm) {\n j = 0;\n checked = false;\n while (j < this.columns && checked === false) {\n if (this.get(i, j) === 0) {\n j++;\n } else if (this.get(i, j) === 1 && j > previousColumn) {\n checked = true;\n previousColumn = j;\n } else {\n isReducedEchelonForm = false;\n checked = true;\n }\n }\n for (let k = j + 1; k < this.rows; k++) {\n if (this.get(i, k) !== 0) {\n isReducedEchelonForm = false;\n }\n }\n i++;\n }\n return isReducedEchelonForm;\n }\n\n echelonForm() {\n let result = this.clone();\n let h = 0;\n let k = 0;\n while (h < result.rows && k < result.columns) {\n let iMax = h;\n for (let i = h; i < result.rows; i++) {\n if (result.get(i, k) > result.get(iMax, k)) {\n iMax = i;\n }\n }\n if (result.get(iMax, k) === 0) {\n k++;\n } else {\n result.swapRows(h, iMax);\n let tmp = result.get(h, k);\n for (let j = k; j < result.columns; j++) {\n result.set(h, j, result.get(h, j) / tmp);\n }\n for (let i = h + 1; i < result.rows; i++) {\n let factor = result.get(i, k) / result.get(h, k);\n result.set(i, k, 0);\n for (let j = k + 1; j < result.columns; j++) {\n result.set(i, j, result.get(i, j) - result.get(h, j) * factor);\n }\n }\n h++;\n k++;\n }\n }\n return result;\n }\n\n reducedEchelonForm() {\n let result = this.echelonForm();\n let m = result.columns;\n let n = result.rows;\n let h = n - 1;\n while (h >= 0) {\n if (result.maxRow(h) === 0) {\n h--;\n } else {\n let p = 0;\n let pivot = false;\n while (p < n && pivot === false) {\n if (result.get(h, p) === 1) {\n pivot = true;\n } else {\n p++;\n }\n }\n for (let i = 0; i < h; i++) {\n let factor = result.get(i, p);\n for (let j = p; j < m; j++) {\n let tmp = result.get(i, j) - factor * result.get(h, j);\n result.set(i, j, tmp);\n }\n }\n h--;\n }\n }\n return result;\n }\n\n set() {\n throw new Error('set method is unimplemented');\n }\n\n get() {\n throw new Error('get method is unimplemented');\n }\n\n repeat(options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { rows = 1, columns = 1 } = options;\n if (!Number.isInteger(rows) || rows <= 0) {\n throw new TypeError('rows must be a positive integer');\n }\n if (!Number.isInteger(columns) || columns <= 0) {\n throw new TypeError('columns must be a positive integer');\n }\n let matrix = new Matrix(this.rows * rows, this.columns * columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n matrix.setSubMatrix(this, this.rows * i, this.columns * j);\n }\n }\n return matrix;\n }\n\n fill(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, value);\n }\n }\n return this;\n }\n\n neg() {\n return this.mulS(-1);\n }\n\n getRow(index) {\n checkRowIndex(this, index);\n let row = [];\n for (let i = 0; i < this.columns; i++) {\n row.push(this.get(index, i));\n }\n return row;\n }\n\n getRowVector(index) {\n return Matrix.rowVector(this.getRow(index));\n }\n\n setRow(index, array) {\n checkRowIndex(this, index);\n array = checkRowVector(this, array);\n for (let i = 0; i < this.columns; i++) {\n this.set(index, i, array[i]);\n }\n return this;\n }\n\n swapRows(row1, row2) {\n checkRowIndex(this, row1);\n checkRowIndex(this, row2);\n for (let i = 0; i < this.columns; i++) {\n let temp = this.get(row1, i);\n this.set(row1, i, this.get(row2, i));\n this.set(row2, i, temp);\n }\n return this;\n }\n\n getColumn(index) {\n checkColumnIndex(this, index);\n let column = [];\n for (let i = 0; i < this.rows; i++) {\n column.push(this.get(i, index));\n }\n return column;\n }\n\n getColumnVector(index) {\n return Matrix.columnVector(this.getColumn(index));\n }\n\n setColumn(index, array) {\n checkColumnIndex(this, index);\n array = checkColumnVector(this, array);\n for (let i = 0; i < this.rows; i++) {\n this.set(i, index, array[i]);\n }\n return this;\n }\n\n swapColumns(column1, column2) {\n checkColumnIndex(this, column1);\n checkColumnIndex(this, column2);\n for (let i = 0; i < this.rows; i++) {\n let temp = this.get(i, column1);\n this.set(i, column1, this.get(i, column2));\n this.set(i, column2, temp);\n }\n return this;\n }\n\n addRowVector(vector) {\n vector = checkRowVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) + vector[j]);\n }\n }\n return this;\n }\n\n subRowVector(vector) {\n vector = checkRowVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) - vector[j]);\n }\n }\n return this;\n }\n\n mulRowVector(vector) {\n vector = checkRowVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) * vector[j]);\n }\n }\n return this;\n }\n\n divRowVector(vector) {\n vector = checkRowVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) / vector[j]);\n }\n }\n return this;\n }\n\n addColumnVector(vector) {\n vector = checkColumnVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) + vector[i]);\n }\n }\n return this;\n }\n\n subColumnVector(vector) {\n vector = checkColumnVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) - vector[i]);\n }\n }\n return this;\n }\n\n mulColumnVector(vector) {\n vector = checkColumnVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) * vector[i]);\n }\n }\n return this;\n }\n\n divColumnVector(vector) {\n vector = checkColumnVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) / vector[i]);\n }\n }\n return this;\n }\n\n mulRow(index, value) {\n checkRowIndex(this, index);\n for (let i = 0; i < this.columns; i++) {\n this.set(index, i, this.get(index, i) * value);\n }\n return this;\n }\n\n mulColumn(index, value) {\n checkColumnIndex(this, index);\n for (let i = 0; i < this.rows; i++) {\n this.set(i, index, this.get(i, index) * value);\n }\n return this;\n }\n\n max() {\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(0, 0);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n if (this.get(i, j) > v) {\n v = this.get(i, j);\n }\n }\n }\n return v;\n }\n\n maxIndex() {\n checkNonEmpty(this);\n let v = this.get(0, 0);\n let idx = [0, 0];\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n if (this.get(i, j) > v) {\n v = this.get(i, j);\n idx[0] = i;\n idx[1] = j;\n }\n }\n }\n return idx;\n }\n\n min() {\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(0, 0);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n if (this.get(i, j) < v) {\n v = this.get(i, j);\n }\n }\n }\n return v;\n }\n\n minIndex() {\n checkNonEmpty(this);\n let v = this.get(0, 0);\n let idx = [0, 0];\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n if (this.get(i, j) < v) {\n v = this.get(i, j);\n idx[0] = i;\n idx[1] = j;\n }\n }\n }\n return idx;\n }\n\n maxRow(row) {\n checkRowIndex(this, row);\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(row, 0);\n for (let i = 1; i < this.columns; i++) {\n if (this.get(row, i) > v) {\n v = this.get(row, i);\n }\n }\n return v;\n }\n\n maxRowIndex(row) {\n checkRowIndex(this, row);\n checkNonEmpty(this);\n let v = this.get(row, 0);\n let idx = [row, 0];\n for (let i = 1; i < this.columns; i++) {\n if (this.get(row, i) > v) {\n v = this.get(row, i);\n idx[1] = i;\n }\n }\n return idx;\n }\n\n minRow(row) {\n checkRowIndex(this, row);\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(row, 0);\n for (let i = 1; i < this.columns; i++) {\n if (this.get(row, i) < v) {\n v = this.get(row, i);\n }\n }\n return v;\n }\n\n minRowIndex(row) {\n checkRowIndex(this, row);\n checkNonEmpty(this);\n let v = this.get(row, 0);\n let idx = [row, 0];\n for (let i = 1; i < this.columns; i++) {\n if (this.get(row, i) < v) {\n v = this.get(row, i);\n idx[1] = i;\n }\n }\n return idx;\n }\n\n maxColumn(column) {\n checkColumnIndex(this, column);\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(0, column);\n for (let i = 1; i < this.rows; i++) {\n if (this.get(i, column) > v) {\n v = this.get(i, column);\n }\n }\n return v;\n }\n\n maxColumnIndex(column) {\n checkColumnIndex(this, column);\n checkNonEmpty(this);\n let v = this.get(0, column);\n let idx = [0, column];\n for (let i = 1; i < this.rows; i++) {\n if (this.get(i, column) > v) {\n v = this.get(i, column);\n idx[0] = i;\n }\n }\n return idx;\n }\n\n minColumn(column) {\n checkColumnIndex(this, column);\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(0, column);\n for (let i = 1; i < this.rows; i++) {\n if (this.get(i, column) < v) {\n v = this.get(i, column);\n }\n }\n return v;\n }\n\n minColumnIndex(column) {\n checkColumnIndex(this, column);\n checkNonEmpty(this);\n let v = this.get(0, column);\n let idx = [0, column];\n for (let i = 1; i < this.rows; i++) {\n if (this.get(i, column) < v) {\n v = this.get(i, column);\n idx[0] = i;\n }\n }\n return idx;\n }\n\n diag() {\n let min = Math.min(this.rows, this.columns);\n let diag = [];\n for (let i = 0; i < min; i++) {\n diag.push(this.get(i, i));\n }\n return diag;\n }\n\n norm(type = 'frobenius') {\n let result = 0;\n if (type === 'max') {\n return this.max();\n } else if (type === 'frobenius') {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n result = result + this.get(i, j) * this.get(i, j);\n }\n }\n return Math.sqrt(result);\n } else {\n throw new RangeError(`unknown norm type: ${type}`);\n }\n }\n\n cumulativeSum() {\n let sum = 0;\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n sum += this.get(i, j);\n this.set(i, j, sum);\n }\n }\n return this;\n }\n\n dot(vector2) {\n if (AbstractMatrix.isMatrix(vector2)) vector2 = vector2.to1DArray();\n let vector1 = this.to1DArray();\n if (vector1.length !== vector2.length) {\n throw new RangeError('vectors do not have the same size');\n }\n let dot = 0;\n for (let i = 0; i < vector1.length; i++) {\n dot += vector1[i] * vector2[i];\n }\n return dot;\n }\n\n mmul(other) {\n other = Matrix.checkMatrix(other);\n\n let m = this.rows;\n let n = this.columns;\n let p = other.columns;\n\n let result = new Matrix(m, p);\n\n let Bcolj = new Float64Array(n);\n for (let j = 0; j < p; j++) {\n for (let k = 0; k < n; k++) {\n Bcolj[k] = other.get(k, j);\n }\n\n for (let i = 0; i < m; i++) {\n let s = 0;\n for (let k = 0; k < n; k++) {\n s += this.get(i, k) * Bcolj[k];\n }\n\n result.set(i, j, s);\n }\n }\n return result;\n }\n\n strassen2x2(other) {\n other = Matrix.checkMatrix(other);\n let result = new Matrix(2, 2);\n const a11 = this.get(0, 0);\n const b11 = other.get(0, 0);\n const a12 = this.get(0, 1);\n const b12 = other.get(0, 1);\n const a21 = this.get(1, 0);\n const b21 = other.get(1, 0);\n const a22 = this.get(1, 1);\n const b22 = other.get(1, 1);\n\n // Compute intermediate values.\n const m1 = (a11 + a22) * (b11 + b22);\n const m2 = (a21 + a22) * b11;\n const m3 = a11 * (b12 - b22);\n const m4 = a22 * (b21 - b11);\n const m5 = (a11 + a12) * b22;\n const m6 = (a21 - a11) * (b11 + b12);\n const m7 = (a12 - a22) * (b21 + b22);\n\n // Combine intermediate values into the output.\n const c00 = m1 + m4 - m5 + m7;\n const c01 = m3 + m5;\n const c10 = m2 + m4;\n const c11 = m1 - m2 + m3 + m6;\n\n result.set(0, 0, c00);\n result.set(0, 1, c01);\n result.set(1, 0, c10);\n result.set(1, 1, c11);\n return result;\n }\n\n strassen3x3(other) {\n other = Matrix.checkMatrix(other);\n let result = new Matrix(3, 3);\n\n const a00 = this.get(0, 0);\n const a01 = this.get(0, 1);\n const a02 = this.get(0, 2);\n const a10 = this.get(1, 0);\n const a11 = this.get(1, 1);\n const a12 = this.get(1, 2);\n const a20 = this.get(2, 0);\n const a21 = this.get(2, 1);\n const a22 = this.get(2, 2);\n\n const b00 = other.get(0, 0);\n const b01 = other.get(0, 1);\n const b02 = other.get(0, 2);\n const b10 = other.get(1, 0);\n const b11 = other.get(1, 1);\n const b12 = other.get(1, 2);\n const b20 = other.get(2, 0);\n const b21 = other.get(2, 1);\n const b22 = other.get(2, 2);\n\n const m1 = (a00 + a01 + a02 - a10 - a11 - a21 - a22) * b11;\n const m2 = (a00 - a10) * (-b01 + b11);\n const m3 = a11 * (-b00 + b01 + b10 - b11 - b12 - b20 + b22);\n const m4 = (-a00 + a10 + a11) * (b00 - b01 + b11);\n const m5 = (a10 + a11) * (-b00 + b01);\n const m6 = a00 * b00;\n const m7 = (-a00 + a20 + a21) * (b00 - b02 + b12);\n const m8 = (-a00 + a20) * (b02 - b12);\n const m9 = (a20 + a21) * (-b00 + b02);\n const m10 = (a00 + a01 + a02 - a11 - a12 - a20 - a21) * b12;\n const m11 = a21 * (-b00 + b02 + b10 - b11 - b12 - b20 + b21);\n const m12 = (-a02 + a21 + a22) * (b11 + b20 - b21);\n const m13 = (a02 - a22) * (b11 - b21);\n const m14 = a02 * b20;\n const m15 = (a21 + a22) * (-b20 + b21);\n const m16 = (-a02 + a11 + a12) * (b12 + b20 - b22);\n const m17 = (a02 - a12) * (b12 - b22);\n const m18 = (a11 + a12) * (-b20 + b22);\n const m19 = a01 * b10;\n const m20 = a12 * b21;\n const m21 = a10 * b02;\n const m22 = a20 * b01;\n const m23 = a22 * b22;\n\n const c00 = m6 + m14 + m19;\n const c01 = m1 + m4 + m5 + m6 + m12 + m14 + m15;\n const c02 = m6 + m7 + m9 + m10 + m14 + m16 + m18;\n const c10 = m2 + m3 + m4 + m6 + m14 + m16 + m17;\n const c11 = m2 + m4 + m5 + m6 + m20;\n const c12 = m14 + m16 + m17 + m18 + m21;\n const c20 = m6 + m7 + m8 + m11 + m12 + m13 + m14;\n const c21 = m12 + m13 + m14 + m15 + m22;\n const c22 = m6 + m7 + m8 + m9 + m23;\n\n result.set(0, 0, c00);\n result.set(0, 1, c01);\n result.set(0, 2, c02);\n result.set(1, 0, c10);\n result.set(1, 1, c11);\n result.set(1, 2, c12);\n result.set(2, 0, c20);\n result.set(2, 1, c21);\n result.set(2, 2, c22);\n return result;\n }\n\n mmulStrassen(y) {\n y = Matrix.checkMatrix(y);\n let x = this.clone();\n let r1 = x.rows;\n let c1 = x.columns;\n let r2 = y.rows;\n let c2 = y.columns;\n if (c1 !== r2) {\n // eslint-disable-next-line no-console\n console.warn(\n `Multiplying ${r1} x ${c1} and ${r2} x ${c2} matrix: dimensions do not match.`,\n );\n }\n\n // Put a matrix into the top left of a matrix of zeros.\n // `rows` and `cols` are the dimensions of the output matrix.\n function embed(mat, rows, cols) {\n let r = mat.rows;\n let c = mat.columns;\n if (r === rows && c === cols) {\n return mat;\n } else {\n let resultat = AbstractMatrix.zeros(rows, cols);\n resultat = resultat.setSubMatrix(mat, 0, 0);\n return resultat;\n }\n }\n\n // Make sure both matrices are the same size.\n // This is exclusively for simplicity:\n // this algorithm can be implemented with matrices of different sizes.\n\n let r = Math.max(r1, r2);\n let c = Math.max(c1, c2);\n x = embed(x, r, c);\n y = embed(y, r, c);\n\n // Our recursive multiplication function.\n function blockMult(a, b, rows, cols) {\n // For small matrices, resort to naive multiplication.\n if (rows <= 512 || cols <= 512) {\n return a.mmul(b); // a is equivalent to this\n }\n\n // Apply dynamic padding.\n if (rows % 2 === 1 && cols % 2 === 1) {\n a = embed(a, rows + 1, cols + 1);\n b = embed(b, rows + 1, cols + 1);\n } else if (rows % 2 === 1) {\n a = embed(a, rows + 1, cols);\n b = embed(b, rows + 1, cols);\n } else if (cols % 2 === 1) {\n a = embed(a, rows, cols + 1);\n b = embed(b, rows, cols + 1);\n }\n\n let halfRows = parseInt(a.rows / 2, 10);\n let halfCols = parseInt(a.columns / 2, 10);\n // Subdivide input matrices.\n let a11 = a.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n let b11 = b.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n\n let a12 = a.subMatrix(0, halfRows - 1, halfCols, a.columns - 1);\n let b12 = b.subMatrix(0, halfRows - 1, halfCols, b.columns - 1);\n\n let a21 = a.subMatrix(halfRows, a.rows - 1, 0, halfCols - 1);\n let b21 = b.subMatrix(halfRows, b.rows - 1, 0, halfCols - 1);\n\n let a22 = a.subMatrix(halfRows, a.rows - 1, halfCols, a.columns - 1);\n let b22 = b.subMatrix(halfRows, b.rows - 1, halfCols, b.columns - 1);\n\n // Compute intermediate values.\n let m1 = blockMult(\n AbstractMatrix.add(a11, a22),\n AbstractMatrix.add(b11, b22),\n halfRows,\n halfCols,\n );\n let m2 = blockMult(AbstractMatrix.add(a21, a22), b11, halfRows, halfCols);\n let m3 = blockMult(a11, AbstractMatrix.sub(b12, b22), halfRows, halfCols);\n let m4 = blockMult(a22, AbstractMatrix.sub(b21, b11), halfRows, halfCols);\n let m5 = blockMult(AbstractMatrix.add(a11, a12), b22, halfRows, halfCols);\n let m6 = blockMult(\n AbstractMatrix.sub(a21, a11),\n AbstractMatrix.add(b11, b12),\n halfRows,\n halfCols,\n );\n let m7 = blockMult(\n AbstractMatrix.sub(a12, a22),\n AbstractMatrix.add(b21, b22),\n halfRows,\n halfCols,\n );\n\n // Combine intermediate values into the output.\n let c11 = AbstractMatrix.add(m1, m4);\n c11.sub(m5);\n c11.add(m7);\n let c12 = AbstractMatrix.add(m3, m5);\n let c21 = AbstractMatrix.add(m2, m4);\n let c22 = AbstractMatrix.sub(m1, m2);\n c22.add(m3);\n c22.add(m6);\n\n // Crop output to the desired size (undo dynamic padding).\n let resultat = AbstractMatrix.zeros(2 * c11.rows, 2 * c11.columns);\n resultat = resultat.setSubMatrix(c11, 0, 0);\n resultat = resultat.setSubMatrix(c12, c11.rows, 0);\n resultat = resultat.setSubMatrix(c21, 0, c11.columns);\n resultat = resultat.setSubMatrix(c22, c11.rows, c11.columns);\n return resultat.subMatrix(0, rows - 1, 0, cols - 1);\n }\n return blockMult(x, y, r, c);\n }\n\n scaleRows(options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { min = 0, max = 1 } = options;\n if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n if (min >= max) throw new RangeError('min must be smaller than max');\n let newMatrix = new Matrix(this.rows, this.columns);\n for (let i = 0; i < this.rows; i++) {\n const row = this.getRow(i);\n if (row.length > 0) {\n rescale(row, { min, max, output: row });\n }\n newMatrix.setRow(i, row);\n }\n return newMatrix;\n }\n\n scaleColumns(options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { min = 0, max = 1 } = options;\n if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n if (min >= max) throw new RangeError('min must be smaller than max');\n let newMatrix = new Matrix(this.rows, this.columns);\n for (let i = 0; i < this.columns; i++) {\n const column = this.getColumn(i);\n if (column.length) {\n rescale(column, {\n min: min,\n max: max,\n output: column,\n });\n }\n newMatrix.setColumn(i, column);\n }\n return newMatrix;\n }\n\n flipRows() {\n const middle = Math.ceil(this.columns / 2);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < middle; j++) {\n let first = this.get(i, j);\n let last = this.get(i, this.columns - 1 - j);\n this.set(i, j, last);\n this.set(i, this.columns - 1 - j, first);\n }\n }\n return this;\n }\n\n flipColumns() {\n const middle = Math.ceil(this.rows / 2);\n for (let j = 0; j < this.columns; j++) {\n for (let i = 0; i < middle; i++) {\n let first = this.get(i, j);\n let last = this.get(this.rows - 1 - i, j);\n this.set(i, j, last);\n this.set(this.rows - 1 - i, j, first);\n }\n }\n return this;\n }\n\n kroneckerProduct(other) {\n other = Matrix.checkMatrix(other);\n\n let m = this.rows;\n let n = this.columns;\n let p = other.rows;\n let q = other.columns;\n\n let result = new Matrix(m * p, n * q);\n for (let i = 0; i < m; i++) {\n for (let j = 0; j < n; j++) {\n for (let k = 0; k < p; k++) {\n for (let l = 0; l < q; l++) {\n result.set(p * i + k, q * j + l, this.get(i, j) * other.get(k, l));\n }\n }\n }\n }\n return result;\n }\n\n kroneckerSum(other) {\n other = Matrix.checkMatrix(other);\n if (!this.isSquare() || !other.isSquare()) {\n throw new Error('Kronecker Sum needs two Square Matrices');\n }\n let m = this.rows;\n let n = other.rows;\n let AxI = this.kroneckerProduct(Matrix.eye(n, n));\n let IxB = Matrix.eye(m, m).kroneckerProduct(other);\n return AxI.add(IxB);\n }\n\n transpose() {\n let result = new Matrix(this.columns, this.rows);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n result.set(j, i, this.get(i, j));\n }\n }\n return result;\n }\n\n sortRows(compareFunction = compareNumbers) {\n for (let i = 0; i < this.rows; i++) {\n this.setRow(i, this.getRow(i).sort(compareFunction));\n }\n return this;\n }\n\n sortColumns(compareFunction = compareNumbers) {\n for (let i = 0; i < this.columns; i++) {\n this.setColumn(i, this.getColumn(i).sort(compareFunction));\n }\n return this;\n }\n\n subMatrix(startRow, endRow, startColumn, endColumn) {\n checkRange(this, startRow, endRow, startColumn, endColumn);\n let newMatrix = new Matrix(\n endRow - startRow + 1,\n endColumn - startColumn + 1,\n );\n for (let i = startRow; i <= endRow; i++) {\n for (let j = startColumn; j <= endColumn; j++) {\n newMatrix.set(i - startRow, j - startColumn, this.get(i, j));\n }\n }\n return newMatrix;\n }\n\n subMatrixRow(indices, startColumn, endColumn) {\n if (startColumn === undefined) startColumn = 0;\n if (endColumn === undefined) endColumn = this.columns - 1;\n if (\n startColumn > endColumn ||\n startColumn < 0 ||\n startColumn >= this.columns ||\n endColumn < 0 ||\n endColumn >= this.columns\n ) {\n throw new RangeError('Argument out of range');\n }\n\n let newMatrix = new Matrix(indices.length, endColumn - startColumn + 1);\n for (let i = 0; i < indices.length; i++) {\n for (let j = startColumn; j <= endColumn; j++) {\n if (indices[i] < 0 || indices[i] >= this.rows) {\n throw new RangeError(`Row index out of range: ${indices[i]}`);\n }\n newMatrix.set(i, j - startColumn, this.get(indices[i], j));\n }\n }\n return newMatrix;\n }\n\n subMatrixColumn(indices, startRow, endRow) {\n if (startRow === undefined) startRow = 0;\n if (endRow === undefined) endRow = this.rows - 1;\n if (\n startRow > endRow ||\n startRow < 0 ||\n startRow >= this.rows ||\n endRow < 0 ||\n endRow >= this.rows\n ) {\n throw new RangeError('Argument out of range');\n }\n\n let newMatrix = new Matrix(endRow - startRow + 1, indices.length);\n for (let i = 0; i < indices.length; i++) {\n for (let j = startRow; j <= endRow; j++) {\n if (indices[i] < 0 || indices[i] >= this.columns) {\n throw new RangeError(`Column index out of range: ${indices[i]}`);\n }\n newMatrix.set(j - startRow, i, this.get(j, indices[i]));\n }\n }\n return newMatrix;\n }\n\n setSubMatrix(matrix, startRow, startColumn) {\n matrix = Matrix.checkMatrix(matrix);\n if (matrix.isEmpty()) {\n return this;\n }\n let endRow = startRow + matrix.rows - 1;\n let endColumn = startColumn + matrix.columns - 1;\n checkRange(this, startRow, endRow, startColumn, endColumn);\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n this.set(startRow + i, startColumn + j, matrix.get(i, j));\n }\n }\n return this;\n }\n\n selection(rowIndices, columnIndices) {\n let indices = checkIndices(this, rowIndices, columnIndices);\n let newMatrix = new Matrix(rowIndices.length, columnIndices.length);\n for (let i = 0; i < indices.row.length; i++) {\n let rowIndex = indices.row[i];\n for (let j = 0; j < indices.column.length; j++) {\n let columnIndex = indices.column[j];\n newMatrix.set(i, j, this.get(rowIndex, columnIndex));\n }\n }\n return newMatrix;\n }\n\n trace() {\n let min = Math.min(this.rows, this.columns);\n let trace = 0;\n for (let i = 0; i < min; i++) {\n trace += this.get(i, i);\n }\n return trace;\n }\n\n clone() {\n let newMatrix = new Matrix(this.rows, this.columns);\n for (let row = 0; row < this.rows; row++) {\n for (let column = 0; column < this.columns; column++) {\n newMatrix.set(row, column, this.get(row, column));\n }\n }\n return newMatrix;\n }\n\n sum(by) {\n switch (by) {\n case 'row':\n return sumByRow(this);\n case 'column':\n return sumByColumn(this);\n case undefined:\n return sumAll(this);\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n product(by) {\n switch (by) {\n case 'row':\n return productByRow(this);\n case 'column':\n return productByColumn(this);\n case undefined:\n return productAll(this);\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n mean(by) {\n const sum = this.sum(by);\n switch (by) {\n case 'row': {\n for (let i = 0; i < this.rows; i++) {\n sum[i] /= this.columns;\n }\n return sum;\n }\n case 'column': {\n for (let i = 0; i < this.columns; i++) {\n sum[i] /= this.rows;\n }\n return sum;\n }\n case undefined:\n return sum / this.size;\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n variance(by, options = {}) {\n if (typeof by === 'object') {\n options = by;\n by = undefined;\n }\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { unbiased = true, mean = this.mean(by) } = options;\n if (typeof unbiased !== 'boolean') {\n throw new TypeError('unbiased must be a boolean');\n }\n switch (by) {\n case 'row': {\n if (!Array.isArray(mean)) {\n throw new TypeError('mean must be an array');\n }\n return varianceByRow(this, unbiased, mean);\n }\n case 'column': {\n if (!Array.isArray(mean)) {\n throw new TypeError('mean must be an array');\n }\n return varianceByColumn(this, unbiased, mean);\n }\n case undefined: {\n if (typeof mean !== 'number') {\n throw new TypeError('mean must be a number');\n }\n return varianceAll(this, unbiased, mean);\n }\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n standardDeviation(by, options) {\n if (typeof by === 'object') {\n options = by;\n by = undefined;\n }\n const variance = this.variance(by, options);\n if (by === undefined) {\n return Math.sqrt(variance);\n } else {\n for (let i = 0; i < variance.length; i++) {\n variance[i] = Math.sqrt(variance[i]);\n }\n return variance;\n }\n }\n\n center(by, options = {}) {\n if (typeof by === 'object') {\n options = by;\n by = undefined;\n }\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { center = this.mean(by) } = options;\n switch (by) {\n case 'row': {\n if (!Array.isArray(center)) {\n throw new TypeError('center must be an array');\n }\n centerByRow(this, center);\n return this;\n }\n case 'column': {\n if (!Array.isArray(center)) {\n throw new TypeError('center must be an array');\n }\n centerByColumn(this, center);\n return this;\n }\n case undefined: {\n if (typeof center !== 'number') {\n throw new TypeError('center must be a number');\n }\n centerAll(this, center);\n return this;\n }\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n scale(by, options = {}) {\n if (typeof by === 'object') {\n options = by;\n by = undefined;\n }\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n let scale = options.scale;\n switch (by) {\n case 'row': {\n if (scale === undefined) {\n scale = getScaleByRow(this);\n } else if (!Array.isArray(scale)) {\n throw new TypeError('scale must be an array');\n }\n scaleByRow(this, scale);\n return this;\n }\n case 'column': {\n if (scale === undefined) {\n scale = getScaleByColumn(this);\n } else if (!Array.isArray(scale)) {\n throw new TypeError('scale must be an array');\n }\n scaleByColumn(this, scale);\n return this;\n }\n case undefined: {\n if (scale === undefined) {\n scale = getScaleAll(this);\n } else if (typeof scale !== 'number') {\n throw new TypeError('scale must be a number');\n }\n scaleAll(this, scale);\n return this;\n }\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n toString(options) {\n return inspectMatrixWithOptions(this, options);\n }\n}\n\nAbstractMatrix.prototype.klass = 'Matrix';\nif (typeof Symbol !== 'undefined') {\n AbstractMatrix.prototype[\n Symbol.for('nodejs.util.inspect.custom')\n ] = inspectMatrix;\n}\n\nfunction compareNumbers(a, b) {\n return a - b;\n}\n\n// Synonyms\nAbstractMatrix.random = AbstractMatrix.rand;\nAbstractMatrix.randomInt = AbstractMatrix.randInt;\nAbstractMatrix.diagonal = AbstractMatrix.diag;\nAbstractMatrix.prototype.diagonal = AbstractMatrix.prototype.diag;\nAbstractMatrix.identity = AbstractMatrix.eye;\nAbstractMatrix.prototype.negate = AbstractMatrix.prototype.neg;\nAbstractMatrix.prototype.tensorProduct =\n AbstractMatrix.prototype.kroneckerProduct;\n\nexport default class Matrix extends AbstractMatrix {\n constructor(nRows, nColumns) {\n super();\n if (Matrix.isMatrix(nRows)) {\n // eslint-disable-next-line no-constructor-return\n return nRows.clone();\n } else if (Number.isInteger(nRows) && nRows >= 0) {\n // Create an empty matrix\n this.data = [];\n if (Number.isInteger(nColumns) && nColumns >= 0) {\n for (let i = 0; i < nRows; i++) {\n this.data.push(new Float64Array(nColumns));\n }\n } else {\n throw new TypeError('nColumns must be a positive integer');\n }\n } else if (Array.isArray(nRows)) {\n // Copy the values from the 2D array\n const arrayData = nRows;\n nRows = arrayData.length;\n nColumns = nRows ? arrayData[0].length : 0;\n if (typeof nColumns !== 'number') {\n throw new TypeError(\n 'Data must be a 2D array with at least one element',\n );\n }\n this.data = [];\n for (let i = 0; i < nRows; i++) {\n if (arrayData[i].length !== nColumns) {\n throw new RangeError('Inconsistent array dimensions');\n }\n this.data.push(Float64Array.from(arrayData[i]));\n }\n } else {\n throw new TypeError(\n 'First argument must be a positive number or an array',\n );\n }\n this.rows = nRows;\n this.columns = nColumns;\n }\n\n set(rowIndex, columnIndex, value) {\n this.data[rowIndex][columnIndex] = value;\n return this;\n }\n\n get(rowIndex, columnIndex) {\n return this.data[rowIndex][columnIndex];\n }\n\n removeRow(index) {\n checkRowIndex(this, index);\n this.data.splice(index, 1);\n this.rows -= 1;\n return this;\n }\n\n addRow(index, array) {\n if (array === undefined) {\n array = index;\n index = this.rows;\n }\n checkRowIndex(this, index, true);\n array = Float64Array.from(checkRowVector(this, array));\n this.data.splice(index, 0, array);\n this.rows += 1;\n return this;\n }\n\n removeColumn(index) {\n checkColumnIndex(this, index);\n for (let i = 0; i < this.rows; i++) {\n const newRow = new Float64Array(this.columns - 1);\n for (let j = 0; j < index; j++) {\n newRow[j] = this.data[i][j];\n }\n for (let j = index + 1; j < this.columns; j++) {\n newRow[j - 1] = this.data[i][j];\n }\n this.data[i] = newRow;\n }\n this.columns -= 1;\n return this;\n }\n\n addColumn(index, array) {\n if (typeof array === 'undefined') {\n array = index;\n index = this.columns;\n }\n checkColumnIndex(this, index, true);\n array = checkColumnVector(this, array);\n for (let i = 0; i < this.rows; i++) {\n const newRow = new Float64Array(this.columns + 1);\n let j = 0;\n for (; j < index; j++) {\n newRow[j] = this.data[i][j];\n }\n newRow[j++] = array[i];\n for (; j < this.columns + 1; j++) {\n newRow[j] = this.data[i][j - 1];\n }\n this.data[i] = newRow;\n }\n this.columns += 1;\n return this;\n }\n}\n\ninstallMathOperations(AbstractMatrix, Matrix);\n","export function installMathOperations(AbstractMatrix, Matrix) {\n AbstractMatrix.prototype.add = function add(value) {\n if (typeof value === 'number') return this.addS(value);\n return this.addM(value);\n };\n\n AbstractMatrix.prototype.addS = function addS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) + value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.addM = function addM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) + matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.add = function add(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.add(value);\n };\n\n AbstractMatrix.prototype.sub = function sub(value) {\n if (typeof value === 'number') return this.subS(value);\n return this.subM(value);\n };\n\n AbstractMatrix.prototype.subS = function subS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) - value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.subM = function subM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) - matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.sub = function sub(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sub(value);\n };\n AbstractMatrix.prototype.subtract = AbstractMatrix.prototype.sub;\n AbstractMatrix.prototype.subtractS = AbstractMatrix.prototype.subS;\n AbstractMatrix.prototype.subtractM = AbstractMatrix.prototype.subM;\n AbstractMatrix.subtract = AbstractMatrix.sub;\n\n AbstractMatrix.prototype.mul = function mul(value) {\n if (typeof value === 'number') return this.mulS(value);\n return this.mulM(value);\n };\n\n AbstractMatrix.prototype.mulS = function mulS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) * value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.mulM = function mulM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) * matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.mul = function mul(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.mul(value);\n };\n AbstractMatrix.prototype.multiply = AbstractMatrix.prototype.mul;\n AbstractMatrix.prototype.multiplyS = AbstractMatrix.prototype.mulS;\n AbstractMatrix.prototype.multiplyM = AbstractMatrix.prototype.mulM;\n AbstractMatrix.multiply = AbstractMatrix.mul;\n\n AbstractMatrix.prototype.div = function div(value) {\n if (typeof value === 'number') return this.divS(value);\n return this.divM(value);\n };\n\n AbstractMatrix.prototype.divS = function divS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) / value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.divM = function divM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) / matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.div = function div(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.div(value);\n };\n AbstractMatrix.prototype.divide = AbstractMatrix.prototype.div;\n AbstractMatrix.prototype.divideS = AbstractMatrix.prototype.divS;\n AbstractMatrix.prototype.divideM = AbstractMatrix.prototype.divM;\n AbstractMatrix.divide = AbstractMatrix.div;\n\n AbstractMatrix.prototype.mod = function mod(value) {\n if (typeof value === 'number') return this.modS(value);\n return this.modM(value);\n };\n\n AbstractMatrix.prototype.modS = function modS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) % value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.modM = function modM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) % matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.mod = function mod(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.mod(value);\n };\n AbstractMatrix.prototype.modulus = AbstractMatrix.prototype.mod;\n AbstractMatrix.prototype.modulusS = AbstractMatrix.prototype.modS;\n AbstractMatrix.prototype.modulusM = AbstractMatrix.prototype.modM;\n AbstractMatrix.modulus = AbstractMatrix.mod;\n\n AbstractMatrix.prototype.and = function and(value) {\n if (typeof value === 'number') return this.andS(value);\n return this.andM(value);\n };\n\n AbstractMatrix.prototype.andS = function andS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) & value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.andM = function andM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) & matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.and = function and(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.and(value);\n };\n\n AbstractMatrix.prototype.or = function or(value) {\n if (typeof value === 'number') return this.orS(value);\n return this.orM(value);\n };\n\n AbstractMatrix.prototype.orS = function orS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) | value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.orM = function orM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) | matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.or = function or(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.or(value);\n };\n\n AbstractMatrix.prototype.xor = function xor(value) {\n if (typeof value === 'number') return this.xorS(value);\n return this.xorM(value);\n };\n\n AbstractMatrix.prototype.xorS = function xorS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) ^ value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.xorM = function xorM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) ^ matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.xor = function xor(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.xor(value);\n };\n\n AbstractMatrix.prototype.leftShift = function leftShift(value) {\n if (typeof value === 'number') return this.leftShiftS(value);\n return this.leftShiftM(value);\n };\n\n AbstractMatrix.prototype.leftShiftS = function leftShiftS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) << value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.leftShiftM = function leftShiftM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) << matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.leftShift = function leftShift(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.leftShift(value);\n };\n\n AbstractMatrix.prototype.signPropagatingRightShift = function signPropagatingRightShift(value) {\n if (typeof value === 'number') return this.signPropagatingRightShiftS(value);\n return this.signPropagatingRightShiftM(value);\n };\n\n AbstractMatrix.prototype.signPropagatingRightShiftS = function signPropagatingRightShiftS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) >> value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.signPropagatingRightShiftM = function signPropagatingRightShiftM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) >> matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.signPropagatingRightShift = function signPropagatingRightShift(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.signPropagatingRightShift(value);\n };\n\n AbstractMatrix.prototype.rightShift = function rightShift(value) {\n if (typeof value === 'number') return this.rightShiftS(value);\n return this.rightShiftM(value);\n };\n\n AbstractMatrix.prototype.rightShiftS = function rightShiftS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) >>> value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.rightShiftM = function rightShiftM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) >>> matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.rightShift = function rightShift(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.rightShift(value);\n };\n AbstractMatrix.prototype.zeroFillRightShift = AbstractMatrix.prototype.rightShift;\n AbstractMatrix.prototype.zeroFillRightShiftS = AbstractMatrix.prototype.rightShiftS;\n AbstractMatrix.prototype.zeroFillRightShiftM = AbstractMatrix.prototype.rightShiftM;\n AbstractMatrix.zeroFillRightShift = AbstractMatrix.rightShift;\n\n AbstractMatrix.prototype.not = function not() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, ~(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.not = function not(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.not();\n };\n\n AbstractMatrix.prototype.abs = function abs() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.abs(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.abs = function abs(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.abs();\n };\n\n AbstractMatrix.prototype.acos = function acos() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.acos(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.acos = function acos(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.acos();\n };\n\n AbstractMatrix.prototype.acosh = function acosh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.acosh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.acosh = function acosh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.acosh();\n };\n\n AbstractMatrix.prototype.asin = function asin() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.asin(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.asin = function asin(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.asin();\n };\n\n AbstractMatrix.prototype.asinh = function asinh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.asinh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.asinh = function asinh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.asinh();\n };\n\n AbstractMatrix.prototype.atan = function atan() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.atan(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.atan = function atan(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.atan();\n };\n\n AbstractMatrix.prototype.atanh = function atanh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.atanh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.atanh = function atanh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.atanh();\n };\n\n AbstractMatrix.prototype.cbrt = function cbrt() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.cbrt(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.cbrt = function cbrt(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.cbrt();\n };\n\n AbstractMatrix.prototype.ceil = function ceil() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.ceil(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.ceil = function ceil(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.ceil();\n };\n\n AbstractMatrix.prototype.clz32 = function clz32() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.clz32(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.clz32 = function clz32(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.clz32();\n };\n\n AbstractMatrix.prototype.cos = function cos() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.cos(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.cos = function cos(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.cos();\n };\n\n AbstractMatrix.prototype.cosh = function cosh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.cosh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.cosh = function cosh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.cosh();\n };\n\n AbstractMatrix.prototype.exp = function exp() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.exp(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.exp = function exp(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.exp();\n };\n\n AbstractMatrix.prototype.expm1 = function expm1() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.expm1(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.expm1 = function expm1(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.expm1();\n };\n\n AbstractMatrix.prototype.floor = function floor() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.floor(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.floor = function floor(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.floor();\n };\n\n AbstractMatrix.prototype.fround = function fround() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.fround(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.fround = function fround(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.fround();\n };\n\n AbstractMatrix.prototype.log = function log() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.log(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.log = function log(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.log();\n };\n\n AbstractMatrix.prototype.log1p = function log1p() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.log1p(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.log1p = function log1p(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.log1p();\n };\n\n AbstractMatrix.prototype.log10 = function log10() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.log10(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.log10 = function log10(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.log10();\n };\n\n AbstractMatrix.prototype.log2 = function log2() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.log2(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.log2 = function log2(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.log2();\n };\n\n AbstractMatrix.prototype.round = function round() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.round(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.round = function round(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.round();\n };\n\n AbstractMatrix.prototype.sign = function sign() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.sign(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.sign = function sign(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sign();\n };\n\n AbstractMatrix.prototype.sin = function sin() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.sin(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.sin = function sin(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sin();\n };\n\n AbstractMatrix.prototype.sinh = function sinh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.sinh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.sinh = function sinh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sinh();\n };\n\n AbstractMatrix.prototype.sqrt = function sqrt() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.sqrt(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.sqrt = function sqrt(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sqrt();\n };\n\n AbstractMatrix.prototype.tan = function tan() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.tan(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.tan = function tan(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.tan();\n };\n\n AbstractMatrix.prototype.tanh = function tanh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.tanh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.tanh = function tanh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.tanh();\n };\n\n AbstractMatrix.prototype.trunc = function trunc() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.trunc(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.trunc = function trunc(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.trunc();\n };\n\n AbstractMatrix.pow = function pow(matrix, arg0) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.pow(arg0);\n };\n\n AbstractMatrix.prototype.pow = function pow(value) {\n if (typeof value === 'number') return this.powS(value);\n return this.powM(value);\n };\n\n AbstractMatrix.prototype.powS = function powS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.pow(this.get(i, j), value));\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.powM = function powM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.pow(this.get(i, j), matrix.get(i, j)));\n }\n }\n return this;\n };\n}\n","import { AbstractMatrix } from '../matrix';\n\nexport default class WrapperMatrix2D extends AbstractMatrix {\n constructor(data) {\n super();\n this.data = data;\n this.rows = data.length;\n this.columns = data[0].length;\n }\n\n set(rowIndex, columnIndex, value) {\n this.data[rowIndex][columnIndex] = value;\n return this;\n }\n\n get(rowIndex, columnIndex) {\n return this.data[rowIndex][columnIndex];\n }\n}\n","export function hypotenuse(a, b) {\n let r = 0;\n if (Math.abs(a) > Math.abs(b)) {\n r = b / a;\n return Math.abs(a) * Math.sqrt(1 + r * r);\n }\n if (b !== 0) {\n r = a / b;\n return Math.abs(b) * Math.sqrt(1 + r * r);\n }\n return 0;\n}\n","import Matrix from '../matrix';\nimport WrapperMatrix2D from '../wrap/WrapperMatrix2D';\n\nimport { hypotenuse } from './util';\n\nexport default class SingularValueDecomposition {\n constructor(value, options = {}) {\n value = WrapperMatrix2D.checkMatrix(value);\n\n if (value.isEmpty()) {\n throw new Error('Matrix must be non-empty');\n }\n\n let m = value.rows;\n let n = value.columns;\n\n const {\n computeLeftSingularVectors = true,\n computeRightSingularVectors = true,\n autoTranspose = false,\n } = options;\n\n let wantu = Boolean(computeLeftSingularVectors);\n let wantv = Boolean(computeRightSingularVectors);\n\n let swapped = false;\n let a;\n if (m < n) {\n if (!autoTranspose) {\n a = value.clone();\n // eslint-disable-next-line no-console\n console.warn(\n 'Computing SVD on a matrix with more columns than rows. Consider enabling autoTranspose',\n );\n } else {\n a = value.transpose();\n m = a.rows;\n n = a.columns;\n swapped = true;\n let aux = wantu;\n wantu = wantv;\n wantv = aux;\n }\n } else {\n a = value.clone();\n }\n\n let nu = Math.min(m, n);\n let ni = Math.min(m + 1, n);\n let s = new Float64Array(ni);\n let U = new Matrix(m, nu);\n let V = new Matrix(n, n);\n\n let e = new Float64Array(n);\n let work = new Float64Array(m);\n\n let si = new Float64Array(ni);\n for (let i = 0; i < ni; i++) si[i] = i;\n\n let nct = Math.min(m - 1, n);\n let nrt = Math.max(0, Math.min(n - 2, m));\n let mrc = Math.max(nct, nrt);\n\n for (let k = 0; k < mrc; k++) {\n if (k < nct) {\n s[k] = 0;\n for (let i = k; i < m; i++) {\n s[k] = hypotenuse(s[k], a.get(i, k));\n }\n if (s[k] !== 0) {\n if (a.get(k, k) < 0) {\n s[k] = -s[k];\n }\n for (let i = k; i < m; i++) {\n a.set(i, k, a.get(i, k) / s[k]);\n }\n a.set(k, k, a.get(k, k) + 1);\n }\n s[k] = -s[k];\n }\n\n for (let j = k + 1; j < n; j++) {\n if (k < nct && s[k] !== 0) {\n let t = 0;\n for (let i = k; i < m; i++) {\n t += a.get(i, k) * a.get(i, j);\n }\n t = -t / a.get(k, k);\n for (let i = k; i < m; i++) {\n a.set(i, j, a.get(i, j) + t * a.get(i, k));\n }\n }\n e[j] = a.get(k, j);\n }\n\n if (wantu && k < nct) {\n for (let i = k; i < m; i++) {\n U.set(i, k, a.get(i, k));\n }\n }\n\n if (k < nrt) {\n e[k] = 0;\n for (let i = k + 1; i < n; i++) {\n e[k] = hypotenuse(e[k], e[i]);\n }\n if (e[k] !== 0) {\n if (e[k + 1] < 0) {\n e[k] = 0 - e[k];\n }\n for (let i = k + 1; i < n; i++) {\n e[i] /= e[k];\n }\n e[k + 1] += 1;\n }\n e[k] = -e[k];\n if (k + 1 < m && e[k] !== 0) {\n for (let i = k + 1; i < m; i++) {\n work[i] = 0;\n }\n for (let i = k + 1; i < m; i++) {\n for (let j = k + 1; j < n; j++) {\n work[i] += e[j] * a.get(i, j);\n }\n }\n for (let j = k + 1; j < n; j++) {\n let t = -e[j] / e[k + 1];\n for (let i = k + 1; i < m; i++) {\n a.set(i, j, a.get(i, j) + t * work[i]);\n }\n }\n }\n if (wantv) {\n for (let i = k + 1; i < n; i++) {\n V.set(i, k, e[i]);\n }\n }\n }\n }\n\n let p = Math.min(n, m + 1);\n if (nct < n) {\n s[nct] = a.get(nct, nct);\n }\n if (m < p) {\n s[p - 1] = 0;\n }\n if (nrt + 1 < p) {\n e[nrt] = a.get(nrt, p - 1);\n }\n e[p - 1] = 0;\n\n if (wantu) {\n for (let j = nct; j < nu; j++) {\n for (let i = 0; i < m; i++) {\n U.set(i, j, 0);\n }\n U.set(j, j, 1);\n }\n for (let k = nct - 1; k >= 0; k--) {\n if (s[k] !== 0) {\n for (let j = k + 1; j < nu; j++) {\n let t = 0;\n for (let i = k; i < m; i++) {\n t += U.get(i, k) * U.get(i, j);\n }\n t = -t / U.get(k, k);\n for (let i = k; i < m; i++) {\n U.set(i, j, U.get(i, j) + t * U.get(i, k));\n }\n }\n for (let i = k; i < m; i++) {\n U.set(i, k, -U.get(i, k));\n }\n U.set(k, k, 1 + U.get(k, k));\n for (let i = 0; i < k - 1; i++) {\n U.set(i, k, 0);\n }\n } else {\n for (let i = 0; i < m; i++) {\n U.set(i, k, 0);\n }\n U.set(k, k, 1);\n }\n }\n }\n\n if (wantv) {\n for (let k = n - 1; k >= 0; k--) {\n if (k < nrt && e[k] !== 0) {\n for (let j = k + 1; j < n; j++) {\n let t = 0;\n for (let i = k + 1; i < n; i++) {\n t += V.get(i, k) * V.get(i, j);\n }\n t = -t / V.get(k + 1, k);\n for (let i = k + 1; i < n; i++) {\n V.set(i, j, V.get(i, j) + t * V.get(i, k));\n }\n }\n }\n for (let i = 0; i < n; i++) {\n V.set(i, k, 0);\n }\n V.set(k, k, 1);\n }\n }\n\n let pp = p - 1;\n let iter = 0;\n let eps = Number.EPSILON;\n while (p > 0) {\n let k, kase;\n for (k = p - 2; k >= -1; k--) {\n if (k === -1) {\n break;\n }\n const alpha =\n Number.MIN_VALUE + eps * Math.abs(s[k] + Math.abs(s[k + 1]));\n if (Math.abs(e[k]) <= alpha || Number.isNaN(e[k])) {\n e[k] = 0;\n break;\n }\n }\n if (k === p - 2) {\n kase = 4;\n } else {\n let ks;\n for (ks = p - 1; ks >= k; ks--) {\n if (ks === k) {\n break;\n }\n let t =\n (ks !== p ? Math.abs(e[ks]) : 0) +\n (ks !== k + 1 ? Math.abs(e[ks - 1]) : 0);\n if (Math.abs(s[ks]) <= eps * t) {\n s[ks] = 0;\n break;\n }\n }\n if (ks === k) {\n kase = 3;\n } else if (ks === p - 1) {\n kase = 1;\n } else {\n kase = 2;\n k = ks;\n }\n }\n\n k++;\n\n switch (kase) {\n case 1: {\n let f = e[p - 2];\n e[p - 2] = 0;\n for (let j = p - 2; j >= k; j--) {\n let t = hypotenuse(s[j], f);\n let cs = s[j] / t;\n let sn = f / t;\n s[j] = t;\n if (j !== k) {\n f = -sn * e[j - 1];\n e[j - 1] = cs * e[j - 1];\n }\n if (wantv) {\n for (let i = 0; i < n; i++) {\n t = cs * V.get(i, j) + sn * V.get(i, p - 1);\n V.set(i, p - 1, -sn * V.get(i, j) + cs * V.get(i, p - 1));\n V.set(i, j, t);\n }\n }\n }\n break;\n }\n case 2: {\n let f = e[k - 1];\n e[k - 1] = 0;\n for (let j = k; j < p; j++) {\n let t = hypotenuse(s[j], f);\n let cs = s[j] / t;\n let sn = f / t;\n s[j] = t;\n f = -sn * e[j];\n e[j] = cs * e[j];\n if (wantu) {\n for (let i = 0; i < m; i++) {\n t = cs * U.get(i, j) + sn * U.get(i, k - 1);\n U.set(i, k - 1, -sn * U.get(i, j) + cs * U.get(i, k - 1));\n U.set(i, j, t);\n }\n }\n }\n break;\n }\n case 3: {\n const scale = Math.max(\n Math.abs(s[p - 1]),\n Math.abs(s[p - 2]),\n Math.abs(e[p - 2]),\n Math.abs(s[k]),\n Math.abs(e[k]),\n );\n const sp = s[p - 1] / scale;\n const spm1 = s[p - 2] / scale;\n const epm1 = e[p - 2] / scale;\n const sk = s[k] / scale;\n const ek = e[k] / scale;\n const b = ((spm1 + sp) * (spm1 - sp) + epm1 * epm1) / 2;\n const c = sp * epm1 * (sp * epm1);\n let shift = 0;\n if (b !== 0 || c !== 0) {\n if (b < 0) {\n shift = 0 - Math.sqrt(b * b + c);\n } else {\n shift = Math.sqrt(b * b + c);\n }\n shift = c / (b + shift);\n }\n let f = (sk + sp) * (sk - sp) + shift;\n let g = sk * ek;\n for (let j = k; j < p - 1; j++) {\n let t = hypotenuse(f, g);\n if (t === 0) t = Number.MIN_VALUE;\n let cs = f / t;\n let sn = g / t;\n if (j !== k) {\n e[j - 1] = t;\n }\n f = cs * s[j] + sn * e[j];\n e[j] = cs * e[j] - sn * s[j];\n g = sn * s[j + 1];\n s[j + 1] = cs * s[j + 1];\n if (wantv) {\n for (let i = 0; i < n; i++) {\n t = cs * V.get(i, j) + sn * V.get(i, j + 1);\n V.set(i, j + 1, -sn * V.get(i, j) + cs * V.get(i, j + 1));\n V.set(i, j, t);\n }\n }\n t = hypotenuse(f, g);\n if (t === 0) t = Number.MIN_VALUE;\n cs = f / t;\n sn = g / t;\n s[j] = t;\n f = cs * e[j] + sn * s[j + 1];\n s[j + 1] = -sn * e[j] + cs * s[j + 1];\n g = sn * e[j + 1];\n e[j + 1] = cs * e[j + 1];\n if (wantu && j < m - 1) {\n for (let i = 0; i < m; i++) {\n t = cs * U.get(i, j) + sn * U.get(i, j + 1);\n U.set(i, j + 1, -sn * U.get(i, j) + cs * U.get(i, j + 1));\n U.set(i, j, t);\n }\n }\n }\n e[p - 2] = f;\n iter = iter + 1;\n break;\n }\n case 4: {\n if (s[k] <= 0) {\n s[k] = s[k] < 0 ? -s[k] : 0;\n if (wantv) {\n for (let i = 0; i <= pp; i++) {\n V.set(i, k, -V.get(i, k));\n }\n }\n }\n while (k < pp) {\n if (s[k] >= s[k + 1]) {\n break;\n }\n let t = s[k];\n s[k] = s[k + 1];\n s[k + 1] = t;\n if (wantv && k < n - 1) {\n for (let i = 0; i < n; i++) {\n t = V.get(i, k + 1);\n V.set(i, k + 1, V.get(i, k));\n V.set(i, k, t);\n }\n }\n if (wantu && k < m - 1) {\n for (let i = 0; i < m; i++) {\n t = U.get(i, k + 1);\n U.set(i, k + 1, U.get(i, k));\n U.set(i, k, t);\n }\n }\n k++;\n }\n iter = 0;\n p--;\n break;\n }\n // no default\n }\n }\n\n if (swapped) {\n let tmp = V;\n V = U;\n U = tmp;\n }\n\n this.m = m;\n this.n = n;\n this.s = s;\n this.U = U;\n this.V = V;\n }\n\n solve(value) {\n let Y = value;\n let e = this.threshold;\n let scols = this.s.length;\n let Ls = Matrix.zeros(scols, scols);\n\n for (let i = 0; i < scols; i++) {\n if (Math.abs(this.s[i]) <= e) {\n Ls.set(i, i, 0);\n } else {\n Ls.set(i, i, 1 / this.s[i]);\n }\n }\n\n let U = this.U;\n let V = this.rightSingularVectors;\n\n let VL = V.mmul(Ls);\n let vrows = V.rows;\n let urows = U.rows;\n let VLU = Matrix.zeros(vrows, urows);\n\n for (let i = 0; i < vrows; i++) {\n for (let j = 0; j < urows; j++) {\n let sum = 0;\n for (let k = 0; k < scols; k++) {\n sum += VL.get(i, k) * U.get(j, k);\n }\n VLU.set(i, j, sum);\n }\n }\n\n return VLU.mmul(Y);\n }\n\n solveForDiagonal(value) {\n return this.solve(Matrix.diag(value));\n }\n\n inverse() {\n let V = this.V;\n let e = this.threshold;\n let vrows = V.rows;\n let vcols = V.columns;\n let X = new Matrix(vrows, this.s.length);\n\n for (let i = 0; i < vrows; i++) {\n for (let j = 0; j < vcols; j++) {\n if (Math.abs(this.s[j]) > e) {\n X.set(i, j, V.get(i, j) / this.s[j]);\n }\n }\n }\n\n let U = this.U;\n\n let urows = U.rows;\n let ucols = U.columns;\n let Y = new Matrix(vrows, urows);\n\n for (let i = 0; i < vrows; i++) {\n for (let j = 0; j < urows; j++) {\n let sum = 0;\n for (let k = 0; k < ucols; k++) {\n sum += X.get(i, k) * U.get(j, k);\n }\n Y.set(i, j, sum);\n }\n }\n\n return Y;\n }\n\n get condition() {\n return this.s[0] / this.s[Math.min(this.m, this.n) - 1];\n }\n\n get norm2() {\n return this.s[0];\n }\n\n get rank() {\n let tol = Math.max(this.m, this.n) * this.s[0] * Number.EPSILON;\n let r = 0;\n let s = this.s;\n for (let i = 0, ii = s.length; i < ii; i++) {\n if (s[i] > tol) {\n r++;\n }\n }\n return r;\n }\n\n get diagonal() {\n return Array.from(this.s);\n }\n\n get threshold() {\n return (Number.EPSILON / 2) * Math.max(this.m, this.n) * this.s[0];\n }\n\n get leftSingularVectors() {\n return this.U;\n }\n\n get rightSingularVectors() {\n return this.V;\n }\n\n get diagonalMatrix() {\n return Matrix.diag(this.s);\n }\n}\n","import { Matrix as MLMatrix, SingularValueDecomposition } from 'ml-matrix';\nexport default class MDS {\n constructor(params) {\n this.distances = params.distances;\n this.dimension = params.dimension || 2;\n this.linkDistance = params.linkDistance;\n }\n layout() {\n const self = this;\n const { dimension, distances, linkDistance } = self;\n try {\n // square distances\n const M = MLMatrix.mul(MLMatrix.pow(distances, 2), -0.5);\n // double centre the rows/columns\n const rowMeans = M.mean('row');\n const colMeans = M.mean('column');\n const totalMean = M.mean();\n M.add(totalMean).subRowVector(rowMeans).subColumnVector(colMeans);\n // take the SVD of the double centred matrix, and return the\n // points from it\n const ret = new SingularValueDecomposition(M);\n const eigenValues = MLMatrix.sqrt(ret.diagonalMatrix).diagonal();\n return ret.leftSingularVectors.toJSON().map((row) => {\n return MLMatrix.mul([row], [eigenValues]).toJSON()[0].splice(0, dimension);\n });\n }\n catch (_a) {\n const res = [];\n for (let i = 0; i < distances.length; i++) {\n const x = Math.random() * linkDistance;\n const y = Math.random() * linkDistance;\n res.push([x, y]);\n }\n return res;\n }\n }\n}\n//# sourceMappingURL=mds.js.map","const SPEED_DIVISOR = 800;\nexport default class RadialNonoverlapForce {\n constructor(params) {\n this.disp = [];\n this.positions = params.positions;\n this.adjMatrix = params.adjMatrix;\n this.focusID = params.focusID;\n this.radii = params.radii;\n this.iterations = params.iterations || 10;\n this.height = params.height || 10;\n this.width = params.width || 10;\n this.speed = params.speed || 100;\n this.gravity = params.gravity || 10;\n this.nodeSizeFunc = params.nodeSizeFunc;\n this.k = params.k || 5;\n this.strictRadial = params.strictRadial;\n this.nodes = params.nodes;\n }\n layout() {\n const self = this;\n const positions = self.positions;\n const disp = [];\n const iterations = self.iterations;\n const maxDisplace = self.width / 10;\n self.maxDisplace = maxDisplace;\n self.disp = disp;\n for (let i = 0; i < iterations; i++) {\n positions.forEach((_, k) => {\n disp[k] = { x: 0, y: 0 };\n });\n // 给重叠的节点增加斥力\n self.getRepulsion();\n self.updatePositions();\n }\n return positions;\n }\n getRepulsion() {\n const self = this;\n const positions = self.positions;\n const nodes = self.nodes;\n const disp = self.disp;\n const k = self.k;\n const radii = self.radii || [];\n positions.forEach((v, i) => {\n disp[i] = { x: 0, y: 0 };\n positions.forEach((u, j) => {\n if (i === j) {\n return;\n }\n // v and u are not on the same circle, return\n if (radii[i] !== radii[j]) {\n return;\n }\n let vecx = v[0] - u[0];\n let vecy = v[1] - u[1];\n let vecLength = Math.sqrt(vecx * vecx + vecy * vecy);\n if (vecLength === 0) {\n vecLength = 1;\n const sign = i > j ? 1 : -1;\n vecx = 0.01 * sign;\n vecy = 0.01 * sign;\n }\n // these two nodes overlap\n if (vecLength < self.nodeSizeFunc(nodes[i]) / 2 + self.nodeSizeFunc(nodes[j]) / 2) {\n const common = (k * k) / vecLength;\n disp[i].x += (vecx / vecLength) * common;\n disp[i].y += (vecy / vecLength) * common;\n }\n });\n });\n }\n updatePositions() {\n const self = this;\n const positions = self.positions;\n const disp = self.disp;\n const speed = self.speed;\n const strictRadial = self.strictRadial;\n const f = self.focusID;\n const maxDisplace = self.maxDisplace || self.width / 10;\n if (strictRadial) {\n disp.forEach((di, i) => {\n const vx = positions[i][0] - positions[f][0];\n const vy = positions[i][1] - positions[f][1];\n const vLength = Math.sqrt(vx * vx + vy * vy);\n let vpx = vy / vLength;\n let vpy = -vx / vLength;\n const diLength = Math.sqrt(di.x * di.x + di.y * di.y);\n let alpha = Math.acos((vpx * di.x + vpy * di.y) / diLength);\n if (alpha > Math.PI / 2) {\n alpha -= Math.PI / 2;\n vpx *= -1;\n vpy *= -1;\n }\n const tdispLength = Math.cos(alpha) * diLength;\n di.x = vpx * tdispLength;\n di.y = vpy * tdispLength;\n });\n }\n // move\n const radii = self.radii;\n positions.forEach((n, i) => {\n if (i === f) {\n return;\n }\n const distLength = Math.sqrt(disp[i].x * disp[i].x + disp[i].y * disp[i].y);\n if (distLength > 0 && i !== f) {\n const limitedDist = Math.min(maxDisplace * (speed / SPEED_DIVISOR), distLength);\n n[0] += (disp[i].x / distLength) * limitedDist;\n n[1] += (disp[i].y / distLength) * limitedDist;\n if (strictRadial) {\n let vx = n[0] - positions[f][0];\n let vy = n[1] - positions[f][1];\n const nfDis = Math.sqrt(vx * vx + vy * vy);\n vx = (vx / nfDis) * radii[i];\n vy = (vy / nfDis) * radii[i];\n n[0] = positions[f][0] + vx;\n n[1] = positions[f][1] + vy;\n }\n }\n });\n }\n}\n//# sourceMappingURL=radialNonoverlapForce.js.map","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\nimport { isNaN, isArray, isFunction, isNumber, isString, floydWarshall, getAdjMatrix, isObject } from \"../../util\";\nimport { Base } from \"../base\";\nimport MDS from \"./mds\";\nimport RadialNonoverlapForce from \"./radialNonoverlapForce\";\nfunction getWeightMatrix(M) {\n const rows = M.length;\n const cols = M[0].length;\n const result = [];\n for (let i = 0; i < rows; i++) {\n const row = [];\n for (let j = 0; j < cols; j++) {\n if (M[i][j] !== 0) {\n row.push(1 / (M[i][j] * M[i][j]));\n }\n else {\n row.push(0);\n }\n }\n result.push(row);\n }\n return result;\n}\nfunction getIndexById(array, id) {\n let index = -1;\n array.forEach((a, i) => {\n if (a.id === id) {\n index = i;\n }\n });\n return index;\n}\nfunction getEDistance(p1, p2) {\n return Math.sqrt((p1[0] - p2[0]) * (p1[0] - p2[0]) + (p1[1] - p2[1]) * (p1[1] - p2[1]));\n}\n/**\n * 辐射状布局\n */\nexport class RadialLayout extends Base {\n constructor(options) {\n super();\n /** 停止迭代的最大迭代数 */\n this.maxIteration = 1000;\n /** 中心点,默认为数据中第一个点 */\n this.focusNode = null;\n /** 每一圈半径 */\n this.unitRadius = null;\n /** 默认边长度 */\n this.linkDistance = 50;\n /** 是否防止重叠 */\n this.preventOverlap = false;\n /** 是否必须是严格的 radial 布局,即每一层的节点严格布局在一个环上。preventOverlap 为 true 时生效 */\n this.strictRadial = true;\n /** 防止重叠步骤的最大迭代次数 */\n this.maxPreventOverlapIteration = 200;\n this.sortStrength = 10;\n this.nodes = [];\n this.edges = [];\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n maxIteration: 1000,\n focusNode: null,\n unitRadius: null,\n linkDistance: 50,\n preventOverlap: false,\n nodeSize: undefined,\n nodeSpacing: undefined,\n strictRadial: true,\n maxPreventOverlapIteration: 200,\n sortBy: undefined,\n sortStrength: 10\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges || [];\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n const linkDistance = self.linkDistance;\n // layout\n let focusNode = null;\n if (isString(self.focusNode)) {\n let found = false;\n for (let i = 0; i < nodes.length; i++) {\n if (nodes[i].id === self.focusNode) {\n focusNode = nodes[i];\n self.focusNode = focusNode;\n found = true;\n i = nodes.length;\n }\n }\n if (!found) {\n focusNode = null;\n }\n }\n else {\n focusNode = self.focusNode;\n }\n // default focus node\n if (!focusNode) {\n focusNode = nodes[0];\n self.focusNode = focusNode;\n }\n // the index of the focusNode in data\n const focusIndex = getIndexById(nodes, focusNode.id);\n self.focusIndex = focusIndex;\n // the graph-theoretic distance (shortest path distance) matrix\n const adjMatrix = getAdjMatrix({ nodes, edges }, false);\n const D = floydWarshall(adjMatrix);\n const maxDistance = self.maxToFocus(D, focusIndex);\n // replace first node in unconnected component to the circle at (maxDistance + 1)\n self.handleInfinity(D, focusIndex, maxDistance + 1);\n self.distances = D;\n // the shortest path distance from each node to focusNode\n const focusNodeD = D[focusIndex];\n const width = self.width || 500;\n const height = self.height || 500;\n let semiWidth = width - center[0] > center[0] ? center[0] : width - center[0];\n let semiHeight = height - center[1] > center[1] ? center[1] : height - center[1];\n if (semiWidth === 0) {\n semiWidth = width / 2;\n }\n if (semiHeight === 0) {\n semiHeight = height / 2;\n }\n // the maxRadius of the graph\n const maxRadius = semiHeight > semiWidth ? semiWidth : semiHeight;\n const maxD = Math.max(...focusNodeD);\n // the radius for each nodes away from focusNode\n const radii = [];\n focusNodeD.forEach((value, i) => {\n if (!self.unitRadius) {\n self.unitRadius = maxRadius / maxD;\n }\n radii[i] = value * self.unitRadius;\n });\n self.radii = radii;\n const eIdealD = self.eIdealDisMatrix();\n // const eIdealD = scaleMatrix(D, linkDistance);\n self.eIdealDistances = eIdealD;\n // the weight matrix, Wij = 1 / dij^(-2)\n const W = getWeightMatrix(eIdealD);\n self.weights = W;\n // the initial positions from mds\n const mds = new MDS({ linkDistance, distances: eIdealD });\n let positions = mds.layout();\n positions.forEach((p) => {\n if (isNaN(p[0])) {\n p[0] = Math.random() * linkDistance;\n }\n if (isNaN(p[1])) {\n p[1] = Math.random() * linkDistance;\n }\n });\n self.positions = positions;\n positions.forEach((p, i) => {\n nodes[i].x = p[0] + center[0];\n nodes[i].y = p[1] + center[1];\n });\n // move the graph to origin, centered at focusNode\n positions.forEach((p) => {\n p[0] -= positions[focusIndex][0];\n p[1] -= positions[focusIndex][1];\n });\n self.run();\n const preventOverlap = self.preventOverlap;\n const nodeSize = self.nodeSize;\n let nodeSizeFunc;\n const strictRadial = self.strictRadial;\n // stagger the overlapped nodes\n if (preventOverlap) {\n const nodeSpacing = self.nodeSpacing;\n let nodeSpacingFunc;\n if (isNumber(nodeSpacing)) {\n nodeSpacingFunc = () => nodeSpacing;\n }\n else if (isFunction(nodeSpacing)) {\n nodeSpacingFunc = nodeSpacing;\n }\n else {\n nodeSpacingFunc = () => 0;\n }\n if (!nodeSize) {\n nodeSizeFunc = (d) => {\n if (d.size) {\n if (isArray(d.size)) {\n const res = d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n return res + nodeSpacingFunc(d);\n }\n if (isObject(d.size)) {\n const res = d.size.width > d.size.height ? d.size.width : d.size.height;\n return res + nodeSpacingFunc(d);\n }\n return d.size + nodeSpacingFunc(d);\n }\n return 10 + nodeSpacingFunc(d);\n };\n }\n else if (isArray(nodeSize)) {\n nodeSizeFunc = (d) => {\n const res = nodeSize[0] > nodeSize[1] ? nodeSize[0] : nodeSize[1];\n return res + nodeSpacingFunc(d);\n };\n }\n else {\n nodeSizeFunc = (d) => nodeSize + nodeSpacingFunc(d);\n }\n const nonoverlapForceParams = {\n nodes,\n nodeSizeFunc,\n adjMatrix,\n positions,\n radii,\n height,\n width,\n strictRadial,\n focusID: focusIndex,\n iterations: self.maxPreventOverlapIteration || 200,\n k: positions.length / 4.5\n };\n const nonoverlapForce = new RadialNonoverlapForce(nonoverlapForceParams);\n positions = nonoverlapForce.layout();\n }\n // move the graph to center\n positions.forEach((p, i) => {\n nodes[i].x = p[0] + center[0];\n nodes[i].y = p[1] + center[1];\n });\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return {\n nodes,\n edges\n };\n }\n run() {\n const self = this;\n const maxIteration = self.maxIteration;\n const positions = self.positions || [];\n const W = self.weights || [];\n const eIdealDis = self.eIdealDistances || [];\n const radii = self.radii || [];\n for (let i = 0; i <= maxIteration; i++) {\n const param = i / maxIteration;\n self.oneIteration(param, positions, radii, eIdealDis, W);\n }\n }\n oneIteration(param, positions, radii, D, W) {\n const self = this;\n const vparam = 1 - param;\n const focusIndex = self.focusIndex;\n positions.forEach((v, i) => {\n // v\n const originDis = getEDistance(v, [0, 0]);\n const reciODis = originDis === 0 ? 0 : 1 / originDis;\n if (i === focusIndex) {\n return;\n }\n let xMolecule = 0;\n let yMolecule = 0;\n let denominator = 0;\n positions.forEach((u, j) => {\n // u\n if (i === j) {\n return;\n }\n // the euclidean distance between v and u\n const edis = getEDistance(v, u);\n const reciEdis = edis === 0 ? 0 : 1 / edis;\n const idealDis = D[j][i];\n // same for x and y\n denominator += W[i][j];\n // x\n xMolecule += W[i][j] * (u[0] + idealDis * (v[0] - u[0]) * reciEdis);\n // y\n yMolecule += W[i][j] * (u[1] + idealDis * (v[1] - u[1]) * reciEdis);\n });\n const reciR = radii[i] === 0 ? 0 : 1 / radii[i];\n denominator *= vparam;\n denominator += param * reciR * reciR;\n // x\n xMolecule *= vparam;\n xMolecule += param * reciR * v[0] * reciODis;\n v[0] = xMolecule / denominator;\n // y\n yMolecule *= vparam;\n yMolecule += param * reciR * v[1] * reciODis;\n v[1] = yMolecule / denominator;\n });\n }\n eIdealDisMatrix() {\n const self = this;\n const nodes = self.nodes;\n if (!nodes)\n return [];\n const D = self.distances;\n const linkDis = self.linkDistance;\n const radii = self.radii || [];\n const unitRadius = self.unitRadius || 50;\n const result = [];\n if (D) {\n D.forEach((row, i) => {\n const newRow = [];\n row.forEach((v, j) => {\n if (i === j) {\n newRow.push(0);\n }\n else if (radii[i] === radii[j]) {\n // i and j are on the same circle\n if (self.sortBy === \"data\") {\n // sort the nodes on the same circle according to the ordering of the data\n newRow.push((v * (Math.abs(i - j) * self.sortStrength)) /\n (radii[i] / unitRadius));\n }\n else if (self.sortBy) {\n // sort the nodes on the same circle according to the attributes\n let iValue = nodes[i][self.sortBy] || 0;\n let jValue = nodes[j][self.sortBy] || 0;\n if (isString(iValue)) {\n iValue = iValue.charCodeAt(0);\n }\n if (isString(jValue)) {\n jValue = jValue.charCodeAt(0);\n }\n newRow.push((v * (Math.abs(iValue - jValue) * self.sortStrength)) /\n (radii[i] / unitRadius));\n }\n else {\n newRow.push((v * linkDis) / (radii[i] / unitRadius));\n }\n }\n else {\n // i and j are on different circle\n // i and j are on different circle\n const link = (linkDis + unitRadius) / 2;\n newRow.push(v * link);\n }\n });\n result.push(newRow);\n });\n }\n return result;\n }\n handleInfinity(matrix, focusIndex, step) {\n const length = matrix.length;\n // 遍历 matrix 中遍历 focus 对应行\n for (let i = 0; i < length; i++) {\n // matrix 关注点对应行的 Inf 项\n if (matrix[focusIndex][i] === Infinity) {\n matrix[focusIndex][i] = step;\n matrix[i][focusIndex] = step;\n // 遍历 matrix 中的 i 行,i 行中非 Inf 项若在 focus 行为 Inf,则替换 focus 行的那个 Inf\n for (let j = 0; j < length; j++) {\n if (matrix[i][j] !== Infinity && matrix[focusIndex][j] === Infinity) {\n matrix[focusIndex][j] = step + matrix[i][j];\n matrix[j][focusIndex] = step + matrix[i][j];\n }\n }\n }\n }\n // 处理其他行的 Inf。根据该行对应点与 focus 距离以及 Inf 项点 与 focus 距离,决定替换值\n for (let i = 0; i < length; i++) {\n if (i === focusIndex) {\n continue;\n }\n for (let j = 0; j < length; j++) {\n if (matrix[i][j] === Infinity) {\n let minus = Math.abs(matrix[focusIndex][i] - matrix[focusIndex][j]);\n minus = minus === 0 ? 1 : minus;\n matrix[i][j] = minus;\n }\n }\n }\n }\n maxToFocus(matrix, focusIndex) {\n let max = 0;\n for (let i = 0; i < matrix[focusIndex].length; i++) {\n if (matrix[focusIndex][i] === Infinity) {\n continue;\n }\n max = matrix[focusIndex][i] > max ? matrix[focusIndex][i] : max;\n }\n return max;\n }\n getType() {\n return \"radial\";\n }\n}\n//# sourceMappingURL=radial.js.map","/**\n * @fileOverview concentric layout\n * @author shiwu.wyy@antfin.com\n * this algorithm refers to <cytoscape.js> - https://github.com/cytoscape/cytoscape.js/\n */\nimport { isString, isArray, isNumber, getDegree, isObject } from \"../util\";\nimport { Base } from \"./base\";\n/**\n * 同心圆布局\n */\nexport class ConcentricLayout extends Base {\n constructor(options) {\n super();\n this.nodeSize = 30;\n /** min spacing between outside of nodes (used for radius adjustment) */\n this.minNodeSpacing = 10;\n /** prevents node overlap, may overflow boundingBox if not enough space */\n this.preventOverlap = false;\n /** whether levels have an equal radial distance betwen them, may cause bounding box overflow */\n this.equidistant = false;\n /** where nodes start in radians */\n this.startAngle = (3 / 2) * Math.PI;\n /** whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false) */\n this.clockwise = true;\n /** 根据 sortBy 指定的属性进行排布,数值高的放在中心,如果是 sortBy 则会计算节点度数,度数最高的放在中心 */\n this.sortBy = \"degree\";\n this.nodes = [];\n this.edges = [];\n this.width = 300;\n this.height = 300;\n /** 迭代结束的回调函数 */\n this.onLayoutEnd = () => { };\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n nodeSize: 30,\n minNodeSpacing: 10,\n preventOverlap: false,\n sweep: undefined,\n equidistant: false,\n startAngle: (3 / 2) * Math.PI,\n clockwise: true,\n maxLevelDiff: undefined,\n sortBy: \"degree\"\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const n = nodes.length;\n if (n === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n if (n === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n const layoutNodes = [];\n let maxNodeSize;\n if (isArray(self.nodeSize)) {\n maxNodeSize = Math.max(self.nodeSize[0], self.nodeSize[1]);\n }\n else {\n maxNodeSize = self.nodeSize;\n }\n nodes.forEach((node) => {\n layoutNodes.push(node);\n let nodeSize = maxNodeSize;\n if (isArray(node.size)) {\n nodeSize = Math.max(node.size[0], node.size[1]);\n }\n else if (isNumber(node.size)) {\n nodeSize = node.size;\n }\n else if (isObject(node.size)) {\n nodeSize = Math.max(node.size.width, node.size.height);\n }\n maxNodeSize = Math.max(maxNodeSize, nodeSize);\n });\n self.clockwise =\n self.counterclockwise !== undefined\n ? !self.counterclockwise\n : self.clockwise;\n // layout\n const nodeMap = {};\n const indexMap = {};\n layoutNodes.forEach((node, i) => {\n nodeMap[node.id] = node;\n indexMap[node.id] = i;\n });\n // get the node degrees\n if (self.sortBy === \"degree\" ||\n !isString(self.sortBy) ||\n layoutNodes[0][self.sortBy] === undefined) {\n self.sortBy = \"degree\";\n if (!isNumber(nodes[0].degree)) {\n const values = getDegree(nodes.length, indexMap, edges);\n layoutNodes.forEach((node, i) => {\n node.degree = values[i];\n });\n }\n }\n // sort nodes by value\n layoutNodes.sort((n1, n2) => n2[self.sortBy] - n1[self.sortBy]);\n self.maxValueNode = layoutNodes[0];\n self.maxLevelDiff =\n self.maxLevelDiff || self.maxValueNode[self.sortBy] / 4;\n // put the values into levels\n const levels = [[]];\n let currentLevel = levels[0];\n layoutNodes.forEach((node) => {\n if (currentLevel.length > 0) {\n const diff = Math.abs(currentLevel[0][self.sortBy] - node[self.sortBy]);\n if (self.maxLevelDiff && diff >= self.maxLevelDiff) {\n currentLevel = [];\n levels.push(currentLevel);\n }\n }\n currentLevel.push(node);\n });\n // create positions for levels\n let minDist = maxNodeSize + self.minNodeSpacing; // min dist between nodes\n if (!self.preventOverlap) {\n // then strictly constrain to bb\n const firstLvlHasMulti = levels.length > 0 && levels[0].length > 1;\n const maxR = Math.min(self.width, self.height) / 2 - minDist;\n const rStep = maxR / (levels.length + (firstLvlHasMulti ? 1 : 0));\n minDist = Math.min(minDist, rStep);\n }\n // find the metrics for each level\n let r = 0;\n levels.forEach((level) => {\n let sweep = self.sweep;\n if (sweep === undefined) {\n sweep = 2 * Math.PI - (2 * Math.PI) / level.length;\n }\n const dTheta = (level.dTheta = sweep / Math.max(1, level.length - 1));\n // calculate the radius\n if (level.length > 1 && self.preventOverlap) {\n // but only if more than one node (can't overlap)\n const dcos = Math.cos(dTheta) - Math.cos(0);\n const dsin = Math.sin(dTheta) - Math.sin(0);\n const rMin = Math.sqrt((minDist * minDist) / (dcos * dcos + dsin * dsin)); // s.t. no nodes overlapping\n r = Math.max(rMin, r);\n }\n level.r = r;\n r += minDist;\n });\n if (self.equidistant) {\n let rDeltaMax = 0;\n let rr = 0;\n for (let i = 0; i < levels.length; i++) {\n const level = levels[i];\n const rDelta = level.r - rr;\n rDeltaMax = Math.max(rDeltaMax, rDelta);\n }\n rr = 0;\n levels.forEach((level, i) => {\n if (i === 0) {\n rr = level.r;\n }\n level.r = rr;\n rr += rDeltaMax;\n });\n }\n // calculate the node positions\n levels.forEach((level) => {\n const dTheta = level.dTheta;\n const rr = level.r;\n level.forEach((node, j) => {\n const theta = self.startAngle + (self.clockwise ? 1 : -1) * dTheta * j;\n node.x = center[0] + rr * Math.cos(theta);\n node.y = center[1] + rr * Math.sin(theta);\n });\n });\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return {\n nodes,\n edges\n };\n }\n getType() {\n return \"concentric\";\n }\n}\n//# sourceMappingURL=concentric.js.map","/**\n * @fileOverview MDS layout\n * @author shiwu.wyy@antfin.com\n */\nimport { Matrix as MLMatrix, SingularValueDecomposition } from \"ml-matrix\";\nimport { floydWarshall, getAdjMatrix, scaleMatrix } from \"../util\";\nimport { Base } from \"./base\";\n/**\n * mds 布局\n */\nexport class MDSLayout extends Base {\n constructor(options) {\n super();\n /** 布局中心 */\n this.center = [0, 0];\n /** 边长度 */\n this.linkDistance = 50;\n this.nodes = [];\n this.edges = [];\n /** 迭代结束的回调函数 */\n this.onLayoutEnd = () => { };\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n center: [0, 0],\n linkDistance: 50\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const { nodes, edges = [] } = self;\n const center = self.center;\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n const linkDistance = self.linkDistance;\n // the graph-theoretic distance (shortest path distance) matrix\n const adjMatrix = getAdjMatrix({ nodes, edges }, false);\n const distances = floydWarshall(adjMatrix);\n self.handleInfinity(distances);\n // scale the ideal edge length acoording to linkDistance\n const scaledD = scaleMatrix(distances, linkDistance);\n self.scaledDistances = scaledD;\n // get positions by MDS\n const positions = self.runMDS();\n self.positions = positions;\n positions.forEach((p, i) => {\n nodes[i].x = p[0] + center[0];\n nodes[i].y = p[1] + center[1];\n });\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return {\n nodes,\n edges\n };\n }\n /**\n * mds 算法\n * @return {array} positions 计算后的节点位置数组\n */\n runMDS() {\n const self = this;\n const dimension = 2;\n const distances = self.scaledDistances;\n // square distances\n const M = MLMatrix.mul(MLMatrix.pow(distances, 2), -0.5);\n // double centre the rows/columns\n const rowMeans = M.mean(\"row\");\n const colMeans = M.mean(\"column\");\n const totalMean = M.mean();\n M.add(totalMean)\n .subRowVector(rowMeans)\n .subColumnVector(colMeans);\n // take the SVD of the double centred matrix, and return the\n // points from it\n const ret = new SingularValueDecomposition(M);\n const eigenValues = MLMatrix.sqrt(ret.diagonalMatrix).diagonal();\n return ret.leftSingularVectors.toJSON().map((row) => {\n return MLMatrix.mul([row], [eigenValues])\n .toJSON()[0]\n .splice(0, dimension);\n });\n }\n handleInfinity(distances) {\n let maxDistance = -999999;\n distances.forEach((row) => {\n row.forEach((value) => {\n if (value === Infinity) {\n return;\n }\n if (maxDistance < value) {\n maxDistance = value;\n }\n });\n });\n distances.forEach((row, i) => {\n row.forEach((value, j) => {\n if (value === Infinity) {\n distances[i][j] = maxDistance;\n }\n });\n });\n }\n getType() {\n return \"mds\";\n }\n}\n//# sourceMappingURL=mds.js.map","/**\n * @fileOverview fruchterman layout\n * @author shiwu.wyy@antfin.com\n */\nimport { Base } from \"./base\";\nimport { getEdgeTerminal, isNumber } from \"../util\";\nconst SPEED_DIVISOR = 800;\n/**\n * fruchterman 布局\n */\nexport class FruchtermanLayout extends Base {\n constructor(options) {\n super();\n /** 停止迭代的最大迭代数 */\n this.maxIteration = 1000;\n /** 重力大小,影响图的紧凑程度 */\n this.gravity = 10;\n /** 速度 */\n this.speed = 5;\n /** 是否产生聚类力 */\n this.clustering = false;\n /** 聚类力大小 */\n this.clusterGravity = 10;\n this.nodes = [];\n this.edges = [];\n this.width = 300;\n this.height = 300;\n this.nodeMap = {};\n this.nodeIdxMap = {};\n /** 迭代结束的回调函数 */\n this.onLayoutEnd = () => { };\n /** 每次迭代结束的回调函数 */\n this.tick = () => { };\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n maxIteration: 1000,\n gravity: 10,\n speed: 1,\n clustering: false,\n clusterGravity: 10\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const nodes = self.nodes;\n if (self.timeInterval !== undefined && typeof window !== \"undefined\") {\n window.clearInterval(self.timeInterval);\n }\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n const nodeMap = {};\n const nodeIdxMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x))\n node.x = Math.random() * this.width;\n if (!isNumber(node.y))\n node.y = Math.random() * this.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n // layout\n return self.run();\n }\n run() {\n const self = this;\n const nodes = self.nodes;\n if (!nodes)\n return;\n const edges = self.edges;\n const maxIteration = self.maxIteration;\n const center = self.center;\n const area = self.height * self.width;\n const maxDisplace = Math.sqrt(area) / 10;\n const k2 = area / (nodes.length + 1);\n const k = Math.sqrt(k2);\n const gravity = self.gravity;\n const speed = self.speed;\n const clustering = self.clustering;\n const clusterMap = {};\n if (clustering) {\n nodes.forEach((n) => {\n if (clusterMap[n.cluster] === undefined) {\n const cluster = {\n name: n.cluster,\n cx: 0,\n cy: 0,\n count: 0\n };\n clusterMap[n.cluster] = cluster;\n }\n const c = clusterMap[n.cluster];\n if (isNumber(n.x)) {\n c.cx += n.x;\n }\n if (isNumber(n.y)) {\n c.cy += n.y;\n }\n c.count++;\n });\n for (const key in clusterMap) {\n clusterMap[key].cx /= clusterMap[key].count;\n clusterMap[key].cy /= clusterMap[key].count;\n }\n }\n if (typeof window === \"undefined\")\n return;\n let iter = 0;\n // interval for render the result after each iteration\n this.timeInterval = window.setInterval(() => {\n if (!nodes)\n return;\n // for (let i = 0; i < maxIteration; i++) {\n const displacements = [];\n nodes.forEach((_, j) => {\n displacements[j] = { x: 0, y: 0 };\n });\n self.applyCalculate(nodes, edges, displacements, k, k2);\n // gravity for clusters\n if (clustering) {\n const clusterGravity = self.clusterGravity || gravity;\n nodes.forEach((n, j) => {\n if (!isNumber(n.x) || !isNumber(n.y))\n return;\n const c = clusterMap[n.cluster];\n const distLength = Math.sqrt((n.x - c.cx) * (n.x - c.cx) + (n.y - c.cy) * (n.y - c.cy));\n const gravityForce = k * clusterGravity;\n displacements[j].x -= (gravityForce * (n.x - c.cx)) / distLength;\n displacements[j].y -= (gravityForce * (n.y - c.cy)) / distLength;\n });\n for (const key in clusterMap) {\n clusterMap[key].cx = 0;\n clusterMap[key].cy = 0;\n clusterMap[key].count = 0;\n }\n nodes.forEach((n) => {\n const c = clusterMap[n.cluster];\n if (isNumber(n.x)) {\n c.cx += n.x;\n }\n if (isNumber(n.y)) {\n c.cy += n.y;\n }\n c.count++;\n });\n for (const key in clusterMap) {\n clusterMap[key].cx /= clusterMap[key].count;\n clusterMap[key].cy /= clusterMap[key].count;\n }\n }\n // gravity\n nodes.forEach((n, j) => {\n if (!isNumber(n.x) || !isNumber(n.y))\n return;\n const gravityForce = 0.01 * k * gravity;\n displacements[j].x -= gravityForce * (n.x - center[0]);\n displacements[j].y -= gravityForce * (n.y - center[1]);\n });\n // move\n nodes.forEach((n, j) => {\n if (isNumber(n.fx) && isNumber(n.fy)) {\n n.x = n.fx;\n n.y = n.fy;\n return;\n }\n if (!isNumber(n.x) || !isNumber(n.y))\n return;\n const distLength = Math.sqrt(displacements[j].x * displacements[j].x +\n displacements[j].y * displacements[j].y);\n if (distLength > 0) {\n // && !n.isFixed()\n const limitedDist = Math.min(maxDisplace * (speed / SPEED_DIVISOR), distLength);\n n.x += (displacements[j].x / distLength) * limitedDist;\n n.y += (displacements[j].y / distLength) * limitedDist;\n }\n });\n if (self.tick)\n self.tick();\n iter++;\n if (iter >= maxIteration) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n window.clearInterval(self.timeInterval);\n }\n }, 0);\n return {\n nodes,\n edges\n };\n }\n applyCalculate(nodes, edges, displacements, k, k2) {\n const self = this;\n self.calRepulsive(nodes, displacements, k2);\n if (edges)\n self.calAttractive(edges, displacements, k);\n }\n calRepulsive(nodes, displacements, k2) {\n nodes.forEach((v, i) => {\n displacements[i] = { x: 0, y: 0 };\n nodes.forEach((u, j) => {\n if (i === j) {\n return;\n }\n if (!isNumber(v.x) ||\n !isNumber(u.x) ||\n !isNumber(v.y) ||\n !isNumber(u.y)) {\n return;\n }\n let vecX = v.x - u.x;\n let vecY = v.y - u.y;\n let vecLengthSqr = vecX * vecX + vecY * vecY;\n if (vecLengthSqr === 0) {\n vecLengthSqr = 1;\n const sign = i > j ? 1 : -1;\n vecX = 0.01 * sign;\n vecY = 0.01 * sign;\n }\n const common = k2 / vecLengthSqr;\n displacements[i].x += vecX * common;\n displacements[i].y += vecY * common;\n });\n });\n }\n calAttractive(edges, displacements, k) {\n edges.forEach((e) => {\n const source = getEdgeTerminal(e, 'source');\n const target = getEdgeTerminal(e, 'target');\n if (!source || !target)\n return;\n const uIndex = this.nodeIdxMap[source];\n const vIndex = this.nodeIdxMap[target];\n if (uIndex === vIndex) {\n return;\n }\n const u = this.nodeMap[source];\n const v = this.nodeMap[target];\n if (!isNumber(v.x) || !isNumber(u.x) || !isNumber(v.y) || !isNumber(u.y)) {\n return;\n }\n const vecX = v.x - u.x;\n const vecY = v.y - u.y;\n const vecLength = Math.sqrt(vecX * vecX + vecY * vecY);\n const common = (vecLength * vecLength) / k;\n displacements[vIndex].x -= (vecX / vecLength) * common;\n displacements[vIndex].y -= (vecY / vecLength) * common;\n displacements[uIndex].x += (vecX / vecLength) * common;\n displacements[uIndex].y += (vecY / vecLength) * common;\n });\n }\n stop() {\n if (this.timeInterval && typeof window !== \"undefined\") {\n window.clearInterval(this.timeInterval);\n }\n }\n destroy() {\n const self = this;\n self.stop();\n self.tick = null;\n self.nodes = null;\n self.edges = null;\n self.destroyed = true;\n }\n getType() {\n return \"fruchterman\";\n }\n}\n//# sourceMappingURL=fruchterman.js.map","export function isNumber(value: any) {\n return typeof value === 'number';\n}\n","import {\n Frustum,\n ICamera,\n IDENTIFIER,\n IInteractorService,\n} from '@antv/g-webgpu-core';\nimport { mat3, mat4, quat, vec3, vec4 } from 'gl-matrix';\nimport { inject, injectable, postConstruct } from 'inversify';\nimport { createVec3, getAngle } from '../utils/math';\nimport Landmark from './Landmark';\n\nexport enum CAMERA_TYPE {\n ORBITING = 'ORBITING',\n EXPLORING = 'EXPLORING',\n TRACKING = 'TRACKING',\n}\n\nexport enum CAMERA_TRACKING_MODE {\n DEFAULT = 'DEFAULT',\n ROTATIONAL = 'ROTATIONAL',\n TRANSLATIONAL = 'TRANSLATIONAL',\n CINEMATIC = 'CINEMATIC',\n}\n\nexport enum CAMERA_PROJECTION_MODE {\n ORTHOGRAPHIC = 'ORTHOGRAPHIC',\n PERSPECTIVE = 'PERSPECTIVE',\n}\n\nconst DEG_2_RAD = Math.PI / 180;\nconst RAD_2_DEG = 180 / Math.PI;\n\n/**\n * 参考「WebGL Insights - 23.Designing Cameras for WebGL Applications」,基于 Responsible Camera 思路设计\n * 保存相机参数,定义相机动作:\n * 1. dolly 沿 n 轴移动\n * 2. pan 沿 u v 轴移动\n * 3. rotate 以方位角旋转\n * 4. 移动到 Landmark,具有平滑的动画效果,其间禁止其他用户交互\n */\n@injectable()\nexport class Camera implements ICamera {\n public static ProjectionMode = {\n ORTHOGRAPHIC: 'ORTHOGRAPHIC',\n PERSPECTIVE: 'PERSPECTIVE',\n };\n /**\n * 相机矩阵\n */\n public matrix = mat4.create();\n\n /**\n * u 轴\n * @see http://learnwebgl.brown37.net/07_cameras/camera_introduction.html#a-camera-definition\n */\n public right = vec3.fromValues(1, 0, 0);\n\n /**\n * v 轴\n */\n public up = vec3.fromValues(0, 1, 0);\n\n /**\n * n 轴\n */\n public forward = vec3.fromValues(0, 0, 1);\n\n /**\n * 相机位置\n */\n public position = vec3.fromValues(0, 0, 1);\n\n /**\n * 视点位置\n */\n public focalPoint = vec3.fromValues(0, 0, 0);\n\n /**\n * 相机位置到视点向量\n * focalPoint - position\n */\n public distanceVector = vec3.fromValues(0, 0, 0);\n\n /**\n * 相机位置到视点距离\n * length(focalPoint - position)\n */\n public distance = 1;\n\n /**\n * @see https://en.wikipedia.org/wiki/Azimuth\n */\n public azimuth = 0;\n public elevation = 0;\n public roll = 0;\n public relAzimuth = 0;\n public relElevation = 0;\n public relRoll = 0;\n\n /**\n * 沿 n 轴移动时,保证移动速度从快到慢\n */\n public dollyingStep = 0;\n public maxDistance = Infinity;\n public minDistance = -Infinity;\n\n /**\n * invert the horizontal coordinate system HCS\n */\n public rotateWorld = false;\n\n @inject(IDENTIFIER.InteractorService)\n public interactor: IInteractorService;\n\n /**\n * 投影矩阵参数\n */\n\n /**\n * field of view [0-360]\n * @see http://en.wikipedia.org/wiki/Angle_of_view\n */\n private fov = 30;\n private near = 0.1;\n private far = 10000;\n private aspect = 1;\n private left: number;\n private rright: number;\n private top: number;\n private bottom: number;\n private zoom = 1;\n private perspective = mat4.create();\n\n private view:\n | {\n enabled: boolean;\n fullWidth: number;\n fullHeight: number;\n offsetX: number;\n offsetY: number;\n width: number;\n height: number;\n }\n | undefined;\n\n private following = undefined;\n\n private type = CAMERA_TYPE.EXPLORING;\n private trackingMode = CAMERA_TRACKING_MODE.DEFAULT;\n private projectionMode = CAMERA_PROJECTION_MODE.PERSPECTIVE;\n\n /**\n * for culling use\n */\n private frustum: Frustum = new Frustum();\n\n /**\n * switch between multiple landmarks\n */\n private landmarks: Landmark[] = [];\n private landmarkAnimationID: number | undefined;\n\n public clone(): Camera {\n const camera = new Camera();\n camera.setType(this.type, undefined);\n camera.interactor = this.interactor;\n return camera;\n }\n\n public getProjectionMode() {\n return this.projectionMode;\n }\n\n public getPerspective() {\n return this.perspective;\n }\n\n public getFrustum() {\n return this.frustum;\n }\n\n public getPosition() {\n return this.position;\n }\n\n public setType(\n type: CAMERA_TYPE,\n trackingMode: CAMERA_TRACKING_MODE | undefined,\n ) {\n this.type = type;\n if (this.type === CAMERA_TYPE.EXPLORING) {\n this.setWorldRotation(true);\n } else {\n this.setWorldRotation(false);\n }\n this._getAngles();\n\n if (this.type === CAMERA_TYPE.TRACKING && trackingMode !== undefined) {\n this.setTrackingMode(trackingMode);\n }\n return this;\n }\n\n public setProjectionMode(projectionMode: CAMERA_PROJECTION_MODE) {\n this.projectionMode = projectionMode;\n return this;\n }\n\n public setTrackingMode(trackingMode: CAMERA_TRACKING_MODE) {\n if (this.type !== CAMERA_TYPE.TRACKING) {\n throw new Error(\n 'Impossible to set a tracking mode if the camera is not of tracking type',\n );\n }\n this.trackingMode = trackingMode;\n return this;\n }\n\n /**\n * If flag is true, it reverses the azimuth and elevation angles.\n * Subsequent calls to rotate, setAzimuth, setElevation,\n * changeAzimuth or changeElevation will cause the inverted effect.\n * setRoll or changeRoll is not affected by this method.\n *\n * This inversion is useful when one wants to simulate that the world\n * is moving, instead of the camera.\n *\n * By default the camera angles are not reversed.\n * @param {Boolean} flag the boolean flag to reverse the angles.\n */\n public setWorldRotation(flag: boolean) {\n this.rotateWorld = flag;\n this._getAngles();\n }\n\n /**\n * 计算 MV 矩阵,为相机矩阵的逆矩阵\n */\n public getViewTransform(): mat4 {\n return mat4.invert(mat4.create(), this.matrix)!;\n }\n\n public getWorldTransform(): mat4 {\n return this.matrix;\n }\n\n /**\n * 设置相机矩阵\n */\n public setMatrix(matrix: mat4) {\n this.matrix = matrix;\n this._update();\n return this;\n }\n\n public setAspect(aspect: number) {\n this.setPerspective(this.near, this.far, this.fov, aspect);\n return this;\n }\n\n /**\n * Sets an offset in a larger frustum, used in PixelPicking\n */\n public setViewOffset(\n fullWidth: number,\n fullHeight: number,\n x: number,\n y: number,\n width: number,\n height: number,\n ) {\n this.aspect = fullWidth / fullHeight;\n if (this.view === undefined) {\n this.view = {\n enabled: true,\n fullWidth: 1,\n fullHeight: 1,\n offsetX: 0,\n offsetY: 0,\n width: 1,\n height: 1,\n };\n }\n\n this.view.enabled = true;\n this.view.fullWidth = fullWidth;\n this.view.fullHeight = fullHeight;\n this.view.offsetX = x;\n this.view.offsetY = y;\n this.view.width = width;\n this.view.height = height;\n\n if (this.projectionMode === CAMERA_PROJECTION_MODE.PERSPECTIVE) {\n this.setPerspective(this.near, this.far, this.fov, this.aspect);\n } else {\n this.setOrthographic(\n this.left,\n this.rright,\n this.top,\n this.bottom,\n this.near,\n this.far,\n );\n }\n return this;\n }\n\n public clearViewOffset() {\n if (this.view !== undefined) {\n this.view.enabled = false;\n }\n\n if (this.projectionMode === CAMERA_PROJECTION_MODE.PERSPECTIVE) {\n this.setPerspective(this.near, this.far, this.fov, this.aspect);\n } else {\n this.setOrthographic(\n this.left,\n this.rright,\n this.top,\n this.bottom,\n this.near,\n this.far,\n );\n }\n return this;\n }\n\n public setPerspective(\n near: number,\n far: number,\n fov: number,\n aspect: number,\n ) {\n this.projectionMode = CAMERA_PROJECTION_MODE.PERSPECTIVE;\n this.fov = fov;\n this.near = near;\n this.far = far;\n this.aspect = aspect;\n mat4.perspective(\n this.perspective,\n this.fov * DEG_2_RAD,\n this.aspect,\n this.near,\n this.far,\n );\n return this;\n }\n\n public setOrthographic(\n l: number,\n r: number,\n t: number,\n b: number,\n near: number,\n far: number,\n ) {\n this.projectionMode = CAMERA_PROJECTION_MODE.ORTHOGRAPHIC;\n this.rright = r;\n this.left = l;\n this.top = t;\n this.bottom = b;\n this.near = near;\n this.far = far;\n\n const dx = (this.rright - this.left) / (2 * this.zoom);\n const dy = (this.top - this.bottom) / (2 * this.zoom);\n const cx = (this.rright + this.left) / 2;\n const cy = (this.top + this.bottom) / 2;\n\n let left = cx - dx;\n let right = cx + dx;\n let top = cy + dy;\n let bottom = cy - dy;\n\n if (this.view !== undefined && this.view.enabled) {\n const scaleW =\n (this.rright - this.left) / this.view.fullWidth / this.zoom;\n const scaleH =\n (this.top - this.bottom) / this.view.fullHeight / this.zoom;\n\n left += scaleW * this.view.offsetX;\n right = left + scaleW * this.view.width;\n top -= scaleH * this.view.offsetY;\n bottom = top - scaleH * this.view.height;\n }\n\n mat4.ortho(this.perspective, left, right, top, bottom, near, far);\n return this;\n }\n\n /**\n * 设置相机位置\n */\n public setPosition(x: number | vec3, y?: number, z?: number) {\n this._setPosition(x, y, z);\n this.setFocalPoint(this.focalPoint);\n return this;\n }\n\n /**\n * 设置视点位置\n */\n public setFocalPoint(x: number | vec3, y?: number, z?: number) {\n let up = vec3.fromValues(0, 1, 0);\n this.focalPoint = createVec3(x, y, z);\n\n if (this.trackingMode === CAMERA_TRACKING_MODE.CINEMATIC) {\n const d = vec3.subtract(vec3.create(), this.focalPoint, this.position);\n x = d[0];\n y = d[1] as number;\n z = d[2] as number;\n const r = vec3.length(d);\n const el = Math.asin(y / r) * RAD_2_DEG;\n const az = 90 + Math.atan2(z, x) * RAD_2_DEG;\n const m = mat4.create();\n mat4.rotateY(m, m, az * DEG_2_RAD);\n mat4.rotateX(m, m, el * DEG_2_RAD);\n up = vec3.transformMat4(vec3.create(), [0, 1, 0], m);\n }\n\n mat4.invert(\n this.matrix,\n mat4.lookAt(mat4.create(), this.position, this.focalPoint, up),\n );\n\n this._getAxes();\n this._getDistance();\n this._getAngles();\n return this;\n }\n\n /**\n * 固定当前视点,按指定距离放置相机\n */\n public setDistance(d: number) {\n if (this.distance === d || d < 0) {\n return;\n }\n\n this.distance = d;\n\n if (this.distance < 0.0002) {\n this.distance = 0.0002;\n }\n this.dollyingStep = this.distance / 100;\n\n const pos = vec3.create();\n d = this.distance;\n const n = this.forward;\n const f = this.focalPoint;\n\n pos[0] = d * n[0] + f[0];\n pos[1] = d * n[1] + f[1];\n pos[2] = d * n[2] + f[2];\n\n this._setPosition(pos);\n return this;\n }\n\n public setMaxDistance(d: number) {\n this.maxDistance = d;\n return this;\n }\n\n public setMinDistance(d: number) {\n this.minDistance = d;\n return this;\n }\n\n /**\n * Changes the initial azimuth of the camera\n */\n public changeAzimuth(az: number) {\n this.setAzimuth(this.azimuth + az);\n return this;\n }\n\n /**\n * Changes the initial elevation of the camera\n */\n public changeElevation(el: number) {\n this.setElevation(this.elevation + el);\n return this;\n }\n\n /**\n * Changes the initial roll of the camera\n */\n public changeRoll(rl: number) {\n this.setRoll(this.roll + rl);\n return this;\n }\n\n /**\n * 设置相机方位角,不同相机模式下需要重新计算相机位置或者是视点位置\n * @param {Number} el the azimuth in degrees\n */\n public setAzimuth(az: number) {\n this.azimuth = getAngle(az);\n this.computeMatrix();\n\n this._getAxes();\n if (\n this.type === CAMERA_TYPE.ORBITING ||\n this.type === CAMERA_TYPE.EXPLORING\n ) {\n this._getPosition();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n this._getFocalPoint();\n }\n return this;\n }\n\n public getAzimuth() {\n return this.azimuth;\n }\n\n /**\n * 设置相机方位角,不同相机模式下需要重新计算相机位置或者是视点位置\n * @param {Number} el the elevation in degrees\n */\n public setElevation(el: number) {\n this.elevation = getAngle(el);\n this.computeMatrix();\n\n this._getAxes();\n if (\n this.type === CAMERA_TYPE.ORBITING ||\n this.type === CAMERA_TYPE.EXPLORING\n ) {\n this._getPosition();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n this._getFocalPoint();\n }\n return this;\n }\n\n /**\n * 设置相机方位角,不同相机模式下需要重新计算相机位置或者是视点位置\n * @param {Number} angle the roll angle\n */\n public setRoll(angle: number) {\n this.roll = getAngle(angle);\n this.computeMatrix();\n\n this._getAxes();\n if (\n this.type === CAMERA_TYPE.ORBITING ||\n this.type === CAMERA_TYPE.EXPLORING\n ) {\n this._getPosition();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n this._getFocalPoint();\n }\n return this;\n }\n\n /**\n * Changes the azimuth and elevation with respect to the current camera axes\n * @param {Number} azimuth the relative azimuth\n * @param {Number} elevation the relative elevation\n * @param {Number} roll the relative roll\n */\n public rotate(azimuth: number, elevation: number, roll: number) {\n if (this.type === CAMERA_TYPE.EXPLORING) {\n azimuth = getAngle(azimuth);\n elevation = getAngle(elevation);\n roll = getAngle(roll);\n\n const rotX = quat.setAxisAngle(\n quat.create(),\n [1, 0, 0],\n (this.rotateWorld ? 1 : -1) * elevation * DEG_2_RAD,\n );\n const rotY = quat.setAxisAngle(\n quat.create(),\n [0, 1, 0],\n (this.rotateWorld ? 1 : -1) * azimuth * DEG_2_RAD,\n );\n\n const rotZ = quat.setAxisAngle(\n quat.create(),\n [0, 0, 1],\n roll * DEG_2_RAD,\n );\n let rotQ = quat.multiply(quat.create(), rotY, rotX);\n rotQ = quat.multiply(quat.create(), rotQ, rotZ);\n const rotMatrix = mat4.fromQuat(mat4.create(), rotQ);\n mat4.translate(this.matrix, this.matrix, [0, 0, -this.distance]);\n mat4.multiply(this.matrix, this.matrix, rotMatrix);\n mat4.translate(this.matrix, this.matrix, [0, 0, this.distance]);\n } else {\n if (Math.abs(this.elevation + elevation) > 90) {\n return;\n }\n this.relElevation = getAngle(elevation);\n this.relAzimuth = getAngle(azimuth);\n this.relRoll = getAngle(roll);\n this.elevation += this.relElevation;\n this.azimuth += this.relAzimuth;\n this.roll += this.relRoll;\n\n this.computeMatrix();\n }\n\n this._getAxes();\n if (\n this.type === CAMERA_TYPE.ORBITING ||\n this.type === CAMERA_TYPE.EXPLORING\n ) {\n this._getPosition();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n this._getFocalPoint();\n }\n\n this._update();\n return this;\n }\n\n /**\n * 沿水平(right) & 垂直(up)平移相机\n */\n public pan(tx: number, ty: number) {\n const coords = createVec3(tx, ty, 0);\n const pos = vec3.clone(this.position);\n\n vec3.add(pos, pos, vec3.scale(vec3.create(), this.right, coords[0]));\n vec3.add(pos, pos, vec3.scale(vec3.create(), this.up, coords[1]));\n\n this._setPosition(pos);\n\n return this;\n }\n\n /**\n * 沿 n 轴移动,当距离视点远时移动速度较快,离视点越近速度越慢\n */\n public dolly(value: number) {\n const n = this.forward;\n const pos = vec3.clone(this.position);\n let step = value * this.dollyingStep;\n const updatedDistance = this.distance + value * this.dollyingStep;\n\n // 限制视点距离范围\n step =\n Math.max(Math.min(updatedDistance, this.maxDistance), this.minDistance) -\n this.distance;\n pos[0] += step * n[0];\n pos[1] += step * n[1];\n pos[2] += step * n[2];\n\n this._setPosition(pos);\n if (\n this.type === CAMERA_TYPE.ORBITING ||\n this.type === CAMERA_TYPE.EXPLORING\n ) {\n // 重新计算视点距离\n this._getDistance();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n // 保持视距,移动视点位置\n vec3.add(this.focalPoint, pos, this.distanceVector);\n }\n return this;\n }\n\n public createLandmark(\n name: string,\n params: {\n position: vec3;\n focalPoint: vec3;\n roll?: number;\n },\n ): Landmark {\n const camera = this.clone();\n camera.setPosition(params.position);\n camera.setFocalPoint(params.focalPoint);\n if (params.roll !== undefined) {\n camera.setRoll(params.roll);\n }\n const landmark = new Landmark(name, camera);\n this.landmarks.push(landmark);\n return landmark;\n }\n\n public setLandmark(name: string) {\n const landmark = new Landmark(name, this);\n this.landmarks.push(landmark);\n return this;\n }\n\n public gotoLandmark(name: string, duration: number = 1000) {\n const landmark = this.landmarks.find((l) => l.name === name);\n if (landmark) {\n if (duration === 0) {\n landmark.retrieve(this);\n return;\n }\n\n if (this.landmarkAnimationID !== undefined) {\n window.cancelAnimationFrame(this.landmarkAnimationID);\n }\n\n // TODO: do not process events during animation\n this.interactor.disconnect();\n\n const destPosition = landmark.getPosition();\n const destFocalPoint = landmark.getFocalPoint();\n const destRoll = landmark.getRoll();\n\n let timeStart: number | undefined;\n const animate = (timestamp: number) => {\n if (timeStart === undefined) {\n timeStart = timestamp;\n }\n const elapsed = timestamp - timeStart;\n // TODO: use better ease function\n const t = (1 - Math.cos((elapsed / duration) * Math.PI)) / 2;\n\n const interFocalPoint = vec3.create();\n const interPosition = vec3.create();\n let interRoll = 0;\n\n vec3.lerp(interFocalPoint, this.focalPoint, destFocalPoint, t);\n vec3.lerp(interPosition, this.position, destPosition, t);\n interRoll = this.roll * (1 - t) + destRoll * t;\n\n this.setFocalPoint(interFocalPoint);\n this.setPosition(interPosition);\n this.setRoll(interRoll);\n this.computeMatrix();\n\n const dist =\n vec3.dist(interFocalPoint, destFocalPoint) +\n vec3.dist(interPosition, destPosition);\n if (dist > 0.01) {\n //\n } else {\n this.setFocalPoint(interFocalPoint);\n this.setPosition(interPosition);\n this.setRoll(interRoll);\n this.computeMatrix();\n this.interactor.connect();\n return;\n }\n\n if (elapsed < duration) {\n this.landmarkAnimationID = window.requestAnimationFrame(animate);\n }\n };\n\n window.requestAnimationFrame(animate);\n }\n }\n\n /**\n * 根据相机矩阵重新计算各种相机参数\n */\n private _update() {\n this._getAxes();\n this._getPosition();\n this._getDistance();\n this._getAngles();\n }\n\n /**\n * 计算相机矩阵\n */\n private computeMatrix() {\n let rotX;\n let rotY;\n // 使用四元数描述 3D 旋转\n // @see https://xiaoiver.github.io/coding/2018/12/28/Camera-%E8%AE%BE%E8%AE%A1-%E4%B8%80.html\n const rotZ = quat.setAxisAngle(\n quat.create(),\n [0, 0, 1],\n this.roll * DEG_2_RAD,\n );\n\n mat4.identity(this.matrix);\n\n // only consider HCS for EXPLORING and ORBITING cameras\n rotX = quat.setAxisAngle(\n quat.create(),\n [1, 0, 0],\n ((this.rotateWorld && this.type !== CAMERA_TYPE.TRACKING) ||\n this.type === CAMERA_TYPE.TRACKING\n ? 1\n : -1) *\n this.elevation *\n DEG_2_RAD,\n );\n rotY = quat.setAxisAngle(\n quat.create(),\n [0, 1, 0],\n ((this.rotateWorld && this.type !== CAMERA_TYPE.TRACKING) ||\n this.type === CAMERA_TYPE.TRACKING\n ? 1\n : -1) *\n this.azimuth *\n DEG_2_RAD,\n );\n\n let rotQ = quat.multiply(quat.create(), rotY, rotX);\n rotQ = quat.multiply(quat.create(), rotQ, rotZ);\n const rotMatrix = mat4.fromQuat(mat4.create(), rotQ);\n\n if (\n this.type === CAMERA_TYPE.ORBITING ||\n this.type === CAMERA_TYPE.EXPLORING\n ) {\n mat4.translate(this.matrix, this.matrix, this.focalPoint);\n mat4.multiply(this.matrix, this.matrix, rotMatrix);\n mat4.translate(this.matrix, this.matrix, [0, 0, this.distance]);\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n mat4.translate(this.matrix, this.matrix, this.position);\n mat4.multiply(this.matrix, this.matrix, rotMatrix);\n }\n }\n\n /**\n * Sets the camera position in the camera matrix\n */\n private _setPosition(x: number | vec3, y?: number, z?: number) {\n this.position = createVec3(x, y, z);\n const m = this.matrix;\n m[12] = this.position[0];\n m[13] = this.position[1];\n m[14] = this.position[2];\n m[15] = 1;\n }\n\n /**\n * Recalculates axes based on the current matrix\n */\n private _getAxes() {\n vec3.copy(\n this.right,\n createVec3(vec4.transformMat4(vec4.create(), [1, 0, 0, 0], this.matrix)),\n );\n vec3.copy(\n this.up,\n createVec3(vec4.transformMat4(vec4.create(), [0, 1, 0, 0], this.matrix)),\n );\n vec3.copy(\n this.forward,\n createVec3(vec4.transformMat4(vec4.create(), [0, 0, 1, 0], this.matrix)),\n );\n vec3.normalize(this.right, this.right);\n vec3.normalize(this.up, this.up);\n vec3.normalize(this.forward, this.forward);\n }\n\n /**\n * Recalculates euler angles based on the current state\n */\n private _getAngles() {\n // Recalculates angles\n const x = this.distanceVector[0];\n const y = this.distanceVector[1];\n const z = this.distanceVector[2];\n const r = vec3.length(this.distanceVector);\n\n // FAST FAIL: If there is no distance we cannot compute angles\n if (r === 0) {\n this.elevation = 0;\n this.azimuth = 0;\n return;\n }\n\n if (this.type === CAMERA_TYPE.TRACKING) {\n this.elevation = Math.asin(y / r) * RAD_2_DEG;\n this.azimuth = Math.atan2(-x, -z) * RAD_2_DEG;\n } else {\n if (this.rotateWorld) {\n this.elevation = Math.asin(y / r) * RAD_2_DEG;\n this.azimuth = Math.atan2(-x, -z) * RAD_2_DEG;\n } else {\n this.elevation = -Math.asin(y / r) * RAD_2_DEG;\n this.azimuth = -Math.atan2(-x, -z) * RAD_2_DEG;\n }\n }\n }\n\n /**\n * 重新计算相机位置,只有 ORBITING 模式相机位置才会发生变化\n */\n private _getPosition() {\n vec3.copy(\n this.position,\n createVec3(vec4.transformMat4(vec4.create(), [0, 0, 0, 1], this.matrix)),\n );\n\n // 相机位置变化,需要重新计算视距\n this._getDistance();\n }\n\n /**\n * 重新计算视点,只有 TRACKING 模式视点才会发生变化\n */\n private _getFocalPoint() {\n vec3.transformMat3(\n this.distanceVector,\n [0, 0, -this.distance],\n mat3.fromMat4(mat3.create(), this.matrix),\n );\n vec3.add(this.focalPoint, this.position, this.distanceVector);\n\n // 视点变化,需要重新计算视距\n this._getDistance();\n }\n\n /**\n * 重新计算视距\n */\n private _getDistance() {\n this.distanceVector = vec3.subtract(\n vec3.create(),\n this.focalPoint,\n this.position,\n );\n this.distance = vec3.length(this.distanceVector);\n this.dollyingStep = this.distance / 100;\n }\n}\n","import { mat4, vec3 } from 'gl-matrix';\nimport { Camera } from './Camera';\n\n/**\n * 保存相机状态,便于后续在多个 Landmark 间移动\n */\nexport default class Landmark {\n public name: string;\n\n private matrix: mat4;\n private right: vec3;\n private up: vec3;\n private forward: vec3;\n private position: vec3;\n private focalPoint: vec3;\n private distanceVector: vec3;\n private distance: number;\n private dollyingStep: number;\n private azimuth = 0;\n private elevation = 0;\n private roll = 0;\n private relAzimuth = 0;\n private relElevation = 0;\n private relRoll = 0;\n\n constructor(name: string, c: Camera) {\n this.name = name;\n\n this.matrix = mat4.clone(c.matrix);\n this.right = vec3.clone(c.right);\n this.up = vec3.clone(c.up);\n this.forward = vec3.clone(c.forward);\n this.position = vec3.clone(c.position);\n this.focalPoint = vec3.clone(c.focalPoint);\n this.distanceVector = vec3.clone(c.distanceVector);\n\n this.azimuth = c.azimuth;\n this.elevation = c.elevation;\n this.roll = c.roll;\n this.relAzimuth = c.relAzimuth;\n this.relElevation = c.relElevation;\n this.relRoll = c.relRoll;\n this.dollyingStep = c.dollyingStep;\n this.distance = c.distance;\n }\n\n public getPosition() {\n return this.position;\n }\n\n public getFocalPoint() {\n return this.focalPoint;\n }\n\n public getRoll() {\n return this.roll;\n }\n\n public retrieve(c: Camera) {\n c.matrix = mat4.copy(c.matrix, this.matrix);\n c.right = vec3.copy(c.right, this.right);\n c.up = vec3.copy(c.up, this.up);\n c.forward = vec3.copy(c.forward, this.forward);\n c.position = vec3.copy(c.position, this.position);\n c.focalPoint = vec3.copy(c.focalPoint, this.focalPoint);\n c.distanceVector = vec3.copy(c.distanceVector, this.distanceVector);\n\n c.azimuth = this.azimuth;\n c.elevation = this.elevation;\n c.roll = this.roll;\n c.relAzimuth = this.relAzimuth;\n c.relElevation = this.relElevation;\n c.relRoll = this.relRoll;\n c.dollyingStep = this.dollyingStep;\n c.distance = this.distance;\n }\n}\n","import {\n ComponentManager,\n Entity,\n GeometryComponent,\n IDENTIFIER,\n} from '@antv/g-webgpu-core';\nimport { inject, injectable } from 'inversify';\n\nexport interface IGeometry<T> {\n setConfig(config: T): void;\n}\n\n@injectable()\nexport class Geometry<T = {}> implements IGeometry<T> {\n public static BOX = 'box';\n public static SPHERE = 'sphere';\n public static PLANE = 'plane';\n public static MERGED = 'merged';\n\n protected config: T;\n\n @inject(IDENTIFIER.GeometryComponentManager)\n private readonly geometry: ComponentManager<GeometryComponent>;\n\n private entity: Entity;\n private component: GeometryComponent;\n\n public getEntity() {\n return this.entity;\n }\n\n public getComponent() {\n return this.component;\n }\n\n public setConfig(config: T) {\n this.config = config;\n }\n\n public setEntity(entity: Entity) {\n this.entity = entity;\n this.component = this.geometry.create(entity);\n this.component.entity = entity;\n this.onEntityCreated();\n }\n\n protected onEntityCreated() {\n //\n }\n}\n","export function createCanvas() {\n if (typeof document !== 'undefined') {\n return document.createElement('canvas');\n } else {\n throw new Error('Cannot create a canvas in this context');\n }\n}\n","const toString = {}.toString;\n\nconst isType = (value: any, type: string): boolean => toString.call(value) === '[object ' + type + ']';\n\nexport default isType;","import {\n AST_TOKEN_TYPES,\n createEntity,\n DefineValuePlaceholder,\n IComputeModel,\n IConfigService,\n IDENTIFIER,\n IRendererService,\n KernelBundle,\n STORAGE_CLASS,\n Target,\n} from '@antv/g-webgpu-core';\n// tslint:disable-next-line:no-submodule-imports\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { inject, injectable } from 'inversify';\nimport { createCanvas } from './utils/canvas';\nimport isArray from './utils/is-array';\nimport { isNumber } from './utils/is-number';\nimport { isTypedArray } from './utils/is-typedarray';\n\n@injectable()\nexport class Kernel {\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n @inject(IDENTIFIER.ConfigService)\n private readonly configService: IConfigService;\n\n private entity = createEntity();\n\n private model: IComputeModel;\n\n private dirty: boolean = true;\n\n private compiledBundle: KernelBundle;\n\n private initPromise: Promise<void>;\n\n public init() {\n const { canvas, engineOptions } = this.configService.get();\n\n this.initPromise = this.engine.init({\n canvas: canvas || createCanvas(),\n swapChainFormat: WebGPUConstants.TextureFormat.BGRA8Unorm,\n antialiasing: false,\n ...engineOptions,\n });\n }\n\n public setBundle(bundle: KernelBundle) {\n // deep clone\n this.compiledBundle = JSON.parse(JSON.stringify(bundle));\n }\n\n public setDispatch(dispatch: [number, number, number]) {\n if (this.compiledBundle.context) {\n this.compiledBundle.context.dispatch = dispatch;\n }\n return this;\n }\n\n public setMaxIteration(maxIteration: number) {\n if (this.compiledBundle.context) {\n this.compiledBundle.context.maxIteration = maxIteration;\n }\n return this;\n }\n\n public setBinding(\n name:\n | string\n | Record<\n string,\n | number\n | number[]\n | Float32Array\n | Uint8Array\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array\n | Kernel\n >,\n data?:\n | number\n | number[]\n | Float32Array\n | Uint8Array\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array\n | Kernel,\n ) {\n if (typeof name === 'string') {\n const isNumberLikeData =\n isNumber(data) || isTypedArray(data) || isArray(data);\n if (this.compiledBundle && this.compiledBundle.context) {\n // set define, eg. setBinding('MAX_LENGTH', 10)\n const existedDefine = this.compiledBundle.context.defines.find(\n (b) => b.name === name,\n );\n if (existedDefine) {\n existedDefine.value = data as number;\n return this;\n }\n\n // set uniform\n const existedBinding = this.compiledBundle.context.uniforms.find(\n (b) => b.name === name,\n );\n if (existedBinding) {\n // update uniform or buffer\n if (isNumberLikeData) {\n // @ts-ignore\n existedBinding.data = data;\n existedBinding.isReferer = false;\n\n if (existedBinding.storageClass === STORAGE_CLASS.Uniform) {\n if (this.model) {\n // @ts-ignore\n this.model.updateUniform(name, data);\n }\n } else {\n if (this.model) {\n // @ts-ignore\n this.model.updateBuffer(name, data);\n }\n }\n } else {\n // update with another kernel\n existedBinding.isReferer = true;\n // @ts-ignore\n existedBinding.data = data as Kernel;\n }\n }\n }\n } else {\n Object.keys(name).forEach((key) => {\n this.setBinding(key, name[key]);\n });\n }\n return this;\n }\n\n public async execute(iteration: number = 1) {\n if (this.dirty) {\n if (this.compiledBundle.context) {\n if (iteration > 1) {\n this.compiledBundle.context.maxIteration = iteration;\n } else {\n this.compiledBundle.context.maxIteration++;\n }\n }\n await this.compile();\n this.dirty = false;\n }\n\n this.engine.beginFrame();\n\n // 首先开启当前 frame 的 compute pass\n this.engine.clear({});\n\n if (this.compiledBundle.context) {\n this.compiledBundle.context.uniforms\n .filter(({ isReferer }) => isReferer)\n .forEach(({ data, name }) => {\n // @ts-ignore\n this.model.confirmInput((data as Kernel).model, name);\n });\n }\n for (let i = 0; i < iteration; i++) {\n this.model.run();\n }\n\n this.engine.endFrame();\n return this;\n }\n\n /**\n * read output from GPUBuffer\n */\n public async getOutput() {\n return this.model.readData();\n }\n\n private async compile() {\n await this.initPromise;\n\n const context = {\n ...this.compiledBundle.context!,\n };\n\n const target = this.engine.supportWebGPU\n ? this.engine.useWGSL\n ? Target.WGSL\n : Target.GLSL450\n : Target.GLSL100;\n let shader = this.compiledBundle.shaders[target];\n\n // this.bindings?.forEach(({ name, data }) => {\n // if (name === name.toUpperCase()) {\n // const define = context.defines.find((d) => d.name === name);\n // if (define) {\n // // @ts-ignore\n // define.value = data;\n // }\n // }\n // });\n\n // 生成运行时 define\n context.defines\n .filter((define) => define.runtime)\n .forEach((define) => {\n const valuePlaceHolder = `${DefineValuePlaceholder}${define.name}`;\n shader = shader.replace(valuePlaceHolder, `${define.value}`);\n });\n\n context.shader = shader;\n\n // 添加 uniform 绑定的数据\n context.uniforms.forEach((uniform) => {\n // const binding = this.bindings.find((b) => b.name === uniform.name);\n // if (binding) {\n // // @ts-ignore\n // uniform.data = binding.referer || binding.data;\n // // @ts-ignore\n // uniform.isReferer = !!binding.referer;\n // }\n\n // 未指定数据,尝试根据 uniform 类型初始化\n if (!uniform.data) {\n if (uniform.storageClass === STORAGE_CLASS.StorageBuffer) {\n let sizePerElement = 1;\n if (uniform.type === AST_TOKEN_TYPES.FloatArray) {\n sizePerElement = 1;\n } else if (uniform.type === AST_TOKEN_TYPES.Vector4FloatArray) {\n sizePerElement = 4;\n }\n uniform.data = new Float32Array(\n context.output.length! * sizePerElement,\n ).fill(0);\n }\n }\n });\n // } else if (uniform.type === 'image2D') {\n // // @ts-ignore\n // buffer.data = new Uint8ClampedArray(context.output.length!).fill(0);\n // }\n\n this.compiledBundle.context = context;\n this.model = await this.engine.createComputeModel(\n this.compiledBundle.context,\n );\n }\n}\n","import isType from './is-type';\n\nexport default (value: any): value is any[] => {\n return Array.isArray ? Array.isArray(value) : isType(value, 'Array');\n}\n\n","import {\n ComponentManager,\n Entity,\n IDENTIFIER,\n MaterialComponent,\n} from '@antv/g-webgpu-core';\nimport { inject, injectable } from 'inversify';\n\nexport interface IMaterial<T> {\n setConfig(config: T): void;\n}\n\n@injectable()\nexport class Material<T = {}> implements IMaterial<T> {\n public static BASIC = 'basic';\n\n protected config: T;\n\n @inject(IDENTIFIER.MaterialComponentManager)\n private readonly material: ComponentManager<MaterialComponent>;\n\n private entity: Entity;\n private component: MaterialComponent;\n\n public getEntity() {\n return this.entity;\n }\n\n public getComponent() {\n return this.component;\n }\n\n public setConfig(config: T) {\n this.config = config;\n }\n\n public setEntity(entity: Entity, type: string) {\n this.entity = entity;\n this.component = this.material.create(entity);\n this.component.entity = entity;\n this.component.type = type;\n this.onEntityCreated();\n }\n\n protected onEntityCreated() {\n //\n }\n}\n","import {\n BufferData,\n ComponentManager,\n CullableComponent,\n Entity,\n GeometryComponent,\n HierarchyComponent,\n IDENTIFIER,\n MaterialComponent,\n MeshComponent,\n SceneGraphSystem,\n TransformComponent,\n} from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\n\nexport interface IRenderable<T> {\n setConfig(config: T): void;\n setAttributes(attributes: Record<string, BufferData | undefined>): void;\n setEntity(entity: Entity): void;\n setMaterial(material: MaterialComponent): void;\n setGeometry(geometry: GeometryComponent): void;\n}\n\n@injectable()\nexport class Renderable<T = {}> implements IRenderable<T> {\n public static POINT = 'point';\n public static LINE = 'line';\n public static GRID = 'grid';\n\n protected attributes: Record<string, BufferData> = {};\n protected config: T;\n\n @inject(IDENTIFIER.MeshComponentManager)\n private readonly mesh: ComponentManager<MeshComponent>;\n\n @inject(IDENTIFIER.CullableComponentManager)\n private readonly cullable: ComponentManager<CullableComponent>;\n\n @inject(IDENTIFIER.TransformComponentManager)\n private readonly transform: ComponentManager<TransformComponent>;\n\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.SceneGraphSystem)\n private readonly sceneGraphSystem: SceneGraphSystem;\n\n private meshComponent: MeshComponent;\n private transformComponent: TransformComponent;\n\n private entity: Entity;\n\n public getEntity() {\n return this.entity;\n }\n\n public getTransformComponent() {\n return this.transformComponent;\n }\n\n public getMeshComponent() {\n return this.meshComponent;\n }\n\n public setConfig(config: T) {\n this.config = config;\n }\n\n public setEntity(entity: Entity) {\n this.entity = entity;\n this.cullable.create(entity);\n this.meshComponent = this.mesh.create(entity);\n this.transformComponent = this.transform.create(entity);\n this.onEntityCreated();\n }\n\n public setMaterial(material: MaterialComponent) {\n this.meshComponent.material = material;\n return this;\n }\n\n public setGeometry(geometry: GeometryComponent) {\n this.meshComponent.geometry = geometry;\n return this;\n }\n\n public setAttributes(attributes: Record<string, BufferData | undefined>) {\n Object.keys(attributes).forEach((name) => {\n if (\n attributes[name] !== undefined &&\n attributes[name] !== this.attributes[name]\n ) {\n this.onAttributeChanged({\n name,\n data: attributes[name]!,\n });\n this.attributes[name] = attributes[name]!;\n }\n });\n }\n\n public setVisible(visible: boolean) {\n this.meshComponent.visible = visible;\n this.meshComponent.children.forEach((childEntity) => {\n const child = this.mesh.getComponentByEntity(childEntity);\n if (child) {\n child.visible = visible;\n }\n });\n return this;\n }\n\n public isVisible() {\n return this.meshComponent.visible;\n }\n\n public attach(parentRenderable: Renderable<T>) {\n this.sceneGraphSystem.attach(this.entity, parentRenderable.entity);\n return this;\n }\n\n public detach() {\n this.sceneGraphSystem.detach(this.entity);\n return this;\n }\n\n public detachChildren() {\n this.sceneGraphSystem.detachChildren(this.entity);\n return this;\n }\n\n protected onEntityCreated() {\n //\n }\n\n protected onAttributeChanged({\n name,\n data,\n }: {\n name: string;\n data: BufferData;\n }) {\n if (this.meshComponent && this.meshComponent.material) {\n this.meshComponent.material.setUniform(\n this.convertAttributeName2UniformName(name),\n data,\n );\n }\n }\n\n protected convertAttributeName2UniformName(attributeName: string) {\n return attributeName;\n }\n}\n","import {\n BufferData,\n IAttribute,\n IAttributeInitializationOptions,\n IBuffer,\n} from '@antv/g-webgpu-core';\nimport regl from 'regl';\nimport ReglBuffer from './ReglBuffer';\n\n/**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#attributes\n */\nexport default class ReglAttribute implements IAttribute {\n private attribute: regl.Attribute;\n private buffer: IBuffer;\n\n constructor(gl: regl.Regl, options: IAttributeInitializationOptions) {\n const { buffer, offset, stride, normalized, size, divisor } = options;\n this.buffer = buffer;\n this.attribute = {\n buffer: (buffer as ReglBuffer).get(),\n offset: offset || 0,\n stride: stride || 0,\n normalized: normalized || false,\n divisor: divisor || 0,\n };\n\n if (size) {\n this.attribute.size = size;\n }\n }\n\n public get() {\n return this.attribute;\n }\n\n public updateBuffer(options: {\n // 用于替换的数据\n data: BufferData;\n // 原 Buffer 替换位置,单位为 byte\n offset: number;\n }) {\n this.buffer.subData(options);\n }\n\n public destroy() {\n this.buffer.destroy();\n }\n}\n","/**\n * @desc 由于 regl 使用大量字符串而非 WebGL 常量,因此需要映射\n */\nimport { gl } from '@antv/g-webgpu-core';\nimport regl from 'regl';\n\n// @see https://github.com/regl-project/regl/blob/gh-pages/lib/constants/primitives.json\nexport const primitiveMap: {\n [key: string]:\n | 'points'\n | 'lines'\n | 'line loop'\n | 'line strip'\n | 'triangles'\n | 'triangle strip'\n | 'triangle fan';\n} = {\n [gl.POINTS]: 'points',\n [gl.LINES]: 'lines',\n [gl.LINE_LOOP]: 'line loop',\n [gl.LINE_STRIP]: 'line strip',\n [gl.TRIANGLES]: 'triangles',\n [gl.TRIANGLE_FAN]: 'triangle fan',\n [gl.TRIANGLE_STRIP]: 'triangle strip',\n};\n\nexport const usageMap: {\n [key: string]: 'static' | 'dynamic' | 'stream';\n} = {\n [gl.STATIC_DRAW]: 'static',\n [gl.DYNAMIC_DRAW]: 'dynamic',\n [gl.STREAM_DRAW]: 'stream',\n};\n\nexport const dataTypeMap: {\n [key: string]:\n | 'int8'\n | 'int16'\n | 'int32'\n | 'uint8'\n | 'uint16'\n | 'uint32'\n | 'float';\n} = {\n [gl.BYTE]: 'int8',\n [gl.UNSIGNED_INT]: 'int16',\n [gl.INT]: 'int32',\n [gl.UNSIGNED_BYTE]: 'uint8',\n [gl.UNSIGNED_SHORT]: 'uint16',\n [gl.UNSIGNED_INT]: 'uint32',\n [gl.FLOAT]: 'float',\n};\n\nexport const formatMap: {\n [key: string]:\n | 'alpha'\n | 'luminance'\n | 'luminance alpha'\n | 'rgb'\n | 'rgba'\n | 'rgba4'\n | 'rgb5 a1'\n | 'rgb565'\n | 'depth'\n | 'depth stencil';\n} = {\n [gl.ALPHA]: 'alpha',\n [gl.LUMINANCE]: 'luminance',\n [gl.LUMINANCE_ALPHA]: 'luminance alpha',\n [gl.RGB]: 'rgb',\n [gl.RGBA]: 'rgba',\n [gl.RGBA4]: 'rgba4',\n [gl.RGB5_A1]: 'rgb5 a1',\n [gl.RGB565]: 'rgb565',\n [gl.DEPTH_COMPONENT]: 'depth',\n [gl.DEPTH_STENCIL]: 'depth stencil',\n};\n\nexport const mipmapMap: {\n [key: string]: 'dont care' | 'nice' | 'fast';\n} = {\n [gl.DONT_CARE]: 'dont care',\n [gl.NICEST]: 'nice',\n [gl.FASTEST]: 'fast',\n};\n\nexport const filterMap: {\n [key: string]:\n | 'nearest'\n | 'linear'\n | 'mipmap'\n | 'nearest mipmap linear'\n | 'linear mipmap nearest'\n | 'nearest mipmap nearest';\n} = {\n [gl.NEAREST]: 'nearest',\n [gl.LINEAR]: 'linear',\n [gl.LINEAR_MIPMAP_LINEAR]: 'mipmap',\n [gl.NEAREST_MIPMAP_LINEAR]: 'nearest mipmap linear',\n [gl.LINEAR_MIPMAP_NEAREST]: 'linear mipmap nearest',\n [gl.NEAREST_MIPMAP_NEAREST]: 'nearest mipmap nearest',\n};\n\nexport const wrapModeMap: {\n [key: string]: 'repeat' | 'clamp' | 'mirror';\n} = {\n [gl.REPEAT]: 'repeat',\n [gl.CLAMP_TO_EDGE]: 'clamp',\n [gl.MIRRORED_REPEAT]: 'mirror',\n};\n\nexport const colorSpaceMap: {\n [key: string]: 'none' | 'browser';\n} = {\n [gl.NONE]: 'none',\n [gl.BROWSER_DEFAULT_WEBGL]: 'browser',\n};\n\nexport const depthFuncMap: {\n [key: string]:\n | 'never'\n | 'always'\n | 'less'\n | 'lequal'\n | 'greater'\n | 'gequal'\n | 'equal'\n | 'notequal';\n} = {\n [gl.NEVER]: 'never',\n [gl.ALWAYS]: 'always',\n [gl.LESS]: 'less',\n [gl.LEQUAL]: 'lequal',\n [gl.GREATER]: 'greater',\n [gl.GEQUAL]: 'gequal',\n [gl.EQUAL]: 'equal',\n [gl.NOTEQUAL]: 'notequal',\n};\n\nexport const blendEquationMap: {\n [key: string]: regl.BlendingEquation;\n} = {\n [gl.FUNC_ADD]: 'add',\n [gl.MIN_EXT]: 'min',\n [gl.MAX_EXT]: 'max',\n [gl.FUNC_SUBTRACT]: 'subtract',\n [gl.FUNC_REVERSE_SUBTRACT]: 'reverse subtract',\n};\n\nexport const blendFuncMap: {\n [key: string]: regl.BlendingFunction;\n} = {\n [gl.ZERO]: 'zero',\n [gl.ONE]: 'one',\n [gl.SRC_COLOR]: 'src color',\n [gl.ONE_MINUS_SRC_COLOR]: 'one minus src color',\n [gl.SRC_ALPHA]: 'src alpha',\n [gl.ONE_MINUS_SRC_ALPHA]: 'one minus src alpha',\n [gl.DST_COLOR]: 'dst color',\n [gl.ONE_MINUS_DST_COLOR]: 'one minus dst color',\n [gl.DST_ALPHA]: 'dst alpha',\n [gl.ONE_MINUS_DST_ALPHA]: 'one minus dst alpha',\n [gl.CONSTANT_COLOR]: 'constant color',\n [gl.ONE_MINUS_CONSTANT_COLOR]: 'one minus constant color',\n [gl.CONSTANT_ALPHA]: 'constant alpha',\n [gl.ONE_MINUS_CONSTANT_ALPHA]: 'one minus constant alpha',\n [gl.SRC_ALPHA_SATURATE]: 'src alpha saturate',\n};\n\nexport const stencilFuncMap: {\n [key: string]: regl.ComparisonOperatorType;\n} = {\n [gl.NEVER]: 'never',\n [gl.ALWAYS]: 'always',\n [gl.LESS]: 'less',\n [gl.LEQUAL]: 'lequal',\n [gl.GREATER]: 'greater',\n [gl.GEQUAL]: 'gequal',\n [gl.EQUAL]: 'equal',\n [gl.NOTEQUAL]: 'notequal',\n};\n\nexport const stencilOpMap: {\n [key: string]: regl.StencilOperationType;\n} = {\n [gl.ZERO]: 'zero',\n [gl.KEEP]: 'keep',\n [gl.REPLACE]: 'replace',\n [gl.INVERT]: 'invert',\n [gl.INCR]: 'increment',\n [gl.DECR]: 'decrement',\n [gl.INCR_WRAP]: 'increment wrap',\n [gl.DECR_WRAP]: 'decrement wrap',\n};\n\nexport const cullFaceMap: {\n [key: string]: regl.FaceOrientationType;\n} = {\n [gl.FRONT]: 'front',\n [gl.BACK]: 'back',\n};\n","import {\n BufferData,\n gl,\n IBuffer,\n IBufferInitializationOptions,\n} from '@antv/g-webgpu-core';\nimport regl from 'regl';\nimport { dataTypeMap, usageMap } from './constants';\n\n/**\n * adaptor for regl.Buffer\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#buffers\n */\nexport default class ReglBuffer implements IBuffer {\n private buffer: regl.Buffer;\n\n constructor(reGl: regl.Regl, options: IBufferInitializationOptions) {\n const { data, usage, type } = options;\n // @ts-ignore\n this.buffer = reGl.buffer({\n data,\n usage: usageMap[usage || gl.STATIC_DRAW],\n type: dataTypeMap[type || gl.UNSIGNED_BYTE],\n // length: 0,\n });\n }\n\n public get() {\n return this.buffer;\n }\n\n public destroy() {\n // this.buffer.destroy();\n }\n\n public subData({ data, offset }: { data: BufferData; offset: number }) {\n // @ts-ignore\n this.buffer.subdata(data, offset);\n }\n}\n","import {\n AST_TOKEN_TYPES,\n createEntity,\n DataType,\n GLSLContext,\n IComputeModel,\n STORAGE_CLASS,\n} from '@antv/g-webgpu-core';\nimport regl from 'regl';\nimport { isTypedArray } from '../utils/is-typedarray';\nimport quadVert from './shaders/quad.vert.glsl';\n\ninterface DataTextureDescriptor {\n id: number;\n data:\n | number\n | number[]\n | Float32Array\n | Uint8Array\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array\n | undefined;\n textureWidth: number;\n texture: regl.Texture2D;\n texelCount: number;\n originalDataLength: number;\n elementsPerTexel: number;\n typedArrayConstructor?: Function;\n isOutput: boolean;\n}\n\nlet textureId = 0;\nconst debug = false;\n\n/**\n * adaptor for regl.DrawCommand\n */\nexport default class ReglComputeModel implements IComputeModel {\n private entity = createEntity();\n private texFBO: regl.Framebuffer2D;\n private computeCommand: regl.DrawCommand;\n private textureCache: {\n [textureName: string]: DataTextureDescriptor;\n } = {};\n private outputTextureName: string;\n private swapOutputTextureName: string;\n private compiledPingpong: boolean;\n private dynamicPingpong: boolean;\n\n constructor(private reGl: regl.Regl, private context: GLSLContext) {\n const uniforms: Record<string, any> = {};\n this.context.uniforms.forEach((uniform) => {\n const { name, type, data, isReferer, storageClass } = uniform;\n // store data with a 2D texture\n if (storageClass === STORAGE_CLASS.StorageBuffer) {\n if (!isReferer) {\n this.textureCache[name] = this.calcDataTexture(name, type, data!);\n const { textureWidth: width, isOutput } = this.textureCache[name];\n uniforms[`${name}Size`] = [width, width];\n\n if (isOutput) {\n this.outputTextureName = name;\n if (this.context.needPingpong) {\n this.outputTextureName = `${name}Output`;\n this.textureCache[this.outputTextureName] = this.calcDataTexture(\n name,\n type,\n data!,\n );\n }\n }\n } else {\n // @ts-ignore\n this.textureCache[name] = {\n data: undefined,\n };\n // refer to another kernel's output,\n // the referred kernel may not have been initialized, so we use dynamic way here\n uniforms[`${name}Size`] = () =>\n // @ts-ignore\n data.compiledBundle.context.output.textureSize;\n }\n\n uniforms[name] = () => {\n if (debug) {\n console.log(\n `[${this.entity}]: ${name} ${this.textureCache[name].id}`,\n );\n }\n return this.textureCache[name].texture;\n };\n } else if (storageClass === STORAGE_CLASS.Uniform) {\n if (\n data &&\n (Array.isArray(data) || isTypedArray(data)) &&\n (data as ArrayLike<number>).length > 16\n ) {\n // up to mat4 which includes 16 elements\n throw new Error(`invalid data type ${type}`);\n }\n // get uniform dynamically\n uniforms[name] = () => uniform.data;\n }\n });\n\n const { textureWidth, texelCount } = this.getOuputDataTexture();\n\n // 传入 output 纹理尺寸和数据长度,便于多余的 texel 提前退出\n uniforms.u_OutputTextureSize = [textureWidth, textureWidth];\n uniforms.u_OutputTexelCount = texelCount;\n\n // 保存在 Kernel 的上下文中,供其他 Kernel 引用\n this.context.output.textureSize = [textureWidth!, textureWidth!];\n\n const drawParams: regl.DrawConfig = {\n attributes: {\n a_Position: [\n [-1, 1, 0],\n [-1, -1, 0],\n [1, 1, 0],\n [1, -1, 0],\n ],\n a_TexCoord: [\n [0, 1],\n [0, 0],\n [1, 1],\n [1, 0],\n ],\n },\n frag: `#ifdef GL_FRAGMENT_PRECISION_HIGH\n precision highp float;\n#else\n precision mediump float;\n#endif\n${this.context.shader}`,\n uniforms,\n vert: quadVert,\n // TODO: use a fullscreen triangle instead.\n primitive: 'triangle strip',\n count: 4,\n };\n\n this.computeCommand = this.reGl(drawParams);\n }\n\n public run() {\n if (this.context.maxIteration > 1 && this.context.needPingpong) {\n this.compiledPingpong = true;\n }\n // need pingpong when (@in@out and execute(10)) or use `setBinding('out', self)`\n // this.needPingpong =\n // !!(this.context.maxIteration > 1 && this.context.needPingpong);\n\n // if (this.relativeOutputTextureNames.length) {\n // const { id, texture } = this.getOuputDataTexture();\n // this.relativeOutputTextureNames.forEach((name) => {\n // this.textureCache[name].id = id;\n // this.textureCache[name].texture = texture;\n // });\n // this.swap();\n // }\n\n if (this.compiledPingpong || this.dynamicPingpong) {\n this.swap();\n }\n\n this.texFBO = this.reGl.framebuffer({\n color: this.getOuputDataTexture().texture,\n });\n this.texFBO.use(() => {\n this.computeCommand();\n });\n if (debug) {\n console.log(`[${this.entity}]: output ${this.getOuputDataTexture().id}`);\n }\n }\n\n public async readData() {\n let pixels: Uint8Array | Float32Array;\n this.reGl({\n framebuffer: this.texFBO,\n })(() => {\n pixels = this.reGl.read();\n });\n\n // @ts-ignore\n if (pixels) {\n const {\n originalDataLength,\n elementsPerTexel,\n typedArrayConstructor = Float32Array,\n } = this.getOuputDataTexture();\n\n let formattedPixels = [];\n if (elementsPerTexel !== 4) {\n for (let i = 0; i < pixels.length; i += 4) {\n if (elementsPerTexel === 1) {\n formattedPixels.push(pixels[i]);\n } else if (elementsPerTexel === 2) {\n formattedPixels.push(pixels[i], pixels[i + 1]);\n } else {\n formattedPixels.push(pixels[i], pixels[i + 1], pixels[i + 2]);\n }\n }\n } else {\n // @ts-ignore\n formattedPixels = pixels;\n }\n\n // 截取多余的部分\n // @ts-ignore\n return new typedArrayConstructor(\n formattedPixels.slice(0, originalDataLength),\n );\n }\n\n return new Float32Array();\n }\n\n public confirmInput(model: IComputeModel, inputName: string) {\n let inputModel: ReglComputeModel;\n // refer to self, same as pingpong\n if (this.entity === (model as ReglComputeModel).entity) {\n this.dynamicPingpong = true;\n inputModel = this;\n } else {\n inputModel = model as ReglComputeModel;\n }\n\n this.textureCache[inputName].id = inputModel.getOuputDataTexture().id;\n this.textureCache[\n inputName\n ].texture = inputModel.getOuputDataTexture().texture;\n\n if (debug) {\n console.log(\n `[${this.entity}]: confirm input ${inputName} from model ${\n inputModel.entity\n }, ${(inputModel as ReglComputeModel).getOuputDataTexture().id}`,\n );\n }\n }\n\n public updateUniform() {\n // already get uniform's data dynamically when created, do nothing here\n }\n\n public updateBuffer(\n bufferName: string,\n data:\n | number[]\n | Float32Array\n | Uint8Array\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array,\n offset: number = 0,\n ) {\n // regenerate data texture\n const buffer = this.context.uniforms.find(\n ({ name }) => name === bufferName,\n );\n if (buffer) {\n const { texture, data: paddingData } = this.calcDataTexture(\n bufferName,\n buffer.type,\n data,\n );\n\n // TODO: destroy outdated texture\n this.textureCache[bufferName].data = paddingData;\n this.textureCache[bufferName].texture = texture;\n }\n }\n\n public destroy() {\n // regl will destroy all resources\n }\n\n private swap() {\n if (!this.swapOutputTextureName) {\n this.createSwapOutputDataTexture();\n }\n\n if (this.compiledPingpong) {\n const outputTextureUniformName = this.context.output.name;\n this.textureCache[\n outputTextureUniformName\n ].id = this.getOuputDataTexture().id;\n this.textureCache[\n outputTextureUniformName\n ].texture = this.getOuputDataTexture().texture;\n }\n\n const tmp = this.outputTextureName;\n this.outputTextureName = this.swapOutputTextureName;\n this.swapOutputTextureName = tmp;\n\n if (debug) {\n console.log(\n `[${this.entity}]: after swap, output ${this.getOuputDataTexture().id}`,\n );\n }\n }\n\n private getOuputDataTexture() {\n return this.textureCache[this.outputTextureName];\n }\n\n private createSwapOutputDataTexture() {\n const texture = this.cloneDataTexture(this.getOuputDataTexture());\n this.swapOutputTextureName = `${this.entity}-swap`;\n this.textureCache[this.swapOutputTextureName] = texture;\n }\n\n private cloneDataTexture(texture: DataTextureDescriptor) {\n const { data, textureWidth } = texture;\n return {\n ...texture,\n id: textureId++,\n // @ts-ignore\n texture: this.reGl.texture({\n width: textureWidth,\n height: textureWidth,\n data,\n type: 'float',\n }),\n };\n }\n\n private calcDataTexture(\n name: string,\n type: DataType,\n data:\n | number\n | number[]\n | Float32Array\n | Uint8Array\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array,\n ) {\n let elementsPerTexel = 1;\n if (type === AST_TOKEN_TYPES.Vector4FloatArray) {\n elementsPerTexel = 4;\n }\n\n // 用 0 补全不足 vec4 的部分\n const paddingData: number[] = [];\n for (let i = 0; i < (data as number[]).length; i += elementsPerTexel) {\n if (elementsPerTexel === 1) {\n paddingData.push((data as number[])[i], 0, 0, 0);\n } else if (elementsPerTexel === 2) {\n paddingData.push(\n (data as number[])[i],\n (data as number[])[i + 1],\n 0,\n 0,\n );\n } else if (elementsPerTexel === 3) {\n paddingData.push(\n (data as number[])[i],\n (data as number[])[i + 1],\n (data as number[])[i + 2],\n 0,\n );\n } else if (elementsPerTexel === 4) {\n paddingData.push(\n (data as number[])[i],\n (data as number[])[i + 1],\n (data as number[])[i + 2],\n (data as number[])[i + 3],\n );\n }\n }\n\n // 使用纹理存储,例如 Array(8) 使用 3 * 3 纹理,末尾空白使用 0 填充\n const originalDataLength = (data as ArrayLike<number>).length;\n const texelCount = Math.ceil(originalDataLength / elementsPerTexel);\n const width = Math.ceil(Math.sqrt(texelCount));\n const paddingTexelCount = width * width;\n if (texelCount < paddingTexelCount) {\n paddingData.push(\n ...new Array((paddingTexelCount - texelCount) * 4).fill(0),\n );\n }\n\n const texture = this.reGl.texture({\n width,\n height: width,\n data: paddingData,\n type: 'float',\n });\n\n return {\n id: textureId++,\n data: paddingData,\n originalDataLength,\n typedArrayConstructor: isTypedArray(data) ? data!.constructor : undefined,\n textureWidth: width,\n texture,\n texelCount,\n elementsPerTexel,\n isOutput: name === this.context.output.name,\n };\n }\n}\n","import {\n gl,\n IElements,\n IElementsInitializationOptions,\n} from '@antv/g-webgpu-core';\nimport regl from 'regl';\nimport { dataTypeMap, usageMap } from './constants';\n\n/**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#elements\n */\nexport default class ReglElements implements IElements {\n private elements: regl.Elements;\n\n constructor(reGl: regl.Regl, options: IElementsInitializationOptions) {\n const { data, usage, type, count } = options;\n\n this.elements = reGl.elements({\n data,\n usage: usageMap[usage || gl.STATIC_DRAW],\n type: dataTypeMap[type || gl.UNSIGNED_BYTE] as\n | 'uint8'\n | 'uint16'\n | 'uint32',\n count,\n });\n }\n\n public get() {\n return this.elements;\n }\n\n public subData({\n data,\n }: {\n data: number[] | number[][] | Uint8Array | Uint16Array | Uint32Array;\n }) {\n this.elements.subdata(data);\n }\n\n public destroy() {\n this.elements.destroy();\n }\n}\n","import {\n gl,\n IFramebuffer,\n IFramebufferInitializationOptions,\n IRenderbuffer,\n ITexture2D,\n} from '@antv/g-webgpu-core';\nimport regl from 'regl';\nimport ReglTexture2D from './ReglTexture2D';\n\n/**\n * adaptor for regl.Framebuffer\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#framebuffers\n */\nexport default class ReglFramebuffer implements IFramebuffer {\n private framebuffer: regl.Framebuffer;\n\n constructor(reGl: regl.Regl, options: IFramebufferInitializationOptions) {\n const { width, height, color, colors, depth, stencil } = options;\n\n const framebufferOptions: regl.FramebufferOptions = {\n width,\n height,\n };\n\n if (Array.isArray(colors)) {\n framebufferOptions.colors = colors.map((c: ITexture2D | IRenderbuffer) =>\n (c as ReglTexture2D).get(),\n );\n }\n\n if (color && typeof color !== 'boolean') {\n framebufferOptions.color = (color as ReglTexture2D).get();\n }\n\n // TODO: depth & stencil\n\n this.framebuffer = reGl.framebuffer(framebufferOptions);\n }\n\n public get() {\n return this.framebuffer;\n }\n\n public destroy() {\n this.framebuffer.destroy();\n }\n\n public resize({ width, height }: { width: number; height: number }) {\n this.framebuffer.resize(width, height);\n }\n}\n","import { IUniform } from '@antv/g-webgpu-core';\nimport { isObject } from './is-object';\nimport { isTypedArray } from './is-typedarray';\n\n/**\n * 考虑结构体命名, eg:\n * a: { b: 1 } -> 'a.b'\n * a: [ { b: 1 } ] -> 'a[0].b'\n */\nexport function extractUniforms(uniforms: {\n [key: string]: IUniform;\n}): {\n [key: string]: IUniform;\n} {\n const extractedUniforms = {};\n Object.keys(uniforms).forEach((uniformName) => {\n extractUniformsRecursively(\n uniformName,\n uniforms[uniformName],\n extractedUniforms,\n '',\n );\n });\n\n return extractedUniforms;\n}\n\nfunction extractUniformsRecursively(\n uniformName: string,\n uniformValue: IUniform,\n uniforms: {\n [key: string]: IUniform;\n },\n prefix: string,\n) {\n if (\n uniformValue === null ||\n typeof uniformValue === 'number' || // u_A: 1\n typeof uniformValue === 'boolean' || // u_A: false\n (Array.isArray(uniformValue) && typeof uniformValue[0] === 'number') || // u_A: [1, 2, 3]\n isTypedArray(uniformValue) || // u_A: Float32Array\n // @ts-ignore\n uniformValue === '' ||\n // @ts-ignore\n uniformValue.resize !== undefined\n ) {\n uniforms[`${prefix && prefix + '.'}${uniformName}`] = uniformValue;\n return;\n }\n\n // u_Struct.a.b.c\n if (isObject(uniformValue)) {\n Object.keys(uniformValue).forEach((childName) => {\n extractUniformsRecursively(\n childName,\n // @ts-ignore\n uniformValue[childName],\n uniforms,\n `${prefix && prefix + '.'}${uniformName}`,\n );\n });\n }\n\n // u_Struct[0].a\n if (Array.isArray(uniformValue)) {\n // @ts-ignore\n uniformValue.forEach((child, idx) => {\n Object.keys(child).forEach((childName) => {\n extractUniformsRecursively(\n childName,\n // @ts-ignore\n child[childName],\n uniforms,\n `${prefix && prefix + '.'}${uniformName}[${idx}]`,\n );\n });\n });\n }\n}\n","export function isObject(value: any) {\n const type = typeof value;\n return value != null && (type === 'object' || type === 'function');\n}\n","import { loadScriptAsync } from '../utils/dom';\n\nlet glslang: any;\nexport default async function() {\n if (glslang) {\n return glslang;\n }\n // // @see https://github.com/webpack/webpack/issues/10446\n // // @see https://github.com/austinEng/webgpu-samples/issues/33\n // const glslangModule = await import(\n // /* webpackIgnore: true */\n // 'https://cdn.jsdelivr.net/npm/@webgpu/glslang@0.0.15/dist/web-devel/glslang.js'\n // );\n // glslang = await glslangModule.default();\n\n await loadScriptAsync('https://preview.babylonjs.com/glslang/glslang.js');\n\n glslang = (window as any).glslang(\n 'https://preview.babylonjs.com/glslang/glslang.wasm',\n );\n\n return glslang;\n}\n","import {\n gl,\n IModel,\n IModelDrawOptions,\n IModelInitializationOptions,\n IUniform,\n} from '@antv/g-webgpu-core';\nimport regl from 'regl';\nimport { extractUniforms } from '../utils/uniform';\nimport {\n blendEquationMap,\n blendFuncMap,\n cullFaceMap,\n depthFuncMap,\n primitiveMap,\n stencilFuncMap,\n stencilOpMap,\n} from './constants';\nimport ReglAttribute from './ReglAttribute';\nimport ReglElements from './ReglElements';\nimport ReglFramebuffer from './ReglFramebuffer';\nimport ReglTexture2D from './ReglTexture2D';\n\n/**\n * adaptor for regl.DrawCommand\n */\nexport default class ReglModel implements IModel {\n private reGl: regl.Regl;\n private drawCommand: regl.DrawCommand;\n private uniforms: {\n [key: string]: IUniform;\n } = {};\n\n constructor(reGl: regl.Regl, options: IModelInitializationOptions) {\n this.reGl = reGl;\n const {\n vs,\n fs,\n defines,\n attributes,\n uniforms,\n primitive,\n count,\n elements,\n depth,\n blend,\n stencil,\n cull,\n instances,\n scissor,\n // @ts-ignore\n viewport,\n } = options;\n const reglUniforms: { [key: string]: IUniform } = {};\n if (uniforms) {\n this.uniforms = extractUniforms(uniforms);\n Object.keys(uniforms).forEach((uniformName) => {\n // use regl prop API\n // @ts-ignore\n reglUniforms[uniformName] = reGl.prop(uniformName);\n });\n }\n\n const reglAttributes: { [key: string]: regl.Attribute } = {};\n Object.keys(attributes).forEach((name: string) => {\n reglAttributes[name] = (attributes[name] as ReglAttribute).get();\n });\n\n const defineStmts = (defines && this.generateDefines(defines)) || '';\n const drawParams: regl.DrawConfig = {\n attributes: reglAttributes,\n frag: `#ifdef GL_FRAGMENT_PRECISION_HIGH\n precision highp float;\n#else\n precision mediump float;\n#endif\n${defineStmts}\n${fs}`,\n uniforms: reglUniforms,\n vert: `\n${defineStmts}\n${vs}`,\n primitive:\n primitiveMap[primitive === undefined ? gl.TRIANGLES : primitive],\n };\n if (instances) {\n drawParams.instances = instances;\n }\n\n // elements 中可能包含 count,此时不应传入\n if (count) {\n drawParams.count = count;\n }\n\n if (elements) {\n drawParams.elements = (elements as ReglElements).get();\n }\n\n if (scissor) {\n drawParams.scissor = scissor;\n }\n\n if (viewport) {\n drawParams.viewport = viewport;\n }\n\n this.initDepthDrawParams({ depth }, drawParams);\n this.initBlendDrawParams({ blend }, drawParams);\n this.initStencilDrawParams({ stencil }, drawParams);\n this.initCullDrawParams({ cull }, drawParams);\n\n this.drawCommand = reGl(drawParams);\n }\n\n public addUniforms(uniforms: { [key: string]: IUniform }) {\n this.uniforms = {\n ...this.uniforms,\n ...extractUniforms(uniforms),\n };\n }\n\n public draw(options: IModelDrawOptions) {\n const uniforms: {\n [key: string]: IUniform;\n } = {\n ...this.uniforms,\n ...extractUniforms(options.uniforms || {}),\n };\n\n const reglDrawProps: {\n [key: string]:\n | regl.Framebuffer\n | regl.Texture2D\n | number\n | number[]\n | boolean;\n } = {};\n\n Object.keys(uniforms).forEach((uniformName: string) => {\n const type = typeof uniforms[uniformName];\n if (\n type === 'boolean' ||\n type === 'number' ||\n Array.isArray(uniforms[uniformName]) ||\n // @ts-ignore\n uniforms[uniformName].BYTES_PER_ELEMENT\n ) {\n reglDrawProps[uniformName] = uniforms[uniformName] as\n | number\n | number[]\n | boolean;\n } else if (type === 'string') {\n // TODO: image url\n } else {\n reglDrawProps[uniformName] = (uniforms[uniformName] as\n | ReglFramebuffer\n | ReglTexture2D).get();\n }\n });\n this.drawCommand(reglDrawProps);\n }\n\n public destroy() {\n // don't need do anything since we will call `rendererService.cleanup()`\n }\n\n /**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#depth-buffer\n */\n private initDepthDrawParams(\n { depth }: Pick<IModelInitializationOptions, 'depth'>,\n drawParams: regl.DrawConfig,\n ) {\n if (depth) {\n drawParams.depth = {\n enable: depth.enable === undefined ? true : !!depth.enable,\n mask: depth.mask === undefined ? true : !!depth.mask,\n func: depthFuncMap[depth.func || gl.LESS],\n range: depth.range || [0, 1],\n };\n }\n }\n\n /**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#blending\n */\n private initBlendDrawParams(\n { blend }: Pick<IModelInitializationOptions, 'blend'>,\n drawParams: regl.DrawConfig,\n ) {\n if (blend) {\n const { enable, func, equation, color = [0, 0, 0, 0] } = blend;\n // @ts-ignore\n drawParams.blend = {\n enable: !!enable,\n func: {\n srcRGB: blendFuncMap[(func && func.srcRGB) || gl.SRC_ALPHA],\n srcAlpha: blendFuncMap[(func && func.srcAlpha) || gl.SRC_ALPHA],\n dstRGB: blendFuncMap[(func && func.dstRGB) || gl.ONE_MINUS_SRC_ALPHA],\n dstAlpha:\n blendFuncMap[(func && func.dstAlpha) || gl.ONE_MINUS_SRC_ALPHA],\n },\n equation: {\n rgb: blendEquationMap[(equation && equation.rgb) || gl.FUNC_ADD],\n alpha: blendEquationMap[(equation && equation.alpha) || gl.FUNC_ADD],\n },\n color,\n };\n }\n }\n\n /**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#stencil\n */\n private initStencilDrawParams(\n { stencil }: Pick<IModelInitializationOptions, 'stencil'>,\n drawParams: regl.DrawConfig,\n ) {\n if (stencil) {\n const {\n enable,\n mask = -1,\n func = {\n cmp: gl.ALWAYS,\n ref: 0,\n mask: -1,\n },\n opFront = {\n fail: gl.KEEP,\n zfail: gl.KEEP,\n zpass: gl.KEEP,\n },\n opBack = {\n fail: gl.KEEP,\n zfail: gl.KEEP,\n zpass: gl.KEEP,\n },\n } = stencil;\n drawParams.stencil = {\n enable: !!enable,\n mask,\n func: {\n ...func,\n cmp: stencilFuncMap[func.cmp],\n },\n opFront: {\n fail: stencilOpMap[opFront.fail],\n zfail: stencilOpMap[opFront.zfail],\n zpass: stencilOpMap[opFront.zpass],\n },\n opBack: {\n fail: stencilOpMap[opBack.fail],\n zfail: stencilOpMap[opBack.zfail],\n zpass: stencilOpMap[opBack.zpass],\n },\n };\n }\n }\n\n /**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#culling\n */\n private initCullDrawParams(\n { cull }: Pick<IModelInitializationOptions, 'cull'>,\n drawParams: regl.DrawConfig,\n ) {\n if (cull) {\n const { enable, face = gl.BACK } = cull;\n drawParams.cull = {\n enable: !!enable,\n face: cullFaceMap[face],\n };\n }\n }\n\n private generateDefines(defines: Record<string, number | boolean>) {\n return Object.keys(defines)\n .map((name) => `#define ${name} ${Number(defines[name])}`)\n .join('\\n');\n }\n}\n","import {\n gl,\n ITexture2D,\n ITexture2DInitializationOptions,\n} from '@antv/g-webgpu-core';\nimport regl from 'regl';\nimport {\n colorSpaceMap,\n dataTypeMap,\n filterMap,\n formatMap,\n mipmapMap,\n wrapModeMap,\n} from './constants';\n\n/**\n * adaptor for regl.Buffer\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#buffers\n */\nexport default class ReglTexture2D implements ITexture2D {\n private texture: regl.Texture2D;\n private width: number;\n private height: number;\n\n constructor(reGl: regl.Regl, options: ITexture2DInitializationOptions) {\n const {\n data,\n type = gl.UNSIGNED_BYTE,\n width,\n height,\n flipY = false,\n format = gl.RGBA,\n mipmap = false,\n wrapS = gl.CLAMP_TO_EDGE,\n wrapT = gl.CLAMP_TO_EDGE,\n aniso = 0,\n alignment = 1,\n premultiplyAlpha = false,\n mag = gl.NEAREST,\n min = gl.NEAREST,\n colorSpace = gl.BROWSER_DEFAULT_WEBGL,\n } = options;\n this.width = width;\n this.height = height;\n\n const textureOptions: regl.Texture2DOptions = {\n width,\n height,\n // @ts-ignore\n type: dataTypeMap[type],\n format: formatMap[format],\n wrapS: wrapModeMap[wrapS],\n wrapT: wrapModeMap[wrapT],\n // @ts-ignore\n mag: filterMap[mag],\n min: filterMap[min],\n alignment,\n flipY,\n colorSpace: colorSpaceMap[colorSpace],\n premultiplyAlpha,\n aniso,\n };\n\n if (data) {\n textureOptions.data = data;\n }\n\n if (typeof mipmap === 'number') {\n textureOptions.mipmap = mipmapMap[mipmap];\n } else if (typeof mipmap === 'boolean') {\n textureOptions.mipmap = mipmap;\n }\n\n this.texture = reGl.texture(textureOptions);\n }\n\n public get() {\n return this.texture;\n }\n public update() {\n // @ts-ignore\n this.texture._texture.bind();\n }\n\n public resize({ width, height }: { width: number; height: number }): void {\n this.texture.resize(width, height);\n this.width = width;\n this.height = height;\n }\n\n public destroy() {\n this.texture.destroy();\n }\n}\n","/**\n * render w/ regl\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md\n */\nimport {\n gl,\n GLSLContext,\n IAttribute,\n IAttributeInitializationOptions,\n IBuffer,\n IBufferInitializationOptions,\n IClearOptions,\n IComputeModel,\n IElements,\n IElementsInitializationOptions,\n IFramebuffer,\n IFramebufferInitializationOptions,\n IModel,\n IModelInitializationOptions,\n IReadPixelsOptions,\n IRendererConfig,\n IRendererService,\n ITexture2D,\n ITexture2DInitializationOptions,\n} from '@antv/g-webgpu-core';\nimport { injectable } from 'inversify';\nimport regl from 'regl';\nimport ReglAttribute from './ReglAttribute';\nimport ReglBuffer from './ReglBuffer';\nimport ReglComputeModel from './ReglComputeModel';\nimport ReglElements from './ReglElements';\nimport ReglFramebuffer from './ReglFramebuffer';\nimport ReglModel from './ReglModel';\nimport ReglTexture2D from './ReglTexture2D';\n\n/**\n * regl renderer\n */\n@injectable()\nexport class WebGLEngine implements IRendererService {\n public supportWebGPU = false;\n public useWGSL = false;\n private $canvas: HTMLCanvasElement;\n private gl: regl.Regl;\n private inited: boolean;\n\n public async init(cfg: IRendererConfig): Promise<void> {\n if (this.inited) {\n return;\n }\n this.$canvas = cfg.canvas!;\n // tslint:disable-next-line:typedef\n this.gl = await new Promise((resolve, reject) => {\n regl({\n canvas: cfg.canvas,\n attributes: {\n alpha: true,\n // use TAA instead of MSAA\n // @see https://www.khronos.org/registry/webgl/specs/1.0/#5.2.1\n antialias: cfg.antialias,\n premultipliedAlpha: true,\n // preserveDrawingBuffer: false,\n },\n pixelRatio: 1,\n // TODO: use extensions\n extensions: [\n 'OES_element_index_uint',\n 'OES_texture_float',\n 'OES_standard_derivatives', // wireframe\n 'angle_instanced_arrays', // VSM shadow map\n ],\n optionalExtensions: [\n 'EXT_texture_filter_anisotropic',\n 'EXT_blend_minmax',\n 'WEBGL_depth_texture',\n ],\n profile: true,\n onDone: (err: Error | null, r?: regl.Regl | undefined): void => {\n if (err || !r) {\n reject(err);\n }\n // @ts-ignore\n resolve(r);\n },\n });\n });\n this.inited = true;\n }\n\n public isFloatSupported() {\n // @see https://github.com/antvis/GWebGPUEngine/issues/26\n // @ts-ignore\n return this.gl.limits.readFloat;\n }\n\n public createModel = async (\n options: IModelInitializationOptions,\n ): Promise<IModel> => {\n if (options.uniforms) {\n await Promise.all(\n Object.keys(options.uniforms).map(async (name) => {\n // @ts-ignore\n if (options.uniforms![name] && options.uniforms![name].load !== undefined) {\n // @ts-ignore\n const texture = await options.uniforms![name].load();\n // @ts-ignore\n options.uniforms[name] = texture;\n }\n }),\n );\n }\n return new ReglModel(this.gl, options);\n };\n\n public createAttribute = (\n options: IAttributeInitializationOptions,\n ): IAttribute => new ReglAttribute(this.gl, options);\n\n public createBuffer = (options: IBufferInitializationOptions): IBuffer =>\n new ReglBuffer(this.gl, options);\n\n public createElements = (\n options: IElementsInitializationOptions,\n ): IElements => new ReglElements(this.gl, options);\n\n public createTexture2D = (\n options: ITexture2DInitializationOptions,\n ): ITexture2D => new ReglTexture2D(this.gl, options);\n\n public createFramebuffer = (options: IFramebufferInitializationOptions) =>\n new ReglFramebuffer(this.gl, options);\n\n public useFramebuffer = (\n framebuffer: IFramebuffer | null,\n drawCommands: () => void,\n ) => {\n this.gl({\n framebuffer: framebuffer ? (framebuffer as ReglFramebuffer).get() : null,\n })(drawCommands);\n };\n\n public createComputeModel = async (\n context: GLSLContext,\n ): Promise<IComputeModel> => {\n return new ReglComputeModel(this.gl, context);\n };\n\n public clear = (options: IClearOptions) => {\n // @see https://github.com/regl-project/regl/blob/gh-pages/API.md#clear-the-draw-buffer\n const { color, depth, stencil, framebuffer = null } = options;\n const reglClearOptions: regl.ClearOptions = {\n color,\n depth,\n stencil,\n };\n\n reglClearOptions.framebuffer =\n framebuffer === null\n ? framebuffer\n : (framebuffer as ReglFramebuffer).get();\n\n this.gl.clear(reglClearOptions);\n };\n\n public setScissor = (\n scissor: Partial<{\n enable: boolean;\n box: { x: number; y: number; width: number; height: number };\n }>,\n ) => {\n if (this.gl && this.gl._gl) {\n // https://developer.mozilla.org/zh-CN/docs/Web/API/WebGLRenderingContext/scissor\n if (scissor.enable && scissor.box) {\n // console.log(scissor.box);\n this.gl._gl.enable(gl.SCISSOR_TEST);\n this.gl._gl.scissor(\n scissor.box.x,\n scissor.box.y,\n scissor.box.width,\n scissor.box.height,\n );\n } else {\n this.gl._gl.disable(gl.SCISSOR_TEST);\n }\n this.gl._refresh();\n }\n };\n\n public viewport = ({\n x,\n y,\n width,\n height,\n }: {\n x: number;\n y: number;\n width: number;\n height: number;\n }) => {\n if (this.gl && this.gl._gl) {\n // use WebGL context directly\n // @see https://github.com/regl-project/regl/blob/gh-pages/API.md#unsafe-escape-hatch\n this.gl._gl.viewport(x, y, width, height);\n this.gl._refresh();\n }\n };\n\n public readPixels = (options: IReadPixelsOptions) => {\n const { framebuffer, x, y, width, height } = options;\n const readPixelsOptions: regl.ReadOptions = {\n x,\n y,\n width,\n height,\n };\n if (framebuffer) {\n readPixelsOptions.framebuffer = (framebuffer as ReglFramebuffer).get();\n }\n return this.gl.read(readPixelsOptions);\n };\n\n public getCanvas = () => {\n return this.$canvas;\n };\n\n public getGLContext = () => {\n return this.gl._gl;\n };\n\n public destroy = () => {\n if (this.gl) {\n // @see https://github.com/regl-project/regl/blob/gh-pages/API.md#clean-up\n this.gl.destroy();\n this.inited = false;\n }\n };\n\n public beginFrame() {\n //\n }\n\n public endFrame() {\n //\n }\n}\n","export function isWindowObjectExist(): boolean {\n return typeof window !== 'undefined';\n}\n\nexport function loadScript(\n scriptUrl: string,\n onSuccess: () => void,\n onError?: (message?: string, exception?: any) => void,\n scriptId?: string,\n) {\n if (!isWindowObjectExist()) {\n return;\n }\n const head = document.getElementsByTagName('head')[0];\n const script = document.createElement('script');\n script.setAttribute('type', 'text/javascript');\n script.setAttribute('src', scriptUrl);\n if (scriptId) {\n script.id = scriptId;\n }\n\n script.onload = () => {\n if (onSuccess) {\n onSuccess();\n }\n };\n\n script.onerror = (e) => {\n if (onError) {\n onError(`Unable to load script '${scriptUrl}'`, e);\n }\n };\n\n head.appendChild(script);\n}\n\nexport function loadScriptAsync(\n scriptUrl: string,\n scriptId?: string,\n): Promise<void> {\n return new Promise((resolve, reject) => {\n loadScript(\n scriptUrl,\n () => {\n resolve();\n },\n (message, exception) => {\n reject(exception);\n },\n );\n });\n}\n","import {\n BufferData,\n IAttribute,\n IAttributeInitializationOptions,\n IBuffer,\n} from '@antv/g-webgpu-core';\nimport { WebGPUEngine } from '.';\nimport WebGPUBuffer from './WebGPUBuffer';\n\nexport default class WebGPUAttribute implements IAttribute {\n private attribute: {\n buffer: GPUBuffer;\n offset: number;\n stride: number;\n normalized: boolean;\n divisor: number;\n size?: number;\n arrayStride: number;\n stepMode: GPUInputStepMode;\n attributes: Iterable<GPUVertexAttributeDescriptor>;\n };\n private buffer: IBuffer;\n\n constructor(\n private engine: WebGPUEngine,\n private options: IAttributeInitializationOptions,\n ) {\n const {\n buffer,\n offset,\n stride,\n normalized,\n size,\n divisor,\n arrayStride,\n attributes,\n stepMode,\n } = options;\n this.buffer = buffer;\n this.attribute = {\n buffer: (buffer as WebGPUBuffer).get(),\n offset: offset || 0,\n stride: stride || 0,\n normalized: normalized || false,\n divisor: divisor || 0,\n arrayStride: arrayStride || 0,\n // @ts-ignore\n attributes,\n stepMode: stepMode || 'vertex',\n };\n\n if (size) {\n this.attribute.size = size;\n }\n }\n\n public get() {\n return this.attribute;\n }\n\n public updateBuffer(options: {\n // 用于替换的数据\n data: BufferData;\n // 原 Buffer 替换位置,单位为 byte\n offset: number;\n }) {\n this.buffer.subData(options);\n }\n\n public destroy() {\n this.buffer.destroy();\n }\n}\n","import {\n BufferData,\n gl,\n IBuffer,\n IBufferInitializationOptions,\n isSafari,\n} from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { WebGPUEngine } from '.';\n\nexport default class WebGPUBuffer implements IBuffer {\n private buffer: GPUBuffer;\n\n constructor(\n private engine: WebGPUEngine,\n private options: IBufferInitializationOptions,\n ) {\n const { data, usage, type } = options;\n this.buffer = this.createBuffer(\n data instanceof Array ? new Float32Array(data) : data,\n // TODO: WebGL 和 WebGPU buffer usage 映射关系\n usage ||\n WebGPUConstants.BufferUsage.Vertex |\n WebGPUConstants.BufferUsage.CopyDst,\n );\n }\n\n public get() {\n return this.buffer;\n }\n\n public destroy() {\n this.buffer.destroy();\n }\n\n public subData({ data, offset }: { data: BufferData; offset: number }) {\n this.setSubData(\n this.buffer,\n offset,\n data instanceof Array ? new Float32Array(data) : data,\n );\n }\n\n private createBuffer(\n view: Exclude<BufferData, number[]>,\n flags: GPUBufferUsageFlags,\n ): GPUBuffer {\n // @ts-ignore\n const padding = view.byteLength % 4;\n const verticesBufferDescriptor = {\n // @ts-ignore\n size: view.byteLength + padding,\n usage: flags,\n };\n const buffer = this.engine.device.createBuffer(verticesBufferDescriptor);\n\n this.setSubData(buffer, 0, view);\n\n return buffer;\n }\n\n /**\n * 不同于 Babylon.js 的版本,使用最新的 GPUQueue.writeBuffer 方法\n * @see https://gpuweb.github.io/gpuweb/#dom-gpuqueue-writebuffer\n * 已废弃创建一个临时的 mapped buffer 用于拷贝数据 @see https://gpuweb.github.io/gpuweb/#GPUDevice-createBufferMapped\n * @see https://github.com/gpuweb/gpuweb/blob/master/design/BufferOperations.md#updating-data-to-an-existing-buffer-like-webgls-buffersubdata\n */\n private setSubData(\n destBuffer: GPUBuffer,\n destOffset: number,\n srcArrayBuffer: Exclude<BufferData, number[]>,\n ) {\n // deprecated API setSubData\n // destBuffer.setSubData(0, srcArrayBuffer);\n\n // deprecated API createBufferMapped\n // use createBuffer & getMappedRange instead\n // const [srcBuffer, arrayBuffer] = this.engine.device.createBufferMapped({\n // size: byteCount,\n // usage: WebGPUConstants.BufferUsage.CopySrc,\n // });\n\n const queue: GPUQueue = isSafari\n ? // @ts-ignore\n this.engine.device.getQueue()\n : this.engine.device.defaultQueue;\n // @ts-ignore\n queue.writeBuffer(destBuffer, destOffset, srcArrayBuffer);\n }\n}\n","import {\n AST_TOKEN_TYPES,\n createEntity,\n GLSLContext,\n IComputeModel,\n isSafari,\n STORAGE_CLASS,\n} from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { WebGPUEngine } from '.';\nimport { isNumber } from '../utils/is-number';\nimport WebGPUBuffer from './WebGPUBuffer';\n\nexport default class WebGPUComputeModel implements IComputeModel {\n private entity = createEntity();\n /**\n * 用于后续渲染时动态更新\n */\n private uniformGPUBufferLayout: Array<{\n name: string;\n offset: number;\n }> = [];\n\n private uniformBuffer: WebGPUBuffer;\n private vertexBuffers: Record<string, WebGPUBuffer> = {};\n private outputBuffer: WebGPUBuffer;\n private bindGroupEntries: GPUBindGroupEntry[];\n private bindGroup: GPUBindGroup;\n\n private computePipeline: GPUComputePipeline;\n\n constructor(private engine: WebGPUEngine, private context: GLSLContext) {}\n\n public async init() {\n const { computeStage } = await this.compileComputePipelineStageDescriptor(\n this.context.shader!,\n );\n\n const buffers = this.context.uniforms.filter(\n (uniform) => uniform.storageClass === STORAGE_CLASS.StorageBuffer,\n );\n const uniforms = this.context.uniforms.filter(\n (uniform) => uniform.storageClass === STORAGE_CLASS.Uniform,\n );\n\n let bufferBindingIndex = uniforms.length ? 1 : 0;\n this.bindGroupEntries = [];\n if (bufferBindingIndex) {\n let offset = 0;\n // FIXME: 所有 uniform 合并成一个 buffer,固定使用 Float32Array 存储,确实会造成一些内存的浪费\n // we use std140 layout @see https://www.khronos.org/opengl/wiki/Interface_Block_(GLSL)\n const mergedUniformData: number[] = [];\n uniforms.forEach((uniform) => {\n if (isNumber(uniform.data)) {\n this.uniformGPUBufferLayout.push({\n name: uniform.name,\n offset,\n });\n offset += 4;\n // @ts-ignore\n mergedUniformData.push(uniform.data);\n } else {\n // @ts-ignore\n let originDataLength = uniform.data?.length || 1;\n if (originDataLength === 3) {\n // vec3 -> vec4\n // @see http://ptgmedia.pearsoncmg.com/images/9780321552624/downloads/0321552628_AppL.pdf\n originDataLength = 4;\n // @ts-ignore\n uniform.data.push(0);\n }\n // 4 elements per block/line\n const padding = (offset / 4) % 4;\n if (padding > 0) {\n const space = 4 - padding;\n if (originDataLength > 1 && originDataLength <= space) {\n if (originDataLength === 2) {\n if (space === 3) {\n offset += 4;\n mergedUniformData.push(0);\n }\n // @ts-ignore\n mergedUniformData.push(...uniform.data);\n this.uniformGPUBufferLayout.push({\n name: uniform.name,\n offset,\n });\n }\n } else {\n for (let i = 0; i < space; i++) {\n offset += 4;\n mergedUniformData.push(0);\n }\n // @ts-ignore\n mergedUniformData.push(...uniform.data);\n this.uniformGPUBufferLayout.push({\n name: uniform.name,\n offset,\n });\n }\n }\n\n offset += 4 * originDataLength;\n }\n });\n\n this.uniformBuffer = new WebGPUBuffer(this.engine, {\n // TODO: 处理 Struct 和 boolean\n // @ts-ignore\n data:\n mergedUniformData instanceof Array\n ? // @ts-ignore\n new Float32Array(mergedUniformData)\n : mergedUniformData,\n usage:\n WebGPUConstants.BufferUsage.Uniform |\n WebGPUConstants.BufferUsage.CopyDst,\n });\n\n this.bindGroupEntries.push({\n binding: 0,\n resource: {\n buffer: this.uniformBuffer.get(),\n },\n });\n }\n\n // create GPUBuffers for storeage buffers\n buffers.forEach((buffer) => {\n if (buffer.data !== null) {\n if (\n buffer.type === AST_TOKEN_TYPES.Vector4FloatArray ||\n buffer.type === AST_TOKEN_TYPES.FloatArray\n ) {\n let gpuBuffer;\n if (buffer.name === this.context.output.name) {\n gpuBuffer = new WebGPUBuffer(this.engine, {\n // @ts-ignore\n data: isFinite(Number(buffer.data)) ? [buffer.data] : buffer.data,\n usage:\n WebGPUConstants.BufferUsage.Storage |\n WebGPUConstants.BufferUsage.CopyDst |\n WebGPUConstants.BufferUsage.CopySrc,\n });\n this.outputBuffer = gpuBuffer;\n this.context.output = {\n name: buffer.name,\n // @ts-ignore\n length: isFinite(Number(buffer.data)) ? 1 : buffer.data.length,\n typedArrayConstructor: Float32Array,\n gpuBuffer: gpuBuffer.get(),\n };\n } else {\n if (buffer.isReferer) {\n // @ts-ignore\n if (buffer.data.model && buffer.data.model.outputBuffer) {\n // @ts-ignore\n gpuBuffer = (buffer.data.model as WebGPUComputeModel)\n .outputBuffer;\n } else {\n // referred kernel haven't been executed\n }\n } else {\n gpuBuffer = new WebGPUBuffer(this.engine, {\n // @ts-ignore\n data: isFinite(Number(buffer.data))\n ? [buffer.data]\n : buffer.data,\n usage:\n WebGPUConstants.BufferUsage.Storage |\n WebGPUConstants.BufferUsage.CopyDst |\n WebGPUConstants.BufferUsage.CopySrc,\n });\n }\n }\n\n // @ts-ignore\n this.vertexBuffers[buffer.name] = gpuBuffer;\n this.bindGroupEntries.push({\n binding: bufferBindingIndex,\n resource: {\n name: buffer.name,\n refer: gpuBuffer ? undefined : buffer.data,\n // @ts-ignore\n buffer: gpuBuffer ? gpuBuffer.get() : undefined,\n },\n });\n bufferBindingIndex++;\n }\n }\n });\n\n // create compute pipeline layout\n this.computePipeline = this.engine.device.createComputePipeline({\n computeStage,\n });\n\n console.log(this.bindGroupEntries);\n\n this.bindGroup = this.engine.device.createBindGroup({\n layout: this.computePipeline.getBindGroupLayout(0),\n entries: this.bindGroupEntries,\n });\n }\n\n public destroy(): void {\n if (this.uniformBuffer) {\n this.uniformBuffer.destroy();\n }\n\n Object.keys(this.vertexBuffers).forEach((bufferName) =>\n this.vertexBuffers[bufferName].destroy(),\n );\n }\n\n public async readData() {\n const { output } = this.context;\n if (output) {\n const { length, typedArrayConstructor, gpuBuffer } = output;\n if (gpuBuffer) {\n // await gpuBuffer.mapAsync(WebGPUConstants.MapMode.Read);\n // const arraybuffer = gpuBuffer.getMappedRange();\n // let arraybuffer;\n\n // if (isSafari) {\n // arraybuffer = await gpuBuffer.mapReadAsync();\n // } else {\n const byteCount = length! * typedArrayConstructor!.BYTES_PER_ELEMENT;\n\n // @see https://developers.google.com/web/updates/2019/08/get-started-with-gpu-compute-on-the-web\n const gpuReadBuffer = this.engine.device.createBuffer({\n size: byteCount,\n usage: GPUBufferUsage.COPY_DST | GPUBufferUsage.MAP_READ,\n });\n const encoder = this.engine.device.createCommandEncoder();\n encoder.copyBufferToBuffer(gpuBuffer, 0, gpuReadBuffer, 0, byteCount);\n const queue: GPUQueue = isSafari\n ? // @ts-ignore\n this.engine.device.getQueue()\n : this.engine.device.defaultQueue;\n queue.submit([encoder.finish()]);\n\n await gpuReadBuffer.mapAsync(WebGPUConstants.MapMode.Read);\n const arraybuffer = gpuReadBuffer.getMappedRange();\n const typedArray = new typedArrayConstructor!(arraybuffer.slice(0));\n gpuReadBuffer.unmap();\n\n return typedArray;\n }\n }\n return new Float32Array();\n }\n\n public run() {\n if (this.engine.currentComputePass) {\n this.engine.currentComputePass.setPipeline(this.computePipeline);\n\n // this.bindGroupEntries.forEach((entry) => {\n // if (!entry.resource.buffer) {\n // // get referred kernel's output\n // const gpuBuffer = (entry.resource.refer.model as WebGPUComputeModel)\n // .outputBuffer;\n // this.vertexBuffers[entry.resource.name] = gpuBuffer;\n // entry.resource.buffer = gpuBuffer.get();\n // }\n // });\n\n // const bindGroup = this.engine.device.createBindGroup({\n // layout: this.computePipeline.getBindGroupLayout(0),\n // entries: this.bindGroupEntries,\n // });\n this.engine.currentComputePass.setBindGroup(0, this.bindGroup);\n this.engine.currentComputePass.dispatch(...this.context.dispatch);\n }\n }\n\n public updateBuffer(\n bufferName: string,\n data:\n | number[]\n | Float32Array\n | Uint8Array\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array,\n offset: number = 0,\n ) {\n const buffer = this.vertexBuffers[bufferName];\n if (buffer) {\n buffer.subData({ data, offset });\n }\n }\n\n public updateUniform(\n uniformName: string,\n data:\n | number\n | number[]\n | Float32Array\n | Uint8Array\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array,\n ) {\n const layout = this.uniformGPUBufferLayout.find(\n (l) => l.name === uniformName,\n );\n\n if (layout) {\n this.uniformBuffer.subData({\n data: Number.isFinite(data)\n ? new Float32Array([data as number])\n : new Float32Array(\n data as\n | number[]\n | Float32Array\n | Uint8Array\n | Uint16Array\n | Uint32Array\n | Int8Array\n | Int16Array\n | Int32Array,\n ),\n offset: layout.offset,\n });\n }\n }\n\n public confirmInput(model: IComputeModel, inputName: string): void {\n // copy output GPUBuffer of kernel\n const inputBuffer = this.vertexBuffers[inputName];\n const outputBuffer = (model as WebGPUComputeModel).outputBuffer;\n\n if (inputBuffer && outputBuffer && inputBuffer !== outputBuffer) {\n const encoder = this.engine.device.createCommandEncoder();\n const {\n length,\n typedArrayConstructor,\n } = (model as WebGPUComputeModel).context.output;\n const byteCount = length! * typedArrayConstructor!.BYTES_PER_ELEMENT;\n encoder.copyBufferToBuffer(\n outputBuffer.get(),\n 0,\n inputBuffer.get(),\n 0,\n byteCount,\n );\n const queue: GPUQueue = isSafari\n ? // @ts-ignore\n this.engine.device.getQueue()\n : this.engine.device.defaultQueue;\n queue.submit([encoder.finish()]);\n }\n }\n\n private compileShaderToSpirV(\n source: string,\n type: string,\n shaderVersion: string,\n ): Promise<Uint32Array> {\n return this.compileRawShaderToSpirV(shaderVersion + source, type);\n }\n\n private compileRawShaderToSpirV(\n source: string,\n type: string,\n ): Promise<Uint32Array> {\n return this.engine.glslang.compileGLSL(source, type);\n }\n\n private async compileComputePipelineStageDescriptor(\n computeCode: string,\n ): Promise<Pick<GPUComputePipelineDescriptor, 'computeStage'>> {\n let computeShader: Uint32Array | string = computeCode;\n const shaderVersion = '#version 450\\n';\n if (!this.engine.options.useWGSL) {\n computeShader = await this.compileShaderToSpirV(\n computeCode,\n 'compute',\n shaderVersion,\n );\n }\n\n return {\n computeStage: {\n module: this.engine.device.createShaderModule({\n code: computeShader,\n // @ts-ignore\n isWHLSL: isSafari,\n }),\n entryPoint: 'main',\n },\n };\n }\n}\n","import {\n BufferData,\n IBuffer,\n IElements,\n IElementsInitializationOptions,\n} from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { WebGPUEngine } from '.';\nimport WebGPUBuffer from './WebGPUBuffer';\n\nexport default class WebGPUElements implements IElements {\n public indexCount: number;\n private buffer: IBuffer;\n\n constructor(\n private engine: WebGPUEngine,\n private options: IElementsInitializationOptions,\n ) {\n const { data, usage, type, count } = options;\n this.indexCount = count || 0;\n\n this.buffer = new WebGPUBuffer(engine, {\n // @ts-ignore\n data: data instanceof Array ? new Uint16Array(data) : data,\n usage:\n WebGPUConstants.BufferUsage.Index | WebGPUConstants.BufferUsage.CopyDst,\n });\n }\n\n public get() {\n return this.buffer;\n }\n\n public subData(options: {\n // 用于替换的数据\n data: BufferData;\n // 原 Buffer 替换位置,单位为 byte\n offset: number;\n }) {\n this.buffer.subData(options);\n }\n\n public destroy() {\n this.buffer.destroy();\n }\n}\n","import {\n gl,\n IFramebuffer,\n IFramebufferInitializationOptions,\n IRenderbuffer,\n ITexture2D,\n} from '@antv/g-webgpu-core';\nimport { WebGPUEngine } from '.';\nimport WebGPUTexture2D from './WebGPUTexture2D';\n\nexport default class WebGPUFramebuffer implements IFramebuffer {\n private colorTexture: WebGPUTexture2D | null;\n private depthTexture: WebGPUTexture2D | null;\n private width: number = 0;\n private height: number = 0;\n\n constructor(\n private engine: WebGPUEngine,\n private options: IFramebufferInitializationOptions,\n ) {\n const { width, height, color, colors, depth, stencil } = options;\n if (color) {\n this.colorTexture = color as WebGPUTexture2D;\n }\n if (depth) {\n this.depthTexture = depth as WebGPUTexture2D;\n }\n // TODO: depth & stencil\n }\n\n public get() {\n return {\n color: this.colorTexture?.get(),\n depth: this.depthTexture?.get(),\n };\n }\n\n public destroy() {\n this.colorTexture?.destroy();\n this.depthTexture?.destroy();\n }\n\n public resize({ width, height }: { width: number; height: number }) {\n if (width !== this.width || height !== this.height) {\n this.colorTexture?.resize({ width, height });\n this.depthTexture?.resize({ width, height });\n }\n this.width = width;\n this.height = height;\n }\n}\n","import { gl, IModelInitializationOptions } from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\n\n// WebGPU 不支持 LINE_LOOP & TRIANGLE_FAN\nexport const primitiveMap: {\n [key: string]:\n | WebGPUConstants.PrimitiveTopology.PointList\n | WebGPUConstants.PrimitiveTopology.LineList\n | WebGPUConstants.PrimitiveTopology.LineStrip\n | WebGPUConstants.PrimitiveTopology.TriangleList\n | WebGPUConstants.PrimitiveTopology.TriangleStrip;\n} = {\n [gl.POINTS]: WebGPUConstants.PrimitiveTopology.PointList,\n [gl.LINES]: WebGPUConstants.PrimitiveTopology.LineList,\n [gl.LINE_LOOP]: WebGPUConstants.PrimitiveTopology.LineList,\n [gl.LINE_STRIP]: WebGPUConstants.PrimitiveTopology.LineStrip,\n [gl.TRIANGLES]: WebGPUConstants.PrimitiveTopology.TriangleList,\n [gl.TRIANGLE_FAN]: WebGPUConstants.PrimitiveTopology.TriangleList,\n [gl.TRIANGLE_STRIP]: WebGPUConstants.PrimitiveTopology.TriangleStrip,\n};\n\nexport const depthFuncMap: {\n [key: string]:\n | WebGPUConstants.CompareFunction.Never\n | WebGPUConstants.CompareFunction.Always\n | WebGPUConstants.CompareFunction.Less\n | WebGPUConstants.CompareFunction.LessEqual\n | WebGPUConstants.CompareFunction.Greater\n | WebGPUConstants.CompareFunction.GreaterEqual\n | WebGPUConstants.CompareFunction.Equal\n | WebGPUConstants.CompareFunction.NotEqual;\n} = {\n [gl.NEVER]: WebGPUConstants.CompareFunction.Never,\n [gl.ALWAYS]: WebGPUConstants.CompareFunction.Always,\n [gl.LESS]: WebGPUConstants.CompareFunction.Less,\n [gl.LEQUAL]: WebGPUConstants.CompareFunction.LessEqual,\n [gl.GREATER]: WebGPUConstants.CompareFunction.Greater,\n [gl.GEQUAL]: WebGPUConstants.CompareFunction.GreaterEqual,\n [gl.EQUAL]: WebGPUConstants.CompareFunction.Equal,\n [gl.NOTEQUAL]: WebGPUConstants.CompareFunction.NotEqual,\n};\n\nexport const blendEquationMap: {\n [key: string]:\n | WebGPUConstants.BlendOperation.Add\n | WebGPUConstants.BlendOperation.Min\n | WebGPUConstants.BlendOperation.Max\n | WebGPUConstants.BlendOperation.Subtract\n | WebGPUConstants.BlendOperation.ReverseSubtract;\n} = {\n [gl.FUNC_ADD]: WebGPUConstants.BlendOperation.Add,\n [gl.MIN_EXT]: WebGPUConstants.BlendOperation.Min,\n [gl.MAX_EXT]: WebGPUConstants.BlendOperation.Max,\n [gl.FUNC_SUBTRACT]: WebGPUConstants.BlendOperation.Subtract,\n [gl.FUNC_REVERSE_SUBTRACT]: WebGPUConstants.BlendOperation.ReverseSubtract,\n};\n\n// @see https://gpuweb.github.io/gpuweb/#blend-state\n// 不支持 'constant alpha' 和 'one minus constant alpha'\nexport const blendFuncMap: {\n [key: string]:\n | WebGPUConstants.BlendFactor.Zero\n | WebGPUConstants.BlendFactor.One\n | WebGPUConstants.BlendFactor.SrcColor\n | WebGPUConstants.BlendFactor.OneMinusSrcColor\n | WebGPUConstants.BlendFactor.SrcAlpha\n | WebGPUConstants.BlendFactor.OneMinusSrcAlpha\n | WebGPUConstants.BlendFactor.DstColor\n | WebGPUConstants.BlendFactor.OneMinusDstColor\n | WebGPUConstants.BlendFactor.DstAlpha\n | WebGPUConstants.BlendFactor.OneMinusDstAlpha\n | WebGPUConstants.BlendFactor.BlendColor\n | WebGPUConstants.BlendFactor.OneMinusBlendColor\n | WebGPUConstants.BlendFactor.SrcAlphaSaturated;\n} = {\n [gl.ZERO]: WebGPUConstants.BlendFactor.Zero,\n [gl.ONE]: WebGPUConstants.BlendFactor.One,\n [gl.SRC_COLOR]: WebGPUConstants.BlendFactor.SrcColor,\n [gl.ONE_MINUS_SRC_COLOR]: WebGPUConstants.BlendFactor.OneMinusSrcColor,\n [gl.SRC_ALPHA]: WebGPUConstants.BlendFactor.SrcAlpha,\n [gl.ONE_MINUS_SRC_ALPHA]: WebGPUConstants.BlendFactor.OneMinusSrcAlpha,\n [gl.DST_COLOR]: WebGPUConstants.BlendFactor.DstColor,\n [gl.ONE_MINUS_DST_COLOR]: WebGPUConstants.BlendFactor.OneMinusDstColor,\n [gl.DST_ALPHA]: WebGPUConstants.BlendFactor.DstAlpha,\n [gl.ONE_MINUS_DST_ALPHA]: WebGPUConstants.BlendFactor.OneMinusDstAlpha,\n [gl.CONSTANT_COLOR]: WebGPUConstants.BlendFactor.BlendColor,\n [gl.ONE_MINUS_CONSTANT_COLOR]: WebGPUConstants.BlendFactor.OneMinusBlendColor,\n // [gl.CONSTANT_ALPHA]: WebGPUConstants.BlendFactor.'constant alpha',\n // [gl.ONE_MINUS_CONSTANT_ALPHA]: WebGPUConstants.BlendFactor.'one minus constant alpha',\n [gl.SRC_ALPHA_SATURATE]: WebGPUConstants.BlendFactor.SrcAlphaSaturated,\n};\n\n// @see https://gpuweb.github.io/gpuweb/#texture-formats\nexport const formatMap: {\n [key: string]:\n | 'r8unorm'\n | 'rgba8unorm'\n | 'depth32float'\n | 'depth24plus-stencil8';\n} = {\n [gl.ALPHA]: 'r8unorm',\n [gl.RGBA]: 'rgba8unorm',\n [gl.DEPTH_COMPONENT]: 'depth32float',\n [gl.DEPTH_STENCIL]: 'depth24plus-stencil8',\n};\n\n// @see https://gpuweb.github.io/gpuweb/#enumdef-gpufiltermode\nexport const filterMap: {\n [key: string]: 'nearest' | 'linear';\n} = {\n [gl.NEAREST]: 'nearest',\n [gl.LINEAR]: 'linear',\n};\n\n// @see https://gpuweb.github.io/gpuweb/#enumdef-gpuaddressmode\nexport const wrapModeMap: {\n [key: string]: 'repeat' | 'clamp-to-edge' | 'mirror-repeat';\n} = {\n [gl.REPEAT]: 'repeat',\n [gl.CLAMP_TO_EDGE]: 'clamp-to-edge',\n [gl.MIRRORED_REPEAT]: 'mirror-repeat',\n};\n\nexport function getCullMode({\n cull,\n}: Pick<IModelInitializationOptions, 'cull'>):\n | 'none'\n | 'front'\n | 'back'\n | undefined {\n if (!cull || !cull.enable) {\n return WebGPUConstants.CullMode.None;\n }\n\n if (cull.face) {\n return cull.face === gl.FRONT\n ? WebGPUConstants.CullMode.Front\n : WebGPUConstants.CullMode.Back;\n }\n}\n\nexport function getDepthStencilStateDescriptor({\n depth,\n stencil,\n}: Pick<IModelInitializationOptions, 'depth' | 'stencil'>):\n | GPUDepthStencilStateDescriptor\n | undefined {\n // TODO: stencil\n\n const stencilFrontBack: GPUStencilStateFaceDescriptor = {\n compare: WebGPUConstants.CompareFunction.Always,\n depthFailOp: WebGPUConstants.StencilOperation.Keep,\n failOp: WebGPUConstants.StencilOperation.Keep,\n passOp: WebGPUConstants.StencilOperation.Keep,\n };\n\n return {\n depthWriteEnabled: depth && depth.enable,\n depthCompare: depthFuncMap[depth?.func || gl.ALWAYS],\n format: WebGPUConstants.TextureFormat.Depth24PlusStencil8,\n stencilFront: stencilFrontBack,\n stencilBack: stencilFrontBack,\n stencilReadMask: 0xffffffff,\n stencilWriteMask: 0xffffffff,\n };\n}\n\n/**\n * @see https://gpuweb.github.io/gpuweb/#color-state\n */\nexport function getColorStateDescriptors(\n { blend }: Pick<IModelInitializationOptions, 'blend'>,\n swapChainFormat: GPUTextureFormat,\n): GPUColorStateDescriptor[] {\n return [\n {\n format: swapChainFormat,\n // https://gpuweb.github.io/gpuweb/#blend-state\n alphaBlend: {\n srcFactor:\n blendFuncMap[(blend && blend.func && blend.func.srcAlpha) || gl.ONE],\n dstFactor:\n blendFuncMap[(blend && blend.func && blend.func.dstAlpha) || gl.ZERO],\n operation:\n blendEquationMap[\n (blend && blend.equation && blend.equation.alpha) || gl.FUNC_ADD\n ],\n },\n colorBlend: {\n srcFactor:\n blendFuncMap[(blend && blend.func && blend.func.srcRGB) || gl.ONE],\n dstFactor:\n blendFuncMap[(blend && blend.func && blend.func.dstRGB) || gl.ZERO],\n operation:\n blendEquationMap[\n (blend && blend.equation && blend.equation.rgb) || gl.FUNC_ADD\n ],\n },\n writeMask: WebGPUConstants.ColorWrite.All,\n },\n ];\n}\n","import {\n gl,\n IModel,\n IModelDrawOptions,\n IModelInitializationOptions,\n isSafari,\n IUniform,\n} from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { WebGPUEngine } from '.';\nimport { extractUniforms } from '../utils/uniform';\nimport {\n getColorStateDescriptors,\n getCullMode,\n getDepthStencilStateDescriptor,\n primitiveMap,\n} from './constants';\nimport WebGPUAttribute from './WebGPUAttribute';\nimport WebGPUBuffer from './WebGPUBuffer';\nimport WebGPUElements from './WebGPUElements';\nimport WebGPUFramebuffer from './WebGPUFramebuffer';\nimport WebGPUTexture2D from './WebGPUTexture2D';\n\n// @ts-ignore\nfunction concatenate(resultConstructor, ...arrays) {\n let totalLength = 0;\n for (const arr of arrays) {\n totalLength += arr.length;\n }\n const result = new resultConstructor(totalLength);\n let offset = 0;\n for (const arr of arrays) {\n result.set(arr, offset);\n offset += arr.length;\n }\n return result;\n}\n\nexport default class WebGPUModel implements IModel {\n private pipelineLayout: GPUPipelineLayout;\n private renderPipeline: GPURenderPipeline;\n private uniformsBindGroupLayout: GPUBindGroupLayout;\n private uniformBindGroup: GPUBindGroup;\n private uniformBuffer: WebGPUBuffer;\n\n private uniforms: {\n [key: string]: IUniform;\n } = {};\n\n /**\n * 用于后续渲染时动态更新\n */\n private uniformGPUBufferLayout: Array<{\n name: string;\n offset: number;\n }> = [];\n\n /**\n * vertex\n */\n private attributeCache: {\n [attributeName: string]: WebGPUAttribute;\n } = {};\n\n /**\n * indices's buffer\n */\n private indexBuffer: WebGPUBuffer;\n private indexCount: number;\n\n constructor(\n private engine: WebGPUEngine,\n private options: IModelInitializationOptions,\n ) {}\n\n public async init() {\n const {\n vs,\n fs,\n attributes,\n uniforms,\n primitive,\n count,\n elements,\n depth,\n blend,\n stencil,\n cull,\n instances,\n } = this.options;\n\n // build shaders first\n const {\n vertexStage,\n fragmentStage,\n } = await this.compilePipelineStageDescriptor(vs, fs, null);\n\n if (uniforms) {\n // create uniform bind groups & layout\n this.buildUniformBindGroup(uniforms);\n }\n\n if (elements) {\n this.indexBuffer = (elements as WebGPUElements).get() as WebGPUBuffer;\n this.indexCount = (elements as WebGPUElements).indexCount;\n }\n\n // TODO: instanced array\n\n const vertexState = {\n vertexBuffers: Object.keys(attributes).map((attributeName, i) => {\n const attribute = attributes[attributeName] as WebGPUAttribute;\n const { arrayStride, stepMode, attributes: ats } = attribute.get();\n this.attributeCache[attributeName] = attribute;\n return {\n arrayStride,\n stepMode,\n attributes: ats,\n };\n }),\n };\n\n const descriptor = {\n sampleCount: this.engine.mainPassSampleCount,\n primitiveTopology: primitiveMap[primitive || gl.TRIANGLES],\n rasterizationState: {\n ...this.getDefaultRasterizationStateDescriptor(),\n // TODO: support frontface\n cullMode: getCullMode({ cull }),\n },\n depthStencilState: getDepthStencilStateDescriptor({\n depth,\n stencil,\n }),\n colorStates: getColorStateDescriptors(\n { blend },\n this.engine.options.swapChainFormat!,\n ),\n layout: this.pipelineLayout,\n vertexStage,\n fragmentStage,\n vertexState,\n };\n\n // create pipeline\n this.renderPipeline = this.engine.device.createRenderPipeline(descriptor);\n }\n\n public addUniforms(uniforms: { [key: string]: IUniform }): void {\n this.uniforms = {\n ...this.uniforms,\n ...extractUniforms(uniforms),\n };\n }\n\n public draw(options: IModelDrawOptions): void {\n const renderPass = this.engine.getCurrentRenderPass();\n\n const uniforms: {\n [key: string]: IUniform;\n } = {\n ...this.uniforms,\n ...extractUniforms(options.uniforms || {}),\n };\n\n const bindGroupBindings: GPUBindGroupEntry[] = [];\n\n // TODO: uniform 发生修改\n Object.keys(uniforms).forEach((uniformName: string) => {\n const type = typeof uniforms[uniformName];\n if (\n type === 'boolean' ||\n type === 'number' ||\n Array.isArray(uniforms[uniformName]) ||\n // @ts-ignore\n uniforms[uniformName].BYTES_PER_ELEMENT\n ) {\n const offset = this.uniformGPUBufferLayout.find(\n ({ name }) => name === uniformName,\n )?.offset;\n if (offset !== null) {\n this.uniformBuffer.subData({\n // @ts-ignore\n data: uniforms[uniformName],\n // @ts-ignore\n offset,\n });\n }\n } else {\n let offset = this.uniformGPUBufferLayout.find(\n ({ name }) => name === uniformName,\n )?.offset;\n if (offset !== null) {\n const textureOrFramebuffer = (uniforms[uniformName] as\n | WebGPUTexture2D\n | WebGPUFramebuffer).get();\n const { texture, sampler } =\n // @ts-ignore\n textureOrFramebuffer.color || textureOrFramebuffer;\n if (sampler) {\n bindGroupBindings.push({\n // @ts-ignore\n binding: offset,\n resource: sampler,\n });\n // @ts-ignore\n offset++;\n }\n bindGroupBindings.push({\n // @ts-ignore\n binding: offset,\n resource: texture.createView(),\n });\n }\n }\n });\n\n if (this.uniformBuffer) {\n bindGroupBindings[0] = {\n binding: 0,\n resource: {\n buffer: this.uniformBuffer.get(), // 返回 GPUBuffer 原生对象\n },\n };\n }\n\n this.uniformBindGroup = this.engine.device.createBindGroup({\n layout: this.uniformsBindGroupLayout,\n entries: bindGroupBindings,\n });\n\n if (this.renderPipeline) {\n renderPass.setPipeline(this.renderPipeline);\n }\n\n renderPass.setBindGroup(0, this.uniformBindGroup);\n\n if (this.indexBuffer) {\n renderPass.setIndexBuffer(\n this.indexBuffer.get(),\n WebGPUConstants.IndexFormat.Uint32,\n 0,\n );\n }\n\n Object.keys(this.attributeCache).forEach((attributeName: string, i) => {\n renderPass.setVertexBuffer(\n 0 + i,\n this.attributeCache[attributeName].get().buffer,\n 0,\n );\n });\n\n // renderPass.draw(verticesCount, instancesCount, verticesStart, 0);\n if (this.indexBuffer) {\n renderPass.drawIndexed(\n this.indexCount,\n this.options.instances || 1,\n 0,\n 0,\n 0,\n );\n } else {\n renderPass.draw(\n this.options.count || 0,\n this.options.instances || 0,\n 0,\n 0,\n );\n }\n }\n\n public destroy(): void {\n throw new Error('Method not implemented.');\n }\n\n private async compilePipelineStageDescriptor(\n vertexCode: string,\n fragmentCode: string,\n defines: string | null,\n ): Promise<\n Pick<GPURenderPipelineDescriptor, 'vertexStage' | 'fragmentStage'>\n > {\n const shaderVersion = '#version 450\\n';\n\n let vertexShader: Uint32Array | string = vertexCode;\n let fragmentShader: Uint32Array | string = fragmentCode;\n if (!this.engine.options.useWGSL) {\n vertexShader = await this.compileShaderToSpirV(\n vertexCode,\n 'vertex',\n shaderVersion,\n );\n fragmentShader = await this.compileShaderToSpirV(\n fragmentCode,\n 'fragment',\n shaderVersion,\n );\n }\n\n return this.createPipelineStageDescriptor(vertexShader, fragmentShader);\n }\n\n private compileShaderToSpirV(\n source: string,\n type: string,\n shaderVersion: string,\n ): Promise<Uint32Array> {\n return this.compileRawShaderToSpirV(shaderVersion + source, type);\n }\n\n private compileRawShaderToSpirV(\n source: string,\n type: string,\n ): Promise<Uint32Array> {\n return this.engine.glslang.compileGLSL(source, type);\n }\n\n private createPipelineStageDescriptor(\n vertexShader: Uint32Array | string,\n fragmentShader: Uint32Array | string,\n ): Pick<GPURenderPipelineDescriptor, 'vertexStage' | 'fragmentStage'> {\n return {\n vertexStage: {\n module: this.engine.device.createShaderModule({\n code: vertexShader,\n // @ts-ignore\n isWHLSL: isSafari,\n }),\n entryPoint: 'main',\n },\n fragmentStage: {\n module: this.engine.device.createShaderModule({\n code: fragmentShader,\n // @ts-ignore\n isWHLSL: isSafari,\n }),\n entryPoint: 'main',\n },\n };\n }\n\n /**\n * @see https://gpuweb.github.io/gpuweb/#rasterization-state\n */\n private getDefaultRasterizationStateDescriptor(): GPURasterizationStateDescriptor {\n return {\n frontFace: WebGPUConstants.FrontFace.CCW,\n cullMode: WebGPUConstants.CullMode.None,\n depthBias: 0,\n depthBiasSlopeScale: 0,\n depthBiasClamp: 0,\n };\n }\n\n private buildUniformBindGroup(uniforms: { [key: string]: IUniform }) {\n let offset = 0;\n // FIXME: 所有 uniform 合并成一个 buffer,固定使用 Float32Array 存储,确实会造成一些内存的浪费\n const mergedUniformData = concatenate(\n Float32Array,\n ...Object.keys(uniforms).map((uniformName) => {\n if (uniforms[uniformName]) {\n this.uniformGPUBufferLayout.push({\n name: uniformName,\n offset,\n });\n // @ts-ignore\n offset += (uniforms[uniformName].length || 1) * 4;\n return uniforms[uniformName];\n } else {\n // texture & framebuffer\n return [];\n }\n }),\n );\n\n const entries: GPUBindGroupLayoutEntry[] = [];\n let hasUniform = false;\n if (mergedUniformData.length) {\n hasUniform = true;\n // TODO: 所有 uniform 绑定到 slot 0,通过解析 Shader 代码判定可见性\n entries.push({\n // TODO: 暂时都绑定到 slot 0\n binding: 0,\n visibility:\n WebGPUConstants.ShaderStage.Fragment |\n WebGPUConstants.ShaderStage.Vertex, // TODO: 暂时 VS 和 FS 都可见\n type: WebGPUConstants.BindingType.UniformBuffer,\n });\n }\n\n // 声明 texture & sampler\n Object.keys(uniforms)\n .filter((uniformName) => uniforms[uniformName] === null)\n .forEach((uniformName, i) => {\n this.uniformGPUBufferLayout.push({\n name: uniformName,\n offset: i * 2 + (hasUniform ? 1 : 0),\n });\n entries.push(\n {\n // Sampler\n binding: i * 2 + (hasUniform ? 1 : 0),\n visibility: WebGPUConstants.ShaderStage.Fragment,\n type: WebGPUConstants.BindingType.Sampler,\n },\n {\n // Texture view\n binding: i * 2 + (hasUniform ? 1 : 0) + 1,\n visibility: WebGPUConstants.ShaderStage.Fragment,\n type: WebGPUConstants.BindingType.SampledTexture,\n },\n );\n });\n\n this.uniformsBindGroupLayout = this.engine.device.createBindGroupLayout({\n // 最新 API 0.0.22 版本使用 entries。Chrome Canary 84.0.4110.0 已实现。\n // 使用 bindings 会报 Warning: GPUBindGroupLayoutDescriptor.bindings is deprecated: renamed to entries\n // @see https://github.com/antvis/GWebGPUEngine/issues/5\n entries,\n });\n\n this.pipelineLayout = this.engine.device.createPipelineLayout({\n bindGroupLayouts: [this.uniformsBindGroupLayout],\n });\n\n if (hasUniform) {\n this.uniformBuffer = new WebGPUBuffer(this.engine, {\n // TODO: 处理 Struct 和 boolean\n // @ts-ignore\n data:\n mergedUniformData instanceof Array\n ? // @ts-ignore\n new Float32Array(mergedUniformData)\n : mergedUniformData,\n usage:\n WebGPUConstants.BufferUsage.Uniform |\n WebGPUConstants.BufferUsage.CopyDst,\n });\n }\n }\n}\n","import {\n gl,\n ITexture2D,\n ITexture2DInitializationOptions,\n} from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { WebGPUEngine } from '.';\nimport { filterMap, formatMap, wrapModeMap } from './constants';\n\n/**\n * adaptor for regl.Buffer\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#buffers\n */\nexport default class WebGPUTexture2D implements ITexture2D {\n private texture: GPUTexture;\n private sampler: GPUSampler;\n private width: number;\n private height: number;\n\n constructor(\n private engine: WebGPUEngine,\n private options: ITexture2DInitializationOptions,\n ) {\n this.createTexture();\n }\n\n public get() {\n return {\n texture: this.texture,\n sampler: this.sampler,\n };\n }\n public update() {\n // TODO\n }\n\n public resize({ width, height }: { width: number; height: number }): void {\n // TODO: it seems that Texture doesn't support `resize`\n if (width !== this.width || height !== this.height) {\n this.destroy();\n this.createTexture();\n }\n this.width = width;\n this.height = height;\n }\n\n public destroy() {\n if (this.texture) {\n this.texture.destroy();\n }\n }\n\n private createTexture() {\n const {\n data,\n type = gl.UNSIGNED_BYTE,\n width,\n height,\n flipY = false,\n format = gl.RGBA,\n mipmap = false,\n wrapS = gl.CLAMP_TO_EDGE,\n wrapT = gl.CLAMP_TO_EDGE,\n aniso = 0,\n alignment = 1,\n premultiplyAlpha = false,\n mag = gl.NEAREST,\n min = gl.NEAREST,\n colorSpace = gl.BROWSER_DEFAULT_WEBGL,\n usage,\n } = this.options;\n this.width = width;\n this.height = height;\n\n this.texture = this.engine.device.createTexture({\n size: [width, height, 1],\n // TODO: arrayLayerCount is deprecated: use size.depth\n // arrayLayerCount: 1,\n mipLevelCount: 1, // TODO: https://gpuweb.github.io/gpuweb/#dom-gputextureviewdescriptor-miplevelcount\n sampleCount: 1,\n dimension: WebGPUConstants.TextureDimension.E2d,\n format: formatMap[format],\n // could throw texture binding usage mismatch\n usage:\n usage ||\n WebGPUConstants.TextureUsage.Sampled |\n WebGPUConstants.TextureUsage.CopyDst,\n });\n\n if (!usage || usage & WebGPUConstants.TextureUsage.Sampled) {\n this.sampler = this.engine.device.createSampler({\n addressModeU: wrapModeMap[wrapS],\n addressModeV: wrapModeMap[wrapT],\n addressModeW: wrapModeMap[wrapS], // TODO: same as addressModeU\n magFilter: filterMap[mag],\n minFilter: filterMap[min],\n maxAnisotropy: aniso, // @see https://gpuweb.github.io/gpuweb/#dom-gpusamplerdescriptor-maxanisotropy\n });\n }\n }\n}\n","/**\n * implements renderService with WebGPU API\n * @see https://webgpu.io/\n * @see https://github.com/BabylonJS/Babylon.js/blob/WebGPU/src/Engines/webgpuEngine.ts\n */\nimport {\n GLSLContext,\n IAttribute,\n IAttributeInitializationOptions,\n IBuffer,\n IBufferInitializationOptions,\n IClearOptions,\n IElements,\n IElementsInitializationOptions,\n IFramebuffer,\n IFramebufferInitializationOptions,\n IModel,\n IModelInitializationOptions,\n IReadPixelsOptions,\n IRendererConfig,\n IRendererService,\n isSafari,\n ITexture2D,\n ITexture2DInitializationOptions,\n IViewport,\n} from '@antv/g-webgpu-core';\n// import { Glslang } from '@webgpu/glslang/dist/web-devel/glslang.onefile';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { vec4 } from 'gl-matrix';\nimport { injectable } from 'inversify';\nimport glslang from './glslang';\nimport WebGPUAttribute from './WebGPUAttribute';\nimport WebGPUBuffer from './WebGPUBuffer';\nimport WebGPUComputeModel from './WebGPUComputeModel';\nimport WebGPUElements from './WebGPUElements';\nimport WebGPUFramebuffer from './WebGPUFramebuffer';\nimport WebGPUModel from './WebGPUModel';\nimport WebGPUTexture2D from './WebGPUTexture2D';\n\ntype Omit<T, K extends keyof T> = Pick<T, Exclude<keyof T, K>>;\ntype WithOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n\n/**\n * regl renderer\n */\n@injectable()\nexport class WebGPUEngine implements IRendererService {\n public supportWebGPU = true;\n public useWGSL = false;\n\n public options: IRendererConfig;\n public canvas: HTMLCanvasElement;\n public context: GPUCanvasContext;\n public glslang: any;\n public adapter: GPUAdapter;\n public device: GPUDevice;\n public swapChain: GPUSwapChain;\n\n public mainPassSampleCount: number;\n\n public mainTexture: GPUTexture;\n public depthTexture: GPUTexture;\n public mainColorAttachments: GPURenderPassColorAttachmentDescriptor[];\n public mainTextureExtends: GPUExtent3D;\n public mainDepthAttachment: GPURenderPassDepthStencilAttachmentDescriptor;\n\n // Frame Life Cycle (recreated each frame)\n public uploadEncoder: GPUCommandEncoder;\n public renderEncoder: GPUCommandEncoder;\n public computeEncoder: GPUCommandEncoder;\n public renderTargetEncoder: GPUCommandEncoder;\n public commandBuffers: GPUCommandBuffer[] = new Array(4).fill(undefined);\n\n // Frame Buffer Life Cycle (recreated for each render target pass)\n public currentRenderPass: GPURenderPassEncoder | null = null;\n public mainRenderPass: GPURenderPassEncoder | null = null;\n public currentRenderTargetViewDescriptor: GPUTextureViewDescriptor;\n public currentComputePass: GPUComputePassEncoder | null = null;\n public bundleEncoder: GPURenderBundleEncoder | null;\n public tempBuffers: GPUBuffer[] = [];\n public currentRenderTarget: WebGPUFramebuffer | null = null;\n\n public readonly uploadEncoderDescriptor = { label: 'upload' };\n public readonly renderEncoderDescriptor = { label: 'render' };\n public readonly renderTargetEncoderDescriptor = { label: 'renderTarget' };\n public readonly computeEncoderDescriptor = { label: 'compute' };\n\n /**\n * 通过名称访问\n */\n private pipelines: {\n [pipelineName: string]: GPURenderPipeline;\n } = {};\n private computePipelines: {\n [pipelineName: string]: GPUComputePipeline;\n } = {};\n\n private readonly defaultSampleCount = 4;\n private readonly clearDepthValue = 1;\n private readonly clearStencilValue = 0;\n private transientViewport: IViewport = {\n x: Infinity,\n y: 0,\n width: 0,\n height: 0,\n };\n private cachedViewport: IViewport = {\n x: 0,\n y: 0,\n width: 0,\n height: 0,\n };\n\n public isFloatSupported() {\n return true;\n }\n\n public async init(config: IRendererConfig): Promise<void> {\n this.canvas = config.canvas!;\n this.options = config;\n this.useWGSL = !!config.useWGSL;\n this.mainPassSampleCount = config.antialiasing\n ? this.defaultSampleCount\n : 1;\n\n await this.initGlslang();\n this.initContextAndSwapChain();\n this.initMainAttachments();\n }\n\n public setScissor(\n scissor: Partial<{\n enable: boolean;\n box: { x: number; y: number; width: number; height: number };\n }>,\n ): void {\n throw new Error('Method not implemented.');\n }\n\n public clear = (options: IClearOptions): void => {\n const { framebuffer, color, depth, stencil } = options;\n\n if (this.options.supportCompute) {\n this.startComputePass();\n }\n\n // We need to recreate the render pass so that the new parameters for clear color / depth / stencil are taken into account\n if (this.currentRenderTarget) {\n if (this.currentRenderPass) {\n this.endRenderTargetRenderPass();\n }\n this.startRenderTargetRenderPass(\n this.currentRenderTarget!,\n color ? color : null,\n !!depth,\n !!stencil,\n );\n } else {\n // if (this.useReverseDepthBuffer) {\n // this._depthCullingState.depthFunc = Constants.GREATER;\n // }\n\n this.mainColorAttachments[0].loadValue = color\n ? color\n : WebGPUConstants.LoadOp.Load;\n\n this.mainDepthAttachment.depthLoadValue = depth\n ? depth\n : WebGPUConstants.LoadOp.Load;\n this.mainDepthAttachment.stencilLoadValue = stencil\n ? this.clearStencilValue\n : WebGPUConstants.LoadOp.Load;\n\n if (this.mainRenderPass) {\n this.endMainRenderPass();\n }\n\n this.startMainRenderPass();\n }\n };\n\n public createModel = async (\n options: IModelInitializationOptions,\n ): Promise<IModel> => {\n const model = new WebGPUModel(this, options);\n await model.init();\n return model;\n };\n\n public createAttribute = (\n options: IAttributeInitializationOptions,\n ): IAttribute => {\n return new WebGPUAttribute(this, options);\n };\n\n public createBuffer = (options: IBufferInitializationOptions): IBuffer => {\n return new WebGPUBuffer(this, options);\n };\n\n public createElements = (\n options: IElementsInitializationOptions,\n ): IElements => {\n return new WebGPUElements(this, options);\n };\n\n public createTexture2D = (\n options: ITexture2DInitializationOptions,\n ): ITexture2D => {\n return new WebGPUTexture2D(this, options);\n };\n\n public createFramebuffer = (\n options: IFramebufferInitializationOptions,\n ): IFramebuffer => {\n return new WebGPUFramebuffer(this, options);\n };\n\n public useFramebuffer = (\n framebuffer: IFramebuffer | null,\n drawCommands: () => void,\n ): void => {\n // bind\n if (this.currentRenderTarget) {\n this.unbindFramebuffer(this.currentRenderTarget);\n }\n this.currentRenderTarget = framebuffer as WebGPUFramebuffer;\n\n // TODO: use mipmap options in framebuffer\n this.currentRenderTargetViewDescriptor = {\n dimension: WebGPUConstants.TextureViewDimension.E2d,\n // mipLevelCount: bindWithMipMaps ? WebGPUTextureHelper.computeNumMipmapLevels(texture.width, texture.height) - lodLevel : 1,\n // baseArrayLayer: faceIndex,\n // baseMipLevel: lodLevel,\n arrayLayerCount: 1,\n aspect: WebGPUConstants.TextureAspect.All,\n };\n\n this.currentRenderPass = null;\n\n drawCommands();\n };\n\n public createComputeModel = async (context: GLSLContext) => {\n const model = new WebGPUComputeModel(this, context);\n await model.init();\n return model;\n };\n\n public getCanvas = (): HTMLCanvasElement => {\n return this.canvas;\n };\n\n public getGLContext = (): WebGLRenderingContext => {\n throw new Error('Method not implemented.');\n };\n\n public viewport = ({\n x,\n y,\n width,\n height,\n }: {\n x: number;\n y: number;\n width: number;\n height: number;\n }): void => {\n if (!this.currentRenderPass) {\n // call viewport() before current render pass created\n this.transientViewport = { x, y, width, height };\n } else if (this.transientViewport.x !== Infinity) {\n const renderPass = this.getCurrentRenderPass();\n // @see https://gpuweb.github.io/gpuweb/#dom-gpurenderpassencoder-setviewport\n renderPass.setViewport(\n this.transientViewport.x,\n this.transientViewport.y,\n this.transientViewport.width,\n this.transientViewport.height,\n 0,\n 1,\n );\n } else if (\n x !== this.cachedViewport.x ||\n y !== this.cachedViewport.y ||\n width !== this.cachedViewport.width ||\n height !== this.cachedViewport.height\n ) {\n this.cachedViewport = { x, y, width, height };\n const renderPass = this.getCurrentRenderPass();\n renderPass.setViewport(x, y, width, height, 0, 1);\n }\n };\n\n public readPixels = (options: IReadPixelsOptions): Uint8Array => {\n throw new Error('Method not implemented.');\n };\n\n public destroy(): void {\n if (this.mainTexture) {\n this.mainTexture.destroy();\n }\n if (this.depthTexture) {\n this.depthTexture.destroy();\n }\n this.tempBuffers.forEach((buffer) => buffer.destroy());\n this.tempBuffers = [];\n }\n\n public beginFrame() {\n this.uploadEncoder = this.device.createCommandEncoder(\n this.uploadEncoderDescriptor,\n );\n this.renderEncoder = this.device.createCommandEncoder(\n this.renderEncoderDescriptor,\n );\n this.renderTargetEncoder = this.device.createCommandEncoder(\n this.renderTargetEncoderDescriptor,\n );\n if (this.options.supportCompute) {\n this.computeEncoder = this.device.createCommandEncoder(\n this.computeEncoderDescriptor,\n );\n }\n }\n\n public endFrame() {\n if (this.options.supportCompute) {\n this.endComputePass();\n }\n\n this.endMainRenderPass();\n\n this.commandBuffers[0] = this.uploadEncoder.finish();\n this.commandBuffers[1] = this.renderEncoder.finish();\n if (this.options.supportCompute) {\n this.commandBuffers[2] = this.computeEncoder.finish();\n }\n this.commandBuffers[3] = this.renderTargetEncoder.finish();\n\n if (isSafari) {\n this.device\n // @ts-ignore\n .getQueue()\n .submit(this.commandBuffers.filter((buffer) => buffer));\n } else {\n this.device.defaultQueue.submit(\n this.commandBuffers.filter((buffer) => buffer),\n );\n }\n }\n\n public getCurrentRenderPass(): GPURenderPassEncoder {\n if (this.currentRenderTarget && !this.currentRenderPass) {\n this.startRenderTargetRenderPass(\n this.currentRenderTarget,\n null,\n false,\n false,\n );\n } else if (!this.currentRenderPass) {\n this.startMainRenderPass();\n }\n\n return this.currentRenderPass!;\n }\n\n private async initGlslang() {\n this.glslang = await glslang();\n this.adapter = (await navigator?.gpu?.requestAdapter()) as GPUAdapter;\n this.device = (await this.adapter.requestDevice()) as GPUDevice;\n }\n\n private initContextAndSwapChain() {\n this.context = (this.canvas.getContext(\n isSafari ? 'gpu' : 'gpupresent',\n ) as unknown) as GPUCanvasContext;\n this.swapChain = this.context.configureSwapChain({\n device: this.device,\n format: this.options.swapChainFormat!,\n usage:\n WebGPUConstants.TextureUsage.OutputAttachment |\n WebGPUConstants.TextureUsage.CopySrc,\n });\n }\n\n private initMainAttachments() {\n this.mainTextureExtends = {\n width: this.canvas.width,\n height: this.canvas.height,\n depth: 1,\n };\n\n if (this.options.antialiasing) {\n const mainTextureDescriptor = {\n size: this.mainTextureExtends,\n // TODO: arrayLayerCount is deprecated: use size.depth\n // arrayLayerCount: 1,\n mipLevelCount: 1,\n sampleCount: this.mainPassSampleCount,\n dimension: WebGPUConstants.TextureDimension.E2d,\n format: WebGPUConstants.TextureFormat.BGRA8Unorm,\n usage: WebGPUConstants.TextureUsage.OutputAttachment,\n };\n\n if (this.mainTexture) {\n this.mainTexture.destroy();\n }\n this.mainTexture = this.device.createTexture(mainTextureDescriptor);\n this.mainColorAttachments = [\n {\n attachment: isSafari\n ? // @ts-ignore\n this.mainTexture.createDefaultView()\n : this.mainTexture.createView(),\n loadValue: [0, 0, 0, 1],\n storeOp: WebGPUConstants.StoreOp.Store,\n },\n ];\n } else {\n this.mainColorAttachments = [\n {\n attachment: isSafari\n ? // @ts-ignore\n this.swapChain.getCurrentTexture().createDefaultView()\n : this.swapChain.getCurrentTexture().createView(),\n loadValue: [0, 0, 0, 1],\n storeOp: WebGPUConstants.StoreOp.Store,\n },\n ];\n }\n\n const depthTextureDescriptor = {\n size: this.mainTextureExtends,\n // arrayLayerCount: 1,\n mipLevelCount: 1,\n sampleCount: this.mainPassSampleCount,\n dimension: WebGPUConstants.TextureDimension.E2d,\n format: isSafari\n ? 'depth32float-stencil8'\n : WebGPUConstants.TextureFormat.Depth24PlusStencil8,\n usage: WebGPUConstants.TextureUsage.OutputAttachment,\n };\n\n if (this.depthTexture) {\n this.depthTexture.destroy();\n }\n\n this.depthTexture = this.device.createTexture(\n // @ts-ignore\n depthTextureDescriptor,\n );\n this.mainDepthAttachment = {\n attachment: isSafari\n ? // @ts-ignore\n this.depthTexture.createDefaultView()\n : this.depthTexture.createView(),\n depthLoadValue: this.clearDepthValue,\n depthStoreOp: WebGPUConstants.StoreOp.Store,\n stencilLoadValue: this.clearStencilValue,\n stencilStoreOp: WebGPUConstants.StoreOp.Store,\n };\n }\n\n private startComputePass() {\n if (this.currentComputePass) {\n this.endComputePass();\n }\n\n this.currentComputePass = this.computeEncoder.beginComputePass();\n }\n\n private startMainRenderPass() {\n if (this.currentRenderPass && !this.currentRenderTarget) {\n this.endMainRenderPass();\n }\n\n // Resolve in case of MSAA\n if (this.options.antialiasing) {\n this.mainColorAttachments[0].resolveTarget = isSafari\n ? // @ts-ignore\n this.swapChain.getCurrentTexture().createDefaultView()\n : this.swapChain.getCurrentTexture().createView();\n } else {\n this.mainColorAttachments[0].attachment = isSafari\n ? // @ts-ignore\n this.swapChain.getCurrentTexture().createDefaultView()\n : this.swapChain.getCurrentTexture().createView();\n }\n\n this.currentRenderPass = this.renderEncoder.beginRenderPass({\n colorAttachments: this.mainColorAttachments,\n depthStencilAttachment: this.mainDepthAttachment, // TODO: use framebuffer's depth & stencil\n });\n\n this.mainRenderPass = this.currentRenderPass;\n\n if (this.cachedViewport) {\n this.viewport(this.cachedViewport);\n }\n }\n\n private startRenderTargetRenderPass(\n renderTarget: WebGPUFramebuffer,\n clearColor: [number, number, number, number] | null,\n clearDepth: boolean,\n clearStencil: boolean = false,\n ) {\n const gpuTexture = renderTarget.get().color?.texture;\n let colorTextureView: GPUTextureView;\n if (gpuTexture) {\n colorTextureView = gpuTexture.createView(\n this.currentRenderTargetViewDescriptor,\n );\n }\n\n const depthStencilTexture = renderTarget.get().depth?.texture;\n let depthStencilTextureView;\n if (depthStencilTexture) {\n depthStencilTextureView = depthStencilTexture.createView();\n }\n\n const renderPass = this.renderTargetEncoder.beginRenderPass({\n colorAttachments: [\n {\n attachment: colorTextureView!,\n loadValue:\n clearColor !== null ? clearColor : WebGPUConstants.LoadOp.Load,\n storeOp: WebGPUConstants.StoreOp.Store,\n },\n ],\n depthStencilAttachment:\n depthStencilTexture && depthStencilTextureView\n ? {\n attachment: depthStencilTextureView,\n depthLoadValue: clearDepth\n ? this.clearDepthValue\n : WebGPUConstants.LoadOp.Load,\n depthStoreOp: WebGPUConstants.StoreOp.Store,\n stencilLoadValue: clearStencil\n ? this.clearStencilValue\n : WebGPUConstants.LoadOp.Load,\n stencilStoreOp: WebGPUConstants.StoreOp.Store,\n }\n : undefined,\n });\n\n this.currentRenderPass = renderPass;\n\n if (this.cachedViewport) {\n this.viewport(this.cachedViewport);\n }\n\n // TODO WEBGPU set the scissor rect and the stencil reference value\n }\n\n private endMainRenderPass() {\n if (\n this.currentRenderPass === this.mainRenderPass &&\n this.currentRenderPass !== null\n ) {\n this.currentRenderPass.endPass();\n this.resetCachedViewport();\n this.currentRenderPass = null;\n this.mainRenderPass = null;\n }\n }\n\n private endComputePass() {\n if (this.currentComputePass) {\n this.currentComputePass.endPass();\n this.currentComputePass = null;\n }\n }\n\n private endRenderTargetRenderPass() {\n if (this.currentRenderPass) {\n this.currentRenderPass.endPass();\n this.resetCachedViewport();\n }\n }\n\n private resetCachedViewport() {\n this.cachedViewport = {\n x: 0,\n y: 0,\n width: 0,\n height: 0,\n };\n }\n\n private unbindFramebuffer(framebuffer: WebGPUFramebuffer) {\n // unbind\n if (\n this.currentRenderPass &&\n this.currentRenderPass !== this.mainRenderPass\n ) {\n this.endRenderTargetRenderPass();\n }\n\n this.transientViewport.x = Infinity;\n this.currentRenderTarget = null;\n\n // if (texture.generateMipMaps && !disableGenerateMipMaps && !texture.isCube) {\n // this._generateMipmaps(texture);\n // }\n\n this.currentRenderPass = this.mainRenderPass;\n }\n}\n","import { generateAABBFromVertices } from '@antv/g-webgpu-core';\nimport { vec3 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { Geometry } from '.';\n\nexport interface IBoxGeometryParams {\n halfExtents: vec3;\n widthSegments: number;\n heightSegments: number;\n depthSegments: number;\n}\n\nconst primitiveUv1Padding = 4.0 / 64;\nconst primitiveUv1PaddingScale = 1.0 - primitiveUv1Padding * 2;\n\n@injectable()\n/**\n * borrow from playcanvas:\n * Creates a procedural box-shaped mesh\n */\nexport class Box extends Geometry<Partial<IBoxGeometryParams>> {\n protected onEntityCreated() {\n const {\n widthSegments = 1,\n heightSegments = 1,\n depthSegments = 1,\n halfExtents = vec3.fromValues(0.5, 0.5, 0.5),\n } = this.config;\n const ws = widthSegments;\n const hs = heightSegments;\n const ds = depthSegments;\n const [hex, hey, hez] = halfExtents;\n\n const corners = [\n vec3.fromValues(-hex, -hey, hez),\n vec3.fromValues(hex, -hey, hez),\n vec3.fromValues(hex, hey, hez),\n vec3.fromValues(-hex, hey, hez),\n vec3.fromValues(hex, -hey, -hez),\n vec3.fromValues(-hex, -hey, -hez),\n vec3.fromValues(-hex, hey, -hez),\n vec3.fromValues(hex, hey, -hez),\n ];\n\n const faceAxes = [\n [0, 1, 3], // FRONT\n [4, 5, 7], // BACK\n [3, 2, 6], // TOP\n [1, 0, 4], // BOTTOM\n [1, 4, 2], // RIGHT\n [5, 0, 6], // LEFT\n ];\n\n const faceNormals = [\n [0, 0, 1], // FRONT\n [0, 0, -1], // BACK\n [0, 1, 0], // TOP\n [0, -1, 0], // BOTTOM\n [1, 0, 0], // RIGHT\n [-1, 0, 0], // LEFT\n ];\n\n const sides = {\n FRONT: 0,\n BACK: 1,\n TOP: 2,\n BOTTOM: 3,\n RIGHT: 4,\n LEFT: 5,\n };\n\n const positions: number[] = [];\n const normals: number[] = [];\n const uvs: number[] = [];\n const uvs1: number[] = [];\n const indices: number[] = [];\n let vcounter = 0;\n\n const generateFace = (\n side: number,\n uSegments: number,\n vSegments: number,\n ) => {\n let u;\n let v;\n let i;\n let j;\n\n for (i = 0; i <= uSegments; i++) {\n for (j = 0; j <= vSegments; j++) {\n const temp1 = vec3.create();\n const temp2 = vec3.create();\n const temp3 = vec3.create();\n const r = vec3.create();\n vec3.lerp(\n temp1,\n corners[faceAxes[side][0]],\n corners[faceAxes[side][1]],\n i / uSegments,\n );\n vec3.lerp(\n temp2,\n corners[faceAxes[side][0]],\n corners[faceAxes[side][2]],\n j / vSegments,\n );\n vec3.sub(temp3, temp2, corners[faceAxes[side][0]]);\n vec3.add(r, temp1, temp3);\n u = i / uSegments;\n v = j / vSegments;\n\n positions.push(r[0], r[1], r[2]);\n normals.push(\n faceNormals[side][0],\n faceNormals[side][1],\n faceNormals[side][2],\n );\n uvs.push(u, v);\n // pack as 3x2\n // 1/3 will be empty, but it's either that or stretched pixels\n // TODO: generate non-rectangular lightMaps, so we could use space without stretching\n u /= 3;\n v /= 3;\n u = u * primitiveUv1PaddingScale + primitiveUv1Padding;\n v = v * primitiveUv1PaddingScale + primitiveUv1Padding;\n u += (side % 3) / 3;\n v += Math.floor(side / 3) / 3;\n uvs1.push(u, v);\n\n if (i < uSegments && j < vSegments) {\n indices.push(vcounter + vSegments + 1, vcounter + 1, vcounter);\n indices.push(\n vcounter + vSegments + 1,\n vcounter + vSegments + 2,\n vcounter + 1,\n );\n }\n\n vcounter++;\n }\n }\n };\n\n generateFace(sides.FRONT, ws, hs);\n generateFace(sides.BACK, ws, hs);\n generateFace(sides.TOP, ws, ds);\n generateFace(sides.BOTTOM, ws, ds);\n generateFace(sides.RIGHT, ds, hs);\n generateFace(sides.LEFT, ds, hs);\n\n // generate AABB\n const aabb = generateAABBFromVertices(positions);\n\n const component = this.getComponent();\n component.indices = Uint32Array.from(indices);\n component.aabb = aabb;\n component.vertexCount = vcounter;\n component.attributes = [\n {\n dirty: true,\n name: 'position',\n data: Float32Array.from(positions),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 0,\n offset: 0,\n format: 'float3',\n },\n ],\n },\n {\n dirty: true,\n name: 'normal',\n data: Float32Array.from(normals),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 1,\n offset: 0,\n format: 'float3',\n },\n ],\n },\n {\n dirty: true,\n name: 'uv',\n data: Float32Array.from(uvs),\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 2,\n offset: 0,\n format: 'float2',\n },\n ],\n },\n ];\n\n // TODO: barycentric & tangent\n }\n}\n","import { AABB, GeometryComponent } from '@antv/g-webgpu-core';\nimport { injectable } from 'inversify';\nimport { Geometry } from '.';\nimport { isNumber } from '../utils/is-number';\nimport { isTypedArray } from '../utils/is-typedarray';\nimport { merge } from '../utils/typedarray';\n\nexport interface IMergedGeometryParams {\n geometries: GeometryComponent[];\n}\n\n@injectable()\n/**\n * merge many geometries into one, use a batch of draw calls\n */\nexport class Merged extends Geometry<Partial<IMergedGeometryParams>> {\n protected onEntityCreated() {\n const { geometries = [] } = this.config;\n\n const mergedComponent = this.getComponent();\n mergedComponent.aabb = new AABB();\n\n const mergedAttributes: GeometryComponent['attributes'] = [];\n const mergedIndices: number[] = [];\n let indexOffset = 0;\n geometries.forEach((geometry) => {\n const { aabb, indices, vertexCount, attributes } = geometry;\n\n // merge aabb\n mergedComponent.aabb.add(aabb);\n mergedComponent.vertexCount += vertexCount;\n\n // merge indices\n if (indices) {\n mergedIndices.push(...indices.map((index) => index + indexOffset));\n }\n indexOffset += vertexCount;\n\n // merge attributes\n attributes.forEach((attribute, i) => {\n if (!mergedAttributes[i]) {\n mergedAttributes[i] = attribute;\n mergedAttributes[i].dirty = true;\n } else {\n if (attribute.data) {\n if (isNumber(attribute.data)) {\n // @ts-ignore\n mergedAttributes[i].push(attribute.data);\n } else if (isTypedArray(attribute.data)) {\n // @ts-ignore\n mergedAttributes[i].data = merge(\n // @ts-ignore\n mergedAttributes[i].data,\n attribute.data,\n );\n } else {\n // @ts-ignore\n mergedAttributes[i].data = mergedAttributes[i].data.concat(\n attribute.data,\n );\n }\n }\n }\n });\n });\n\n mergedComponent.attributes = mergedAttributes;\n mergedComponent.indices = Uint32Array.from(mergedIndices);\n mergedComponent.dirty = true;\n }\n}\n","export function merge(a: Float32Array, b: Float32Array) {\n // Checks for truthy values on both arrays\n if (!a && !b) {\n throw new Error('Please specify valid arguments for parameters a and b.');\n }\n\n // Checks for truthy values or empty arrays on each argument\n // to avoid the unnecessary construction of a new array and\n // the type comparison\n if (!b || b.length === 0) {\n return a;\n }\n if (!a || a.length === 0) {\n return b;\n }\n\n // Make sure that both typed arrays are of the same type\n if (Object.prototype.toString.call(a) !== Object.prototype.toString.call(b)) {\n throw new Error(\n 'The types of the two arguments passed for parameters a and b do not match.',\n );\n }\n\n // @ts-ignore\n const c = new a.constructor(a.length + b.length);\n c.set(a);\n c.set(b, a.length);\n\n return c;\n}\n","import { generateAABBFromVertices } from '@antv/g-webgpu-core';\nimport { vec3 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { Geometry } from '.';\n\nexport interface IPlaneGeometryParams {\n halfExtents: vec3;\n widthSegments: number;\n lengthSegments: number;\n}\n\n@injectable()\n/**\n * borrow from playcanvas\n */\nexport class Plane extends Geometry<Partial<IPlaneGeometryParams>> {\n protected onEntityCreated() {\n const {\n halfExtents = [0.5, 0.5],\n widthSegments = 5,\n lengthSegments = 5,\n } = this.config;\n\n const positions: number[] = [];\n const normals: number[] = [];\n const uvs: number[] = [];\n const indices: number[] = [];\n let vcounter = 0;\n\n for (let i = 0; i <= widthSegments; i++) {\n for (let j = 0; j <= lengthSegments; j++) {\n const x = -halfExtents[0] + (2.0 * halfExtents[0] * i) / widthSegments;\n const y = 0.0;\n const z = -(\n -halfExtents[1] +\n (2.0 * halfExtents[1] * j) / lengthSegments\n );\n const u = i / widthSegments;\n const v = j / lengthSegments;\n\n positions.push(x, y, z);\n normals.push(0.0, 1.0, 0.0);\n uvs.push(u, v);\n\n if (i < widthSegments && j < lengthSegments) {\n indices.push(vcounter + lengthSegments + 1, vcounter + 1, vcounter);\n indices.push(\n vcounter + lengthSegments + 1,\n vcounter + lengthSegments + 2,\n vcounter + 1,\n );\n }\n\n vcounter++;\n }\n }\n\n // generate AABB\n const aabb = generateAABBFromVertices(positions);\n\n const component = this.getComponent();\n component.indices = Uint32Array.from(indices);\n component.aabb = aabb;\n component.vertexCount = vcounter;\n component.attributes = [\n {\n dirty: true,\n name: 'position',\n data: Float32Array.from(positions),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 0,\n offset: 0,\n format: 'float3',\n },\n ],\n },\n {\n dirty: true,\n name: 'normal',\n data: Float32Array.from(normals),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 1,\n offset: 0,\n format: 'float3',\n },\n ],\n },\n {\n dirty: true,\n name: 'uv',\n data: Float32Array.from(uvs),\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 2,\n offset: 0,\n format: 'float2',\n },\n ],\n },\n ];\n\n // TODO: barycentric & tangent\n }\n}\n","import { generateAABBFromVertices } from '@antv/g-webgpu-core';\nimport { vec3 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { Geometry } from '.';\n\nexport interface ISphereGeometryParams {\n radius: number;\n latitudeBands: number;\n longitudeBands: number;\n}\n\n@injectable()\n/**\n * borrow from playcanvas\n */\nexport class Sphere extends Geometry<Partial<ISphereGeometryParams>> {\n protected onEntityCreated() {\n const {\n radius = 0.5,\n latitudeBands = 16,\n longitudeBands = 16,\n } = this.config;\n\n const positions: number[] = [];\n const normals: number[] = [];\n const uvs: number[] = [];\n const indices: number[] = [];\n\n for (let lat = 0; lat <= latitudeBands; lat++) {\n const theta = (lat * Math.PI) / latitudeBands;\n const sinTheta = Math.sin(theta);\n const cosTheta = Math.cos(theta);\n\n for (let lon = 0; lon <= longitudeBands; lon++) {\n // Sweep the sphere from the positive Z axis to match a 3DS Max sphere\n const phi = (lon * 2 * Math.PI) / longitudeBands - Math.PI / 2.0;\n const sinPhi = Math.sin(phi);\n const cosPhi = Math.cos(phi);\n\n const x = cosPhi * sinTheta;\n const y = cosTheta;\n const z = sinPhi * sinTheta;\n const u = 1.0 - lon / longitudeBands;\n const v = 1.0 - lat / latitudeBands;\n\n positions.push(x * radius, y * radius, z * radius);\n normals.push(x, y, z);\n uvs.push(u, v);\n }\n }\n\n for (let lat = 0; lat < latitudeBands; ++lat) {\n for (let lon = 0; lon < longitudeBands; ++lon) {\n const first = lat * (longitudeBands + 1) + lon;\n const second = first + longitudeBands + 1;\n\n indices.push(first + 1, second, first);\n indices.push(first + 1, second + 1, second);\n }\n }\n\n // generate AABB\n const aabb = generateAABBFromVertices(positions);\n\n const component = this.getComponent();\n component.indices = Uint32Array.from(indices);\n component.aabb = aabb;\n component.vertexCount = positions.length / 3;\n component.attributes = [\n {\n dirty: true,\n name: 'position',\n data: Float32Array.from(positions),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 0,\n offset: 0,\n format: 'float3',\n },\n ],\n },\n {\n dirty: true,\n name: 'normal',\n data: Float32Array.from(normals),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 1,\n offset: 0,\n format: 'float3',\n },\n ],\n },\n {\n dirty: true,\n name: 'uv',\n data: Float32Array.from(uvs),\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 2,\n offset: 0,\n format: 'float2',\n },\n ],\n },\n ];\n\n // TODO: barycentric & tangent\n }\n}\n","import {\n IDENTIFIER,\n IRendererService,\n IShaderModuleService,\n} from '@antv/g-webgpu-core';\nimport { mat3 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { Material } from '..';\nimport { Texture2D } from '../../texture/Texture2D';\nimport webglFragmentShaderGLSL from './shaders/webgl.basic.frag.glsl';\nimport webglVertexShaderGLSL from './shaders/webgl.basic.vert.glsl';\nimport webgpuFragmentShaderGLSL from './shaders/webgpu.basic.frag.glsl';\nimport webgpuVertexShaderGLSL from './shaders/webgpu.basic.vert.glsl';\n\nexport interface IBasicMaterialParams {\n map: Texture2D;\n}\n\n@injectable()\n/**\n * This material is not affected by lights.\n * @see https://threejs.org/docs/#api/en/materials/MeshBasicMaterial\n */\nexport class Basic extends Material<Partial<IBasicMaterialParams>> {\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n @inject(IDENTIFIER.ShaderModuleService)\n private readonly shaderModuleService: IShaderModuleService;\n\n protected onEntityCreated() {\n const component = this.getComponent();\n const vertexShaderGLSL = this.engine.supportWebGPU\n ? webgpuVertexShaderGLSL\n : webglVertexShaderGLSL;\n const fragmentShaderGLSL = this.engine.supportWebGPU\n ? webgpuFragmentShaderGLSL\n : webglFragmentShaderGLSL;\n\n this.shaderModuleService.registerModule('material-basic', {\n vs: vertexShaderGLSL,\n fs: fragmentShaderGLSL,\n });\n const {\n vs,\n fs,\n uniforms: extractedUniforms,\n } = this.shaderModuleService.getModule('material-basic');\n\n component.vertexShaderGLSL = vs!;\n component.fragmentShaderGLSL = fs!;\n // @ts-ignore\n component.setUniform(extractedUniforms);\n\n if (this.config.map) {\n component.setDefines({\n USE_UV: 1,\n USE_MAP: 1,\n });\n component.setUniform({\n // @ts-ignore\n map: this.config.map,\n uvTransform: mat3.create(),\n });\n }\n }\n}\n","import {\n BufferData,\n GeometrySystem,\n gl,\n IDENTIFIER,\n IShaderModuleService,\n MaterialSystem,\n} from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\nimport { Renderable } from '../Renderable';\nimport gridFrag from './shaders/webgl.grid.frag.glsl';\nimport gridVert from './shaders/webgl.grid.vert.glsl';\n\ninterface IGridConfig {\n gridColor: number[];\n gridSize: number;\n}\n\n@injectable()\nexport class Grid extends Renderable<Partial<IGridConfig>> {\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.MaterialSystem)\n private readonly materialSystem: MaterialSystem;\n\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.GeometrySystem)\n private readonly geometrySystem: GeometrySystem;\n\n @inject(IDENTIFIER.ShaderModuleService)\n private readonly shaderModuleService: IShaderModuleService;\n\n protected onAttributeChanged({\n name,\n data,\n }: {\n name: string;\n data: BufferData;\n }) {\n const mesh = this.getMeshComponent();\n if (mesh && mesh.material) {\n if (name === 'gridColor') {\n mesh.material.setUniform('u_GridColor', data);\n mesh.material.setUniform('u_GridColor2', data);\n } else if (name === 'gridSize') {\n mesh.material.setUniform('u_GridSize', data);\n mesh.material.setUniform('u_GridSize2', data);\n }\n }\n }\n\n protected onEntityCreated() {\n this.shaderModuleService.registerModule('grid', {\n vs: gridVert,\n fs: gridFrag,\n });\n const {\n vs,\n fs,\n uniforms: extractedUniforms,\n } = this.shaderModuleService.getModule('grid');\n\n const material = this.materialSystem.createShaderMaterial({\n vertexShader: vs!,\n fragmentShader: fs!,\n });\n this.setMaterial(material);\n\n const geometry = this.geometrySystem.createBufferGeometry({\n vertexCount: 4,\n });\n this.setGeometry(geometry);\n\n material\n .setCull({\n enable: false,\n face: gl.BACK,\n })\n .setDepth({\n enable: true,\n func: gl.LESS,\n });\n\n // @ts-ignore\n material.setUniform(extractedUniforms);\n\n this.setAttributes({\n gridColor: this.config.gridColor,\n gridSize: this.config.gridSize,\n });\n\n geometry.setIndex([0, 3, 2, 2, 1, 0]);\n\n geometry.setAttribute(\n 'a_Position',\n Float32Array.from([-4, -1, -4, 4, -1, -4, 4, -1, 4, -4, -1, 4]),\n {\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 0,\n offset: 0,\n format: 'float2',\n },\n ],\n },\n );\n }\n}\n","// @ts-ignore\nimport { copy, create, dot } from 'gl-vec2';\n// @ts-ignore\nimport { computeMiter, direction, normal } from 'polyline-miter-util';\n\nfunction extrusions(\n positions: number[][],\n out: any,\n point: number[],\n normal: number[],\n scale: number,\n) {\n addNext(out, normal, -scale);\n addNext(out, normal, scale);\n positions.push(point);\n positions.push(point);\n}\n\nfunction addNext(out: any[][], normal: number[], length: number) {\n out.push([[normal[0], normal[1]], length]);\n}\n\nexport default function(\n points: number[][],\n closed: boolean,\n indexOffset?: number,\n) {\n const lineA = [0, 0];\n const lineB = [0, 0];\n const tangent = [0, 0];\n const miter = [0, 0];\n let _lastFlip = -1;\n let _started = false;\n let _normal: any = null;\n const tmp = create();\n let count = indexOffset || 0;\n const miterLimit = 3;\n\n const out: any = [];\n const attrPos: number[][] = [];\n const attrIndex = [];\n const attrCounters: number[] = [0, 0];\n if (closed) {\n points = points.slice();\n points.push(points[0]);\n }\n\n const total = points.length;\n for (let i = 1; i < total; i++) {\n const index = count;\n const last = points[i - 1];\n const cur = points[i];\n const next = i < points.length - 1 ? points[i + 1] : null;\n\n attrCounters.push(i / total, i / total);\n\n direction(lineA, cur, last);\n\n if (!_normal) {\n _normal = [0, 0];\n normal(_normal, lineA);\n }\n\n if (!_started) {\n _started = true;\n extrusions(attrPos, out, last, _normal, 1);\n }\n\n attrIndex.push([index + 0, index + 1, index + 2]);\n\n if (!next) {\n // no miter, simple segment\n normal(_normal, lineA); // reset normal\n extrusions(attrPos, out, cur, _normal, 1);\n attrIndex.push(\n _lastFlip === 1\n ? [index, index + 2, index + 3]\n : [index + 2, index + 1, index + 3],\n );\n\n count += 2;\n } else {\n // miter with last\n // get unit dir of next line\n direction(lineB, next, cur);\n\n // stores tangent & miter\n let miterLen = computeMiter(tangent, miter, lineA, lineB, 1);\n\n // get orientation\n let flip = dot(tangent, _normal) < 0 ? -1 : 1;\n\n const bevel = miterLen > miterLimit;\n\n // 处理相邻线段重叠的情况\n if (!isFinite(miterLen)) {\n normal(_normal, lineA); // reset normal\n extrusions(attrPos, out, cur, _normal, 1);\n attrIndex.push(\n _lastFlip === 1\n ? [index, index + 2, index + 3]\n : [index + 2, index + 1, index + 3],\n );\n\n count += 2;\n _lastFlip = flip;\n continue;\n }\n\n if (bevel) {\n miterLen = miterLimit;\n attrCounters.push(i / total);\n\n // next two points in our first segment\n addNext(out, _normal, -flip);\n attrPos.push(cur);\n addNext(out, miter, miterLen * flip);\n attrPos.push(cur);\n\n attrIndex.push(\n _lastFlip !== -flip\n ? [index, index + 2, index + 3]\n : [index + 2, index + 1, index + 3],\n );\n\n // now add the bevel triangle\n attrIndex.push([index + 2, index + 3, index + 4]);\n\n normal(tmp, lineB);\n copy(_normal, tmp); // store normal for next round\n\n addNext(out, _normal, -flip);\n attrPos.push(cur);\n\n // the miter is now the normal for our next join\n count += 3;\n } else {\n // miter\n // next two points for our miter join\n extrusions(attrPos, out, cur, miter, miterLen);\n attrIndex.push(\n _lastFlip === 1\n ? [index, index + 2, index + 3]\n : [index + 2, index + 1, index + 3],\n );\n\n flip = -1;\n\n // the miter is now the normal for our next join\n copy(_normal, miter);\n count += 2;\n }\n _lastFlip = flip;\n }\n }\n\n return {\n normals: out,\n attrIndex,\n attrPos,\n attrCounters,\n };\n}\n","import {\n BufferData,\n GeometrySystem,\n gl,\n IDENTIFIER,\n IShaderModuleService,\n MaterialSystem,\n} from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\nimport { encodePickingColor } from '../../utils/picking';\nimport getNormals from '../../utils/polyline-normals';\nimport { Renderable } from '../Renderable';\nimport lineFrag from './shaders/webgl.line.frag.glsl';\nimport lineVert from './shaders/webgl.line.vert.glsl';\n\ninterface ILineConfig {\n id: number;\n points: number[][];\n thickness: number;\n color: [number, number, number, number]; // sRGB\n dashOffset: number;\n dashArray: number;\n dashRatio: number;\n}\n\n@injectable()\nexport class Line extends Renderable<Partial<ILineConfig>> {\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.MaterialSystem)\n private readonly materialSystem: MaterialSystem;\n\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.GeometrySystem)\n private readonly geometrySystem: GeometrySystem;\n\n @inject(IDENTIFIER.ShaderModuleService)\n private readonly shaderModuleService: IShaderModuleService;\n\n private vertexCount: number;\n\n protected onAttributeChanged({\n name,\n data,\n }: {\n name: string;\n data: BufferData;\n }) {\n const mesh = this.getMeshComponent();\n if (mesh && mesh.material) {\n switch (name) {\n case 'dashArray':\n mesh.material.setUniform('u_dash_array', data);\n break;\n case 'dashOffset':\n mesh.material.setUniform('u_dash_offset', data);\n break;\n case 'dashRatio':\n mesh.material.setUniform('u_dash_ratio', data);\n break;\n case 'thickness':\n mesh.material.setUniform('u_thickness', data);\n break;\n case 'color':\n const colors = new Array(this.vertexCount)\n .fill(undefined)\n .map(() => data)\n .reduce((prev, cur) => {\n // @ts-ignore\n return [...prev, ...cur];\n }, []);\n // @ts-ignore\n mesh.geometry.setAttribute('a_color', Float32Array.from(colors), {\n arrayStride: 4 * 4,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 1,\n offset: 0,\n format: 'float4',\n },\n ],\n });\n break;\n }\n }\n }\n\n protected onEntityCreated() {\n this.shaderModuleService.registerModule('line', {\n vs: lineVert,\n fs: lineFrag,\n });\n const {\n vs,\n fs,\n uniforms: extractedUniforms,\n } = this.shaderModuleService.getModule('line');\n\n const material = this.materialSystem.createShaderMaterial({\n vertexShader: vs!,\n fragmentShader: fs!,\n });\n\n const { normals, attrIndex, attrPos, attrCounters } = getNormals(\n this.config.points!,\n false,\n );\n const vertexCount = attrPos.length;\n this.vertexCount = vertexCount;\n const geometry = this.geometrySystem.createBufferGeometry({\n vertexCount,\n });\n\n this.setMaterial(material);\n this.setGeometry(geometry);\n\n material\n .setCull({\n enable: false,\n face: gl.BACK,\n })\n // @ts-ignore\n .setUniform(extractedUniforms);\n\n this.setAttributes({\n dashArray: this.config.dashArray,\n dashOffset: this.config.dashOffset,\n dashRatio: this.config.dashRatio,\n thickness: this.config.thickness,\n });\n\n const attrNormal: number[][] = [];\n const attrMiter: number[] = [];\n\n normals.forEach((n: number[][]) => {\n const norm = n[0];\n const miter = n[1];\n attrNormal.push([norm[0], norm[1]]);\n // @ts-ignore\n attrMiter.push(miter);\n });\n\n // [[0,1,2], [2,1,3]]\n geometry.setIndex(\n attrIndex.reduce((prev, cur) => {\n return [...prev, ...cur];\n }, []),\n );\n\n geometry.setAttribute(\n 'a_pos',\n Float32Array.from(\n attrPos.reduce((prev, cur) => {\n return [...prev, ...cur];\n }, []),\n ),\n {\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 0,\n offset: 0,\n format: 'float2',\n },\n ],\n },\n );\n\n const colors = new Array(vertexCount)\n .fill(undefined)\n .map(() => [...this.config.color!])\n .reduce((prev, cur) => {\n return [...prev, ...cur];\n }, []);\n geometry.setAttribute('a_color', Float32Array.from(colors), {\n arrayStride: 4 * 4,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 1,\n offset: 0,\n format: 'float4',\n },\n ],\n });\n\n geometry.setAttribute('a_line_miter', Float32Array.from(attrMiter), {\n arrayStride: 4 * 1,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 2,\n offset: 0,\n format: 'float',\n },\n ],\n });\n\n geometry.setAttribute(\n 'a_line_normal',\n Float32Array.from(\n attrNormal.reduce((prev, cur) => {\n return [...prev, ...cur];\n }, []),\n ),\n {\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 3,\n offset: 0,\n format: 'float2',\n },\n ],\n },\n );\n\n geometry.setAttribute('a_counters', Float32Array.from(attrCounters), {\n arrayStride: 4 * 1,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 4,\n offset: 0,\n format: 'float',\n },\n ],\n });\n }\n}\n","import {\n BufferData,\n GeometrySystem,\n gl,\n IDENTIFIER,\n IShaderModuleService,\n MaterialSystem,\n} from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\nimport { encodePickingColor } from '../../utils/picking';\nimport { Renderable } from '../Renderable';\nimport pointFrag from './shaders/webgl.point.frag.glsl';\nimport pointVert from './shaders/webgl.point.vert.glsl';\n\nconst pointShapes = [\n 'circle',\n 'triangle',\n 'square',\n 'pentagon',\n 'hexagon',\n 'octogon',\n 'hexagram',\n 'rhombus',\n 'vesica',\n];\n\ninterface IPointConfig {\n id: number;\n shape:\n | 'circle'\n | 'triangle'\n | 'square'\n | 'pentagon'\n | 'hexagon'\n | 'octogon'\n | 'hexagram'\n | 'rhombus'\n | 'vesica';\n position: [number, number];\n size: [number, number];\n color: [number, number, number, number]; // sRGB\n opacity: number;\n strokeWidth: number;\n strokeOpacity: number;\n strokeColor: [number, number, number, number]; // sRGB\n}\n\ninterface IInstanceAttributes {\n positions: number[];\n instancedOffsets: number[];\n instancedColors: number[];\n instancedSizes: number[];\n instancedShapes: number[];\n instancedPickingColors: number[];\n}\n\n/**\n * Use SDF to draw 2D point with stroke.\n */\n@injectable()\nexport class Point extends Renderable<\n Partial<IPointConfig> | Array<Partial<IPointConfig>>\n> {\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.MaterialSystem)\n private readonly materialSystem: MaterialSystem;\n\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.GeometrySystem)\n private readonly geometrySystem: GeometrySystem;\n\n @inject(IDENTIFIER.ShaderModuleService)\n private readonly shaderModuleService: IShaderModuleService;\n\n protected onAttributeChanged({\n name,\n data,\n }: {\n name: string;\n data: BufferData;\n }) {\n const mesh = this.getMeshComponent();\n if (mesh && mesh.material) {\n if (name === 'strokeWidth') {\n mesh.material.setUniform('u_stroke_width', data);\n } else if (name === 'strokeColor') {\n mesh.material.setUniform('u_stroke_color', data);\n } else if (name === 'strokeOpacity') {\n mesh.material.setUniform('u_stroke_opacity', data);\n } else if (name === 'opacity') {\n mesh.material.setUniform('u_opacity', data);\n } else if (name === 'blur') {\n mesh.material.setUniform('u_blur', data);\n }\n }\n }\n\n protected onEntityCreated() {\n this.shaderModuleService.registerModule('grid', {\n vs: pointVert,\n fs: pointFrag,\n });\n const {\n vs,\n fs,\n uniforms: extractedUniforms,\n } = this.shaderModuleService.getModule('grid');\n\n const material = this.materialSystem.createShaderMaterial({\n vertexShader: vs!,\n fragmentShader: fs!,\n cull: {\n enable: false,\n },\n depth: {\n enable: false,\n },\n blend: {\n enable: true,\n func: {\n srcRGB: gl.SRC_ALPHA,\n dstRGB: gl.ONE_MINUS_SRC_ALPHA,\n srcAlpha: 1,\n dstAlpha: 1,\n },\n },\n });\n\n // TODO: support define stroke-relative props per point\n material.setUniform({\n u_device_pixel_ratio: window.devicePixelRatio,\n ...extractedUniforms,\n });\n\n const attributes = this.buildAttributes();\n\n const geometry = this.geometrySystem.createInstancedBufferGeometry({\n maxInstancedCount: attributes.instancedOffsets.length / 2,\n vertexCount: 6,\n });\n\n geometry.setIndex([0, 2, 1, 0, 3, 2]);\n\n geometry.setAttribute('position', Float32Array.from(attributes.positions), {\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [\n {\n shaderLocation: 0,\n offset: 0,\n format: 'float2',\n },\n ],\n });\n\n geometry.setAttribute(\n 'offset',\n Float32Array.from(attributes.instancedOffsets),\n {\n arrayStride: 4 * 2,\n stepMode: 'instance',\n attributes: [\n {\n shaderLocation: 1,\n offset: 0,\n format: 'float2',\n },\n ],\n },\n );\n\n geometry.setAttribute(\n 'color',\n Float32Array.from(attributes.instancedColors),\n {\n arrayStride: 4 * 4,\n stepMode: 'instance',\n attributes: [\n {\n shaderLocation: 2,\n offset: 0,\n format: 'float4',\n },\n ],\n },\n );\n\n geometry.setAttribute(\n 'size',\n Float32Array.from(attributes.instancedSizes),\n {\n arrayStride: 4,\n stepMode: 'instance',\n attributes: [\n {\n shaderLocation: 3,\n offset: 0,\n format: 'float',\n },\n ],\n },\n );\n\n geometry.setAttribute(\n 'shape',\n Float32Array.from(attributes.instancedShapes),\n {\n arrayStride: 4,\n stepMode: 'instance',\n attributes: [\n {\n shaderLocation: 4,\n offset: 0,\n format: 'float',\n },\n ],\n },\n );\n\n geometry.setAttribute(\n 'a_PickingColor',\n Float32Array.from(attributes.instancedPickingColors),\n {\n arrayStride: 4 * 3,\n stepMode: 'instance',\n attributes: [\n {\n shaderLocation: 6,\n offset: 0,\n format: 'float3',\n },\n ],\n },\n );\n\n this.setMaterial(material);\n this.setGeometry(geometry);\n }\n\n private buildAttribute(\n config: Partial<IPointConfig>,\n attributes: IInstanceAttributes,\n index: number,\n ) {\n attributes.instancedPickingColors.push(\n ...encodePickingColor(config.id || index),\n );\n\n attributes.instancedShapes.push(\n pointShapes.indexOf(config.shape || 'circle'),\n );\n attributes.instancedColors.push(...(config.color || [1, 0, 0, 1]));\n attributes.instancedOffsets.push(...(config.position || [0, 0]));\n attributes.instancedSizes.push(...(config.size || [0.2, 0.2]));\n }\n\n private buildAttributes() {\n const attributes: IInstanceAttributes = {\n positions: [1, 1, 1, -1, -1, -1, -1, 1],\n instancedOffsets: [],\n instancedColors: [],\n instancedSizes: [],\n instancedShapes: [],\n instancedPickingColors: [],\n };\n\n if (Array.isArray(this.config)) {\n this.config.forEach((config, i) => {\n this.buildAttribute(config, attributes, i);\n });\n } else {\n this.buildAttribute(this.config, attributes, 0);\n }\n\n return attributes;\n }\n}\n","export function encodePickingColor(\n featureIdx: number,\n): [number, number, number] {\n return [\n (featureIdx + 1) & 255,\n ((featureIdx + 1) >> 8) & 255,\n (((featureIdx + 1) >> 8) >> 8) & 255,\n ];\n}\n","import {\n IClearOptions,\n IConfigService,\n IDENTIFIER,\n IRendererService,\n IShaderModuleService,\n ISystem,\n IView,\n} from '@antv/g-webgpu-core';\n// tslint:disable-next-line:no-submodule-imports\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { Container, inject, injectable, multiInject } from 'inversify';\nimport mapFragDeclaration from './material/shaders/map.frag.declaration.glsl';\nimport mapFragMain from './material/shaders/map.frag.main.glsl';\nimport uvFragDeclaration from './material/shaders/uv.frag.declaration.glsl';\nimport uvVertDeclaration from './material/shaders/uv.vert.declaration.glsl';\nimport uvVertMain from './material/shaders/uv.vert.main.glsl';\n\n@injectable()\nexport class Renderer {\n public container: Container;\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n @inject(IDENTIFIER.ShaderModuleService)\n private readonly shaderModule: IShaderModuleService;\n\n @inject(IDENTIFIER.ConfigService)\n private readonly configService: IConfigService;\n\n // @multiInject(IDENTIFIER.Systems)\n // private readonly systems: ISystem[];\n\n private inited: boolean = false;\n\n private rendering: boolean = false;\n\n private pendings: Array<() => void> = [];\n\n private views: IView[] = [];\n private size: { width: number; height: number };\n\n public async init() {\n // 模块化处理\n this.shaderModule.registerBuiltinModules();\n this.shaderModule.registerModule('uv.vert.declaration', {\n vs: uvVertDeclaration,\n });\n this.shaderModule.registerModule('uv.vert.main', {\n vs: uvVertMain,\n });\n this.shaderModule.registerModule('uv.frag.declaration', {\n fs: uvFragDeclaration,\n });\n this.shaderModule.registerModule('map.frag.declaration', {\n fs: mapFragDeclaration,\n });\n this.shaderModule.registerModule('map.frag.main', {\n fs: mapFragMain,\n });\n\n const systems = this.container.getAll<ISystem>(IDENTIFIER.Systems);\n\n const config = this.configService.get();\n\n if (config.canvas) {\n await this.engine.init({\n canvas: config.canvas,\n swapChainFormat: WebGPUConstants.TextureFormat.BGRA8Unorm,\n antialiasing: false,\n });\n\n for (const system of systems) {\n if (system.initialize) {\n await system.initialize();\n }\n }\n\n this.inited = true;\n }\n }\n\n public async render(...views: IView[]) {\n if (!this.inited || this.rendering) {\n return;\n }\n\n if (this.pendings.length) {\n this.pendings.forEach((pending) => {\n pending();\n });\n }\n\n this.rendering = true;\n this.engine.beginFrame();\n\n const systems = this.container.getAll<ISystem>(IDENTIFIER.Systems);\n for (const system of systems) {\n if (system.execute) {\n await system.execute(views);\n }\n }\n\n // 录制一遍绘制命令,后续直接播放\n // if (this.useRenderBundle) {\n // if (!this.renderBundleRecorded) {\n // this.engine.startRecordBundle();\n // if (this.onUpdate) {\n // await this.onUpdate(this.engine);\n // }\n // this.renderBundle = this.engine.stopRecordBundle();\n // this.renderBundleRecorded = true;\n // }\n // this.engine.executeBundles([this.renderBundle]);\n // } else {\n // if (this.onUpdate) {\n // await this.onUpdate(this.engine);\n // }\n // }\n\n this.engine.endFrame();\n this.rendering = false;\n }\n\n public clear(options: IClearOptions) {\n if (this.inited) {\n this.engine.clear(options);\n } else {\n this.pendings.unshift(() => {\n this.engine.clear(options);\n this.pendings.shift();\n });\n }\n return this;\n }\n\n // public setScissor(\n // scissor: Partial<{\n // enable: boolean;\n // box: {\n // x: number;\n // y: number;\n // width: number;\n // height: number;\n // };\n // }>,\n // ) {\n // this.engine.setScissor(scissor);\n // return this;\n // }\n\n public setSize({ width, height }: { width: number; height: number }) {\n const canvas = this.engine.getCanvas();\n this.size = { width, height };\n canvas.width = width;\n canvas.height = height;\n return this;\n }\n\n public getSize() {\n return this.size;\n }\n}\n","import { Entity, IScene } from '@antv/g-webgpu-core';\nimport { injectable } from 'inversify';\nimport { Renderable } from '.';\n\n@injectable()\nexport class Scene implements IScene {\n private entities: Entity[] = [];\n\n public getEntities() {\n return this.entities;\n }\n\n public addRenderable(renderable: Renderable) {\n this.addEntity(renderable.getEntity());\n return this;\n }\n\n public removeRenderable(renderable: Renderable) {\n this.removeEntity(renderable.getEntity());\n return this;\n }\n\n public addLight() {\n\n }\n\n private addEntity(entity: Entity) {\n if (this.entities.indexOf(entity) === -1) {\n this.entities.push(entity);\n }\n return this;\n }\n\n private removeEntity(entity: Entity) {\n const index = this.entities.indexOf(entity);\n this.entities.splice(index, 1);\n return this;\n }\n}\n","import { ITexture2D } from '@antv/g-webgpu-core';\nimport { injectable } from 'inversify';\n\n@injectable()\nexport class TextureCache {\n private cache: Record<string, ITexture2D> = {};\n\n public get(name: string) {\n return this.cache[name];\n }\n\n public set(name: string, texture: ITexture2D) {\n this.cache[name] = texture;\n }\n}\n","import {\n IClearOptions,\n IConfigService,\n IDENTIFIER,\n IRendererService,\n IShaderModuleService,\n ISystem,\n ITexture2D,\n ITexture2DInitializationOptions,\n IView,\n} from '@antv/g-webgpu-core';\nimport { inject, injectable } from 'inversify';\nimport { TextureCache } from './Cache';\n\n@injectable()\nexport class Texture2D {\n @inject(TextureCache)\n private readonly textureCache: TextureCache;\n\n @inject(IDENTIFIER.RenderEngine)\n private readonly engine: IRendererService;\n\n private config: ITexture2DInitializationOptions & { url: string };\n private loaded = false;\n private texture: ITexture2D;\n\n public setConfig(config: ITexture2DInitializationOptions & { url: string }) {\n this.config = config;\n }\n\n public isLoaded() {\n return this.loaded;\n }\n\n // public update(config: ITexture2DInitializationOptions) {\n // if (this.loaded && this.texture) {\n // const t = this.texture.get();\n // }\n // }\n\n public async load() {\n if (this.config.url) {\n return new Promise<ITexture2D>((resolve, reject) => {\n const existed = this.textureCache.get(this.config.url);\n if (existed) {\n resolve(existed);\n } else {\n const image = new Image();\n image.crossOrigin = 'Anonymous';\n image.src = this.config.url;\n image.onload = () => {\n const texture = this.engine.createTexture2D({\n ...this.config,\n data: image,\n width: image.width,\n height: image.height,\n flipY: true,\n });\n this.textureCache.set(this.config.url, texture);\n this.texture = texture;\n this.loaded = true;\n resolve(texture);\n };\n image.onerror = () => {\n reject();\n };\n }\n });\n } else {\n this.loaded = true;\n this.texture = this.engine.createTexture2D(this.config);\n return this.texture;\n }\n }\n}\n","import {\n ICamera,\n IDENTIFIER,\n IScene,\n IView,\n IViewport,\n RendererSystem,\n} from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\n\n@injectable()\nexport class View implements IView {\n @inject(IDENTIFIER.Systems)\n @named(IDENTIFIER.RendererSystem)\n private readonly rendererSystem: RendererSystem;\n\n private camera: ICamera;\n private scene: IScene;\n private viewport: IViewport = {\n x: 0,\n y: 0,\n width: 0,\n height: 0,\n };\n private clearColor: [number, number, number, number] = [1, 1, 1, 1];\n\n public getCamera() {\n return this.camera;\n }\n\n public getScene() {\n return this.scene;\n }\n\n public getViewport() {\n return this.viewport;\n }\n\n public getClearColor() {\n return this.clearColor;\n }\n\n public setCamera(camera: ICamera) {\n this.camera = camera;\n return this;\n }\n\n public setScene(scene: IScene) {\n this.scene = scene;\n return this;\n }\n\n public setViewport(viewport: IViewport) {\n this.viewport = viewport;\n return this;\n }\n\n public setClearColor(clearColor: [number, number, number, number]) {\n this.clearColor = clearColor;\n return this;\n }\n\n public pick(position: { x: number; y: number }) {\n return this.rendererSystem.pick(position, this);\n }\n}\n","// tslint:disable-next-line:no-reference\n/// <reference path=\"../../../node_modules/@webgpu/types/dist/index.d.ts\" />\nimport {\n ComponentManager,\n createEntity,\n createWorldContainer,\n Entity,\n GeometrySystem,\n // container,\n IConfig,\n IConfigService,\n IDENTIFIER,\n IInteractorService,\n IRendererService,\n ISystem,\n ITexture2D,\n ITexture2DInitializationOptions,\n KernelBundle,\n MaterialSystem,\n MeshComponent,\n TransformComponent,\n} from '@antv/g-webgpu-core';\nimport { WebGLEngine, WebGPUEngine } from '@antv/g-webgpu-engine';\n// tslint:disable-next-line:no-submodule-imports\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { Container, inject, injectable } from 'inversify';\nimport { Camera } from './camera/Camera';\nimport { Geometry, IGeometry } from './geometry';\nimport { Box } from './geometry/Box';\nimport { Merged } from './geometry/Merged';\nimport { Plane } from './geometry/Plane';\nimport { Sphere } from './geometry/Sphere';\nimport { Kernel } from './Kernel';\nimport { IMaterial, Material } from './material';\nimport { Basic } from './material/basic';\nimport { Grid } from './renderable/grid';\nimport { Line } from './renderable/line';\nimport { Point } from './renderable/point';\nimport { IRenderable, Renderable } from './renderable/Renderable';\nimport { Renderer } from './Renderer';\nimport { Scene } from './Scene';\nimport { TextureCache } from './texture/Cache';\nimport { Texture2D } from './texture/Texture2D';\nimport { createCanvas } from './utils/canvas';\nimport { View } from './View';\n\n@injectable()\nexport class World {\n public static create(config: Partial<IConfig> = {}) {\n const worldContainer = createWorldContainer();\n\n // bind render engine, fallback to WebGL\n const engineClazz = !navigator.gpu ? WebGLEngine : WebGPUEngine;\n if (!worldContainer.isBound(IDENTIFIER.RenderEngine)) {\n worldContainer\n .bind<IRendererService>(IDENTIFIER.RenderEngine)\n // @ts-ignore\n .to(engineClazz)\n .inSingletonScope();\n }\n\n worldContainer.bind(Renderer).toSelf();\n worldContainer.bind(Kernel).toSelf();\n worldContainer.bind(Renderable).toSelf();\n worldContainer.bind(View).toSelf();\n worldContainer.bind(Camera).toSelf();\n worldContainer.bind(Scene).toSelf();\n worldContainer.bind(World).toSelf();\n worldContainer.bind(TextureCache).toSelf();\n worldContainer.bind(Texture2D).toSelf();\n\n // bind geometries\n worldContainer\n .bind<IGeometry<unknown>>(IDENTIFIER.Geometry)\n .to(Box)\n .whenTargetNamed(Geometry.BOX);\n worldContainer\n .bind<IGeometry<unknown>>(IDENTIFIER.Geometry)\n .to(Sphere)\n .whenTargetNamed(Geometry.SPHERE);\n worldContainer\n .bind<IGeometry<unknown>>(IDENTIFIER.Geometry)\n .to(Plane)\n .whenTargetNamed(Geometry.PLANE);\n worldContainer\n .bind<IGeometry<unknown>>(IDENTIFIER.Geometry)\n .to(Merged)\n .whenTargetNamed(Geometry.MERGED);\n\n // bind materials\n worldContainer\n .bind<IMaterial<unknown>>(IDENTIFIER.Material)\n .to(Basic)\n .whenTargetNamed(Material.BASIC);\n\n // bind renderables\n worldContainer\n .bind<IRenderable<unknown>>(IDENTIFIER.Renderable)\n .to(Point)\n .whenTargetNamed(Renderable.POINT);\n worldContainer\n .bind<IRenderable<unknown>>(IDENTIFIER.Renderable)\n .to(Line)\n .whenTargetNamed(Renderable.LINE);\n worldContainer\n .bind<IRenderable<unknown>>(IDENTIFIER.Renderable)\n .to(Grid)\n .whenTargetNamed(Renderable.GRID);\n\n const world = worldContainer.get(World);\n world.setContainer(worldContainer);\n world.setConfig(config);\n return world;\n }\n\n @inject(IDENTIFIER.ConfigService)\n private readonly configService: IConfigService;\n\n private container: Container;\n\n public async getEngine() {\n const engine = this.container.get<IRendererService>(\n IDENTIFIER.RenderEngine,\n );\n const { canvas, engineOptions } = this.configService.get();\n await engine.init({\n canvas: canvas || createCanvas(),\n swapChainFormat: WebGPUConstants.TextureFormat.BGRA8Unorm,\n antialiasing: false,\n ...engineOptions,\n });\n return engine;\n }\n\n /**\n * get transform component\n * @param entity\n */\n public getTransformComponent(entity: Entity) {\n const manager = this.container.get<ComponentManager<TransformComponent>>(\n IDENTIFIER.TransformComponentManager,\n );\n return manager.getComponentByEntity(entity);\n }\n\n public getMeshComponent(entity: Entity) {\n const manager = this.container.get<ComponentManager<MeshComponent>>(\n IDENTIFIER.MeshComponentManager,\n );\n return manager.getComponentByEntity(entity);\n }\n\n public setConfig(config: Partial<IConfig>) {\n this.configService.set(config);\n }\n\n public setContainer(container: Container) {\n this.container = container;\n }\n\n public getContainer() {\n return this.container;\n }\n\n public createEntity() {\n return createEntity();\n }\n\n public createScene() {\n return this.container.get(Scene);\n }\n\n public createCamera() {\n return this.container.get(Camera);\n }\n\n public createView() {\n return this.container.get(View);\n }\n\n // public createLight(type: string,) {\n // return this.container.getNamed(IDENTIFIER.Light, type)\n // }\n\n public createRenderable<T>(type?: string, config?: T) {\n const renderable: Renderable = type\n ? this.container.getNamed(IDENTIFIER.Renderable, type)\n : this.container.get(Renderable);\n const entity = createEntity();\n renderable.setConfig(config || {});\n renderable.setEntity(entity);\n return renderable;\n }\n\n public createGeometry<T>(type: string, config?: T) {\n const geometry: Geometry = this.container.getNamed(\n IDENTIFIER.Geometry,\n type,\n );\n const entity = createEntity();\n geometry.setConfig(config || {});\n geometry.setEntity(entity);\n return geometry.getComponent();\n }\n\n public createMaterial<T>(type: string, config?: T) {\n const material: Material = this.container.getNamed(\n IDENTIFIER.Material,\n type,\n );\n const entity = createEntity();\n material.setConfig(config || {});\n material.setEntity(entity, type);\n return material.getComponent();\n }\n\n public createTexture2D(\n config: ITexture2DInitializationOptions & { url: string },\n ) {\n const texture = this.container.get(Texture2D);\n texture.setConfig(config);\n return texture;\n }\n\n public createBufferGeometry(params?: { vertexCount: number }) {\n const geometrySystem = this.container.getNamed<GeometrySystem>(\n IDENTIFIER.Systems,\n IDENTIFIER.GeometrySystem,\n );\n return geometrySystem.createBufferGeometry(params);\n }\n\n public createInstancedBufferGeometry(params: {\n maxInstancedCount: number;\n vertexCount: number;\n }) {\n const geometrySystem = this.container.getNamed<GeometrySystem>(\n IDENTIFIER.Systems,\n IDENTIFIER.GeometrySystem,\n );\n return geometrySystem.createInstancedBufferGeometry(params);\n }\n\n public createShaderMaterial(params: {\n vertexShader: string;\n fragmentShader: string;\n }) {\n const materialSystem = this.container.getNamed<MaterialSystem>(\n IDENTIFIER.Systems,\n IDENTIFIER.MaterialSystem,\n );\n return materialSystem.createShaderMaterial(params);\n }\n\n public createKernel(precompiledBundle: KernelBundle | string) {\n const kernel = this.container.get(Kernel);\n if (typeof precompiledBundle === 'string') {\n kernel.setBundle(JSON.parse(precompiledBundle));\n } else {\n kernel.setBundle(precompiledBundle);\n }\n kernel.init();\n return kernel;\n }\n\n public createRenderer() {\n const renderer = this.container.get(Renderer);\n renderer.container = this.container;\n renderer.init();\n return renderer;\n }\n\n public destroy() {\n const systems = this.container.getAll<ISystem>(IDENTIFIER.Systems);\n systems.forEach((system) => {\n if (system.tearDown) {\n system.tearDown();\n }\n });\n const engine = this.container.get<IRendererService>(\n IDENTIFIER.RenderEngine,\n );\n engine.destroy();\n const interactor = this.container.get<IInteractorService>(\n IDENTIFIER.InteractorService,\n );\n interactor.destroy();\n }\n}\n","import { isNumber } from './';\nimport { getEdgeTerminal } from './math';\n/**\n * 将 number | Function 类型的参数转换为 return number 的 Function\n * @param {number | Function} value 需要被转换的值\n * @param {number} defaultV 返回函数的默认返回值\n * @return {Function} 转换后的函数\n */\nexport const proccessToFunc = (value, defaultV) => {\n let func;\n if (!value) {\n func = () => {\n return defaultV || 1;\n };\n }\n else if (isNumber(value)) {\n func = () => {\n return value;\n };\n }\n else {\n func = value;\n }\n return func;\n};\n/**\n * 将节点和边数据转换为 GPU 可读的数组。并返回 maxEdgePerVetex,每个节点上最多的边数\n * @param {NodeConfig[]} nodes 需要被转换的值\n * @param {EdgeConfig[]} edges 返回函数的默认返回值\n * @return {Object} 转换后的数组及 maxEdgePerVetex 组成的对象\n */\nexport const buildTextureData = (nodes, edges) => {\n const dataArray = [];\n const nodeDict = [];\n const mapIdPos = {};\n let i = 0;\n for (i = 0; i < nodes.length; i++) {\n const n = nodes[i];\n mapIdPos[n.id] = i;\n dataArray.push(n.x);\n dataArray.push(n.y);\n dataArray.push(0);\n dataArray.push(0);\n nodeDict.push([]);\n }\n for (i = 0; i < edges.length; i++) {\n const e = edges[i];\n const source = getEdgeTerminal(e, 'source');\n const target = getEdgeTerminal(e, 'target');\n nodeDict[mapIdPos[source]].push(mapIdPos[target]);\n nodeDict[mapIdPos[target]].push(mapIdPos[source]);\n }\n let maxEdgePerVetex = 0;\n for (i = 0; i < nodes.length; i++) {\n const offset = dataArray.length;\n const dests = nodeDict[i];\n const len = dests.length;\n dataArray[i * 4 + 2] = offset;\n dataArray[i * 4 + 3] = dests.length;\n maxEdgePerVetex = Math.max(maxEdgePerVetex, dests.length);\n for (let j = 0; j < len; ++j) {\n const dest = dests[j];\n dataArray.push(+dest);\n }\n }\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0);\n }\n return {\n maxEdgePerVetex,\n array: new Float32Array(dataArray),\n };\n};\n/**\n* 将节点和边数据转换为 GPU 可读的数组,每条边带有一个属性。并返回 maxEdgePerVetex,每个节点上最多的边数\n* @param {NodeConfig[]} nodes 节点数组\n* @param {EdgeConfig[]} edges 边数组\n* @param {Function} attrs 读取边属性的函数\n* @return {Object} 转换后的数组及 maxEdgePerVetex 组成的对象\n*/\n// export const buildTextureDataWithOneEdgeAttr = (nodes: OutNode[], edges: Edge[], attrs: Function): {\n// array: Float32Array,\n// maxEdgePerVetex: number\n// } => {\n// const dataArray = [];\n// const nodeDict: any = [];\n// const mapIdPos: IndexMap = {};\n// let i = 0;\n// for (i = 0; i < nodes.length; i++) {\n// const n = nodes[i];\n// mapIdPos[n.id] = i;\n// dataArray.push(n.x);\n// dataArray.push(n.y);\n// dataArray.push(0);\n// dataArray.push(0);\n// nodeDict.push([]);\n// }\n// for (i = 0; i < edges.length; i++) {\n// const e = edges[i];\n// nodeDict[mapIdPos[e.source]].push(mapIdPos[e.target]);\n// nodeDict[mapIdPos[e.source]].push(attrs(e)); // 理想边长,后续可以改成每条边不同\n// nodeDict[mapIdPos[e.target]].push(mapIdPos[e.source]);\n// nodeDict[mapIdPos[e.target]].push(attrs(e)); // 理想边长,后续可以改成每条边不同\n// }\n// let maxEdgePerVetex = 0;\n// for (i = 0; i < nodes.length; i++) {\n// const offset: number = dataArray.length;\n// const dests = nodeDict[i]; // dest 中节点 id 与边长间隔存储,即一位节点 id,一位边长……\n// const len = dests.length;\n// dataArray[i * 4 + 2] = offset;\n// dataArray[i * 4 + 3] = len / 2; // 第四位存储与该节点相关的所有节点个数\n// maxEdgePerVetex = Math.max(maxEdgePerVetex, len / 2);\n// for (let j = 0; j < len; ++j) {\n// const dest = dests[j];\n// dataArray.push(+dest);\n// }\n// }\n// // 不是 4 的倍数,填充 0\n// while (dataArray.length % 4 !== 0) {\n// dataArray.push(0);\n// }\n// return {\n// array: new Float32Array(dataArray),\n// maxEdgePerVetex\n// }\n// }\n/**\n* 将节点和边数据转换为 GPU 可读的数组,每条边带有一个以上属性。并返回 maxEdgePerVetex,每个节点上最多的边数\n* @param {NodeConfig[]} nodes 节点数组\n* @param {EdgeConfig[]} edges 边数组\n* @param {Function} attrs 读取边属性的函数\n* @return {Object} 转换后的数组及 maxEdgePerVetex 组成的对象\n*/\nexport const buildTextureDataWithTwoEdgeAttr = (nodes, edges, attrs1, attrs2) => {\n const dataArray = [];\n const nodeDict = [];\n const mapIdPos = {};\n let i = 0;\n for (i = 0; i < nodes.length; i++) {\n const n = nodes[i];\n mapIdPos[n.id] = i;\n dataArray.push(n.x);\n dataArray.push(n.y);\n dataArray.push(0);\n dataArray.push(0);\n nodeDict.push([]);\n }\n for (i = 0; i < edges.length; i++) {\n const e = edges[i];\n const source = getEdgeTerminal(e, 'source');\n const target = getEdgeTerminal(e, 'target');\n nodeDict[mapIdPos[source]].push(mapIdPos[target]);\n nodeDict[mapIdPos[source]].push(attrs1(e));\n nodeDict[mapIdPos[source]].push(attrs2(e));\n nodeDict[mapIdPos[source]].push(0);\n nodeDict[mapIdPos[target]].push(mapIdPos[source]);\n nodeDict[mapIdPos[target]].push(attrs1(e));\n nodeDict[mapIdPos[target]].push(attrs2(e));\n nodeDict[mapIdPos[target]].push(0);\n }\n let maxEdgePerVetex = 0;\n for (i = 0; i < nodes.length; i++) {\n const offset = dataArray.length;\n const dests = nodeDict[i]; // dest 中节点 id 与边长间隔存储,即一位节点 id,一位边长……\n const len = dests.length;\n // dataArray[i * 4 + 2] = offset;\n // dataArray[i * 4 + 3] = len / 4; // 第四位存储与该节点相关的所有节点个数\n // pack offset & length into float32: offset 20bit, length 12bit\n dataArray[i * 4 + 2] = offset + 1048576 * len / 4;\n dataArray[i * 4 + 3] = 0; // 第四位存储与上一次的距离差值\n maxEdgePerVetex = Math.max(maxEdgePerVetex, len / 4);\n for (let j = 0; j < len; ++j) {\n const dest = dests[j];\n dataArray.push(+dest);\n }\n }\n // 不是 4 的倍数,填充 0\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0);\n }\n return {\n maxEdgePerVetex,\n array: new Float32Array(dataArray),\n };\n};\n/**\n* transform the extended attributes of nodes or edges to a texture array\n* @param {string[]} attributeNames attributes' name to be read from items and put into output array\n* @param {ModelConfig[]} items the items to be read\n* @return {Float32Array} the attributes' value array to be read by GPU\n*/\nexport const attributesToTextureData = (attributeNames, items) => {\n const dataArray = [];\n const attributeNum = attributeNames.length;\n const attributteStringMap = {};\n items.forEach((item) => {\n attributeNames.forEach((name, i) => {\n if (attributteStringMap[item[name]] === undefined) {\n attributteStringMap[item[name]] = Object.keys(attributteStringMap).length;\n }\n dataArray.push(attributteStringMap[item[name]]);\n // insure each node's attributes take inter number of grids\n if (i === attributeNum - 1) {\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0);\n }\n }\n });\n });\n return {\n array: new Float32Array(dataArray),\n count: Object.keys(attributteStringMap).length\n };\n};\n/**\n* transform the number array format of extended attributes of nodes or edges to a texture array\n* @param {string[]} attributeNames attributes' name to be read from items and put into output array\n* @return {Float32Array} the attributes' value array to be read by GPU\n*/\nexport const arrayToTextureData = (valueArrays) => {\n const dataArray = [];\n const attributeNum = valueArrays.length;\n const itemNum = valueArrays[0].length;\n for (let j = 0; j < itemNum; j++) {\n valueArrays.forEach((valueArray, i) => {\n dataArray.push(valueArray[j]);\n // insure each node's attributes take inter number of grids\n if (i === attributeNum - 1) {\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0);\n }\n }\n });\n }\n return new Float32Array(dataArray);\n};\n//# sourceMappingURL=gpu.js.map","// @ts-nocheck\n/**\n * @fileOverview fruchterman layout\n * @author shiwu.wyy@antfin.com\n */\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { Base } from \"../base\";\nimport { isNumber } from \"../../util\";\n// @ts-ignore\nimport { World } from \"@antv/g-webgpu\";\n// compile at runtime in dev mode\nimport { buildTextureData, attributesToTextureData } from \"../../util/gpu\";\n// use compiled bundle in prod mode\nimport { fruchtermanBundle, clusterBundle } from \"./fruchtermanShader\";\nimport { LAYOUT_MESSAGE } from \"../constants\";\n/**\n * fruchterman 布局\n */\nexport class FruchtermanGPULayout extends Base {\n constructor(options) {\n super();\n /** 停止迭代的最大迭代数 */\n this.maxIteration = 1000;\n /** 重力大小,影响图的紧凑程度 */\n this.gravity = 10;\n /** 速度 */\n this.speed = 1;\n /** 是否产生聚类力 */\n this.clustering = false;\n /** 根据哪个字段聚类 */\n this.clusterField = \"cluster\";\n /** 聚类力大小 */\n this.clusterGravity = 10;\n /** 是否启用web worker。前提是在web worker里执行布局,否则无效\t*/\n this.workerEnabled = false;\n this.nodes = [];\n this.edges = [];\n this.width = 300;\n this.height = 300;\n this.nodeMap = {};\n this.nodeIdxMap = {};\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n maxIteration: 1000,\n gravity: 10,\n speed: 1,\n clustering: false,\n clusterGravity: 10\n };\n }\n /**\n * 执行布局\n */\n execute() {\n return __awaiter(this, void 0, void 0, function* () {\n const self = this;\n const nodes = self.nodes;\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n const nodeMap = {};\n const nodeIdxMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x))\n node.x = Math.random() * this.width;\n if (!isNumber(node.y))\n node.y = Math.random() * this.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n // layout\n yield self.run();\n });\n }\n executeWithWorker(canvas, ctx) {\n return __awaiter(this, void 0, void 0, function* () {\n const self = this;\n const nodes = self.nodes;\n const center = self.center;\n if (!nodes || nodes.length === 0) {\n return;\n }\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n return;\n }\n const nodeMap = {};\n const nodeIdxMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x))\n node.x = Math.random() * this.width;\n if (!isNumber(node.y))\n node.y = Math.random() * this.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n // layout\n yield self.run(canvas, ctx);\n });\n }\n run(canvas, ctx) {\n return __awaiter(this, void 0, void 0, function* () {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const maxIteration = self.maxIteration;\n const center = self.center;\n const area = self.height * self.width;\n let maxDisplace = Math.sqrt(area) / 10;\n const k2 = area / (nodes.length + 1);\n const k = Math.sqrt(k2);\n const speed = self.speed;\n const clustering = self.clustering;\n const { array: attributeArray, count: clusterCount } = attributesToTextureData([self.clusterField], nodes);\n // pushing the fx and fy\n nodes.forEach((node, i) => {\n let fx = 0;\n let fy = 0;\n if (isNumber(node.fx) && isNumber(node.fy)) {\n fx = node.fx || 0.001;\n fy = node.fy || 0.001;\n }\n attributeArray[4 * i + 1] = fx;\n attributeArray[4 * i + 2] = fy;\n });\n const numParticles = nodes.length;\n const { maxEdgePerVetex, array: nodesEdgesArray } = buildTextureData(nodes, edges);\n const workerEnabled = self.workerEnabled;\n let world;\n if (workerEnabled) {\n world = World.create({\n canvas,\n engineOptions: {\n supportCompute: true\n }\n });\n }\n else {\n world = World.create({\n engineOptions: {\n supportCompute: true\n }\n });\n }\n // compile at runtime in dev mode\n // const compiler = new Compiler()\n // const fruchtermanBundle = compiler.compileBundle(fruchtermanCode)\n // const clusterBundle = compiler.compileBundle(clusterCode)\n // use compiled bundle in prod mode\n // console.log(fruchtermanBundle.toString())\n // console.log(clusterBundle.toString())\n const onLayoutEnd = self.onLayoutEnd;\n const clusterCenters = [];\n for (let i = 0; i < clusterCount; i++) {\n clusterCenters.push(0, 0, 0, 0);\n }\n const kernelFruchterman = world\n .createKernel(fruchtermanBundle)\n .setDispatch([numParticles, 1, 1])\n .setBinding({\n u_Data: nodesEdgesArray,\n u_K: k,\n u_K2: k2,\n u_Gravity: self.gravity,\n u_ClusterGravity: self.clusterGravity || self.gravity || 1,\n u_Speed: speed,\n u_MaxDisplace: maxDisplace,\n u_Clustering: clustering ? 1 : 0,\n u_Center: center,\n u_AttributeArray: attributeArray,\n u_ClusterCenters: clusterCenters,\n MAX_EDGE_PER_VERTEX: maxEdgePerVetex,\n VERTEX_COUNT: numParticles\n });\n let kernelCluster;\n if (clustering) {\n kernelCluster = world\n .createKernel(clusterBundle)\n .setDispatch([clusterCount, 1, 1])\n .setBinding({\n u_Data: nodesEdgesArray,\n u_NodeAttributes: attributeArray,\n u_ClusterCenters: clusterCenters,\n VERTEX_COUNT: numParticles,\n CLUSTER_COUNT: clusterCount\n });\n }\n const execute = () => __awaiter(this, void 0, void 0, function* () {\n for (let i = 0; i < maxIteration; i++) {\n // eslint-disable-next-line no-await-in-loop\n yield kernelFruchterman.execute();\n if (clustering) {\n kernelCluster.setBinding({\n u_Data: kernelFruchterman\n });\n // eslint-disable-next-line no-await-in-loop\n yield kernelCluster.execute();\n kernelFruchterman.setBinding({\n u_ClusterCenters: kernelCluster\n });\n }\n kernelFruchterman.setBinding({\n u_MaxDisplace: maxDisplace *= 0.99\n });\n }\n const finalParticleData = yield kernelFruchterman.getOutput();\n if (canvas) {\n // 传递数据给主线程\n ctx.postMessage({\n type: LAYOUT_MESSAGE.GPUEND,\n vertexEdgeData: finalParticleData\n // edgeIndexBufferData,\n });\n }\n else {\n nodes.forEach((node, i) => {\n const x = finalParticleData[4 * i];\n const y = finalParticleData[4 * i + 1];\n node.x = x;\n node.y = y;\n });\n }\n if (onLayoutEnd)\n onLayoutEnd();\n });\n yield execute();\n });\n }\n getType() {\n return \"fruchterman-gpu\";\n }\n}\n//# sourceMappingURL=fruchterman.js.map","export const fruchtermanCode = `\nimport { globalInvocationID } from 'g-webgpu';\nconst MAX_EDGE_PER_VERTEX;\nconst VERTEX_COUNT;\n@numthreads(1, 1, 1)\nclass Fruchterman {\n @in @out\n u_Data: vec4[];\n @in\n u_K: float;\n @in\n u_K2: float;\n \n @in\n u_Center: vec2;\n @in\n u_Gravity: float;\n @in\n u_ClusterGravity: float;\n @in\n u_Speed: float;\n @in\n u_MaxDisplace: float;\n @in\n u_Clustering: float;\n @in\n u_AttributeArray: vec4[];\n @in\n u_ClusterCenters: vec4[];\n calcRepulsive(i: int, currentNode: vec4): vec2 {\n let dx = 0, dy = 0;\n for (let j = 0; j < VERTEX_COUNT; j++) {\n if (i != j) {\n const nextNode = this.u_Data[j];\n const xDist = currentNode[0] - nextNode[0];\n const yDist = currentNode[1] - nextNode[1];\n const dist = (xDist * xDist + yDist * yDist) + 0.01;\n let param = this.u_K2 / dist;\n \n if (dist > 0.0) {\n dx += param * xDist;\n dy += param * yDist;\n if (xDist == 0 && yDist == 0) {\n const sign = i < j ? 1 : -1;\n dx += param * sign;\n dy += param * sign;\n }\n }\n }\n }\n return [dx, dy];\n }\n calcGravity(currentNode: vec4, nodeAttributes: vec4): vec2 { // \n let dx = 0, dy = 0;\n const vx = currentNode[0] - this.u_Center[0];\n const vy = currentNode[1] - this.u_Center[1];\n const gf = 0.01 * this.u_K * this.u_Gravity;\n dx = gf * vx;\n dy = gf * vy;\n if (this.u_Clustering == 1) {\n const clusterIdx = int(nodeAttributes[0]);\n const center = this.u_ClusterCenters[clusterIdx];\n const cvx = currentNode[0] - center[0];\n const cvy = currentNode[1] - center[1];\n const dist = sqrt(cvx * cvx + cvy * cvy) + 0.01;\n const parma = this.u_K * this.u_ClusterGravity / dist;\n dx += parma * cvx;\n dy += parma * cvy;\n }\n return [dx, dy];\n }\n calcAttractive(i: int, currentNode: vec4): vec2 {\n let dx = 0, dy = 0;\n const arr_offset = int(floor(currentNode[2] + 0.5));\n const length = int(floor(currentNode[3] + 0.5));\n const node_buffer: vec4;\n for (let p = 0; p < MAX_EDGE_PER_VERTEX; p++) {\n if (p >= length) break;\n const arr_idx = arr_offset + p;\n // when arr_idx % 4 == 0 update currentNodedx_buffer\n const buf_offset = arr_idx - arr_idx / 4 * 4;\n if (p == 0 || buf_offset == 0) {\n node_buffer = this.u_Data[int(arr_idx / 4)];\n }\n const float_j = buf_offset == 0 ? node_buffer[0] :\n buf_offset == 1 ? node_buffer[1] :\n buf_offset == 2 ? node_buffer[2] :\n node_buffer[3];\n const nextNode = this.u_Data[int(float_j)];\n const xDist = currentNode[0] - nextNode[0];\n const yDist = currentNode[1] - nextNode[1];\n const dist = sqrt(xDist * xDist + yDist * yDist) + 0.01;\n let attractiveF = dist / this.u_K;\n \n if (dist > 0.0) {\n dx -= xDist * attractiveF;\n dy -= yDist * attractiveF;\n if (xDist == 0 && yDist == 0) {\n const sign = i < int(float_j) ? 1 : -1;\n dx -= sign * attractiveF;\n dy -= sign * attractiveF;\n }\n }\n }\n return [dx, dy];\n }\n @main\n compute() {\n const i = globalInvocationID.x;\n const currentNode = this.u_Data[i];\n let dx = 0, dy = 0;\n if (i >= VERTEX_COUNT) {\n this.u_Data[i] = currentNode;\n return;\n }\n\n // [gravity, fx, fy, 0]\n const nodeAttributes = this.u_AttributeArray[i];\n\n if (nodeAttributes[1] != 0 && nodeAttributes[2] != 0) {\n // the node is fixed\n this.u_Data[i] = [\n nodeAttributes[1],\n nodeAttributes[2],\n currentNode[2],\n currentNode[3]\n ];\n return;\n }\n\n // repulsive\n const repulsive = this.calcRepulsive(i, currentNode);\n dx += repulsive[0];\n dy += repulsive[1];\n // attractive\n const attractive = this.calcAttractive(i, currentNode);\n dx += attractive[0];\n dy += attractive[1];\n // gravity\n const gravity = this.calcGravity(currentNode, nodeAttributes);\n dx -= gravity[0];\n dy -= gravity[1];\n // speed\n dx *= this.u_Speed;\n dy *= this.u_Speed;\n\n // move\n const distLength = sqrt(dx * dx + dy * dy);\n if (distLength > 0.0) {\n const limitedDist = min(this.u_MaxDisplace * this.u_Speed, distLength);\n this.u_Data[i] = [\n currentNode[0] + dx / distLength * limitedDist,\n currentNode[1] + dy / distLength * limitedDist,\n currentNode[2],\n currentNode[3]\n ];\n }\n }\n}\n`;\nexport const fruchtermanBundle = `{\"shaders\":{\"WGSL\":\"import \\\\\"GLSL.std.450\\\\\" as std;\\\\n\\\\n\\\\n# var gWebGPUDebug : bool = false;\\\\n# var gWebGPUDebugOutput : vec4<f32> = vec4<f32>(0.0);\\\\n\\\\n[[builtin global_invocation_id]] var<in> globalInvocationID : vec3<u32>;\\\\n# [[builtin work_group_size]] var<in> workGroupSize : vec3<u32>;\\\\n# [[builtin work_group_id]] var<in> workGroupID : vec3<u32>;\\\\n[[builtin local_invocation_id]] var<in> localInvocationID : vec3<u32>;\\\\n# [[builtin num_work_groups]] var<in> numWorkGroups : vec3<u32>;\\\\n[[builtin local_invocation_idx]] var<in> localInvocationIndex : u32;\\\\n\\\\ntype GWebGPUParams = [[block]] struct {\\\\n [[offset 0]] u_K : f32;\\\\n [[offset 4]] u_K2 : f32;\\\\n [[offset 8]] u_Center : vec2<f32>;\\\\n [[offset 16]] u_Gravity : f32;\\\\n [[offset 20]] u_ClusterGravity : f32;\\\\n [[offset 24]] u_Speed : f32;\\\\n [[offset 28]] u_MaxDisplace : f32;\\\\n [[offset 32]] u_Clustering : f32;\\\\n};\\\\n[[binding 0, set 0]] var<uniform> gWebGPUUniformParams : GWebGPUParams;\\\\ntype GWebGPUBuffer0 = [[block]] struct {\\\\n [[offset 0]] u_Data : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 1, set 0]] var<storage_buffer> gWebGPUBuffer0 : GWebGPUBuffer0;\\\\ntype GWebGPUBuffer1 = [[block]] struct {\\\\n [[offset 0]] u_AttributeArray : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 2, set 0]] var<storage_buffer> gWebGPUBuffer1 : GWebGPUBuffer1;\\\\ntype GWebGPUBuffer2 = [[block]] struct {\\\\n [[offset 0]] u_ClusterCenters : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 3, set 0]] var<storage_buffer> gWebGPUBuffer2 : GWebGPUBuffer2;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nfn calcRepulsive(i : i32, currentNode : vec4<f32>) -> vec2<f32> {var dx : f32 = 0.0;\\\\nvar dy : f32 = 0.0;\\\\nfor (var j : i32 = 0; j < __DefineValuePlaceholder__VERTEX_COUNT; j = j + 1) {if (i != j) {var nextNode : vec4<f32> = gWebGPUBuffer0.u_Data[j];\\\\nvar xDist : f32 = currentNode.x - nextNode.x;\\\\nvar yDist : f32 = currentNode.y - nextNode.y;\\\\nvar dist : f32 = ((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nvar param : f32 = gWebGPUUniformParams.u_K2 / dist;\\\\nif (dist > 0.0) {dx = dx + param * xDist;\\\\ndy = dy + param * yDist;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {var sign : f32 = select(1.0, -1.0, i < j);\\\\ndx = dx + param * std::sign;\\\\ndy = dy + param * std::sign;}}}}\\\\nreturn vec2<f32>(dx, dy);}\\\\nfn calcGravity(currentNode : vec4<f32>, nodeAttributes : vec4<f32>) -> vec2<f32> {var dx : f32 = 0.0;\\\\nvar dy : f32 = 0.0;\\\\nvar vx : f32 = currentNode.x - gWebGPUUniformParams.u_Center.x;\\\\nvar vy : f32 = currentNode.y - gWebGPUUniformParams.u_Center.y;\\\\nvar gf : f32 = (0.01 * gWebGPUUniformParams.u_K) * gWebGPUUniformParams.u_Gravity;\\\\ndx = gf * vx;\\\\ndy = gf * vy;\\\\nif (gWebGPUUniformParams.u_Clustering == 1.0) {var clusterIdx : i32 = i32(nodeAttributes.x);\\\\nvar center : vec4<f32> = gWebGPUBuffer2.u_ClusterCenters[clusterIdx];\\\\nvar cvx : f32 = currentNode.x - center.x;\\\\nvar cvy : f32 = currentNode.y - center.y;\\\\nvar dist : f32 = std::sqrt((cvx * cvx) + (cvy * cvy)) + 0.01;\\\\nvar parma : f32 = (gWebGPUUniformParams.u_K * gWebGPUUniformParams.u_ClusterGravity) / dist;\\\\ndx = dx + parma * cvx;\\\\ndy = dy + parma * cvy;}\\\\nreturn vec2<f32>(dx, dy);}\\\\nfn calcAttractive(i : i32, currentNode : vec4<f32>) -> vec2<f32> {var dx : f32 = 0.0;\\\\nvar dy : f32 = 0.0;\\\\nvar arr_offset : i32 = i32(std::floor(currentNode.z + 0.5));\\\\nvar length : i32 = i32(std::floor(currentNode.w + 0.5));\\\\nvar node_buffer : vec4<f32>;\\\\nfor (var p : i32 = 0; p < __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX; p = p + 1) {if (p >= length) {break;}\\\\nvar arr_idx : i32 = arr_offset + i32(p);\\\\nvar buf_offset : i32 = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = gWebGPUBuffer0.u_Data[i32(arr_idx / 4)];}\\\\nvar float_j : f32 = select(node_buffer.x, select(node_buffer.y, select(node_buffer.z, node_buffer.w, buf_offset == 2), buf_offset == 1), buf_offset == 0);\\\\nvar nextNode : vec4<f32> = gWebGPUBuffer0.u_Data[i32(float_j)];\\\\nvar xDist : f32 = currentNode.x - nextNode.x;\\\\nvar yDist : f32 = currentNode.y - nextNode.y;\\\\nvar dist : f32 = std::sqrt((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nvar attractiveF : f32 = dist / gWebGPUUniformParams.u_K;\\\\nif (dist > 0.0) {dx = dx - xDist * attractiveF;\\\\ndy = dy - yDist * attractiveF;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {var sign : f32 = select(1.0, -1.0, i < i32(float_j));\\\\ndx = dx - std::sign * attractiveF;\\\\ndy = dy - std::sign * attractiveF;}}}\\\\nreturn vec2<f32>(dx, dy);}\\\\nfn main() -> void {var i : i32 = globalInvocationID.x;\\\\nvar currentNode : vec4<f32> = gWebGPUBuffer0.u_Data[i];\\\\nvar dx : f32 = 0.0;\\\\nvar dy : f32 = 0.0;\\\\nif (i >= __DefineValuePlaceholder__VERTEX_COUNT) {gWebGPUBuffer0.u_Data[i] = currentNode;\\\\nreturn ;}\\\\nvar nodeAttributes : vec4<f32> = gWebGPUBuffer1.u_AttributeArray[i];\\\\nif ((nodeAttributes.y != 0.0) && (nodeAttributes.z != 0.0)) {gWebGPUBuffer0.u_Data[i] = vec4<f32>(nodeAttributes.y, nodeAttributes.z, currentNode.z, currentNode.w);\\\\nreturn ;}\\\\nvar repulsive : vec2<f32> = calcRepulsive(i, currentNode);\\\\ndx = dx + repulsive.x;\\\\ndy = dy + repulsive.y;\\\\nvar attractive : vec2<f32> = calcAttractive(i, currentNode);\\\\ndx = dx + attractive.x;\\\\ndy = dy + attractive.y;\\\\nvar gravity : vec2<f32> = calcGravity(currentNode, nodeAttributes);\\\\ndx = dx - gravity.x;\\\\ndy = dy - gravity.y;\\\\ndx = dx * gWebGPUUniformParams.u_Speed;\\\\ndy = dy * gWebGPUUniformParams.u_Speed;\\\\nvar distLength : f32 = std::sqrt((dx * dx) + (dy * dy));\\\\nif (distLength > 0.0) {var limitedDist : f32 = std::min(gWebGPUUniformParams.u_MaxDisplace * gWebGPUUniformParams.u_Speed, distLength);\\\\ngWebGPUBuffer0.u_Data[i] = vec4<f32>(currentNode.x + ((dx / distLength) * limitedDist), currentNode.y + ((dy / distLength) * limitedDist), currentNode.z, currentNode.w);}\\\\nreturn;}\\\\n\\\\nentry_point compute as \\\\\"main\\\\\" = main;\\\\n\",\"GLSL450\":\"\\\\n\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\nivec3 globalInvocationID = ivec3(gl_GlobalInvocationID);\\\\nivec3 workGroupSize = ivec3(1,1,1);\\\\nivec3 workGroupID = ivec3(gl_WorkGroupID);\\\\nivec3 localInvocationID = ivec3(gl_LocalInvocationID);\\\\nivec3 numWorkGroups = ivec3(gl_NumWorkGroups);\\\\nint localInvocationIndex = int(gl_LocalInvocationIndex);\\\\n\\\\nlayout(std140, set = 0, binding = 0) uniform GWebGPUParams {\\\\n float u_K;\\\\n float u_K2;\\\\n vec2 u_Center;\\\\n float u_Gravity;\\\\n float u_ClusterGravity;\\\\n float u_Speed;\\\\n float u_MaxDisplace;\\\\n float u_Clustering;\\\\n} gWebGPUUniformParams;\\\\nlayout(std430, set = 0, binding = 1) buffer GWebGPUBuffer0 {\\\\n vec4 u_Data[];\\\\n} gWebGPUBuffer0;\\\\n\\\\nlayout(std430, set = 0, binding = 2) buffer readonly GWebGPUBuffer1 {\\\\n vec4 u_AttributeArray[];\\\\n} gWebGPUBuffer1;\\\\n\\\\nlayout(std430, set = 0, binding = 3) buffer readonly GWebGPUBuffer2 {\\\\n vec4 u_ClusterCenters[];\\\\n} gWebGPUBuffer2;\\\\n\\\\n\\\\n\\\\n#define MAX_EDGE_PER_VERTEX __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\nlayout (\\\\n local_size_x = 1,\\\\n local_size_y = 1,\\\\n local_size_z = 1\\\\n) in;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nvec2 calcRepulsive(int i, vec4 currentNode) {float dx = 0.0;\\\\nfloat dy = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {if (i != j) {vec4 nextNode = gWebGPUBuffer0.u_Data[j];\\\\nfloat xDist = currentNode.x - nextNode.x;\\\\nfloat yDist = currentNode.y - nextNode.y;\\\\nfloat dist = ((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nfloat param = gWebGPUUniformParams.u_K2 / dist;\\\\nif (dist > 0.0) {dx += param * xDist;\\\\ndy += param * yDist;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {float sign = (i < j) ? (1.0) : (-1.0);\\\\ndx += param * sign;\\\\ndy += param * sign;}}}}\\\\nreturn vec2(dx, dy);}\\\\nvec2 calcGravity(vec4 currentNode, vec4 nodeAttributes) {float dx = 0.0;\\\\nfloat dy = 0.0;\\\\nfloat vx = currentNode.x - gWebGPUUniformParams.u_Center.x;\\\\nfloat vy = currentNode.y - gWebGPUUniformParams.u_Center.y;\\\\nfloat gf = (0.01 * gWebGPUUniformParams.u_K) * gWebGPUUniformParams.u_Gravity;\\\\ndx = gf * vx;\\\\ndy = gf * vy;\\\\nif (gWebGPUUniformParams.u_Clustering == 1.0) {int clusterIdx = int(nodeAttributes.x);\\\\nvec4 center = gWebGPUBuffer2.u_ClusterCenters[clusterIdx];\\\\nfloat cvx = currentNode.x - center.x;\\\\nfloat cvy = currentNode.y - center.y;\\\\nfloat dist = sqrt((cvx * cvx) + (cvy * cvy)) + 0.01;\\\\nfloat parma = (gWebGPUUniformParams.u_K * gWebGPUUniformParams.u_ClusterGravity) / dist;\\\\ndx += parma * cvx;\\\\ndy += parma * cvy;}\\\\nreturn vec2(dx, dy);}\\\\nvec2 calcAttractive(int i, vec4 currentNode) {float dx = 0.0;\\\\nfloat dy = 0.0;\\\\nint arr_offset = int(floor(currentNode.z + 0.5));\\\\nint length = int(floor(currentNode.w + 0.5));\\\\nvec4 node_buffer;\\\\nfor (int p = 0; p < MAX_EDGE_PER_VERTEX; p++) {if (p >= length) {break;}\\\\nint arr_idx = arr_offset + int(p);\\\\nint buf_offset = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = gWebGPUBuffer0.u_Data[int(arr_idx / 4)];}\\\\nfloat float_j = (buf_offset == 0) ? (node_buffer.x) : ((buf_offset == 1) ? (node_buffer.y) : ((buf_offset == 2) ? (node_buffer.z) : (node_buffer.w)));\\\\nvec4 nextNode = gWebGPUBuffer0.u_Data[int(float_j)];\\\\nfloat xDist = currentNode.x - nextNode.x;\\\\nfloat yDist = currentNode.y - nextNode.y;\\\\nfloat dist = sqrt((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nfloat attractiveF = dist / gWebGPUUniformParams.u_K;\\\\nif (dist > 0.0) {dx -= xDist * attractiveF;\\\\ndy -= yDist * attractiveF;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {float sign = (i < int(float_j)) ? (1.0) : (-1.0);\\\\ndx -= sign * attractiveF;\\\\ndy -= sign * attractiveF;}}}\\\\nreturn vec2(dx, dy);}\\\\nvoid main() {int i = globalInvocationID.x;\\\\nvec4 currentNode = gWebGPUBuffer0.u_Data[i];\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nif (i >= VERTEX_COUNT) {gWebGPUBuffer0.u_Data[i] = currentNode;\\\\nreturn ;}\\\\nvec4 nodeAttributes = gWebGPUBuffer1.u_AttributeArray[i];\\\\nif ((nodeAttributes.y != 0.0) && (nodeAttributes.z != 0.0)) {gWebGPUBuffer0.u_Data[i] = vec4(nodeAttributes.y, nodeAttributes.z, currentNode.z, currentNode.w);\\\\nreturn ;}\\\\nvec2 repulsive = calcRepulsive(i, currentNode);\\\\ndx += repulsive.x;\\\\ndy += repulsive.y;\\\\nvec2 attractive = calcAttractive(i, currentNode);\\\\ndx += attractive.x;\\\\ndy += attractive.y;\\\\nvec2 gravity = calcGravity(currentNode, nodeAttributes);\\\\ndx -= gravity.x;\\\\ndy -= gravity.y;\\\\ndx *= gWebGPUUniformParams.u_Speed;\\\\ndy *= gWebGPUUniformParams.u_Speed;\\\\nfloat distLength = sqrt((dx * dx) + (dy * dy));\\\\nif (distLength > 0.0) {float limitedDist = min(gWebGPUUniformParams.u_MaxDisplace * gWebGPUUniformParams.u_Speed, distLength);\\\\ngWebGPUBuffer0.u_Data[i] = vec4(currentNode.x + ((dx / distLength) * limitedDist), currentNode.y + ((dy / distLength) * limitedDist), currentNode.z, currentNode.w);}}\\\\n\",\"GLSL100\":\"\\\\n\\\\nfloat epsilon = 0.00001;\\\\nvec2 addrTranslation_1Dto2D(float address1D, vec2 texSize) {\\\\n vec2 conv_const = vec2(1.0 / texSize.x, 1.0 / (texSize.x * texSize.y));\\\\n vec2 normAddr2D = float(address1D) * conv_const;\\\\n return vec2(fract(normAddr2D.x + epsilon), normAddr2D.y);\\\\n}\\\\n\\\\nvoid barrier() {}\\\\n \\\\n\\\\nuniform vec2 u_OutputTextureSize;\\\\nuniform int u_OutputTexelCount;\\\\nvarying vec2 v_TexCoord;\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\n#define MAX_EDGE_PER_VERTEX __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n\\\\nuniform sampler2D u_Data;\\\\nuniform vec2 u_DataSize;\\\\nvec4 getDatau_Data(vec2 address2D) {\\\\n return vec4(texture2D(u_Data, address2D).rgba);\\\\n}\\\\nvec4 getDatau_Data(float address1D) {\\\\n return getDatau_Data(addrTranslation_1Dto2D(address1D, u_DataSize));\\\\n}\\\\nvec4 getDatau_Data(int address1D) {\\\\n return getDatau_Data(float(address1D));\\\\n}\\\\nuniform float u_K;\\\\nuniform float u_K2;\\\\nuniform vec2 u_Center;\\\\nuniform float u_Gravity;\\\\nuniform float u_ClusterGravity;\\\\nuniform float u_Speed;\\\\nuniform float u_MaxDisplace;\\\\nuniform float u_Clustering;\\\\nuniform sampler2D u_AttributeArray;\\\\nuniform vec2 u_AttributeArraySize;\\\\nvec4 getDatau_AttributeArray(vec2 address2D) {\\\\n return vec4(texture2D(u_AttributeArray, address2D).rgba);\\\\n}\\\\nvec4 getDatau_AttributeArray(float address1D) {\\\\n return getDatau_AttributeArray(addrTranslation_1Dto2D(address1D, u_AttributeArraySize));\\\\n}\\\\nvec4 getDatau_AttributeArray(int address1D) {\\\\n return getDatau_AttributeArray(float(address1D));\\\\n}\\\\nuniform sampler2D u_ClusterCenters;\\\\nuniform vec2 u_ClusterCentersSize;\\\\nvec4 getDatau_ClusterCenters(vec2 address2D) {\\\\n return vec4(texture2D(u_ClusterCenters, address2D).rgba);\\\\n}\\\\nvec4 getDatau_ClusterCenters(float address1D) {\\\\n return getDatau_ClusterCenters(addrTranslation_1Dto2D(address1D, u_ClusterCentersSize));\\\\n}\\\\nvec4 getDatau_ClusterCenters(int address1D) {\\\\n return getDatau_ClusterCenters(float(address1D));\\\\n}\\\\nvec2 calcRepulsive(int i, vec4 currentNode) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {if (i != j) {vec4 nextNode = getDatau_Data(j);\\\\nfloat xDist = currentNode.x - nextNode.x;\\\\nfloat yDist = currentNode.y - nextNode.y;\\\\nfloat dist = ((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nfloat param = u_K2 / dist;\\\\nif (dist > 0.0) {dx += param * xDist;\\\\ndy += param * yDist;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {float sign = (i < j) ? (1.0) : (-1.0);\\\\ndx += param * sign;\\\\ndy += param * sign;}}}}\\\\nreturn vec2(dx, dy);}\\\\nvec2 calcGravity(vec4 currentNode, vec4 nodeAttributes) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nfloat vx = currentNode.x - u_Center.x;\\\\nfloat vy = currentNode.y - u_Center.y;\\\\nfloat gf = (0.01 * u_K) * u_Gravity;\\\\ndx = gf * vx;\\\\ndy = gf * vy;\\\\nif (u_Clustering == 1.0) {int clusterIdx = int(nodeAttributes.x);\\\\nvec4 center = getDatau_ClusterCenters(clusterIdx);\\\\nfloat cvx = currentNode.x - center.x;\\\\nfloat cvy = currentNode.y - center.y;\\\\nfloat dist = sqrt((cvx * cvx) + (cvy * cvy)) + 0.01;\\\\nfloat parma = (u_K * u_ClusterGravity) / dist;\\\\ndx += parma * cvx;\\\\ndy += parma * cvy;}\\\\nreturn vec2(dx, dy);}\\\\nvec2 calcAttractive(int i, vec4 currentNode) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nint arr_offset = int(floor(currentNode.z + 0.5));\\\\nint length = int(floor(currentNode.w + 0.5));\\\\nvec4 node_buffer;\\\\nfor (int p = 0; p < MAX_EDGE_PER_VERTEX; p++) {if (p >= length) {break;}\\\\nint arr_idx = arr_offset + int(p);\\\\nint buf_offset = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = getDatau_Data(int(arr_idx / 4));}\\\\nfloat float_j = (buf_offset == 0) ? (node_buffer.x) : ((buf_offset == 1) ? (node_buffer.y) : ((buf_offset == 2) ? (node_buffer.z) : (node_buffer.w)));\\\\nvec4 nextNode = getDatau_Data(int(float_j));\\\\nfloat xDist = currentNode.x - nextNode.x;\\\\nfloat yDist = currentNode.y - nextNode.y;\\\\nfloat dist = sqrt((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nfloat attractiveF = dist / u_K;\\\\nif (dist > 0.0) {dx -= xDist * attractiveF;\\\\ndy -= yDist * attractiveF;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {float sign = (i < int(float_j)) ? (1.0) : (-1.0);\\\\ndx -= sign * attractiveF;\\\\ndy -= sign * attractiveF;}}}\\\\nreturn vec2(dx, dy);}\\\\nvoid main() {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nint i = globalInvocationID.x;\\\\nvec4 currentNode = getDatau_Data(i);\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nif (i >= VERTEX_COUNT) {gl_FragColor = vec4(currentNode);\\\\nreturn ;}\\\\nvec4 nodeAttributes = getDatau_AttributeArray(i);\\\\nif ((nodeAttributes.y != 0.0) && (nodeAttributes.z != 0.0)) {gl_FragColor = vec4(vec4(nodeAttributes.y, nodeAttributes.z, currentNode.z, currentNode.w));\\\\nreturn ;}\\\\nvec2 repulsive = calcRepulsive(i, currentNode);\\\\ndx += repulsive.x;\\\\ndy += repulsive.y;\\\\nvec2 attractive = calcAttractive(i, currentNode);\\\\ndx += attractive.x;\\\\ndy += attractive.y;\\\\nvec2 gravity = calcGravity(currentNode, nodeAttributes);\\\\ndx -= gravity.x;\\\\ndy -= gravity.y;\\\\ndx *= u_Speed;\\\\ndy *= u_Speed;\\\\nfloat distLength = sqrt((dx * dx) + (dy * dy));\\\\nif (distLength > 0.0) {float limitedDist = min(u_MaxDisplace * u_Speed, distLength);\\\\ngl_FragColor = vec4(vec4(currentNode.x + ((dx / distLength) * limitedDist), currentNode.y + ((dy / distLength) * limitedDist), currentNode.z, currentNode.w));}if (gWebGPUDebug) {\\\\n gl_FragColor = gWebGPUDebugOutput;\\\\n}}\\\\n\"},\"context\":{\"name\":\"\",\"dispatch\":[1,1,1],\"threadGroupSize\":[1,1,1],\"maxIteration\":1,\"defines\":[{\"name\":\"MAX_EDGE_PER_VERTEX\",\"type\":\"Float\",\"runtime\":true},{\"name\":\"VERTEX_COUNT\",\"type\":\"Float\",\"runtime\":true}],\"uniforms\":[{\"name\":\"u_Data\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":false,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_K\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_K2\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_Center\",\"type\":\"vec2<f32>\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_Gravity\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_ClusterGravity\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_Speed\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_MaxDisplace\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_Clustering\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_AttributeArray\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_ClusterCenters\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]}],\"globalDeclarations\":[],\"output\":{\"name\":\"u_Data\",\"size\":[1,1],\"length\":1},\"needPingpong\":true}}`;\nexport const clusterCode = `\nimport { globalInvocationID } from 'g-webgpu';\nconst VERTEX_COUNT;\nconst CLUSTER_COUNT;\n@numthreads(1, 1, 1)\nclass CalcCenter {\n @in\n u_Data: vec4[];\n @in\n u_NodeAttributes: vec4[]; // [[clusterIdx, 0, 0, 0], ...]\n @in @out\n u_ClusterCenters: vec4[]; // [[cx, cy, nodeCount, clusterIdx], ...]\n @main\n compute() {\n const i = globalInvocationID.x;\n const center = this.u_ClusterCenters[i];\n let sumx = 0;\n let sumy = 0;\n let count = 0;\n for (let j = 0; j < VERTEX_COUNT; j++) {\n const attributes = this.u_NodeAttributes[j];\n const clusterIdx = int(attributes[0]);\n const vertex = this.u_Data[j];\n if (clusterIdx == i) {\n sumx += vertex.x;\n sumy += vertex.y;\n count += 1;\n }\n }\n this.u_ClusterCenters[i] = [\n sumx / count,\n sumy / count,\n count,\n i\n ];\n }\n}\n`;\nexport const clusterBundle = `{\"shaders\":{\"WGSL\":\"import \\\\\"GLSL.std.450\\\\\" as std;\\\\n\\\\n\\\\n# var gWebGPUDebug : bool = false;\\\\n# var gWebGPUDebugOutput : vec4<f32> = vec4<f32>(0.0);\\\\n\\\\n[[builtin global_invocation_id]] var<in> globalInvocationID : vec3<u32>;\\\\n# [[builtin work_group_size]] var<in> workGroupSize : vec3<u32>;\\\\n# [[builtin work_group_id]] var<in> workGroupID : vec3<u32>;\\\\n[[builtin local_invocation_id]] var<in> localInvocationID : vec3<u32>;\\\\n# [[builtin num_work_groups]] var<in> numWorkGroups : vec3<u32>;\\\\n[[builtin local_invocation_idx]] var<in> localInvocationIndex : u32;\\\\n\\\\n\\\\ntype GWebGPUBuffer0 = [[block]] struct {\\\\n [[offset 0]] u_Data : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 0, set 0]] var<storage_buffer> gWebGPUBuffer0 : GWebGPUBuffer0;\\\\ntype GWebGPUBuffer1 = [[block]] struct {\\\\n [[offset 0]] u_NodeAttributes : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 1, set 0]] var<storage_buffer> gWebGPUBuffer1 : GWebGPUBuffer1;\\\\ntype GWebGPUBuffer2 = [[block]] struct {\\\\n [[offset 0]] u_ClusterCenters : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 2, set 0]] var<storage_buffer> gWebGPUBuffer2 : GWebGPUBuffer2;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nfn main() -> void {var i : i32 = globalInvocationID.x;\\\\nvar center : vec4<f32> = gWebGPUBuffer2.u_ClusterCenters[i];\\\\nvar sumx : f32 = 0.0;\\\\nvar sumy : f32 = 0.0;\\\\nvar count : f32 = 0.0;\\\\nfor (var j : i32 = 0; j < __DefineValuePlaceholder__VERTEX_COUNT; j = j + 1) {var attributes : vec4<f32> = gWebGPUBuffer1.u_NodeAttributes[j];\\\\nvar clusterIdx : i32 = i32(attributes.x);\\\\nvar vertex : vec4<f32> = gWebGPUBuffer0.u_Data[j];\\\\nif (clusterIdx == i) {sumx = sumx + vertex.x;\\\\nsumy = sumy + vertex.y;\\\\ncount = count + 1.0;}}\\\\ngWebGPUBuffer2.u_ClusterCenters[i] = vec4<f32>(sumx / count, sumy / count, count, i);\\\\nreturn;}\\\\n\\\\nentry_point compute as \\\\\"main\\\\\" = main;\\\\n\",\"GLSL450\":\"\\\\n\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\nivec3 globalInvocationID = ivec3(gl_GlobalInvocationID);\\\\nivec3 workGroupSize = ivec3(1,1,1);\\\\nivec3 workGroupID = ivec3(gl_WorkGroupID);\\\\nivec3 localInvocationID = ivec3(gl_LocalInvocationID);\\\\nivec3 numWorkGroups = ivec3(gl_NumWorkGroups);\\\\nint localInvocationIndex = int(gl_LocalInvocationIndex);\\\\n\\\\n\\\\nlayout(std430, set = 0, binding = 0) buffer readonly GWebGPUBuffer0 {\\\\n vec4 u_Data[];\\\\n} gWebGPUBuffer0;\\\\n\\\\nlayout(std430, set = 0, binding = 1) buffer readonly GWebGPUBuffer1 {\\\\n vec4 u_NodeAttributes[];\\\\n} gWebGPUBuffer1;\\\\n\\\\nlayout(std430, set = 0, binding = 2) buffer GWebGPUBuffer2 {\\\\n vec4 u_ClusterCenters[];\\\\n} gWebGPUBuffer2;\\\\n\\\\n\\\\n\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n#define CLUSTER_COUNT __DefineValuePlaceholder__CLUSTER_COUNT\\\\nlayout (\\\\n local_size_x = 1,\\\\n local_size_y = 1,\\\\n local_size_z = 1\\\\n) in;\\\\n\\\\n\\\\n\\\\nvoid main() {int i = globalInvocationID.x;\\\\nvec4 center = gWebGPUBuffer2.u_ClusterCenters[i];\\\\nfloat sumx = 0.0;\\\\nfloat sumy = 0.0;\\\\nfloat count = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {vec4 attributes = gWebGPUBuffer1.u_NodeAttributes[j];\\\\nint clusterIdx = int(attributes.x);\\\\nvec4 vertex = gWebGPUBuffer0.u_Data[j];\\\\nif (clusterIdx == i) {sumx += vertex.x;\\\\nsumy += vertex.y;\\\\ncount += 1.0;}}\\\\ngWebGPUBuffer2.u_ClusterCenters[i] = vec4(sumx / count, sumy / count, count, i);}\\\\n\",\"GLSL100\":\"\\\\n\\\\nfloat epsilon = 0.00001;\\\\nvec2 addrTranslation_1Dto2D(float address1D, vec2 texSize) {\\\\n vec2 conv_const = vec2(1.0 / texSize.x, 1.0 / (texSize.x * texSize.y));\\\\n vec2 normAddr2D = float(address1D) * conv_const;\\\\n return vec2(fract(normAddr2D.x + epsilon), normAddr2D.y);\\\\n}\\\\n\\\\nvoid barrier() {}\\\\n \\\\n\\\\nuniform vec2 u_OutputTextureSize;\\\\nuniform int u_OutputTexelCount;\\\\nvarying vec2 v_TexCoord;\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n#define CLUSTER_COUNT __DefineValuePlaceholder__CLUSTER_COUNT\\\\n\\\\nuniform sampler2D u_Data;\\\\nuniform vec2 u_DataSize;\\\\nvec4 getDatau_Data(vec2 address2D) {\\\\n return vec4(texture2D(u_Data, address2D).rgba);\\\\n}\\\\nvec4 getDatau_Data(float address1D) {\\\\n return getDatau_Data(addrTranslation_1Dto2D(address1D, u_DataSize));\\\\n}\\\\nvec4 getDatau_Data(int address1D) {\\\\n return getDatau_Data(float(address1D));\\\\n}\\\\nuniform sampler2D u_NodeAttributes;\\\\nuniform vec2 u_NodeAttributesSize;\\\\nvec4 getDatau_NodeAttributes(vec2 address2D) {\\\\n return vec4(texture2D(u_NodeAttributes, address2D).rgba);\\\\n}\\\\nvec4 getDatau_NodeAttributes(float address1D) {\\\\n return getDatau_NodeAttributes(addrTranslation_1Dto2D(address1D, u_NodeAttributesSize));\\\\n}\\\\nvec4 getDatau_NodeAttributes(int address1D) {\\\\n return getDatau_NodeAttributes(float(address1D));\\\\n}\\\\nuniform sampler2D u_ClusterCenters;\\\\nuniform vec2 u_ClusterCentersSize;\\\\nvec4 getDatau_ClusterCenters(vec2 address2D) {\\\\n return vec4(texture2D(u_ClusterCenters, address2D).rgba);\\\\n}\\\\nvec4 getDatau_ClusterCenters(float address1D) {\\\\n return getDatau_ClusterCenters(addrTranslation_1Dto2D(address1D, u_ClusterCentersSize));\\\\n}\\\\nvec4 getDatau_ClusterCenters(int address1D) {\\\\n return getDatau_ClusterCenters(float(address1D));\\\\n}\\\\nvoid main() {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nint i = globalInvocationID.x;\\\\nvec4 center = getDatau_ClusterCenters(i);\\\\nfloat sumx = 0.0;\\\\nfloat sumy = 0.0;\\\\nfloat count = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {vec4 attributes = getDatau_NodeAttributes(j);\\\\nint clusterIdx = int(attributes.x);\\\\nvec4 vertex = getDatau_Data(j);\\\\nif (clusterIdx == i) {sumx += vertex.x;\\\\nsumy += vertex.y;\\\\ncount += 1.0;}}\\\\ngl_FragColor = vec4(vec4(sumx / count, sumy / count, count, i));if (gWebGPUDebug) {\\\\n gl_FragColor = gWebGPUDebugOutput;\\\\n}}\\\\n\"},\"context\":{\"name\":\"\",\"dispatch\":[1,1,1],\"threadGroupSize\":[1,1,1],\"maxIteration\":1,\"defines\":[{\"name\":\"VERTEX_COUNT\",\"type\":\"Float\",\"runtime\":true},{\"name\":\"CLUSTER_COUNT\",\"type\":\"Float\",\"runtime\":true}],\"uniforms\":[{\"name\":\"u_Data\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_NodeAttributes\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_ClusterCenters\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":false,\"writeonly\":false,\"size\":[1,1]}],\"globalDeclarations\":[],\"output\":{\"name\":\"u_ClusterCenters\",\"size\":[1,1],\"length\":1},\"needPingpong\":true}}`;\n//# sourceMappingURL=fruchtermanShader.js.map","// @ts-nocheck\n/**\n * @fileOverview fruchterman layout\n * @author shiwu.wyy@antfin.com\n */\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { Base } from \"../base\";\nimport { isNumber } from \"../../util\";\n// @ts-ignore\nimport { World } from \"@antv/g-webgpu\";\nimport { proccessToFunc, buildTextureDataWithTwoEdgeAttr, arrayToTextureData } from \"../../util/gpu\";\nimport { getDegree } from \"../../util/math\";\nimport { gForceBundle, aveMovementBundle } from \"./gForceShader\";\nimport { LAYOUT_MESSAGE } from \"../constants\";\n/**\n * graphin 中的 force 布局\n */\nexport class GForceGPULayout extends Base {\n constructor(options) {\n super();\n /** 停止迭代的最大迭代数 */\n this.maxIteration = 1000;\n /** 弹簧引力系数 */\n this.edgeStrength = 200;\n /** 斥力系数 */\n this.nodeStrength = 1000;\n /** 库伦系数 */\n this.coulombDisScale = 0.005;\n /** 阻尼系数 */\n this.damping = 0.9;\n /** 最大速度 */\n this.maxSpeed = 1000;\n /** 一次迭代的平均移动距离小于该值时停止迭代 */\n this.minMovement = 0.5;\n /** 迭代中衰减 */\n this.interval = 0.02;\n /** 斥力的一个系数 */\n this.factor = 1;\n /** 理想边长 */\n this.linkDistance = 1;\n /** 重力大小 */\n this.gravity = 10;\n /** 是否启用web worker。前提是在web worker里执行布局,否则无效\t*/\n this.workerEnabled = false;\n this.nodes = [];\n this.edges = [];\n this.width = 300;\n this.height = 300;\n this.nodeMap = {};\n this.nodeIdxMap = {};\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n maxIteration: 2000,\n gravity: 10,\n clustering: false,\n clusterGravity: 10\n };\n }\n /**\n * 执行布局\n */\n execute() {\n return __awaiter(this, void 0, void 0, function* () {\n const self = this;\n const nodes = self.nodes;\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n const nodeMap = {};\n const nodeIdxMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x))\n node.x = Math.random() * self.width;\n if (!isNumber(node.y))\n node.y = Math.random() * self.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n self.nodeStrength = proccessToFunc(self.nodeStrength, 1);\n self.edgeStrength = proccessToFunc(self.edgeStrength, 1);\n // layout\n yield self.run();\n });\n }\n executeWithWorker(canvas, ctx) {\n const self = this;\n const nodes = self.nodes;\n const center = self.center;\n if (!nodes || nodes.length === 0) {\n return;\n }\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n return;\n }\n const nodeMap = {};\n const nodeIdxMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x))\n node.x = Math.random() * self.width;\n if (!isNumber(node.y))\n node.y = Math.random() * self.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n self.nodeStrength = proccessToFunc(self.nodeStrength, 1);\n self.edgeStrength = proccessToFunc(self.edgeStrength, 1);\n // layout\n self.run(canvas, ctx);\n }\n run(canvas, ctx) {\n return __awaiter(this, void 0, void 0, function* () {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const maxIteration = self.maxIteration;\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n const numParticles = nodes.length;\n self.linkDistance = proccessToFunc(self.linkDistance);\n self.edgeStrength = proccessToFunc(self.edgeStrength);\n const { maxEdgePerVetex, array: nodesEdgesArray } = buildTextureDataWithTwoEdgeAttr(nodes, edges, self.linkDistance, self.edgeStrength);\n // init degree for mass\n self.degrees = getDegree(nodes.length, self.nodeIdxMap, edges);\n const masses = [];\n const nodeStrengths = [];\n const centerXs = [];\n const centerYs = [];\n const centerGravities = [];\n const fxs = [];\n const fys = [];\n if (!self.getMass) {\n self.getMass = (d) => {\n return self.degrees[self.nodeIdxMap[d.id]] || 1;\n };\n }\n const gravity = self.gravity;\n const center = self.center;\n nodes.forEach((node, i) => {\n masses.push(self.getMass(node));\n nodeStrengths.push(self.nodeStrength(node));\n if (!self.degrees[i])\n self.degrees[i] = 0;\n let nodeGravity = [center[0], center[1], gravity];\n if (self.getCenter) {\n const customCenter = self.getCenter(node, self.degrees[i]);\n if (customCenter &&\n isNumber(customCenter[0]) &&\n isNumber(customCenter[1]) &&\n isNumber(customCenter[2])) {\n nodeGravity = customCenter;\n }\n }\n centerXs.push(nodeGravity[0]);\n centerYs.push(nodeGravity[1]);\n centerGravities.push(nodeGravity[2]);\n if (isNumber(node.fx) && isNumber(node.fy)) {\n fxs.push(node.fx || 0.001);\n fys.push(node.fy || 0.001);\n }\n else {\n fxs.push(0);\n fys.push(0);\n }\n });\n // 每个节点的额外属性占两个数组各一格,nodeAttributeArray1 中是:mass, degree, nodeSterngth, 0\n const nodeAttributeArray1 = arrayToTextureData([\n masses,\n self.degrees,\n nodeStrengths,\n fxs\n ]);\n // nodeAttributeArray2 中是:centerX, centerY, gravity, 0,\n const nodeAttributeArray2 = arrayToTextureData([\n centerXs,\n centerYs,\n centerGravities,\n fys\n ]);\n const workerEnabled = self.workerEnabled;\n let world;\n if (workerEnabled) {\n world = World.create({\n canvas,\n engineOptions: {\n supportCompute: true\n }\n });\n }\n else {\n world = World.create({\n engineOptions: {\n supportCompute: true\n }\n });\n }\n // TODO: 最终的预编译代码放入到 gForceShader.ts 中直接引入,不再需要下面三行\n // const compiler = new Compiler();\n // const gForceBundle = compiler.compileBundle(gForceCode);\n // console.log(gForceBundle.toString());\n const onLayoutEnd = self.onLayoutEnd;\n const initPreviousData = [];\n nodesEdgesArray.forEach((value) => {\n initPreviousData.push(value);\n });\n for (let i = 0; i < 4; i++) {\n initPreviousData.push(0);\n }\n const kernelGForce = world\n .createKernel(gForceBundle)\n .setDispatch([numParticles, 1, 1])\n .setBinding({\n u_Data: nodesEdgesArray,\n u_damping: self.damping,\n u_maxSpeed: self.maxSpeed,\n u_minMovement: self.minMovement,\n u_coulombDisScale: self.coulombDisScale,\n u_factor: self.factor,\n u_NodeAttributeArray1: nodeAttributeArray1,\n u_NodeAttributeArray2: nodeAttributeArray2,\n MAX_EDGE_PER_VERTEX: maxEdgePerVetex,\n VERTEX_COUNT: numParticles,\n u_AveMovement: initPreviousData,\n u_interval: self.interval // 每次迭代更新,首次设置为 interval,在 onIterationCompleted 中更新\n });\n // const aveMovementBundle = compiler.compileBundle(aveMovementCode);\n // console.log(aveMovementBundle.toString());\n const kernelAveMovement = world\n .createKernel(aveMovementBundle)\n .setDispatch([1, 1, 1])\n .setBinding({\n u_Data: nodesEdgesArray,\n VERTEX_COUNT: numParticles,\n u_AveMovement: [0, 0, 0, 0]\n });\n // 执行迭代\n // let midRes = nodesEdgesArray;\n const execute = () => __awaiter(this, void 0, void 0, function* () {\n for (let i = 0; i < maxIteration; i++) {\n // TODO: 似乎都来自 kernelGForce 是一个引用\n // 当前坐标作为下一次迭代的 PreviousData\n // if (i > 0) {\n // kernelAveMovement.setBinding({\n // u_PreviousData: kernelGForce\n // });\n // }\n // eslint-disable-next-line no-await-in-loop\n yield kernelGForce.execute();\n // midRes = await kernelGForce.getOutput();\n // 每次迭代完成后\n // 计算平均位移,用于提前终止迭代\n kernelAveMovement.setBinding({\n u_Data: kernelGForce\n });\n // eslint-disable-next-line no-await-in-loop\n yield kernelAveMovement.execute();\n // 更新衰减函数\n const stepInterval = Math.max(0.02, self.interval - i * 0.002);\n kernelGForce.setBinding({\n u_interval: stepInterval,\n u_AveMovement: kernelAveMovement\n });\n }\n const finalParticleData = yield kernelGForce.getOutput();\n // 所有迭代完成后\n if (canvas) {\n // 传递数据给主线程\n ctx.postMessage({\n type: LAYOUT_MESSAGE.GPUEND,\n vertexEdgeData: finalParticleData\n // edgeIndexBufferData,\n });\n }\n else {\n nodes.forEach((node, i) => {\n const x = finalParticleData[4 * i];\n const y = finalParticleData[4 * i + 1];\n node.x = x;\n node.y = y;\n });\n }\n if (onLayoutEnd)\n onLayoutEnd();\n });\n yield execute();\n });\n }\n getType() {\n return \"gForce-gpu\";\n }\n}\n//# sourceMappingURL=gForce.js.map","export const gForceCode = `\nimport { globalInvocationID } from 'g-webgpu';\n\nconst MAX_EDGE_PER_VERTEX;\nconst VERTEX_COUNT;\nconst SHIFT_20 = 1048576;\n\n@numthreads(1, 1, 1)\nclass GGForce {\n @in @out\n u_Data: vec4[];\n\n @in\n u_damping: float;\n \n @in\n u_maxSpeed: float;\n\n @in\n u_minMovement: float;\n\n @in\n u_AveMovement: vec4[];\n\n @in\n u_coulombDisScale: float;\n\n @in\n u_factor: float;\n\n @in\n u_NodeAttributeArray1: vec4[];\n\n @in\n u_NodeAttributeArray2: vec4[];\n\n @in\n u_interval: float;\n\n unpack_float(packedValue: float): ivec2 {\n const packedIntValue = int(packedValue);\n const v0 = packedIntValue / SHIFT_20;\n return [v0, packedIntValue - v0 * SHIFT_20];\n }\n\n calcRepulsive(i: int, currentNode: vec4): vec2 {\n let ax = 0, ay = 0;\n for (let j: int = 0; j < VERTEX_COUNT; j++) {\n if (i != j) {\n const nextNode = this.u_Data[j];\n const vx = currentNode[0] - nextNode[0];\n const vy = currentNode[1] - nextNode[1];\n const dist = sqrt(vx * vx + vy * vy) + 0.01;\n const n_dist = (dist + 0.1) * this.u_coulombDisScale;\n const direx = vx / dist;\n const direy = vy / dist;\n const attributesi = this.u_NodeAttributeArray1[i];\n const attributesj = this.u_NodeAttributeArray1[j];\n const massi = attributesi[0];\n const nodeStrengthi = attributesi[2];\n const nodeStrengthj = attributesj[2];\n const nodeStrength = (nodeStrengthi + nodeStrengthj) / 2;\n // const param = nodeStrength * this.u_factor / (n_dist * n_dist * massi);\n const param = nodeStrength * this.u_factor / (n_dist * n_dist);\n ax += direx * param;\n ay += direy * param;\n }\n }\n return [ax, ay];\n }\n\n calcGravity(i: int, currentNode: vec4, attributes2: vec4): vec2 {\n // note: attributes2 = [centerX, centerY, gravity, 0]\n\n const vx = currentNode[0] - attributes2[0];\n const vy = currentNode[1] - attributes2[1];\n \n const ax = vx * attributes2[2];\n const ay = vy * attributes2[2];\n \n return [ax, ay];\n }\n\n calcAttractive(i: int, currentNode: vec4, attributes1: vec4): vec2 {\n // note: attributes1 = [mass, degree, nodeSterngth, 0]\n\n const mass = attributes1[0];\n let ax = 0, ay = 0;\n // const arr_offset = int(floor(currentNode[2] + 0.5));\n // const length = int(floor(currentNode[3] + 0.5));\n\n const compressed = this.unpack_float(currentNode[2]);\n const length = compressed[0];\n const arr_offset = compressed[1];\n\n const node_buffer: vec4;\n for (let p: int = 0; p < MAX_EDGE_PER_VERTEX; p++) {\n if (p >= length) break;\n const arr_idx = arr_offset + 4 * p; // i 节点的第 p 条边开始的小格子位置\n const buf_offset = arr_idx - arr_idx / 4 * 4;\n if (p == 0 || buf_offset == 0) {\n node_buffer = this.u_Data[int(arr_idx / 4)]; // 大格子,大格子位置=小个子位置 / 4,\n }\n\n let float_j: float = node_buffer[0];\n\n const nextNode = this.u_Data[int(float_j)];\n const vx = nextNode[0] - currentNode[0];\n const vy = nextNode[1] - currentNode[1];\n const dist = sqrt(vx * vx + vy * vy) + 0.01;\n const direx = vx / dist;\n const direy = vy / dist;\n const edgeLength = node_buffer[1];\n const edgeStrength = node_buffer[2];\n const diff: float = edgeLength - dist;//edgeLength\n // const param = diff * this.u_stiffness / mass; //\n const param = diff * edgeStrength / mass; // \n ax -= direx * param;\n ay -= direy * param;\n }\n return [ax, ay];\n }\n\n @main\n compute() {\n const i = globalInvocationID.x;\n const currentNode = this.u_Data[i];\n const movement = u_AveMovement[0];\n let ax = 0, ay = 0;\n\n if (i >= VERTEX_COUNT || movement.x < u_minMovement) {\n this.u_Data[i] = currentNode;\n return;\n }\n\n // 每个节点属性占两个数组中各一格\n // [mass, degree, nodeStrength, fx]\n const nodeAttributes1 = this.u_NodeAttributeArray1[i];\n // [centerX, centerY, centerGravity, fy]\n const nodeAttributes2 = this.u_NodeAttributeArray2[i];\n\n // repulsive\n const repulsive = this.calcRepulsive(i, currentNode);\n ax += repulsive[0];\n ay += repulsive[1];\n\n // attractive\n const attractive = this.calcAttractive(i, currentNode, nodeAttributes1);\n ax += attractive[0];\n ay += attractive[1];\n\n // gravity\n const gravity = this.calcGravity(i, currentNode, nodeAttributes2);\n ax -= gravity[0];\n ay -= gravity[1];\n\n // speed\n const param = this.u_interval * this.u_damping;\n let vx = ax * param;\n let vy = ay * param;\n const vlength = sqrt(vx * vx + vy * vy) + 0.0001;\n if (vlength > this.u_maxSpeed) {\n const param2 = this.u_maxSpeed / vlength;\n vx = param2 * vx;\n vy = param2 * vy;\n }\n\n // move\n if (nodeAttributes1[3] != 0 && nodeAttributes2[3] != 0) {\n this.u_Data[i] = [\n nodeAttributes1[3],\n nodeAttributes2[3],\n currentNode[2],\n 0\n ];\n } else {\n const distx = vx * this.u_interval;\n const disty = vy * this.u_interval;\n const distLength = sqrt(distx * distx + disty * disty);\n this.u_Data[i] = [\n currentNode[0] + distx,\n currentNode[1] + disty,\n currentNode[2],\n distLength\n ];\n }\n \n // the avarage move distance\n // need to share memory\n \n }\n}\n`;\nexport const gForceBundle = `{\"shaders\":{\"WGSL\":\"import \\\\\"GLSL.std.450\\\\\" as std;\\\\n\\\\n\\\\n# var gWebGPUDebug : bool = false;\\\\n# var gWebGPUDebugOutput : vec4<f32> = vec4<f32>(0.0);\\\\n\\\\n[[builtin global_invocation_id]] var<in> globalInvocationID : vec3<u32>;\\\\n# [[builtin work_group_size]] var<in> workGroupSize : vec3<u32>;\\\\n# [[builtin work_group_id]] var<in> workGroupID : vec3<u32>;\\\\n[[builtin local_invocation_id]] var<in> localInvocationID : vec3<u32>;\\\\n# [[builtin num_work_groups]] var<in> numWorkGroups : vec3<u32>;\\\\n[[builtin local_invocation_idx]] var<in> localInvocationIndex : u32;\\\\n\\\\ntype GWebGPUParams = [[block]] struct {\\\\n [[offset 0]] u_damping : f32;\\\\n [[offset 4]] u_maxSpeed : f32;\\\\n [[offset 8]] u_minMovement : f32;\\\\n \\\\n [[offset 12]] u_coulombDisScale : f32;\\\\n [[offset 16]] u_factor : f32;\\\\n \\\\n \\\\n [[offset 20]] u_interval : f32;\\\\n};\\\\n[[binding 0, set 0]] var<uniform> gWebGPUUniformParams : GWebGPUParams;\\\\ntype GWebGPUBuffer0 = [[block]] struct {\\\\n [[offset 0]] u_Data : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 1, set 0]] var<storage_buffer> gWebGPUBuffer0 : GWebGPUBuffer0;\\\\ntype GWebGPUBuffer1 = [[block]] struct {\\\\n [[offset 0]] u_AveMovement : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 2, set 0]] var<storage_buffer> gWebGPUBuffer1 : GWebGPUBuffer1;\\\\ntype GWebGPUBuffer2 = [[block]] struct {\\\\n [[offset 0]] u_NodeAttributeArray1 : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 3, set 0]] var<storage_buffer> gWebGPUBuffer2 : GWebGPUBuffer2;\\\\ntype GWebGPUBuffer3 = [[block]] struct {\\\\n [[offset 0]] u_NodeAttributeArray2 : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 4, set 0]] var<storage_buffer> gWebGPUBuffer3 : GWebGPUBuffer3;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nfn unpack_float(packedValue : f32) -> vec2<i32> {var packedIntValue : i32 = i32(packedValue);\\\\nvar v0 : i32 = packedIntValue / 1048576;\\\\nreturn vec2<i32>(v0, packedIntValue - (v0 * 1048576));}\\\\nfn calcRepulsive(i : i32, currentNode : vec4<f32>) -> vec2<f32> {var ax : f32 = 0.0;\\\\nvar ay : f32 = 0.0;\\\\nfor (var j : i32 = 0; j < __DefineValuePlaceholder__VERTEX_COUNT; j = j + 1) {if (i != j) {var nextNode : vec4<f32> = gWebGPUBuffer0.u_Data[j];\\\\nvar vx : f32 = currentNode.x - nextNode.x;\\\\nvar vy : f32 = currentNode.y - nextNode.y;\\\\nvar dist : f32 = std::sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nvar n_dist : f32 = (dist + 0.1) * gWebGPUUniformParams.u_coulombDisScale;\\\\nvar direx : f32 = vx / dist;\\\\nvar direy : f32 = vy / dist;\\\\nvar attributesi : vec4<f32> = gWebGPUBuffer2.u_NodeAttributeArray1[i];\\\\nvar attributesj : vec4<f32> = gWebGPUBuffer2.u_NodeAttributeArray1[j];\\\\nvar massi : f32 = attributesi.x;\\\\nvar nodeStrengthi : f32 = attributesi.z;\\\\nvar nodeStrengthj : f32 = attributesj.z;\\\\nvar nodeStrength : f32 = (nodeStrengthi + nodeStrengthj) / 2.0;\\\\nvar param : f32 = (nodeStrength * gWebGPUUniformParams.u_factor) / (n_dist * n_dist);\\\\nax = ax + direx * param;\\\\nay = ay + direy * param;}}\\\\nreturn vec2<f32>(ax, ay);}\\\\nfn calcGravity(i : i32, currentNode : vec4<f32>, attributes2 : vec4<f32>) -> vec2<f32> {var vx : f32 = currentNode.x - attributes2.x;\\\\nvar vy : f32 = currentNode.y - attributes2.y;\\\\nvar ax : f32 = vx * attributes2.z;\\\\nvar ay : f32 = vy * attributes2.z;\\\\nreturn vec2<f32>(ax, ay);}\\\\nfn calcAttractive(i : i32, currentNode : vec4<f32>, attributes1 : vec4<f32>) -> vec2<f32> {var mass : f32 = attributes1.x;\\\\nvar ax : f32 = 0.0;\\\\nvar ay : f32 = 0.0;\\\\nvar compressed : vec2<i32> = unpack_float(currentNode.z);\\\\nvar length : i32 = compressed.x;\\\\nvar arr_offset : i32 = compressed.y;\\\\nvar node_buffer : vec4<f32>;\\\\nfor (var p : i32 = 0; p < __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX; p = p + 1) {if (p >= length) {break;}\\\\nvar arr_idx : i32 = arr_offset + (4 * p);\\\\nvar buf_offset : i32 = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = gWebGPUBuffer0.u_Data[i32(arr_idx / 4)];}\\\\nvar float_j : f32 = node_buffer.x;\\\\nvar nextNode : vec4<f32> = gWebGPUBuffer0.u_Data[i32(float_j)];\\\\nvar vx : f32 = nextNode.x - currentNode.x;\\\\nvar vy : f32 = nextNode.y - currentNode.y;\\\\nvar dist : f32 = std::sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nvar direx : f32 = vx / dist;\\\\nvar direy : f32 = vy / dist;\\\\nvar edgeLength : f32 = node_buffer.y;\\\\nvar edgeStrength : f32 = node_buffer.z;\\\\nvar diff : f32 = edgeLength - dist;\\\\nvar param : f32 = (diff * edgeStrength) / mass;\\\\nax = ax - direx * param;\\\\nay = ay - direy * param;}\\\\nreturn vec2<f32>(ax, ay);}\\\\nfn main() -> void {var i : i32 = globalInvocationID.x;\\\\nvar currentNode : vec4<f32> = gWebGPUBuffer0.u_Data[i];\\\\nvar movement : vec4<f32> = gWebGPUBuffer1.u_AveMovement[0];\\\\nvar ax : f32 = 0.0;\\\\nvar ay : f32 = 0.0;\\\\nif ((i >= __DefineValuePlaceholder__VERTEX_COUNT) || (movement.x < gWebGPUUniformParams.u_minMovement)) {gWebGPUBuffer0.u_Data[i] = currentNode;\\\\nreturn ;}\\\\nvar nodeAttributes1 : vec4<f32> = gWebGPUBuffer2.u_NodeAttributeArray1[i];\\\\nvar nodeAttributes2 : vec4<f32> = gWebGPUBuffer3.u_NodeAttributeArray2[i];\\\\nvar repulsive : vec2<f32> = calcRepulsive(i, currentNode);\\\\nax = ax + repulsive.x;\\\\nay = ay + repulsive.y;\\\\nvar attractive : vec2<f32> = calcAttractive(i, currentNode, nodeAttributes1);\\\\nax = ax + attractive.x;\\\\nay = ay + attractive.y;\\\\nvar gravity : vec2<f32> = calcGravity(i, currentNode, nodeAttributes2);\\\\nax = ax - gravity.x;\\\\nay = ay - gravity.y;\\\\nvar param : f32 = gWebGPUUniformParams.u_interval * gWebGPUUniformParams.u_damping;\\\\nvar vx : f32 = ax * param;\\\\nvar vy : f32 = ay * param;\\\\nvar vlength : f32 = std::sqrt((vx * vx) + (vy * vy)) + 0.0001;\\\\nif (vlength > gWebGPUUniformParams.u_maxSpeed) {var param2 : f32 = gWebGPUUniformParams.u_maxSpeed / vlength;\\\\nvx = param2 * vx;\\\\nvy = param2 * vy;}\\\\nvar distx : f32 = vx * gWebGPUUniformParams.u_interval;\\\\nvar disty : f32 = vy * gWebGPUUniformParams.u_interval;\\\\nvar distLength : f32 = std::sqrt((distx * distx) + (disty * disty));\\\\nif ((nodeAttributes1.w != 0.0) && (nodeAttributes2.w != 0.0)) {gWebGPUBuffer0.u_Data[i] = vec4<f32>(nodeAttributes1.w, nodeAttributes2.w, currentNode.z, 0.0);}else {gWebGPUBuffer0.u_Data[i] = vec4<f32>(currentNode.x + distx, currentNode.y + disty, currentNode.z, distLength);}\\\\nreturn;}\\\\n\\\\nentry_point compute as \\\\\"main\\\\\" = main;\\\\n\",\"GLSL450\":\"\\\\n\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\nivec3 globalInvocationID = ivec3(gl_GlobalInvocationID);\\\\nivec3 workGroupSize = ivec3(1,1,1);\\\\nivec3 workGroupID = ivec3(gl_WorkGroupID);\\\\nivec3 localInvocationID = ivec3(gl_LocalInvocationID);\\\\nivec3 numWorkGroups = ivec3(gl_NumWorkGroups);\\\\nint localInvocationIndex = int(gl_LocalInvocationIndex);\\\\n\\\\nlayout(std140, set = 0, binding = 0) uniform GWebGPUParams {\\\\n float u_damping;\\\\n float u_maxSpeed;\\\\n float u_minMovement;\\\\n \\\\n float u_coulombDisScale;\\\\n float u_factor;\\\\n \\\\n \\\\n float u_interval;\\\\n} gWebGPUUniformParams;\\\\nlayout(std430, set = 0, binding = 1) buffer GWebGPUBuffer0 {\\\\n vec4 u_Data[];\\\\n} gWebGPUBuffer0;\\\\n\\\\nlayout(std430, set = 0, binding = 2) buffer readonly GWebGPUBuffer1 {\\\\n vec4 u_AveMovement[];\\\\n} gWebGPUBuffer1;\\\\n\\\\nlayout(std430, set = 0, binding = 3) buffer readonly GWebGPUBuffer2 {\\\\n vec4 u_NodeAttributeArray1[];\\\\n} gWebGPUBuffer2;\\\\n\\\\nlayout(std430, set = 0, binding = 4) buffer readonly GWebGPUBuffer3 {\\\\n vec4 u_NodeAttributeArray2[];\\\\n} gWebGPUBuffer3;\\\\n\\\\n\\\\n\\\\n#define MAX_EDGE_PER_VERTEX __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n#define SHIFT_20 1048576.0\\\\nlayout (\\\\n local_size_x = 1,\\\\n local_size_y = 1,\\\\n local_size_z = 1\\\\n) in;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nivec2 unpack_float(float packedValue) {int packedIntValue = int(packedValue);\\\\nint v0 = packedIntValue / int(SHIFT_20);\\\\nreturn ivec2(v0, packedIntValue - (v0 * int(SHIFT_20)));}\\\\nvec2 calcRepulsive(int i, vec4 currentNode) {float ax = 0.0;\\\\nfloat ay = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {if (i != j) {vec4 nextNode = gWebGPUBuffer0.u_Data[j];\\\\nfloat vx = currentNode.x - nextNode.x;\\\\nfloat vy = currentNode.y - nextNode.y;\\\\nfloat dist = sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nfloat n_dist = (dist + 0.1) * gWebGPUUniformParams.u_coulombDisScale;\\\\nfloat direx = vx / dist;\\\\nfloat direy = vy / dist;\\\\nvec4 attributesi = gWebGPUBuffer2.u_NodeAttributeArray1[i];\\\\nvec4 attributesj = gWebGPUBuffer2.u_NodeAttributeArray1[j];\\\\nfloat massi = attributesi.x;\\\\nfloat nodeStrengthi = attributesi.z;\\\\nfloat nodeStrengthj = attributesj.z;\\\\nfloat nodeStrength = (nodeStrengthi + nodeStrengthj) / 2.0;\\\\nfloat param = (nodeStrength * gWebGPUUniformParams.u_factor) / (n_dist * n_dist);\\\\nax += direx * param;\\\\nay += direy * param;}}\\\\nreturn vec2(ax, ay);}\\\\nvec2 calcGravity(int i, vec4 currentNode, vec4 attributes2) {float vx = currentNode.x - attributes2.x;\\\\nfloat vy = currentNode.y - attributes2.y;\\\\nfloat ax = vx * attributes2.z;\\\\nfloat ay = vy * attributes2.z;\\\\nreturn vec2(ax, ay);}\\\\nvec2 calcAttractive(int i, vec4 currentNode, vec4 attributes1) {float mass = attributes1.x;\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nivec2 compressed = unpack_float(currentNode.z);\\\\nint length = compressed.x;\\\\nint arr_offset = compressed.y;\\\\nvec4 node_buffer;\\\\nfor (int p = 0; p < MAX_EDGE_PER_VERTEX; p++) {if (p >= length) {break;}\\\\nint arr_idx = arr_offset + (4 * p);\\\\nint buf_offset = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = gWebGPUBuffer0.u_Data[int(arr_idx / 4)];}\\\\nfloat float_j = node_buffer.x;\\\\nvec4 nextNode = gWebGPUBuffer0.u_Data[int(float_j)];\\\\nfloat vx = nextNode.x - currentNode.x;\\\\nfloat vy = nextNode.y - currentNode.y;\\\\nfloat dist = sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nfloat direx = vx / dist;\\\\nfloat direy = vy / dist;\\\\nfloat edgeLength = node_buffer.y;\\\\nfloat edgeStrength = node_buffer.z;\\\\nfloat diff = edgeLength - dist;\\\\nfloat param = (diff * edgeStrength) / mass;\\\\nax -= direx * param;\\\\nay -= direy * param;}\\\\nreturn vec2(ax, ay);}\\\\nvoid main() {int i = globalInvocationID.x;\\\\nvec4 currentNode = gWebGPUBuffer0.u_Data[i];\\\\nvec4 movement = gWebGPUBuffer1.u_AveMovement[0];\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nif ((i >= VERTEX_COUNT) || (movement.x < gWebGPUUniformParams.u_minMovement)) {gWebGPUBuffer0.u_Data[i] = currentNode;\\\\nreturn ;}\\\\nvec4 nodeAttributes1 = gWebGPUBuffer2.u_NodeAttributeArray1[i];\\\\nvec4 nodeAttributes2 = gWebGPUBuffer3.u_NodeAttributeArray2[i];\\\\nvec2 repulsive = calcRepulsive(i, currentNode);\\\\nax += repulsive.x;\\\\nay += repulsive.y;\\\\nvec2 attractive = calcAttractive(i, currentNode, nodeAttributes1);\\\\nax += attractive.x;\\\\nay += attractive.y;\\\\nvec2 gravity = calcGravity(i, currentNode, nodeAttributes2);\\\\nax -= gravity.x;\\\\nay -= gravity.y;\\\\nfloat param = gWebGPUUniformParams.u_interval * gWebGPUUniformParams.u_damping;\\\\nfloat vx = ax * param;\\\\nfloat vy = ay * param;\\\\nfloat vlength = sqrt((vx * vx) + (vy * vy)) + 0.0001;\\\\nif (vlength > gWebGPUUniformParams.u_maxSpeed) {float param2 = gWebGPUUniformParams.u_maxSpeed / vlength;\\\\nvx = param2 * vx;\\\\nvy = param2 * vy;}\\\\nfloat distx = vx * gWebGPUUniformParams.u_interval;\\\\nfloat disty = vy * gWebGPUUniformParams.u_interval;\\\\nfloat distLength = sqrt((distx * distx) + (disty * disty));\\\\nif ((nodeAttributes1.w != 0.0) && (nodeAttributes2.w != 0.0)) {gWebGPUBuffer0.u_Data[i] = vec4(nodeAttributes1.w, nodeAttributes2.w, currentNode.z, 0.0);}else {gWebGPUBuffer0.u_Data[i] = vec4(currentNode.x + distx, currentNode.y + disty, currentNode.z, distLength);}}\\\\n\",\"GLSL100\":\"\\\\n\\\\nfloat epsilon = 0.00001;\\\\nvec2 addrTranslation_1Dto2D(float address1D, vec2 texSize) {\\\\n vec2 conv_const = vec2(1.0 / texSize.x, 1.0 / (texSize.x * texSize.y));\\\\n vec2 normAddr2D = float(address1D) * conv_const;\\\\n return vec2(fract(normAddr2D.x + epsilon), normAddr2D.y);\\\\n}\\\\n\\\\nvoid barrier() {}\\\\n \\\\n\\\\nuniform vec2 u_OutputTextureSize;\\\\nuniform int u_OutputTexelCount;\\\\nvarying vec2 v_TexCoord;\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\n#define MAX_EDGE_PER_VERTEX __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n#define SHIFT_20 1048576.0\\\\n\\\\nuniform sampler2D u_Data;\\\\nuniform vec2 u_DataSize;\\\\nvec4 getDatau_Data(vec2 address2D) {\\\\n return vec4(texture2D(u_Data, address2D).rgba);\\\\n}\\\\nvec4 getDatau_Data(float address1D) {\\\\n return getDatau_Data(addrTranslation_1Dto2D(address1D, u_DataSize));\\\\n}\\\\nvec4 getDatau_Data(int address1D) {\\\\n return getDatau_Data(float(address1D));\\\\n}\\\\nuniform float u_damping;\\\\nuniform float u_maxSpeed;\\\\nuniform float u_minMovement;\\\\nuniform sampler2D u_AveMovement;\\\\nuniform vec2 u_AveMovementSize;\\\\nvec4 getDatau_AveMovement(vec2 address2D) {\\\\n return vec4(texture2D(u_AveMovement, address2D).rgba);\\\\n}\\\\nvec4 getDatau_AveMovement(float address1D) {\\\\n return getDatau_AveMovement(addrTranslation_1Dto2D(address1D, u_AveMovementSize));\\\\n}\\\\nvec4 getDatau_AveMovement(int address1D) {\\\\n return getDatau_AveMovement(float(address1D));\\\\n}\\\\nuniform float u_coulombDisScale;\\\\nuniform float u_factor;\\\\nuniform sampler2D u_NodeAttributeArray1;\\\\nuniform vec2 u_NodeAttributeArray1Size;\\\\nvec4 getDatau_NodeAttributeArray1(vec2 address2D) {\\\\n return vec4(texture2D(u_NodeAttributeArray1, address2D).rgba);\\\\n}\\\\nvec4 getDatau_NodeAttributeArray1(float address1D) {\\\\n return getDatau_NodeAttributeArray1(addrTranslation_1Dto2D(address1D, u_NodeAttributeArray1Size));\\\\n}\\\\nvec4 getDatau_NodeAttributeArray1(int address1D) {\\\\n return getDatau_NodeAttributeArray1(float(address1D));\\\\n}\\\\nuniform sampler2D u_NodeAttributeArray2;\\\\nuniform vec2 u_NodeAttributeArray2Size;\\\\nvec4 getDatau_NodeAttributeArray2(vec2 address2D) {\\\\n return vec4(texture2D(u_NodeAttributeArray2, address2D).rgba);\\\\n}\\\\nvec4 getDatau_NodeAttributeArray2(float address1D) {\\\\n return getDatau_NodeAttributeArray2(addrTranslation_1Dto2D(address1D, u_NodeAttributeArray2Size));\\\\n}\\\\nvec4 getDatau_NodeAttributeArray2(int address1D) {\\\\n return getDatau_NodeAttributeArray2(float(address1D));\\\\n}\\\\nuniform float u_interval;\\\\nivec2 unpack_float(float packedValue) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nint packedIntValue = int(packedValue);\\\\nint v0 = packedIntValue / int(SHIFT_20);\\\\nreturn ivec2(v0, packedIntValue - (v0 * int(SHIFT_20)));}\\\\nvec2 calcRepulsive(int i, vec4 currentNode) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {if (i != j) {vec4 nextNode = getDatau_Data(j);\\\\nfloat vx = currentNode.x - nextNode.x;\\\\nfloat vy = currentNode.y - nextNode.y;\\\\nfloat dist = sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nfloat n_dist = (dist + 0.1) * u_coulombDisScale;\\\\nfloat direx = vx / dist;\\\\nfloat direy = vy / dist;\\\\nvec4 attributesi = getDatau_NodeAttributeArray1(i);\\\\nvec4 attributesj = getDatau_NodeAttributeArray1(j);\\\\nfloat massi = attributesi.x;\\\\nfloat nodeStrengthi = attributesi.z;\\\\nfloat nodeStrengthj = attributesj.z;\\\\nfloat nodeStrength = (nodeStrengthi + nodeStrengthj) / 2.0;\\\\nfloat param = (nodeStrength * u_factor) / (n_dist * n_dist);\\\\nax += direx * param;\\\\nay += direy * param;}}\\\\nreturn vec2(ax, ay);}\\\\nvec2 calcGravity(int i, vec4 currentNode, vec4 attributes2) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat vx = currentNode.x - attributes2.x;\\\\nfloat vy = currentNode.y - attributes2.y;\\\\nfloat ax = vx * attributes2.z;\\\\nfloat ay = vy * attributes2.z;\\\\nreturn vec2(ax, ay);}\\\\nvec2 calcAttractive(int i, vec4 currentNode, vec4 attributes1) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat mass = attributes1.x;\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nivec2 compressed = unpack_float(currentNode.z);\\\\nint length = compressed.x;\\\\nint arr_offset = compressed.y;\\\\nvec4 node_buffer;\\\\nfor (int p = 0; p < MAX_EDGE_PER_VERTEX; p++) {if (p >= length) {break;}\\\\nint arr_idx = arr_offset + (4 * p);\\\\nint buf_offset = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = getDatau_Data(int(arr_idx / 4));}\\\\nfloat float_j = node_buffer.x;\\\\nvec4 nextNode = getDatau_Data(int(float_j));\\\\nfloat vx = nextNode.x - currentNode.x;\\\\nfloat vy = nextNode.y - currentNode.y;\\\\nfloat dist = sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nfloat direx = vx / dist;\\\\nfloat direy = vy / dist;\\\\nfloat edgeLength = node_buffer.y;\\\\nfloat edgeStrength = node_buffer.z;\\\\nfloat diff = edgeLength - dist;\\\\nfloat param = (diff * edgeStrength) / mass;\\\\nax -= direx * param;\\\\nay -= direy * param;}\\\\nreturn vec2(ax, ay);}\\\\nvoid main() {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nint i = globalInvocationID.x;\\\\nvec4 currentNode = getDatau_Data(i);\\\\nvec4 movement = getDatau_AveMovement(0.0);\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nif ((i >= VERTEX_COUNT) || (movement.x < u_minMovement)) {gl_FragColor = vec4(currentNode);\\\\nreturn ;}\\\\nvec4 nodeAttributes1 = getDatau_NodeAttributeArray1(i);\\\\nvec4 nodeAttributes2 = getDatau_NodeAttributeArray2(i);\\\\nvec2 repulsive = calcRepulsive(i, currentNode);\\\\nax += repulsive.x;\\\\nay += repulsive.y;\\\\nvec2 attractive = calcAttractive(i, currentNode, nodeAttributes1);\\\\nax += attractive.x;\\\\nay += attractive.y;\\\\nvec2 gravity = calcGravity(i, currentNode, nodeAttributes2);\\\\nax -= gravity.x;\\\\nay -= gravity.y;\\\\nfloat param = u_interval * u_damping;\\\\nfloat vx = ax * param;\\\\nfloat vy = ay * param;\\\\nfloat vlength = sqrt((vx * vx) + (vy * vy)) + 0.0001;\\\\nif (vlength > u_maxSpeed) {float param2 = u_maxSpeed / vlength;\\\\nvx = param2 * vx;\\\\nvy = param2 * vy;}\\\\nfloat distx = vx * u_interval;\\\\nfloat disty = vy * u_interval;\\\\nfloat distLength = sqrt((distx * distx) + (disty * disty));\\\\nif ((nodeAttributes1.w != 0.0) && (nodeAttributes2.w != 0.0)) {gl_FragColor = vec4(vec4(nodeAttributes1.w, nodeAttributes2.w, currentNode.z, 0.0));}else {gl_FragColor = vec4(vec4(currentNode.x + distx, currentNode.y + disty, currentNode.z, distLength));}if (gWebGPUDebug) {\\\\n gl_FragColor = gWebGPUDebugOutput;\\\\n}}\\\\n\"},\"context\":{\"name\":\"\",\"dispatch\":[1,1,1],\"threadGroupSize\":[1,1,1],\"maxIteration\":1,\"defines\":[{\"name\":\"MAX_EDGE_PER_VERTEX\",\"type\":\"Float\",\"runtime\":true},{\"name\":\"VERTEX_COUNT\",\"type\":\"Float\",\"runtime\":true},{\"name\":\"SHIFT_20\",\"type\":\"Float\",\"value\":1048576,\"runtime\":false}],\"uniforms\":[{\"name\":\"u_Data\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":false,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_damping\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_maxSpeed\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_minMovement\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_AveMovement\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_coulombDisScale\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_factor\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_NodeAttributeArray1\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_NodeAttributeArray2\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_interval\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]}],\"globalDeclarations\":[],\"output\":{\"name\":\"u_Data\",\"size\":[1,1],\"length\":1},\"needPingpong\":true}}`;\nexport const aveMovementCode = `\nconst VERTEX_COUNT;\n@numthreads(1, 1, 1)\nclass CalcAveMovement {\n @in\n u_Data: vec4[];\n @in\n u_iter: float;\n @in @out\n u_AveMovement: vec4[];\n @main\n compute() {\n let movement = 0;\n for (let j: int = 0; j < VERTEX_COUNT; j++) {\n const vertex = this.u_Data[j];\n movement += vertex[3];\n }\n movement = movement / float(VERTEX_COUNT);\n this.u_AveMovement[0] = [movement, 0, 0, 0];\n }\n}\n`;\nexport const aveMovementBundle = `{\"shaders\":{\"WGSL\":\"import \\\\\"GLSL.std.450\\\\\" as std;\\\\n\\\\n\\\\n# var gWebGPUDebug : bool = false;\\\\n# var gWebGPUDebugOutput : vec4<f32> = vec4<f32>(0.0);\\\\n\\\\n[[builtin global_invocation_id]] var<in> globalInvocationID : vec3<u32>;\\\\n# [[builtin work_group_size]] var<in> workGroupSize : vec3<u32>;\\\\n# [[builtin work_group_id]] var<in> workGroupID : vec3<u32>;\\\\n[[builtin local_invocation_id]] var<in> localInvocationID : vec3<u32>;\\\\n# [[builtin num_work_groups]] var<in> numWorkGroups : vec3<u32>;\\\\n[[builtin local_invocation_idx]] var<in> localInvocationIndex : u32;\\\\n\\\\ntype GWebGPUParams = [[block]] struct {\\\\n [[offset 0]] u_iter : f32;\\\\n};\\\\n[[binding 0, set 0]] var<uniform> gWebGPUUniformParams : GWebGPUParams;\\\\ntype GWebGPUBuffer0 = [[block]] struct {\\\\n [[offset 0]] u_Data : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 1, set 0]] var<storage_buffer> gWebGPUBuffer0 : GWebGPUBuffer0;\\\\ntype GWebGPUBuffer1 = [[block]] struct {\\\\n [[offset 0]] u_AveMovement : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 2, set 0]] var<storage_buffer> gWebGPUBuffer1 : GWebGPUBuffer1;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nfn main() -> void {var movement : f32 = 0.0;\\\\nfor (var j : i32 = 0; j < __DefineValuePlaceholder__VERTEX_COUNT; j = j + 1) {var vertex : vec4<f32> = gWebGPUBuffer0.u_Data[j];\\\\nmovement = movement + vertex.w;}\\\\nmovement = movement / f32(__DefineValuePlaceholder__VERTEX_COUNT);\\\\ngWebGPUBuffer1.u_AveMovement[0] = vec4<f32>(movement, 0.0, 0.0, 0.0);\\\\nreturn;}\\\\n\\\\nentry_point compute as \\\\\"main\\\\\" = main;\\\\n\",\"GLSL450\":\"\\\\n\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\nivec3 globalInvocationID = ivec3(gl_GlobalInvocationID);\\\\nivec3 workGroupSize = ivec3(1,1,1);\\\\nivec3 workGroupID = ivec3(gl_WorkGroupID);\\\\nivec3 localInvocationID = ivec3(gl_LocalInvocationID);\\\\nivec3 numWorkGroups = ivec3(gl_NumWorkGroups);\\\\nint localInvocationIndex = int(gl_LocalInvocationIndex);\\\\n\\\\nlayout(std140, set = 0, binding = 0) uniform GWebGPUParams {\\\\n float u_iter;\\\\n} gWebGPUUniformParams;\\\\nlayout(std430, set = 0, binding = 1) buffer readonly GWebGPUBuffer0 {\\\\n vec4 u_Data[];\\\\n} gWebGPUBuffer0;\\\\n\\\\nlayout(std430, set = 0, binding = 2) buffer GWebGPUBuffer1 {\\\\n vec4 u_AveMovement[];\\\\n} gWebGPUBuffer1;\\\\n\\\\n\\\\n\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\nlayout (\\\\n local_size_x = 1,\\\\n local_size_y = 1,\\\\n local_size_z = 1\\\\n) in;\\\\n\\\\n\\\\n\\\\nvoid main() {float movement = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {vec4 vertex = gWebGPUBuffer0.u_Data[j];\\\\nmovement += vertex.w;}\\\\nmovement = movement / float(VERTEX_COUNT);\\\\ngWebGPUBuffer1.u_AveMovement[0] = vec4(movement, 0.0, 0.0, 0.0);}\\\\n\",\"GLSL100\":\"\\\\n\\\\nfloat epsilon = 0.00001;\\\\nvec2 addrTranslation_1Dto2D(float address1D, vec2 texSize) {\\\\n vec2 conv_const = vec2(1.0 / texSize.x, 1.0 / (texSize.x * texSize.y));\\\\n vec2 normAddr2D = float(address1D) * conv_const;\\\\n return vec2(fract(normAddr2D.x + epsilon), normAddr2D.y);\\\\n}\\\\n\\\\nvoid barrier() {}\\\\n \\\\n\\\\nuniform vec2 u_OutputTextureSize;\\\\nuniform int u_OutputTexelCount;\\\\nvarying vec2 v_TexCoord;\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n\\\\nuniform sampler2D u_Data;\\\\nuniform vec2 u_DataSize;\\\\nvec4 getDatau_Data(vec2 address2D) {\\\\n return vec4(texture2D(u_Data, address2D).rgba);\\\\n}\\\\nvec4 getDatau_Data(float address1D) {\\\\n return getDatau_Data(addrTranslation_1Dto2D(address1D, u_DataSize));\\\\n}\\\\nvec4 getDatau_Data(int address1D) {\\\\n return getDatau_Data(float(address1D));\\\\n}\\\\nuniform float u_iter;\\\\nuniform sampler2D u_AveMovement;\\\\nuniform vec2 u_AveMovementSize;\\\\nvec4 getDatau_AveMovement(vec2 address2D) {\\\\n return vec4(texture2D(u_AveMovement, address2D).rgba);\\\\n}\\\\nvec4 getDatau_AveMovement(float address1D) {\\\\n return getDatau_AveMovement(addrTranslation_1Dto2D(address1D, u_AveMovementSize));\\\\n}\\\\nvec4 getDatau_AveMovement(int address1D) {\\\\n return getDatau_AveMovement(float(address1D));\\\\n}\\\\nvoid main() {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat movement = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {vec4 vertex = getDatau_Data(j);\\\\nmovement += vertex.w;}\\\\nmovement = movement / float(VERTEX_COUNT);\\\\ngl_FragColor = vec4(vec4(movement, 0.0, 0.0, 0.0));if (gWebGPUDebug) {\\\\n gl_FragColor = gWebGPUDebugOutput;\\\\n}}\\\\n\"},\"context\":{\"name\":\"\",\"dispatch\":[1,1,1],\"threadGroupSize\":[1,1,1],\"maxIteration\":1,\"defines\":[{\"name\":\"VERTEX_COUNT\",\"type\":\"Float\",\"runtime\":true}],\"uniforms\":[{\"name\":\"u_Data\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_iter\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_AveMovement\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":false,\"writeonly\":false,\"size\":[1,1]}],\"globalDeclarations\":[],\"output\":{\"name\":\"u_AveMovement\",\"size\":[1,1],\"length\":1},\"needPingpong\":true}}`;\n//# sourceMappingURL=gForceShader.js.map","/**\n * @fileOverview Combo force layout\n * @author shiwu.wyy@antfin.com\n */\nimport { Base } from \"./base\";\nimport { isArray, isNumber, isFunction, traverseTreeUp, isObject, getEdgeTerminal } from \"../util\";\n/**\n * force layout for graph with combos\n */\nexport class ComboForceLayout extends Base {\n constructor(options) {\n super();\n /** 布局中心 */\n this.center = [0, 0];\n /** 停止迭代的最大迭代数 */\n this.maxIteration = 100;\n /** 重力大小,影响图的紧凑程度 */\n this.gravity = 10;\n /** 群组中心力大小 */\n this.comboGravity = 10;\n /** 默认边长度 */\n this.linkDistance = 10;\n /** 每次迭代位移的衰减相关参数 */\n this.alpha = 1;\n this.alphaMin = 0.001;\n this.alphaDecay = 1 - Math.pow(this.alphaMin, (1 / 300));\n this.alphaTarget = 0;\n /** 节点运动速度衰减参数 */\n this.velocityDecay = 0.6;\n /** 边引力大小 */\n this.edgeStrength = 0.6;\n /** 节点引力大小 */\n this.nodeStrength = 30;\n /** 是否开启防止重叠 */\n this.preventOverlap = false;\n /** 是否开启节点之间的防止重叠 */\n this.preventNodeOverlap = false;\n /** 是否开启 Combo 之间的防止重叠 */\n this.preventComboOverlap = false;\n /** 防止重叠的碰撞力大小 */\n this.collideStrength = undefined;\n /** 防止重叠的碰撞力大小 */\n this.nodeCollideStrength = 0.5;\n /** 防止重叠的碰撞力大小 */\n this.comboCollideStrength = 0.5;\n /** Combo 最小间距,防止重叠时的间隙 */\n this.comboSpacing = 20;\n /** Combo 内部的 padding */\n this.comboPadding = 10;\n /** 优化计算斥力的速度,两节点间距超过 optimizeRangeFactor * width 则不再计算斥力和重叠斥力 */\n this.optimizeRangeFactor = 1;\n /** 每次迭代的回调函数 */\n this.onTick = () => { };\n /** 迭代结束的回调函数 */\n this.onLayoutEnd = () => { };\n /** 根据边两端节点层级差距的调整引力系数的因子,取值范围 [0, 1]。层级差距越大,引力越小 */\n this.depthAttractiveForceScale = 1;\n /** 根据边两端节点层级差距的调整斥力系数的因子,取值范围 [1, Infinity]。层级差距越大,斥力越大 */\n this.depthRepulsiveForceScale = 2;\n /** 内部计算参数 */\n this.nodes = [];\n this.edges = [];\n this.combos = [];\n this.comboTrees = [];\n this.width = 300;\n this.height = 300;\n this.bias = [];\n this.nodeMap = {};\n this.oriComboMap = {};\n this.indexMap = {};\n this.comboMap = {};\n this.previousLayouted = false;\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {\n maxIteration: 100,\n center: [0, 0],\n gravity: 10,\n speed: 1,\n comboGravity: 30,\n preventOverlap: false,\n preventComboOverlap: true,\n preventNodeOverlap: true,\n nodeSpacing: undefined,\n collideStrength: undefined,\n nodeCollideStrength: 0.5,\n comboCollideStrength: 0.5,\n comboSpacing: 20,\n comboPadding: 10,\n edgeStrength: 0.6,\n nodeStrength: 30,\n linkDistance: 10\n };\n }\n /**\n * 执行布局\n */\n execute() {\n const self = this;\n const nodes = self.nodes;\n const center = self.center;\n self.comboTree = {\n id: \"comboTreeRoot\",\n depth: -1,\n children: self.comboTrees\n };\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n return;\n }\n self.initVals();\n // layout\n self.run();\n if (self.onLayoutEnd)\n self.onLayoutEnd();\n }\n run() {\n const self = this;\n const nodes = self.nodes;\n const maxIteration = self.previousLayouted\n ? self.maxIteration / 5\n : self.maxIteration;\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n const center = self.center;\n const velocityDecay = self.velocityDecay;\n // init the positions to make the nodes with same combo gather around the combo\n const comboMap = self.comboMap;\n if (!self.previousLayouted)\n self.initPos(comboMap);\n // iterate\n for (let i = 0; i < maxIteration; i++) {\n const displacements = [];\n nodes.forEach((_, j) => {\n displacements[j] = { x: 0, y: 0 };\n });\n self.applyCalculate(displacements);\n // gravity for combos\n self.applyComboCenterForce(displacements);\n // move\n nodes.forEach((n, j) => {\n if (!isNumber(n.x) || !isNumber(n.y))\n return;\n n.x += displacements[j].x * velocityDecay;\n n.y += displacements[j].y * velocityDecay;\n });\n self.alpha += (self.alphaTarget - self.alpha) * self.alphaDecay;\n self.onTick();\n }\n // move to center\n const meanCenter = [0, 0];\n nodes.forEach((n) => {\n if (!isNumber(n.x) || !isNumber(n.y))\n return;\n meanCenter[0] += n.x;\n meanCenter[1] += n.y;\n });\n meanCenter[0] /= nodes.length;\n meanCenter[1] /= nodes.length;\n const centerOffset = [center[0] - meanCenter[0], center[1] - meanCenter[1]];\n nodes.forEach((n, j) => {\n if (!isNumber(n.x) || !isNumber(n.y))\n return;\n n.x += centerOffset[0];\n n.y += centerOffset[1];\n });\n // arrange the empty combo\n self.combos.forEach((combo) => {\n const mapped = comboMap[combo.id];\n if (mapped && mapped.empty) {\n combo.x = mapped.cx || combo.x;\n combo.y = mapped.cy || combo.y;\n }\n });\n self.previousLayouted = true;\n }\n initVals() {\n const self = this;\n const edges = self.edges;\n const nodes = self.nodes;\n const combos = self.combos;\n const count = {};\n const nodeMap = {};\n const indexMap = {};\n nodes.forEach((node, i) => {\n nodeMap[node.id] = node;\n indexMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.indexMap = indexMap;\n const oriComboMap = {};\n combos.forEach((combo) => {\n oriComboMap[combo.id] = combo;\n });\n self.oriComboMap = oriComboMap;\n self.comboMap = self.getComboMap();\n const preventOverlap = self.preventOverlap;\n self.preventComboOverlap = self.preventComboOverlap || preventOverlap;\n self.preventNodeOverlap = self.preventNodeOverlap || preventOverlap;\n const collideStrength = self.collideStrength;\n if (collideStrength) {\n self.comboCollideStrength = collideStrength;\n self.nodeCollideStrength = collideStrength;\n }\n self.comboCollideStrength = self.comboCollideStrength\n ? self.comboCollideStrength\n : 0;\n self.nodeCollideStrength = self.nodeCollideStrength\n ? self.nodeCollideStrength\n : 0;\n // get edge bias\n for (let i = 0; i < edges.length; ++i) {\n const source = getEdgeTerminal(edges[i], 'source');\n const target = getEdgeTerminal(edges[i], 'target');\n if (count[source])\n count[source]++;\n else\n count[source] = 1;\n if (count[target])\n count[target]++;\n else\n count[target] = 1;\n }\n const bias = [];\n for (let i = 0; i < edges.length; ++i) {\n const source = getEdgeTerminal(edges[i], 'source');\n const target = getEdgeTerminal(edges[i], 'target');\n bias[i] = count[source] / (count[source] + count[target]);\n }\n this.bias = bias;\n const nodeSize = self.nodeSize;\n const nodeSpacing = self.nodeSpacing;\n let nodeSizeFunc;\n let nodeSpacingFunc;\n // nodeSpacing to function\n if (isNumber(nodeSpacing)) {\n nodeSpacingFunc = () => nodeSpacing;\n }\n else if (isFunction(nodeSpacing)) {\n nodeSpacingFunc = nodeSpacing;\n }\n else {\n nodeSpacingFunc = () => 0;\n }\n this.nodeSpacing = nodeSpacingFunc;\n // nodeSize to function\n if (!nodeSize) {\n nodeSizeFunc = (d) => {\n if (d.size) {\n if (isArray(d.size)) {\n const res = d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n return res / 2;\n }\n if (isObject(d.size)) {\n const res = d.size.width > d.size.height ? d.size.width : d.size.height;\n return res / 2;\n }\n return d.size / 2;\n }\n return 10;\n };\n }\n else if (isFunction(nodeSize)) {\n nodeSizeFunc = (d) => {\n return nodeSize(d);\n };\n }\n else if (isArray(nodeSize)) {\n const larger = nodeSize[0] > nodeSize[1] ? nodeSize[0] : nodeSize[1];\n const radius = larger / 2;\n nodeSizeFunc = (d) => radius;\n }\n else {\n // number type\n const radius = nodeSize / 2;\n nodeSizeFunc = (d) => radius;\n }\n this.nodeSize = nodeSizeFunc;\n // comboSpacing to function\n const comboSpacing = self.comboSpacing;\n let comboSpacingFunc;\n if (isNumber(comboSpacing)) {\n comboSpacingFunc = () => comboSpacing;\n }\n else if (isFunction(comboSpacing)) {\n comboSpacingFunc = comboSpacing;\n }\n else {\n // null type\n comboSpacingFunc = () => 0;\n }\n this.comboSpacing = comboSpacingFunc;\n // comboPadding to function\n const comboPadding = self.comboPadding;\n let comboPaddingFunc;\n if (isNumber(comboPadding)) {\n comboPaddingFunc = () => comboPadding;\n }\n else if (isArray(comboPadding)) {\n comboPaddingFunc = () => Math.max.apply(null, comboPadding);\n }\n else if (isFunction(comboPadding)) {\n comboPaddingFunc = comboPadding;\n }\n else {\n // null type\n comboPaddingFunc = () => 0;\n }\n this.comboPadding = comboPaddingFunc;\n // linkDistance to function\n let linkDistance = this.linkDistance;\n let linkDistanceFunc;\n if (!linkDistance) {\n linkDistance = 10;\n }\n if (isNumber(linkDistance)) {\n linkDistanceFunc = (d) => {\n return linkDistance;\n };\n }\n else {\n linkDistanceFunc = linkDistance;\n }\n this.linkDistance = linkDistanceFunc;\n // linkStrength to function\n let edgeStrength = this.edgeStrength;\n let edgeStrengthFunc;\n if (!edgeStrength) {\n edgeStrength = 1;\n }\n if (isNumber(edgeStrength)) {\n edgeStrengthFunc = (d) => {\n return edgeStrength;\n };\n }\n else {\n edgeStrengthFunc = edgeStrength;\n }\n this.edgeStrength = edgeStrengthFunc;\n // nodeStrength to function\n let nodeStrength = this.nodeStrength;\n let nodeStrengthFunc;\n if (!nodeStrength) {\n nodeStrength = 30;\n }\n if (isNumber(nodeStrength)) {\n nodeStrengthFunc = (d) => {\n return nodeStrength;\n };\n }\n else {\n nodeStrengthFunc = nodeStrength;\n }\n this.nodeStrength = nodeStrengthFunc;\n }\n initPos(comboMap) {\n const self = this;\n const nodes = self.nodes;\n nodes.forEach((node, i) => {\n const comboId = node.comboId;\n const combo = comboMap[comboId];\n if (comboId && combo) {\n node.x = combo.cx + 100 / (i + 1);\n node.y = combo.cy + 100 / (i + 1);\n }\n else {\n node.x = 100 / (i + 1);\n node.y = 100 / (i + 1);\n }\n });\n }\n getComboMap() {\n const self = this;\n const nodeMap = self.nodeMap;\n const indexMap = self.indexMap;\n const comboTrees = self.comboTrees;\n const oriComboMap = self.oriComboMap;\n const comboMap = {};\n (comboTrees || []).forEach((ctree) => {\n const treeChildren = [];\n traverseTreeUp(ctree, (treeNode) => {\n if (treeNode.itemType === \"node\")\n return true; // skip it\n if (!oriComboMap[treeNode.id])\n return true; // means it is hidden, skip it\n if (comboMap[treeNode.id] === undefined) {\n const combo = {\n id: treeNode.id,\n name: treeNode.id,\n cx: 0,\n cy: 0,\n count: 0,\n depth: self.oriComboMap[treeNode.id].depth || 0,\n children: []\n };\n comboMap[treeNode.id] = combo;\n }\n const children = treeNode.children;\n if (children) {\n children.forEach((child) => {\n if (!comboMap[child.id] && !nodeMap[child.id])\n return true; // means it is hidden\n treeChildren.push(child);\n });\n }\n const c = comboMap[treeNode.id];\n c.cx = 0;\n c.cy = 0;\n // In order to layout the empty combo, add a virtual node to it\n if (treeChildren.length === 0) {\n c.empty = true;\n const oriCombo = oriComboMap[treeNode.id];\n const idx = Object.keys(nodeMap).length;\n const virtualNodeId = `${treeNode.id}-visual-child-${idx}`;\n const vnode = {\n id: virtualNodeId,\n x: oriCombo.x,\n y: oriCombo.y,\n depth: c.depth + 1,\n itemType: \"node\"\n };\n self.nodes.push(vnode);\n nodeMap[virtualNodeId] = vnode;\n indexMap[virtualNodeId] = idx;\n c.cx = oriCombo.x;\n c.cy = oriCombo.y;\n treeChildren.push(vnode);\n }\n treeChildren.forEach((child) => {\n c.count++;\n if (child.itemType !== \"node\") {\n const childCombo = comboMap[child.id];\n if (isNumber(childCombo.cx))\n c.cx += childCombo.cx;\n if (isNumber(childCombo.cy))\n c.cy += childCombo.cy;\n return;\n }\n const node = nodeMap[child.id];\n // means the node is hidden, skip it\n if (!node)\n return;\n if (isNumber(node.x)) {\n c.cx += node.x;\n }\n if (isNumber(node.y)) {\n c.cy += node.y;\n }\n });\n c.cx /= c.count;\n c.cy /= c.count;\n c.children = treeChildren;\n return true;\n });\n });\n return comboMap;\n }\n applyComboCenterForce(displacements) {\n const self = this;\n const gravity = self.gravity;\n const comboGravity = self.comboGravity || gravity;\n const alpha = this.alpha;\n const comboTrees = self.comboTrees;\n const indexMap = self.indexMap;\n const nodeMap = self.nodeMap;\n const comboMap = self.comboMap;\n (comboTrees || []).forEach((ctree) => {\n traverseTreeUp(ctree, (treeNode) => {\n if (treeNode.itemType === \"node\")\n return true; // skip it\n const combo = comboMap[treeNode.id];\n // means the combo is hidden, skip it\n if (!combo)\n return true;\n const c = comboMap[treeNode.id];\n // higher depth the combo, larger the gravity\n const gravityScale = ((c.depth + 1) / 10) * 0.5;\n // apply combo center force for all the descend nodes in this combo\n // and update the center position and count for this combo\n const comboX = c.cx;\n const comboY = c.cy;\n c.cx = 0;\n c.cy = 0;\n c.children.forEach((child) => {\n if (child.itemType !== \"node\") {\n const childCombo = comboMap[child.id];\n if (childCombo && isNumber(childCombo.cx))\n c.cx += childCombo.cx;\n if (childCombo && isNumber(childCombo.cy))\n c.cy += childCombo.cy;\n return;\n }\n const node = nodeMap[child.id];\n const vecX = (node.x - comboX) || 0.005;\n const vecY = (node.y - comboY) || 0.005;\n const l = Math.sqrt(vecX * vecX + vecY * vecY);\n const childIdx = indexMap[node.id];\n const params = ((comboGravity * alpha) / l) * gravityScale;\n displacements[childIdx].x -= vecX * params;\n displacements[childIdx].y -= vecY * params;\n if (isNumber(node.x))\n c.cx += node.x;\n if (isNumber(node.y))\n c.cy += node.y;\n });\n c.cx /= c.count;\n c.cy /= c.count;\n return true;\n });\n });\n }\n applyCalculate(displacements) {\n const self = this;\n const comboMap = self.comboMap;\n const nodes = self.nodes;\n // store the vx, vy, and distance to reduce dulplicate calculation\n const vecMap = {};\n nodes.forEach((v, i) => {\n nodes.forEach((u, j) => {\n if (i < j)\n return;\n const vx = (v.x - u.x) || 0.005;\n const vy = (v.y - u.y) || 0.005;\n let vl2 = vx * vx + vy * vy;\n const vl = Math.sqrt(vl2);\n if (vl2 < 1)\n vl2 = vl;\n vecMap[`${v.id}-${u.id}`] = { vx, vy, vl2, vl };\n vecMap[`${u.id}-${v.id}`] = { vl2, vl, vx: -vx, vy: -vy };\n });\n });\n // get the sizes of the combos\n self.updateComboSizes(comboMap);\n self.calRepulsive(displacements, vecMap);\n self.calAttractive(displacements, vecMap);\n const preventComboOverlap = self.preventComboOverlap;\n if (preventComboOverlap)\n self.comboNonOverlapping(displacements, comboMap);\n }\n /**\n * Update the sizes of the combos according to their children\n * Used for combos nonoverlap, but not re-render the combo shapes\n */\n updateComboSizes(comboMap) {\n const self = this;\n const comboTrees = self.comboTrees;\n const nodeMap = self.nodeMap;\n const nodeSize = self.nodeSize;\n const comboSpacing = self.comboSpacing;\n const comboPadding = self.comboPadding;\n (comboTrees || []).forEach((ctree) => {\n const treeChildren = [];\n traverseTreeUp(ctree, (treeNode) => {\n if (treeNode.itemType === \"node\")\n return true; // skip it\n const c = comboMap[treeNode.id];\n // means the combo is hidden, skip it\n if (!c)\n return false;\n const children = treeNode.children;\n if (children) {\n children.forEach((child) => {\n // means the combo is hidden.\n if (!comboMap[child.id] && !nodeMap[child.id])\n return;\n treeChildren.push(child);\n });\n }\n c.minX = Infinity;\n c.minY = Infinity;\n c.maxX = -Infinity;\n c.maxY = -Infinity;\n treeChildren.forEach((child) => {\n if (child.itemType !== \"node\")\n return true; // skip it\n const node = nodeMap[child.id];\n if (!node)\n return true; // means it is hidden\n const r = nodeSize(node);\n const nodeMinX = node.x - r;\n const nodeMinY = node.y - r;\n const nodeMaxX = node.x + r;\n const nodeMaxY = node.y + r;\n if (c.minX > nodeMinX)\n c.minX = nodeMinX;\n if (c.minY > nodeMinY)\n c.minY = nodeMinY;\n if (c.maxX < nodeMaxX)\n c.maxX = nodeMaxX;\n if (c.maxY < nodeMaxY)\n c.maxY = nodeMaxY;\n });\n let minSize = self.oriComboMap[treeNode.id].size || 10;\n if (isArray(minSize))\n minSize = minSize[0];\n const maxLength = Math.max(c.maxX - c.minX, c.maxY - c.minY, minSize);\n c.r = maxLength / 2 + comboSpacing(c) / 2 + comboPadding(c);\n return true;\n });\n });\n }\n /**\n * prevent the overlappings among combos\n */\n comboNonOverlapping(displacements, comboMap) {\n const self = this;\n const comboTree = self.comboTree;\n const comboCollideStrength = self.comboCollideStrength;\n const indexMap = self.indexMap;\n const nodeMap = self.nodeMap;\n traverseTreeUp(comboTree, (treeNode) => {\n if (!comboMap[treeNode.id] &&\n !nodeMap[treeNode.id] &&\n treeNode.id !== \"comboTreeRoot\") {\n return false;\n } // means it is hidden\n const children = treeNode.children;\n // 同个子树下的子 combo 间两两对比\n if (children && children.length > 1) {\n children.forEach((v, i) => {\n if (v.itemType === \"node\")\n return false; // skip it\n const cv = comboMap[v.id];\n if (!cv)\n return; // means it is hidden, skip it\n children.forEach((u, j) => {\n if (i <= j)\n return false;\n if (u.itemType === \"node\")\n return false; // skip it\n const cu = comboMap[u.id];\n if (!cu)\n return false; // means it is hidden, skip it\n const vx = (cv.cx - cu.cx) || 0.005;\n const vy = (cv.cy - cu.cy) || 0.005;\n const l = vx * vx + vy * vy;\n const rv = cv.r || 1;\n const ru = cu.r || 1;\n const r = rv + ru;\n const ru2 = ru * ru;\n const rv2 = rv * rv;\n // overlapping\n if (l < r * r) {\n const vnodes = v.children;\n if (!vnodes || vnodes.length === 0)\n return false; // skip it\n const unodes = u.children;\n if (!unodes || unodes.length === 0)\n return false; // skip it\n const sqrtl = Math.sqrt(l);\n const ll = ((r - sqrtl) / sqrtl) * comboCollideStrength;\n const xl = vx * ll;\n const yl = vy * ll;\n const rratio = ru2 / (rv2 + ru2);\n const irratio = 1 - rratio;\n // 两兄弟 combo 的子节点上施加斥力\n vnodes.forEach((vn) => {\n if (vn.itemType !== \"node\")\n return false; // skip it\n if (!nodeMap[vn.id])\n return; // means it is hidden, skip it\n const vindex = indexMap[vn.id];\n unodes.forEach((un) => {\n if (un.itemType !== \"node\")\n return false;\n if (!nodeMap[un.id])\n return false; // means it is hidden, skip it\n const uindex = indexMap[un.id];\n displacements[vindex].x += xl * rratio;\n displacements[vindex].y += yl * rratio;\n displacements[uindex].x -= xl * irratio;\n displacements[uindex].y -= yl * irratio;\n });\n });\n }\n });\n });\n }\n return true;\n });\n }\n /**\n * Calculate the repulsive force between each node pair\n * @param displacements The array stores the displacements for nodes\n * @param vecMap The map stores vector between each node pair\n */\n calRepulsive(displacements, vecMap) {\n const self = this;\n const nodes = self.nodes;\n const max = self.width * self.optimizeRangeFactor;\n const nodeStrength = self.nodeStrength;\n const alpha = self.alpha;\n const nodeCollideStrength = self.nodeCollideStrength;\n const preventNodeOverlap = self.preventNodeOverlap;\n const nodeSizeFunc = self.nodeSize;\n const nodeSpacingFunc = self.nodeSpacing;\n const scale = self.depthRepulsiveForceScale;\n const center = self.center;\n nodes.forEach((v, i) => {\n if (!v.x || !v.y)\n return;\n // center gravity\n if (center) {\n const gravity = self.gravity;\n const vecX = (v.x - center[0]) || 0.005;\n const vecY = (v.y - center[1]) || 0.005;\n const l = Math.sqrt(vecX * vecX + vecY * vecY);\n displacements[i].x -= (vecX * gravity * alpha) / l;\n displacements[i].y -= (vecY * gravity * alpha) / l;\n }\n nodes.forEach((u, j) => {\n if (i === j) {\n return;\n }\n if (!u.x || !u.y)\n return;\n const { vl2, vl } = vecMap[`${v.id}-${u.id}`];\n if (vl > max)\n return;\n const { vx, vy } = vecMap[`${v.id}-${u.id}`];\n let depthDiff = Math.log(Math.abs(u.depth - v.depth) / 10) + 1 || 1;\n depthDiff = depthDiff < 1 ? 1 : depthDiff;\n if (u.comboId !== v.comboId)\n depthDiff += 1;\n const depthParam = depthDiff ? Math.pow(scale, depthDiff) : 1;\n const params = ((nodeStrength(u) * alpha) / vl2) * depthParam;\n displacements[i].x += vx * params;\n displacements[i].y += vy * params;\n // prevent node overlappings\n if (i < j && preventNodeOverlap) {\n const ri = (nodeSizeFunc(v) + nodeSpacingFunc(v)) || 1;\n const rj = (nodeSizeFunc(u) + nodeSpacingFunc(u)) || 1;\n const r = ri + rj;\n if (vl2 < r * r) {\n const ll = ((r - vl) / vl) * nodeCollideStrength;\n const rj2 = rj * rj;\n let rratio = rj2 / (ri * ri + rj2);\n const xl = vx * ll;\n const yl = vy * ll;\n displacements[i].x += xl * rratio;\n displacements[i].y += yl * rratio;\n rratio = 1 - rratio;\n displacements[j].x -= xl * rratio;\n displacements[j].y -= yl * rratio;\n }\n }\n });\n });\n }\n /**\n * Calculate the attractive force between the node pair with edge\n * @param displacements The array stores the displacements for nodes\n * @param vecMap The map stores vector between each node pair\n */\n calAttractive(displacements, vecMap) {\n const self = this;\n const edges = self.edges;\n const linkDistance = self.linkDistance;\n const alpha = self.alpha;\n const edgeStrength = self.edgeStrength;\n const bias = self.bias;\n const scale = self.depthAttractiveForceScale;\n edges.forEach((e, i) => {\n const source = getEdgeTerminal(e, 'source');\n const target = getEdgeTerminal(e, 'target');\n if (!source || !target || source === target)\n return;\n const uIndex = self.indexMap[source];\n const vIndex = self.indexMap[target];\n const u = self.nodeMap[source];\n const v = self.nodeMap[target];\n if (!u || !v)\n return;\n let depthDiff = u.depth === v.depth ? 0 : Math.log(Math.abs(u.depth - v.depth) / 10);\n if (u.comboId === v.comboId) {\n depthDiff = depthDiff / 2;\n }\n let depthParam = depthDiff ? Math.pow(scale, depthDiff) : 1;\n if (u.comboId !== v.comboId && depthParam === 1) {\n depthParam = scale / 2;\n }\n else if (u.comboId === v.comboId) {\n depthParam = 2;\n }\n if (!isNumber(v.x) || !isNumber(u.x) || !isNumber(v.y) || !isNumber(u.y)) {\n return;\n }\n const { vl, vx, vy } = vecMap[`${target}-${source}`];\n const l = ((vl - linkDistance(e)) / vl) * alpha * edgeStrength(e) * depthParam;\n const vecX = vx * l;\n const vecY = vy * l;\n const b = bias[i];\n displacements[vIndex].x -= vecX * b;\n displacements[vIndex].y -= vecY * b;\n displacements[uIndex].x += vecX * (1 - b);\n displacements[uIndex].y += vecY * (1 - b);\n });\n }\n getType() {\n return \"comboForce\";\n }\n}\n//# sourceMappingURL=comboForce.js.map","// represents a body(a point mass) and its position\nexport default class Body {\n constructor(params) {\n /**\n * the id of this body, the same with the node id\n * @type {number}\n */\n this.id = params.id || 0;\n /**\n * the position of this body\n * @type {number}\n */\n this.rx = params.rx;\n /**\n * the position of this body\n * @type {number}\n */\n this.ry = params.ry;\n /**\n * the force acting on this body\n * @type {number}\n */\n this.fx = 0;\n /**\n * the force acting on this body\n * @type {number}\n */\n this.fy = 0;\n /**\n * the mass of this body, =1 for a node\n * @type {number}\n */\n this.mass = params.mass;\n /**\n * the degree of the node represented by this body\n * @type {number}\n */\n this.degree = params.degree;\n /**\n * the parameter for repulsive force, = kr\n * @type {number}\n */\n this.g = params.g || 0;\n }\n // returns the euclidean distance\n distanceTo(bo) {\n const dx = this.rx - bo.rx;\n const dy = this.ry - bo.ry;\n return Math.hypot(dx, dy);\n }\n setPos(x, y) {\n this.rx = x;\n this.ry = y;\n }\n // resets the forces\n resetForce() {\n this.fx = 0;\n this.fy = 0;\n }\n addForce(b) {\n const dx = b.rx - this.rx;\n const dy = b.ry - this.ry;\n let dist = Math.hypot(dx, dy);\n dist = dist < 0.0001 ? 0.0001 : dist;\n // the repulsive defined by force atlas 2\n const F = (this.g * (this.degree + 1) * (b.degree + 1)) / dist;\n this.fx += F * dx / dist;\n this.fy += F * dy / dist;\n }\n // if quad contains this body\n in(quad) {\n return quad.contains(this.rx, this.ry);\n }\n // returns a new body\n add(bo) {\n const nenwMass = this.mass + bo.mass;\n const x = (this.rx * this.mass + bo.rx * bo.mass) / nenwMass;\n const y = (this.ry * this.mass + bo.ry * bo.mass) / nenwMass;\n const dg = this.degree + bo.degree;\n const params = {\n rx: x,\n ry: y,\n mass: nenwMass,\n degree: dg\n };\n return new Body(params);\n }\n}\n//# sourceMappingURL=body.js.map","export default class Quad {\n constructor(params) {\n /**\n * the center position of this quad\n * @type {number}\n */\n this.xmid = params.xmid;\n /**\n * the center position of this quad\n * @type {number}\n */\n this.ymid = params.ymid;\n /**\n * the length of this quad\n * @type {number}\n */\n this.length = params.length;\n /**\n * the mass center of this quad\n * @type {number}\n */\n this.massCenter = params.massCenter || [0, 0];\n /**\n * the mass of this quad\n * @type {number}\n */\n this.mass = params.mass || 1;\n }\n getLength() {\n return this.length;\n }\n contains(x, y) {\n const halfLen = this.length / 2;\n return (x <= this.xmid + halfLen &&\n x >= this.xmid - halfLen &&\n y <= this.ymid + halfLen &&\n y >= this.ymid - halfLen);\n }\n // northwest quadrant\n // tslint:disable-next-line\n NW() {\n const x = this.xmid - this.length / 4;\n const y = this.ymid + this.length / 4;\n const len = this.length / 2;\n const params = {\n xmid: x,\n ymid: y,\n length: len\n };\n const NW = new Quad(params);\n return NW;\n }\n // northeast\n // tslint:disable-next-line\n NE() {\n const x = this.xmid + this.length / 4;\n const y = this.ymid + this.length / 4;\n const len = this.length / 2;\n const params = {\n xmid: x,\n ymid: y,\n length: len\n };\n const NE = new Quad(params);\n return NE;\n }\n // southwest\n // tslint:disable-next-line\n SW() {\n const x = this.xmid - this.length / 4;\n const y = this.ymid - this.length / 4;\n const len = this.length / 2;\n const params = {\n xmid: x,\n ymid: y,\n length: len\n };\n const SW = new Quad(params);\n return SW;\n }\n // southeast\n // tslint:disable-next-line\n SE() {\n const x = this.xmid + this.length / 4;\n const y = this.ymid - this.length / 4;\n const len = this.length / 2;\n const params = {\n xmid: x,\n ymid: y,\n length: len\n };\n const SE = new Quad(params);\n return SE;\n }\n}\n//# sourceMappingURL=quad.js.map","/**\n * @fileOverview quadTree\n * @author shiwu.wyy@antfin.com\n */\nexport default class QuadTree {\n // each quadtree represents a quadrant and an aggregate body\n // that represents all bodies inside the quadrant\n constructor(param) {\n /**\n * (aggregated) body in this quad\n * @type {object}\n */\n this.body = null;\n /**\n * tree representing the northwest quadrant\n * @type {object}\n */\n this.quad = null;\n this.NW = null;\n this.NE = null;\n this.SW = null;\n this.SE = null;\n /**\n * threshold\n * @type {number}\n */\n this.theta = 0.5;\n if (param != null)\n this.quad = param;\n }\n // insert a body(node) into the tree\n insert(bo) {\n // if this node does not contain a body, put the new body bo here\n if (this.body == null) {\n this.body = bo;\n return;\n }\n // internal node\n if (!this._isExternal()) {\n // update mass info\n this.body = this.body.add(bo);\n // insert body into quadrant\n this._putBody(bo);\n }\n else { // external node\n // divide this region into four children\n if (this.quad) {\n this.NW = new QuadTree(this.quad.NW());\n this.NE = new QuadTree(this.quad.NE());\n this.SW = new QuadTree(this.quad.SW());\n this.SE = new QuadTree(this.quad.SE());\n }\n // insert this body and bo\n this._putBody(this.body);\n this._putBody(bo);\n // update the mass info\n this.body = this.body.add(bo);\n }\n }\n // inserts bo into a quad\n // tslint:disable-next-line\n _putBody(bo) {\n if (!this.quad)\n return;\n if (bo.in(this.quad.NW()) && this.NW)\n this.NW.insert(bo);\n else if (bo.in(this.quad.NE()) && this.NE)\n this.NE.insert(bo);\n else if (bo.in(this.quad.SW()) && this.SW)\n this.SW.insert(bo);\n else if (bo.in(this.quad.SE()) && this.SE)\n this.SE.insert(bo);\n }\n // tslint:disable-next-line\n _isExternal() {\n // four children are null\n return (this.NW == null && this.NE == null && this.SW == null && this.SE == null);\n }\n // update the forces\n updateForce(bo) {\n if (this.body == null || bo === this.body) {\n return;\n }\n // if the current node is external\n if (this._isExternal())\n bo.addForce(this.body);\n // internal nodes\n else {\n const s = this.quad ? this.quad.getLength() : 0;\n const d = this.body.distanceTo(bo);\n // b is far enough\n if ((s / d) < this.theta)\n bo.addForce(this.body);\n else {\n this.NW && this.NW.updateForce(bo);\n this.NE && this.NE.updateForce(bo);\n this.SW && this.SW.updateForce(bo);\n this.SE && this.SE.updateForce(bo);\n }\n }\n }\n}\n//# sourceMappingURL=quadTree.js.map","import { Base } from \"../base\";\nimport { getEdgeTerminal, isArray, isNumber, isObject } from \"../../util\";\nimport Body from './body';\nimport Quad from './quad';\nimport QuadTree from './quadTree';\nexport class ForceAtlas2Layout extends Base {\n constructor(options) {\n super();\n /** 布局中心 */\n this.center = [0, 0];\n /** 宽度 */\n this.width = 300;\n /** 高度 */\n this.height = 300;\n this.nodes = [];\n this.edges = [];\n /**\n * the parameter for repulsive forces,\n * it will scale the layout but won't change the layout\n * larger the kr, looser the layout\n * @type {number}\n */\n this.kr = 5;\n /**\n * the parameter for gravity forces\n * @type {number}\n */\n this.kg = 1;\n /**\n * modes:\n * 'normal' for normal using\n * 'linlog' for compact clusters.\n * @type {string}\n */\n this.mode = 'normal';\n /**\n * whether preventing the node overlapping\n * @type {boolean}\n */\n this.preventOverlap = false;\n /**\n * whether active the dissuade hub mode\n * true: grant authorities (nodes with a high indegree)\n * a more central position than hubs (nodes with a high outdegree)\n * @type {boolean}\n */\n this.dissuadeHubs = false;\n /**\n * whether active the barnes hut optimization on computing repulsive forces\n * @type {boolean}\n */\n this.barnesHut = undefined;\n /**\n * the max iteration number\n * @type {number}\n */\n this.maxIteration = 0;\n /**\n * control the global velocity\n * defualt: 0.1(gephi)\n * @type {number}\n */\n this.ks = 0.1;\n /**\n * the max global velocity\n * @type {number}\n */\n this.ksmax = 10;\n /**\n * the tolerance for the global swinging\n * @type {number}\n */\n this.tao = 0.1;\n /**\n * the function of layout complete listener, display the legend and minimap after layout\n * @type {function}\n */\n this.onLayoutEnd = () => { };\n /**\n * activate prune or not.\n * prune the leaves during most iterations, layout the leaves in the last 50 iteraitons.\n * if prune === '', it will be activated when the nodes number > 100\n * note that it will reduce the quality of the layout\n * @type {boolean}\n */\n this.prune = undefined;\n this.updateCfg(options);\n }\n getDefaultCfg() {\n return {};\n }\n // execute the layout\n execute() {\n const self = this;\n const { nodes, onLayoutEnd, prune, } = self;\n let maxIteration = self.maxIteration;\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n // the whidth of each nodes\n const sizes = [];\n const nodeNum = nodes.length;\n for (let i = 0; i < nodeNum; i += 1) {\n const node = nodes[i];\n let nodeWidth = 10;\n let nodeHeight = 10;\n if (isNumber(node.size)) {\n nodeWidth = node.size;\n nodeHeight = node.size;\n }\n if (isArray(node.size)) {\n if (!isNaN(node.size[0]))\n nodeWidth = node.size[0];\n if (!isNaN(node.size[1]))\n nodeHeight = node.size[1];\n }\n else if (isObject(node.size)) {\n nodeWidth = node.size.width;\n nodeHeight = node.size.height;\n }\n if (self.getWidth && !isNaN(self.getWidth(node)))\n nodeHeight = self.getWidth(node);\n if (self.getHeight && !isNaN(self.getHeight(node)))\n nodeWidth = self.getHeight(node);\n const maxSize = Math.max(nodeWidth, nodeHeight);\n sizes.push(maxSize);\n }\n if (self.barnesHut === undefined && nodeNum > 250)\n self.barnesHut = true;\n if (self.prune === undefined && nodeNum > 100)\n self.prune = true;\n if (this.maxIteration === 0 && !self.prune) {\n maxIteration = 250;\n if (nodeNum <= 200 && nodeNum > 100)\n maxIteration = 1000;\n else if (nodeNum > 200)\n maxIteration = 1200;\n this.maxIteration = maxIteration;\n }\n else if (this.maxIteration === 0 && prune) {\n maxIteration = 100;\n if (nodeNum <= 200 && nodeNum > 100)\n maxIteration = 500;\n else if (nodeNum > 200)\n maxIteration = 950;\n this.maxIteration = maxIteration;\n }\n if (!self.kr) {\n self.kr = 50;\n if (nodeNum > 100 && nodeNum <= 500)\n self.kr = 20;\n else if (nodeNum > 500)\n self.kr = 1;\n }\n if (!self.kg) {\n self.kg = 20;\n if (nodeNum > 100 && nodeNum <= 500)\n self.kg = 10;\n else if (nodeNum > 500)\n self.kg = 1;\n }\n this.nodes = self.updateNodesByForces(sizes);\n onLayoutEnd();\n }\n updateNodesByForces(sizes) {\n const self = this;\n const { edges, maxIteration } = self;\n let nodes = self.nodes;\n const nonLoopEdges = edges.filter((edge) => {\n const source = getEdgeTerminal(edge, 'source');\n const target = getEdgeTerminal(edge, 'target');\n return source !== target;\n });\n const size = nodes.length;\n const esize = nonLoopEdges.length;\n const degrees = [];\n const idMap = {};\n const edgeEndsIdMap = {};\n // tslint:disable-next-line\n const Es = [];\n for (let i = 0; i < size; i += 1) {\n idMap[nodes[i].id] = i;\n degrees[i] = 0;\n if (nodes[i].x === undefined || isNaN(nodes[i].x)) {\n nodes[i].x = Math.random() * 1000;\n }\n if (nodes[i].y === undefined || isNaN(nodes[i].y)) {\n nodes[i].y = Math.random() * 1000;\n }\n Es.push({ x: nodes[i].x, y: nodes[i].y });\n }\n for (let i = 0; i < esize; i += 1) {\n let node1;\n let node2;\n let sIdx = 0;\n let tIdx = 0;\n for (let j = 0; j < size; j += 1) {\n const source = getEdgeTerminal(nonLoopEdges[i], 'source');\n const target = getEdgeTerminal(nonLoopEdges[i], 'target');\n if (nodes[j].id === source) {\n node1 = nodes[j];\n sIdx = j;\n }\n else if (nodes[j].id === target) {\n node2 = nodes[j];\n tIdx = j;\n }\n edgeEndsIdMap[i] = { sourceIdx: sIdx, targetIdx: tIdx };\n }\n if (node1)\n degrees[idMap[node1.id]] += 1;\n if (node2)\n degrees[idMap[node2.id]] += 1;\n }\n let iteration = maxIteration;\n nodes = this.iterate(iteration, idMap, edgeEndsIdMap, esize, degrees, sizes);\n // if prune, place the leaves around their parents, and then re-layout for several iterations.\n if (self.prune) {\n for (let j = 0; j < esize; j += 1) {\n if (degrees[edgeEndsIdMap[j].sourceIdx] <= 1) {\n nodes[edgeEndsIdMap[j].sourceIdx].x = nodes[edgeEndsIdMap[j].targetIdx].x;\n nodes[edgeEndsIdMap[j].sourceIdx].y = nodes[edgeEndsIdMap[j].targetIdx].y;\n }\n else if (degrees[edgeEndsIdMap[j].targetIdx] <= 1) {\n nodes[edgeEndsIdMap[j].targetIdx].x = nodes[edgeEndsIdMap[j].sourceIdx].x;\n nodes[edgeEndsIdMap[j].targetIdx].y = nodes[edgeEndsIdMap[j].sourceIdx].y;\n }\n }\n self.prune = false;\n self.barnesHut = false;\n iteration = 100;\n nodes = this.iterate(iteration, idMap, edgeEndsIdMap, esize, degrees, sizes);\n }\n return nodes;\n }\n iterate(iteration, idMap, edgeEndsIdMap, esize, degrees, sizes) {\n const self = this;\n let { nodes } = self;\n const { kr, preventOverlap } = self;\n const { barnesHut } = self;\n const nodeNum = nodes.length;\n let sg = 0;\n const krPrime = 100;\n let iter = iteration;\n const prevoIter = 50;\n let forces = [];\n const preForces = [];\n const bodies = [];\n for (let i = 0; i < nodeNum; i += 1) {\n forces[2 * i] = 0;\n forces[2 * i + 1] = 0;\n if (barnesHut) {\n const params = {\n id: i,\n rx: nodes[i].x,\n ry: nodes[i].y,\n mass: 1,\n g: kr,\n degree: degrees[i]\n };\n bodies[i] = new Body(params);\n }\n }\n while (iter > 0) {\n for (let i = 0; i < nodeNum; i += 1) {\n preForces[2 * i] = forces[2 * i];\n preForces[2 * i + 1] = forces[2 * i + 1];\n forces[2 * i] = 0;\n forces[2 * i + 1] = 0;\n }\n // attractive forces, existing on every actual edge\n forces = this.getAttrForces(iter, prevoIter, esize, idMap, edgeEndsIdMap, degrees, sizes, forces);\n // repulsive forces and Gravity, existing on every node pair\n // if preventOverlap, using the no-optimized method in the last prevoIter instead.\n if (barnesHut && ((preventOverlap && iter > prevoIter) || !preventOverlap)) {\n forces = this.getOptRepGraForces(forces, bodies, degrees);\n }\n else {\n forces = this.getRepGraForces(iter, prevoIter, forces, krPrime, sizes, degrees);\n }\n // update the positions\n const res = this.updatePos(forces, preForces, sg, degrees);\n nodes = res.nodes;\n sg = res.sg;\n iter--;\n if (self.tick)\n self.tick();\n }\n return nodes;\n }\n getAttrForces(iter, prevoIter, esize, idMap, edgeEndsIdMap, degrees, sizes, forces) {\n const self = this;\n const { nodes, preventOverlap, dissuadeHubs, mode, prune } = self;\n for (let i = 0; i < esize; i += 1) {\n const sourceNode = nodes[edgeEndsIdMap[i].sourceIdx];\n const sourceIdx = edgeEndsIdMap[i].sourceIdx;\n const targetNode = nodes[edgeEndsIdMap[i].targetIdx];\n const targetIdx = edgeEndsIdMap[i].targetIdx;\n if (prune && (degrees[sourceIdx] <= 1 || degrees[targetIdx] <= 1))\n continue;\n const dir = [targetNode.x - sourceNode.x, targetNode.y - sourceNode.y];\n let eucliDis = Math.hypot(dir[0], dir[1]);\n eucliDis = eucliDis < 0.0001 ? 0.0001 : eucliDis;\n dir[0] = dir[0] / eucliDis;\n dir[1] = dir[1] / eucliDis;\n if (preventOverlap && iter < prevoIter)\n eucliDis = eucliDis - sizes[sourceIdx] - sizes[targetIdx];\n let Fa1 = eucliDis; // tslint:disable-line\n let Fa2 = Fa1; // tslint:disable-line\n if (mode === 'linlog') {\n Fa1 = Math.log(1 + eucliDis);\n Fa2 = Fa1;\n }\n if (dissuadeHubs) {\n Fa1 = eucliDis / degrees[sourceIdx];\n Fa2 = eucliDis / degrees[targetIdx];\n }\n if (preventOverlap && iter < prevoIter && eucliDis <= 0) {\n Fa1 = 0;\n Fa2 = 0;\n }\n else if (preventOverlap && iter < prevoIter && eucliDis > 0) {\n Fa1 = eucliDis;\n Fa2 = eucliDis;\n }\n forces[2 * idMap[sourceNode.id]] += Fa1 * dir[0];\n forces[2 * idMap[targetNode.id]] -= Fa2 * dir[0];\n forces[2 * idMap[sourceNode.id] + 1] += Fa1 * dir[1];\n forces[2 * idMap[targetNode.id] + 1] -= Fa2 * dir[1];\n }\n return forces;\n }\n getRepGraForces(iter, prevoIter, forces, krPrime, sizes, degrees) {\n const self = this;\n const { nodes, preventOverlap, kr, kg, center, prune } = self;\n const nodeNum = nodes.length;\n for (let i = 0; i < nodeNum; i += 1) {\n for (let j = i + 1; j < nodeNum; j += 1) {\n if (prune && (degrees[i] <= 1 || degrees[j] <= 1))\n continue;\n const dir = [nodes[j].x - nodes[i].x, nodes[j].y - nodes[i].y];\n let eucliDis = Math.hypot(dir[0], dir[1]);\n eucliDis = eucliDis < 0.0001 ? 0.0001 : eucliDis;\n dir[0] = dir[0] / eucliDis;\n dir[1] = dir[1] / eucliDis;\n if (preventOverlap && iter < prevoIter)\n eucliDis = eucliDis - sizes[i] - sizes[j];\n let Fr = kr * (degrees[i] + 1) * (degrees[j] + 1) / eucliDis; // tslint:disable-line\n if (preventOverlap && iter < prevoIter && eucliDis < 0) {\n Fr = krPrime * (degrees[i] + 1) * (degrees[j] + 1);\n }\n else if (preventOverlap && iter < prevoIter && eucliDis === 0) {\n Fr = 0;\n }\n else if (preventOverlap && iter < prevoIter && eucliDis > 0) {\n Fr = kr * (degrees[i] + 1) * (degrees[j] + 1) / eucliDis;\n }\n forces[2 * i] -= Fr * dir[0];\n forces[2 * j] += Fr * dir[0];\n forces[2 * i + 1] -= Fr * dir[1];\n forces[2 * j + 1] += Fr * dir[1];\n }\n // gravity\n const dir = [nodes[i].x - center[0], nodes[i].y - center[1]];\n const eucliDis = Math.hypot(dir[0], dir[1]);\n dir[0] = dir[0] / eucliDis;\n dir[1] = dir[1] / eucliDis;\n const Fg = kg * (degrees[i] + 1); // tslint:disable-line\n forces[2 * i] -= Fg * dir[0];\n forces[2 * i + 1] -= Fg * dir[1];\n }\n return forces;\n }\n getOptRepGraForces(forces, bodies, degrees) {\n const self = this;\n const { nodes, kg, center, prune } = self;\n const nodeNum = nodes.length;\n let minx = 9e10;\n let maxx = -9e10;\n let miny = 9e10;\n let maxy = -9e10;\n for (let i = 0; i < nodeNum; i += 1) {\n if (prune && (degrees[i] <= 1))\n continue;\n bodies[i].setPos(nodes[i].x, nodes[i].y);\n if (nodes[i].x >= maxx)\n maxx = nodes[i].x;\n if (nodes[i].x <= minx)\n minx = nodes[i].x;\n if (nodes[i].y >= maxy)\n maxy = nodes[i].y;\n if (nodes[i].y <= miny)\n miny = nodes[i].y;\n }\n const width = Math.max(maxx - minx, maxy - miny);\n const quadParams = {\n xmid: (maxx + minx) / 2,\n ymid: (maxy + miny) / 2,\n length: width,\n massCenter: center,\n mass: nodeNum\n };\n const quad = new Quad(quadParams);\n const quadTree = new QuadTree(quad);\n // build the tree, insert the nodes(quads) into the tree\n for (let i = 0; i < nodeNum; i += 1) {\n if (prune && (degrees[i] <= 1))\n continue;\n if (bodies[i].in(quad))\n quadTree.insert(bodies[i]);\n }\n // update the repulsive forces and the gravity.\n for (let i = 0; i < nodeNum; i += 1) {\n if (prune && (degrees[i] <= 1))\n continue;\n bodies[i].resetForce();\n quadTree.updateForce(bodies[i]);\n forces[2 * i] -= bodies[i].fx;\n forces[2 * i + 1] -= bodies[i].fy;\n // gravity\n const dir = [nodes[i].x - center[0], nodes[i].y - center[1]];\n let eucliDis = Math.hypot(dir[0], dir[1]);\n eucliDis = eucliDis < 0.0001 ? 0.0001 : eucliDis;\n dir[0] = dir[0] / eucliDis;\n dir[1] = dir[1] / eucliDis;\n const Fg = kg * (degrees[i] + 1); // tslint:disable-line\n forces[2 * i] -= Fg * dir[0];\n forces[2 * i + 1] -= Fg * dir[1];\n }\n return forces;\n }\n updatePos(forces, preForces, sg, degrees) {\n const self = this;\n const { nodes, ks, tao, prune, ksmax } = self;\n const nodeNum = nodes.length;\n const swgns = [];\n const trans = [];\n // swg(G) and tra(G)\n let swgG = 0;\n let traG = 0;\n for (let i = 0; i < nodeNum; i += 1) {\n if (prune && (degrees[i] <= 1))\n continue;\n const minus = [forces[2 * i] - preForces[2 * i],\n forces[2 * i + 1] - preForces[2 * i + 1]\n ];\n const minusNorm = Math.hypot(minus[0], minus[1]);\n const add = [forces[2 * i] + preForces[2 * i],\n forces[2 * i + 1] + preForces[2 * i + 1]\n ];\n const addNorm = Math.hypot(add[0], add[1]);\n swgns[i] = minusNorm;\n trans[i] = addNorm / 2;\n swgG += (degrees[i] + 1) * swgns[i];\n traG += (degrees[i] + 1) * trans[i];\n }\n const preSG = sg;\n sg = tao * traG / swgG; // tslint:disable-line\n if (preSG !== 0) {\n sg = sg > (1.5 * preSG) ? (1.5 * preSG) : sg; // tslint:disable-line\n }\n // update the node positions\n for (let i = 0; i < nodeNum; i += 1) {\n if (prune && (degrees[i] <= 1))\n continue;\n let sn = ks * sg / (1 + sg * Math.sqrt(swgns[i]));\n let absForce = Math.hypot(forces[2 * i], forces[2 * i + 1]);\n absForce = absForce < 0.0001 ? 0.0001 : absForce;\n const max = ksmax / absForce;\n sn = sn > max ? max : sn;\n const dnx = sn * forces[2 * i];\n const dny = sn * forces[2 * i + 1];\n nodes[i].x += dnx;\n nodes[i].y += dny;\n }\n return { nodes, sg };\n }\n}\n//# sourceMappingURL=index.js.map","import { registerLayout, getLayoutByName } from \"../registy\";\nexport class Layout {\n constructor(options) {\n const layoutClass = getLayoutByName(options.type);\n this.layoutInstance = new layoutClass(options);\n }\n layout(data) {\n return this.layoutInstance.layout(data);\n }\n updateCfg(cfg) {\n this.layoutInstance.updateCfg(cfg);\n }\n init(data) {\n this.layoutInstance.init(data);\n }\n execute() {\n this.layoutInstance.execute();\n }\n getDefaultCfg() {\n return this.layoutInstance.getDefaultCfg();\n }\n destroy() {\n return this.layoutInstance.destroy();\n }\n}\n// FIXME\n// FOR G6\n// tslint:disable-next-line\nexport const Layouts = new Proxy({}, {\n // tslint:disable-line\n get: (target, propKey) => {\n return getLayoutByName(propKey);\n },\n set: (target, propKey, value) => {\n registerLayout(propKey, value);\n return true;\n }\n});\n//# sourceMappingURL=layout.js.map","import { Util } from '@antv/g6-core';\nimport { isNumber } from '@antv/util';\nvar traverseTree = Util.traverseTree;\n/**\n * 将 number | Function 类型的参数转换为 return number 的 Function\n * @param {number | Function} value 需要被转换的值\n * @param {number} defaultV 返回函数的默认返回值\n * @return {Function} 转换后的函数\n */\n\nexport var proccessToFunc = function proccessToFunc(value, defaultV) {\n var func;\n\n if (!value) {\n func = function func(d) {\n return defaultV || 1;\n };\n } else if (isNumber(value)) {\n func = function func(d) {\n return value;\n };\n } else {\n func = value;\n }\n\n return func;\n};\n/**\n * 将节点和边数据转换为 GPU 可读的数组。并返回 maxEdgePerVetex,每个节点上最多的边数\n * @param {NodeConfig[]} nodes 需要被转换的值\n * @param {EdgeConfig[]} edges 返回函数的默认返回值\n * @return {Object} 转换后的数组及 maxEdgePerVetex 组成的对象\n */\n\nexport var buildTextureData = function buildTextureData(nodes, edges) {\n var dataArray = [];\n var nodeDict = [];\n var mapIdPos = {};\n var i = 0;\n\n for (i = 0; i < nodes.length; i++) {\n var n = nodes[i];\n mapIdPos[n.id] = i;\n dataArray.push(n.x);\n dataArray.push(n.y);\n dataArray.push(0);\n dataArray.push(0);\n nodeDict.push([]);\n }\n\n for (i = 0; i < edges.length; i++) {\n var e = edges[i];\n nodeDict[mapIdPos[e.source]].push(mapIdPos[e.target]);\n nodeDict[mapIdPos[e.target]].push(mapIdPos[e.source]);\n }\n\n var maxEdgePerVetex = 0;\n\n for (i = 0; i < nodes.length; i++) {\n var offset = dataArray.length;\n var dests = nodeDict[i];\n var len = dests.length;\n dataArray[i * 4 + 2] = offset;\n dataArray[i * 4 + 3] = dests.length;\n maxEdgePerVetex = Math.max(maxEdgePerVetex, dests.length);\n\n for (var j = 0; j < len; ++j) {\n var dest = dests[j];\n dataArray.push(+dest);\n }\n }\n\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0);\n }\n\n return {\n array: new Float32Array(dataArray),\n maxEdgePerVetex: maxEdgePerVetex\n };\n};\n/**\n * 将节点和边数据转换为 GPU 可读的数组,每条边带有一个属性。并返回 maxEdgePerVetex,每个节点上最多的边数\n * @param {NodeConfig[]} nodes 节点数组\n * @param {EdgeConfig[]} edges 边数组\n * @param {Function} attrs 读取边属性的函数\n * @return {Object} 转换后的数组及 maxEdgePerVetex 组成的对象\n */\n\nexport var buildTextureDataWithOneEdgeAttr = function buildTextureDataWithOneEdgeAttr(nodes, edges, attrs) {\n var dataArray = [];\n var nodeDict = [];\n var mapIdPos = {};\n var i = 0;\n\n for (i = 0; i < nodes.length; i++) {\n var n = nodes[i];\n mapIdPos[n.id] = i;\n dataArray.push(n.x);\n dataArray.push(n.y);\n dataArray.push(0);\n dataArray.push(0);\n nodeDict.push([]);\n }\n\n for (i = 0; i < edges.length; i++) {\n var e = edges[i];\n nodeDict[mapIdPos[e.source]].push(mapIdPos[e.target]);\n nodeDict[mapIdPos[e.source]].push(attrs(e)); // 理想边长,后续可以改成每条边不同\n\n nodeDict[mapIdPos[e.target]].push(mapIdPos[e.source]);\n nodeDict[mapIdPos[e.target]].push(attrs(e)); // 理想边长,后续可以改成每条边不同\n }\n\n var maxEdgePerVetex = 0;\n\n for (i = 0; i < nodes.length; i++) {\n var offset = dataArray.length;\n var dests = nodeDict[i]; // dest 中节点 id 与边长间隔存储,即一位节点 id,一位边长……\n\n var len = dests.length;\n dataArray[i * 4 + 2] = offset;\n dataArray[i * 4 + 3] = len / 2; // 第四位存储与该节点相关的所有节点个数\n\n maxEdgePerVetex = Math.max(maxEdgePerVetex, len / 2);\n\n for (var j = 0; j < len; ++j) {\n var dest = dests[j];\n dataArray.push(+dest);\n }\n } // 不是 4 的倍数,填充 0\n\n\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0);\n }\n\n return {\n array: new Float32Array(dataArray),\n maxEdgePerVetex: maxEdgePerVetex\n };\n};\n/**\n * 将节点和边数据转换为 GPU 可读的数组,每条边带有一个以上属性。并返回 maxEdgePerVetex,每个节点上最多的边数\n * @param {NodeConfig[]} nodes 节点数组\n * @param {EdgeConfig[]} edges 边数组\n * @param {Function} attrs 读取边属性的函数\n * @return {Object} 转换后的数组及 maxEdgePerVetex 组成的对象\n */\n\nexport var buildTextureDataWithTwoEdgeAttr = function buildTextureDataWithTwoEdgeAttr(nodes, edges, attrs1, attrs2) {\n var dataArray = [];\n var nodeDict = [];\n var mapIdPos = {};\n var i = 0;\n\n for (i = 0; i < nodes.length; i++) {\n var n = nodes[i];\n mapIdPos[n.id] = i;\n dataArray.push(n.x);\n dataArray.push(n.y);\n dataArray.push(0);\n dataArray.push(0);\n nodeDict.push([]);\n }\n\n for (i = 0; i < edges.length; i++) {\n var e = edges[i];\n nodeDict[mapIdPos[e.source]].push(mapIdPos[e.target]);\n nodeDict[mapIdPos[e.source]].push(attrs1(e));\n nodeDict[mapIdPos[e.source]].push(attrs2(e));\n nodeDict[mapIdPos[e.source]].push(0);\n nodeDict[mapIdPos[e.target]].push(mapIdPos[e.source]);\n nodeDict[mapIdPos[e.target]].push(attrs1(e));\n nodeDict[mapIdPos[e.target]].push(attrs2(e));\n nodeDict[mapIdPos[e.target]].push(0);\n }\n\n var maxEdgePerVetex = 0;\n\n for (i = 0; i < nodes.length; i++) {\n var offset = dataArray.length;\n var dests = nodeDict[i]; // dest 中节点 id 与边长间隔存储,即一位节点 id,一位边长……\n\n var len = dests.length; // dataArray[i * 4 + 2] = offset;\n // dataArray[i * 4 + 3] = len / 4; // 第四位存储与该节点相关的所有节点个数\n // pack offset & length into float32: offset 20bit, length 12bit\n\n dataArray[i * 4 + 2] = offset + 1048576 * len / 4;\n dataArray[i * 4 + 3] = 0; // 第四位存储与上一次的距离差值\n\n maxEdgePerVetex = Math.max(maxEdgePerVetex, len / 4);\n\n for (var j = 0; j < len; ++j) {\n var dest = dests[j];\n dataArray.push(+dest);\n }\n } // 不是 4 的倍数,填充 0\n\n\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0);\n }\n\n return {\n array: new Float32Array(dataArray),\n maxEdgePerVetex: maxEdgePerVetex\n };\n};\n/**\n * transform the extended attributes of nodes or edges to a texture array\n * @param {string[]} attributeNames attributes' name to be read from items and put into output array\n * @param {ModelConfig[]} items the items to be read\n * @return {Float32Array} the attributes' value array to be read by GPU\n */\n\nexport var attributesToTextureData = function attributesToTextureData(attributeNames, items) {\n var dataArray = [];\n var attributeNum = attributeNames.length;\n var attributteStringMap = {};\n items.forEach(function (item) {\n attributeNames.forEach(function (name, i) {\n if (attributteStringMap[item[name]] === undefined) {\n attributteStringMap[item[name]] = Object.keys(attributteStringMap).length;\n }\n\n dataArray.push(attributteStringMap[item[name]]); // insure each node's attributes take inter number of grids\n\n if (i === attributeNum - 1) {\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0);\n }\n }\n });\n });\n return {\n array: new Float32Array(dataArray),\n count: Object.keys(attributteStringMap).length\n };\n};\n/**\n * transform the number array format of extended attributes of nodes or edges to a texture array\n * @param {string[]} attributeNames attributes' name to be read from items and put into output array\n * @return {Float32Array} the attributes' value array to be read by GPU\n */\n\nexport var arrayToTextureData = function arrayToTextureData(valueArrays) {\n var dataArray = [];\n var attributeNum = valueArrays.length;\n var itemNum = valueArrays[0].length;\n\n var _loop_1 = function _loop_1(j) {\n valueArrays.forEach(function (valueArray, i) {\n dataArray.push(valueArray[j]); // insure each node's attributes take inter number of grids\n\n if (i === attributeNum - 1) {\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0);\n }\n }\n });\n };\n\n for (var j = 0; j < itemNum; j++) {\n _loop_1(j);\n }\n\n return new Float32Array(dataArray);\n};\n/**\n *\n * @param data Tree graph data\n * @param layout\n */\n\nexport var radialLayout = function radialLayout(data, layout) {\n // 布局方式有 H / V / LR / RL / TB / BT\n var VERTICAL_LAYOUTS = ['V', 'TB', 'BT'];\n var min = {\n x: Infinity,\n y: Infinity\n };\n var max = {\n x: -Infinity,\n y: -Infinity\n }; // 默认布局是垂直布局TB,此时x对应rad,y对应r\n\n var rScale = 'x';\n var radScale = 'y';\n\n if (layout && VERTICAL_LAYOUTS.indexOf(layout) >= 0) {\n // 若是水平布局,y对应rad,x对应r\n radScale = 'x';\n rScale = 'y';\n }\n\n var count = 0;\n traverseTree(data, function (node) {\n count++;\n\n if (node.x > max.x) {\n max.x = node.x;\n }\n\n if (node.x < min.x) {\n min.x = node.x;\n }\n\n if (node.y > max.y) {\n max.y = node.y;\n }\n\n if (node.y < min.y) {\n min.y = node.y;\n }\n\n return true;\n });\n var avgRad = Math.PI * 2 / count;\n var radDiff = max[radScale] - min[radScale];\n\n if (radDiff === 0) {\n return data;\n }\n\n traverseTree(data, function (node) {\n var radial = (node[radScale] - min[radScale]) / radDiff * (Math.PI * 2 - avgRad) + avgRad;\n var r = Math.abs(rScale === 'x' ? node.x - data.x : node.y - data.y);\n node.x = r * Math.cos(radial);\n node.y = r * Math.sin(radial);\n return true;\n });\n return data;\n};","/**\n * 调用 gpuDetector.webgl 判断当前浏览器是否支持 webgl。(支持 gpgpu 的浏览器一定也支持 webgl)\n */\nexport var gpuDetector = function gpuDetector() {\n if (typeof window === 'undefined' || typeof document === 'undefined') return {};\n return {\n canvas: !!window.CanvasRenderingContext2D,\n webgl: function () {\n try {\n var canvas = document.createElement('canvas');\n return !!(window.WebGLRenderingContext && (canvas.getContext('webgl') || canvas.getContext('experimental-webgl')));\n } catch (e) {\n return false;\n }\n }(),\n workers: !!window.Worker,\n fileapi: window.File && window.FileReader && window.FileList && window.Blob,\n getWebGLErrorMessage: function getWebGLErrorMessage() {\n var element = document.createElement('div');\n element.id = 'webgl-error-message';\n element.style.fontFamily = 'monospace';\n element.style.fontSize = '13px';\n element.style.fontWeight = 'normal';\n element.style.textAlign = 'center';\n element.style.background = '#fff';\n element.style.color = '#000';\n element.style.padding = '1.5em';\n element.style.width = '400px';\n element.style.margin = '5em auto 0';\n\n if (!this.webgl) {\n element.innerHTML = window.WebGLRenderingContext ? ['Your graphics card does not seem to support <a href=\"http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation\" rel=\"external nofollow\" rel=\"external nofollow\" style=\"color:#000\">WebGL</a>.<br />', 'Find out how to get it <a href=\"http://get.webgl.org/\" rel=\"external nofollow\" rel=\"external nofollow\" style=\"color:#000\">here</a>.'].join('\\n') : ['Your browser does not seem to support <a href=\"http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation\" rel=\"external nofollow\" rel=\"external nofollow\" style=\"color:#000\">WebGL</a>.<br/>', 'Find out how to get it <a href=\"http://get.webgl.org/\" rel=\"external nofollow\" rel=\"external nofollow\" style=\"color:#000\">here</a>.'].join('\\n');\n }\n\n return element;\n },\n addGetWebGLMessage: function addGetWebGLMessage(parameters) {\n parameters = parameters || {};\n var parent = parameters.parent !== undefined ? parameters.parent : document.body;\n var id = parameters.id !== undefined ? parameters.id : 'oldie';\n var element = gpuDetector().getWebGLErrorMessage();\n element.id = id;\n parent.appendChild(element);\n }\n };\n};","import { __assign } from \"tslib\";\nimport * as ColorUtil from './color';\nimport * as LayoutUtil from './layout';\nimport * as GpuUtil from './gpu';\nimport { Util } from '@antv/g6-core';\n\nvar G6Util = __assign(__assign(__assign(__assign({}, Util), ColorUtil), LayoutUtil), GpuUtil);\n\nexport default G6Util;","import Hierarchy from '@antv/hierarchy';\nimport Util from '../util';\nvar radialLayout = Util.radialLayout;\n\nvar TreeLayout = function () {\n function TreeLayout(cfg) {\n this.type = cfg.type;\n this.radial = cfg.radial;\n this.config = cfg;\n }\n\n TreeLayout.prototype.init = function (data) {\n var _this = this;\n\n this.data = data;\n\n if (this.radial) {\n this.layoutMethod = function (data) {\n var layoutData = Hierarchy[_this.type](data, _this.config);\n\n radialLayout(layoutData);\n return layoutData;\n };\n\n return;\n }\n\n this.layoutMethod = function (data) {\n return Hierarchy[_this.type](data, _this.config);\n };\n };\n\n TreeLayout.prototype.execute = function () {\n return this.layoutMethod(this.data, this.config);\n };\n\n TreeLayout.prototype.layout = function (data) {\n this.init(data);\n return this.execute();\n };\n\n return TreeLayout;\n}();\n\nexport default TreeLayout;","import { Layouts as Layout, registerLayout as oRegisterLayout, GridLayout, RandomLayout, ForceLayout, CircularLayout, DagreLayout, RadialLayout, ConcentricLayout, MDSLayout, FruchtermanGPULayout, FruchtermanLayout, GForceLayout, GForceGPULayout, ComboForceLayout, ForceAtlas2Layout } from '@antv/layout';\nimport TreeLayout from './tree-layout';\noRegisterLayout('grid', GridLayout);\noRegisterLayout('random', RandomLayout);\noRegisterLayout('force', ForceLayout);\noRegisterLayout('circular', CircularLayout);\noRegisterLayout('dagre', DagreLayout);\noRegisterLayout('radial', RadialLayout);\noRegisterLayout('concentric', ConcentricLayout);\noRegisterLayout('mds', MDSLayout);\noRegisterLayout('fruchterman', FruchtermanLayout);\noRegisterLayout('fruchterman-gpu', FruchtermanGPULayout);\noRegisterLayout('gForce', GForceLayout);\noRegisterLayout('gForce-gpu', GForceGPULayout);\noRegisterLayout('comboForce', ComboForceLayout);\noRegisterLayout('forceAtlas2', ForceAtlas2Layout);\n\nvar registerLayout = function registerLayout(name, layoutOverride) {\n layoutOverride.isCustomLayout = true;\n oRegisterLayout(name, layoutOverride);\n};\n\nexport { TreeLayout, Layout, registerLayout };","var WebWorker = function () {\n function WebWorker(worker, workerScirptURL) {\n var code = worker.toString();\n var blob = new Blob([\"importScripts('\" + workerScirptURL + \"');(\" + code + \")()\"], {\n type: 'text/javascript'\n });\n return new Worker(URL.createObjectURL(blob));\n }\n\n return WebWorker;\n}();\n\nexport default WebWorker;","import WebWorker from './work';\nexport var LayoutWorker = function LayoutWorker(workerScriptURL) {\n if (workerScriptURL === void 0) {\n workerScriptURL = 'https://unpkg.com/@antv/layout@latest/dist/layout.min.js';\n }\n\n function workerCode() {\n var LAYOUT_MESSAGE = {\n // run layout\n RUN: 'LAYOUT_RUN',\n // layout ended with success\n END: 'LAYOUT_END',\n // layout error\n ERROR: 'LAYOUT_ERROR',\n // layout tick, used in force directed layout\n TICK: 'LAYOUT_TICK',\n GPURUN: 'GPU_LAYOUT_RUN',\n GPUEND: 'GPU_LAYOUT_END'\n }; // @ts-ignore\n\n layout.registerLayout('grid', layout.GridLayout); // @ts-ignore\n\n layout.registerLayout('random', layout.RandomLayout); // @ts-ignore\n\n layout.registerLayout('force', layout.ForceLayout); // @ts-ignore\n\n layout.registerLayout('circular', layout.CircularLayout); // @ts-ignore\n\n layout.registerLayout('dagre', layout.DagreLayout); // @ts-ignore\n\n layout.registerLayout('radial', layout.RadialLayout); // @ts-ignore\n\n layout.registerLayout('concentric', layout.ConcentricLayout); // @ts-ignore\n\n layout.registerLayout('mds', layout.MDSLayout); // @ts-ignore\n\n layout.registerLayout('fruchterman', layout.FruchtermanLayout); // @ts-ignore\n\n layout.registerLayout('fruchterman-gpu', layout.FruchtermanGPULayout); // @ts-ignore\n\n layout.registerLayout('gForce', layout.GForceLayout); // @ts-ignore\n\n layout.registerLayout('gForce-gpu', layout.GForceGPULayout); // @ts-ignore\n\n layout.registerLayout('comboForce', layout.ComboForceLayout); // @ts-ignore\n\n layout.registerLayout('forceAtlas2', layout.ForceAtlas2Layout);\n\n function isLayoutMessage(event) {\n var type = event.data.type;\n return type === LAYOUT_MESSAGE.RUN || type === LAYOUT_MESSAGE.GPURUN;\n }\n\n function handleLayoutMessage(event) {\n var _this = this;\n\n var type = event.data.type;\n\n switch (type) {\n case LAYOUT_MESSAGE.RUN:\n {\n var _a = event.data,\n nodes_1 = _a.nodes,\n edges = _a.edges,\n _b = _a.layoutCfg,\n layoutCfg = _b === void 0 ? {} : _b;\n var layoutType = layoutCfg.type; // @ts-ignore\n\n var LayoutClass = layout.getLayoutByName(layoutType);\n\n if (!LayoutClass) {\n this.postMessage({\n type: LAYOUT_MESSAGE.ERROR,\n message: \"layout \" + layoutType + \" not found\"\n });\n break;\n }\n\n var layoutMethod_1;\n\n layoutCfg.onLayoutEnd = function () {\n _this.postMessage({\n type: LAYOUT_MESSAGE.END,\n nodes: nodes_1\n });\n\n layoutMethod_1 === null || layoutMethod_1 === void 0 ? void 0 : layoutMethod_1.destroy();\n };\n\n layoutMethod_1 = new LayoutClass(layoutCfg);\n layoutMethod_1.init({\n nodes: nodes_1,\n edges: edges\n });\n layoutMethod_1.execute();\n break;\n }\n\n case LAYOUT_MESSAGE.GPURUN:\n {\n var _c = event.data,\n nodes = _c.nodes,\n edges = _c.edges,\n _d = _c.layoutCfg,\n layoutCfg = _d === void 0 ? {} : _d,\n canvas = _c.canvas;\n var layoutType = layoutCfg.type; // @ts-ignore\n\n var LayoutClass = layout.getLayoutByName(layoutType);\n\n if (!LayoutClass) {\n this.postMessage({\n type: LAYOUT_MESSAGE.ERROR,\n message: \"layout \" + layoutType + \" not found\"\n });\n break;\n }\n\n if (layoutType.split('-')[1] !== 'gpu') {\n this.postMessage({\n type: LAYOUT_MESSAGE.ERROR,\n message: \"layout \" + layoutType + \" does not support GPU\"\n });\n break;\n }\n\n var layoutMethod = new LayoutClass(layoutCfg);\n layoutMethod.init({\n nodes: nodes,\n edges: edges\n });\n layoutMethod.executeWithWorker(canvas, this);\n break;\n }\n\n default:\n break;\n }\n }\n\n onmessage = function onmessage(event) {\n if (isLayoutMessage(event)) {\n handleLayoutMessage(event);\n }\n };\n }\n\n var layoutWorker = new WebWorker(workerCode, workerScriptURL);\n return layoutWorker;\n};","/**\n * @fileoverview constants for layout\n * @author changzhe.zb@antfin.com\n */\n\n/** layout message type */\nexport var LAYOUT_MESSAGE = {\n // run layout\n RUN: 'LAYOUT_RUN',\n // layout ended with success\n END: 'LAYOUT_END',\n // layout error\n ERROR: 'LAYOUT_ERROR',\n // layout tick, used in force directed layout\n TICK: 'LAYOUT_TICK',\n GPURUN: 'GPU_LAYOUT_RUN',\n GPUEND: 'GPU_LAYOUT_END'\n};","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nimport { __awaiter, __extends, __generator } from \"tslib\";\nimport { AbstractLayout } from '@antv/g6-core';\nimport { Layout } from '../../layout';\nimport { LayoutWorker } from '../../layout/worker/layout.worker';\nimport { LAYOUT_MESSAGE } from '../../layout/worker/layoutConst';\nimport { gpuDetector } from '../../util/gpu';\nimport { mix, clone } from '@antv/util'; // eslint-disable-next-line @typescript-eslint/no-implied-eval\n\nvar mockRaf = function mockRaf(cb) {\n return setTimeout(cb, 16);\n};\n\nvar mockCaf = function mockCaf(reqId) {\n return clearTimeout(reqId);\n};\n\nvar helper = {\n // pollyfill\n requestAnimationFrame: function requestAnimationFrame(callback) {\n var fn = typeof window !== 'undefined' ? window.requestAnimationFrame || window.webkitRequestAnimationFrame || mockRaf : mockRaf;\n return fn(callback);\n },\n cancelAnimationFrame: function cancelAnimationFrame(requestId) {\n var fn = typeof window !== 'undefined' ? window.cancelAnimationFrame || window.webkitCancelAnimationFrame || mockCaf : mockCaf;\n return fn(requestId);\n }\n};\nvar GPU_LAYOUT_NAMES = ['fruchterman', 'gForce'];\nvar LAYOUT_PIPES_ADJUST_NAMES = ['force', 'grid', 'circular'];\n\nvar LayoutController = function (_super) {\n __extends(LayoutController, _super); // the configurations of the layout\n // private layoutCfg: any; // LayoutOptions\n // the type name of the layout\n // private layoutType: string;\n // private data: GraphData;\n // private layoutMethods: typeof Layout;\n\n\n function LayoutController(graph) {\n var _this = _super.call(this, graph) || this;\n\n _this.graph = graph;\n _this.layoutCfg = graph.get('layout') || {};\n _this.layoutType = _this.getLayoutType();\n _this.worker = null;\n _this.workerData = {};\n\n _this.initLayout();\n\n return _this;\n } // eslint-disable-next-line class-methods-use-this\n\n\n LayoutController.prototype.initLayout = function () {// no data before rendering\n }; // get layout worker and create one if not exists\n\n\n LayoutController.prototype.getWorker = function () {\n if (this.worker) {\n return this.worker;\n }\n\n if (typeof Worker === 'undefined') {\n // 如果当前浏览器不支持 web worker,则不使用 web worker\n console.warn('Web worker is not supported in current browser.');\n this.worker = null;\n } else {\n this.worker = LayoutWorker(this.layoutCfg.workerScriptURL);\n }\n\n return this.worker;\n }; // stop layout worker\n\n\n LayoutController.prototype.stopWorker = function () {\n var workerData = this.workerData;\n\n if (!this.worker) {\n return;\n }\n\n this.worker.terminate();\n this.worker = null; // 重新开始新的布局之前,先取消之前布局的requestAnimationFrame。\n\n if (workerData.requestId) {\n helper.cancelAnimationFrame(workerData.requestId);\n workerData.requestId = null;\n }\n\n if (workerData.requestId2) {\n helper.cancelAnimationFrame(workerData.requestId2);\n workerData.requestId2 = null;\n }\n };\n\n LayoutController.prototype.execLayoutMethod = function (layoutCfg, order) {\n var _this = this;\n\n return new Promise(function (reslove, reject) {\n return __awaiter(_this, void 0, void 0, function () {\n var graph, layoutType, isForce, onTick_1, tick, enableTick, layoutMethod, onTick_2, tick, layoutData;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n graph = this.graph;\n if (graph.get('destroyed')) return [2\n /*return*/\n ];\n layoutType = layoutCfg.type; // 每个布局方法都需要注册\n\n layoutCfg.onLayoutEnd = function () {\n graph.emit('aftersublayout', {\n type: layoutType\n });\n reslove();\n }; // 若用户指定开启 gpu,且当前浏览器支持 webgl,且该算法存在 GPU 版本(目前仅支持 fruchterman 和 gForce),使用 gpu 版本的布局\n\n\n if (layoutType && this.isGPU) {\n if (!this.hasGPUVersion(layoutType)) {\n console.warn(\"The '\" + layoutType + \"' layout does not support GPU calculation for now, it will run in CPU.\");\n } else {\n layoutType = layoutType + \"-gpu\";\n }\n }\n\n isForce = layoutType === 'force' || layoutType === 'g6force' || layoutType === 'gForce';\n\n if (isForce) {\n onTick_1 = layoutCfg.onTick;\n\n tick = function tick() {\n if (onTick_1) {\n onTick_1();\n }\n\n graph.refreshPositions();\n };\n\n layoutCfg.tick = tick;\n } else if (layoutCfg.type === 'comboForce') {\n layoutCfg.comboTrees = graph.get('comboTrees');\n }\n\n enableTick = false;\n\n try {\n layoutMethod = new Layout[layoutType](layoutCfg);\n } catch (e) {\n console.warn(\"The layout method: '\" + layoutType + \"' does not exist! Please specify it first.\");\n reject();\n } // 是否需要迭代的方式完成布局。这里是来自布局对象的实例属性,是由布局的定义者在布局类定义的。\n\n\n enableTick = layoutMethod.enableTick;\n\n if (enableTick) {\n onTick_2 = layoutCfg.onTick;\n\n tick = function tick() {\n if (onTick_2) {\n onTick_2();\n }\n\n graph.refreshPositions();\n };\n\n layoutMethod.tick = tick;\n }\n\n layoutData = this.filterLayoutData(this.data, layoutCfg);\n addLayoutOrder(layoutData, order);\n layoutMethod.init(layoutData); // 若存在节点没有位置信息,且没有设置 layout,在 initPositions 中 random 给出了所有节点的位置,不需要再次执行 random 布局\n // 所有节点都有位置信息,且指定了 layout,则执行布局(代表不是第一次进行布局)\n\n graph.emit('beforesublayout', {\n type: layoutType\n });\n return [4\n /*yield*/\n , layoutMethod.execute()];\n\n case 1:\n _a.sent();\n\n if (layoutMethod.isCustomLayout && layoutCfg.onLayoutEnd) layoutCfg.onLayoutEnd();\n this.layoutMethods[order] = layoutMethod;\n return [2\n /*return*/\n ];\n }\n });\n });\n });\n };\n\n LayoutController.prototype.updateLayoutMethod = function (layoutMethod, layoutCfg) {\n var _this = this;\n\n return new Promise(function (reslove, reject) {\n return __awaiter(_this, void 0, void 0, function () {\n var graph, layoutType, layoutData;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n graph = this.graph;\n layoutType = layoutCfg === null || layoutCfg === void 0 ? void 0 : layoutCfg.type; // 每个布局方法都需要注册\n\n layoutCfg.onLayoutEnd = function () {\n graph.emit('aftersublayout', {\n type: layoutType\n });\n reslove();\n };\n\n layoutData = this.filterLayoutData(this.data, layoutCfg);\n layoutMethod.init(layoutData);\n layoutMethod.updateCfg(layoutCfg);\n graph.emit('beforesublayout', {\n type: layoutType\n });\n return [4\n /*yield*/\n , layoutMethod.execute()];\n\n case 1:\n _a.sent();\n\n if (layoutMethod.isCustomLayout && layoutCfg.onLayoutEnd) layoutCfg.onLayoutEnd();\n return [2\n /*return*/\n ];\n }\n });\n });\n });\n };\n /**\n * @param {function} success callback\n * @return {boolean} 是否使用web worker布局\n */\n\n\n LayoutController.prototype.layout = function (success) {\n var _this = this;\n\n var graph = this.graph;\n this.data = this.setDataFromGraph();\n var _a = this.data,\n nodes = _a.nodes,\n hiddenNodes = _a.hiddenNodes;\n\n if (!nodes) {\n return false;\n }\n\n var width = graph.get('width');\n var height = graph.get('height');\n var layoutCfg = {};\n Object.assign(layoutCfg, {\n width: width,\n height: height,\n center: [width / 2, height / 2]\n }, this.layoutCfg);\n this.layoutCfg = layoutCfg;\n this.destoryLayoutMethods();\n graph.emit('beforelayout');\n this.initPositions(layoutCfg.center, nodes); // init hidden nodes\n\n this.initPositions(layoutCfg.center, hiddenNodes); // 防止用户直接用 -gpu 结尾指定布局\n\n var layoutType = layoutCfg.type;\n\n if (layoutType && layoutType.split('-')[1] === 'gpu') {\n layoutType = layoutType.split('-')[0];\n layoutCfg.gpuEnabled = true;\n } // 若用户指定开启 gpu,且当前浏览器支持 webgl,且该算法存在 GPU 版本(目前仅支持 fruchterman 和 gForce),使用 gpu 版本的布局\n\n\n var enableGPU = false;\n\n if (layoutCfg.gpuEnabled) {\n enableGPU = true; // 打开下面语句将会导致 webworker 报找不到 window\n\n if (!gpuDetector().webgl) {\n console.warn(\"Your browser does not support webGL or GPGPU. The layout will run in CPU.\");\n enableGPU = false;\n }\n }\n\n this.isGPU = enableGPU; // 在 onAllLayoutEnd 中执行用户自定义 onLayoutEnd,触发 afterlayout、更新节点位置、fitView/fitCenter、触发 afterrender\n\n var onLayoutEnd = layoutCfg.onLayoutEnd,\n layoutEndFormatted = layoutCfg.layoutEndFormatted,\n adjust = layoutCfg.adjust;\n\n if (!layoutEndFormatted) {\n layoutCfg.layoutEndFormatted = true;\n\n layoutCfg.onAllLayoutEnd = function () {\n return __awaiter(_this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // 执行用户自定义 onLayoutEnd\n if (onLayoutEnd) {\n onLayoutEnd();\n } // 更新节点位置\n\n\n this.refreshLayout();\n if (!(adjust && layoutCfg.pipes)) return [3\n /*break*/\n , 2];\n return [4\n /*yield*/\n , this.adjustPipesBox(this.data, adjust)];\n\n case 1:\n _a.sent();\n\n this.refreshLayout();\n _a.label = 2;\n\n case 2:\n // 触发 afterlayout\n graph.emit('afterlayout');\n return [2\n /*return*/\n ];\n }\n });\n });\n };\n }\n\n this.stopWorker();\n\n if (layoutCfg.workerEnabled && this.layoutWithWorker(this.data)) {\n // 如果启用布局web worker并且浏览器支持web worker,用web worker布局。否则回退到不用web worker布局。\n return true;\n }\n\n var start = Promise.resolve();\n\n if (layoutCfg.type) {\n start = start.then(function () {\n return __awaiter(_this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n return [4\n /*yield*/\n , this.execLayoutMethod(layoutCfg, 0)];\n\n case 1:\n return [2\n /*return*/\n , _a.sent()];\n }\n });\n });\n });\n } else if (layoutCfg.pipes) {\n layoutCfg.pipes.forEach(function (cfg, index) {\n start = start.then(function () {\n return __awaiter(_this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n return [4\n /*yield*/\n , this.execLayoutMethod(cfg, index)];\n\n case 1:\n return [2\n /*return*/\n , _a.sent()];\n }\n });\n });\n });\n });\n } // 最后统一在外部调用onAllLayoutEnd\n\n\n start.then(function () {\n if (layoutCfg.onAllLayoutEnd) layoutCfg.onAllLayoutEnd(); // 在执行 execute 后立即执行 success,且在 timeBar 中有 throttle,可以防止 timeBar 监听 afterrender 进行 changeData 后 layout,从而死循环\n // 对于 force 一类布局完成后的 fitView 需要用户自己在 onLayoutEnd 中配置\n\n if (success) success();\n }).catch(function (error) {\n console.warn('graph layout failed,', error);\n });\n return false;\n };\n /**\n * layout with web worker\n * @param {object} data graph data\n * @return {boolean} 是否支持web worker\n */\n\n\n LayoutController.prototype.layoutWithWorker = function (data) {\n var _this = this;\n\n var _a = this,\n layoutCfg = _a.layoutCfg,\n graph = _a.graph;\n\n var worker = this.getWorker(); // 每次worker message event handler调用之间的共享数据,会被修改。\n\n var workerData = this.workerData;\n\n if (!worker) {\n return false;\n }\n\n workerData.requestId = null;\n workerData.requestId2 = null;\n workerData.currentTick = null;\n workerData.currentTickData = null;\n graph.emit('beforelayout');\n var start = Promise.resolve();\n\n if (layoutCfg.type) {\n start = start.then(function () {\n return _this.runWebworker(worker, data, layoutCfg);\n });\n } else if (layoutCfg.pipes) {\n var _loop_1 = function _loop_1(cfg) {\n start = start.then(function () {\n return _this.runWebworker(worker, data, cfg);\n });\n };\n\n for (var _i = 0, _b = layoutCfg.pipes; _i < _b.length; _i++) {\n var cfg = _b[_i];\n\n _loop_1(cfg);\n }\n } // 最后统一在外部调用onAllLayoutEnd\n\n\n start.then(function () {\n if (layoutCfg.onAllLayoutEnd) layoutCfg.onAllLayoutEnd();\n }).catch(function (error) {\n console.error('layout failed', error);\n });\n return true;\n };\n\n LayoutController.prototype.runWebworker = function (worker, allData, layoutCfg) {\n var _this = this;\n\n var isGPU = this.isGPU;\n var data = this.filterLayoutData(allData, layoutCfg);\n var nodes = data.nodes,\n edges = data.edges;\n var offScreenCanvas = document.createElement('canvas');\n var gpuWorkerAbility = isGPU && typeof window !== 'undefined' && // eslint-disable-next-line @typescript-eslint/dot-notation\n window.navigator && !navigator[\"gpu\"] && // WebGPU 还不支持 OffscreenCanvas\n 'OffscreenCanvas' in window && 'transferControlToOffscreen' in offScreenCanvas; // NOTE: postMessage的message参数里面不能包含函数,否则postMessage会报错,\n // 例如:'function could not be cloned'。\n // 详情参考:https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Structured_clone_algorithm\n // 所以这里需要把过滤layoutCfg里的函数字段过滤掉。\n\n var filteredLayoutCfg = filterObject(layoutCfg, function (value) {\n return typeof value !== 'function';\n });\n\n if (!gpuWorkerAbility) {\n worker.postMessage({\n type: LAYOUT_MESSAGE.RUN,\n nodes: nodes,\n edges: edges,\n layoutCfg: filteredLayoutCfg\n });\n } else {\n var offscreen = offScreenCanvas.transferControlToOffscreen(); // filteredLayoutCfg.canvas = offscreen;\n\n filteredLayoutCfg.type = filteredLayoutCfg.type + \"-gpu\";\n worker.postMessage({\n type: LAYOUT_MESSAGE.GPURUN,\n nodes: nodes,\n edges: edges,\n layoutCfg: filteredLayoutCfg,\n canvas: offscreen\n }, [offscreen]);\n }\n\n return new Promise(function (reslove, reject) {\n worker.onmessage = function (event) {\n _this.handleWorkerMessage(reslove, reject, event, data, layoutCfg);\n };\n });\n }; // success callback will be called when updating graph positions for the first time.\n\n\n LayoutController.prototype.handleWorkerMessage = function (reslove, reject, event, data, layoutCfg) {\n var _a = this,\n graph = _a.graph,\n workerData = _a.workerData;\n\n var eventData = event.data;\n var type = eventData.type;\n\n var onTick = function onTick() {\n if (layoutCfg.onTick) {\n layoutCfg.onTick();\n }\n };\n\n switch (type) {\n case LAYOUT_MESSAGE.TICK:\n workerData.currentTick = eventData.currentTick;\n workerData.currentTickData = eventData;\n\n if (!workerData.requestId) {\n workerData.requestId = helper.requestAnimationFrame(function requestId() {\n updateLayoutPosition(data, eventData);\n graph.refreshPositions();\n onTick();\n\n if (eventData.currentTick === eventData.totalTicks) {\n // 如果是最后一次tick\n reslove();\n } else if (workerData.currentTick === eventData.totalTicks) {\n // 注意这里workerData.currentTick可能已经不再是前面赋值时候的值了,\n // 因为在requestAnimationFrame等待时间里,可能产生新的tick。\n // 如果当前tick不是最后一次tick,并且所有的tick消息都已发出来了,那么需要用最后一次tick的数据再刷新一次。\n workerData.requestId2 = helper.requestAnimationFrame(function requestId2() {\n updateLayoutPosition(data, workerData.currentTickData);\n graph.refreshPositions();\n workerData.requestId2 = null;\n onTick();\n reslove();\n });\n }\n\n workerData.requestId = null;\n });\n }\n\n break;\n\n case LAYOUT_MESSAGE.END:\n // 如果没有tick消息(非力导布局)\n if (workerData.currentTick == null) {\n updateLayoutPosition(data, eventData);\n reslove();\n }\n\n break;\n\n case LAYOUT_MESSAGE.GPUEND:\n // 如果没有tick消息(非力导布局)\n if (workerData.currentTick == null) {\n updateGPUWorkerLayoutPosition(data, eventData);\n reslove();\n }\n\n break;\n\n case LAYOUT_MESSAGE.ERROR:\n console.warn('Web-Worker layout error!', eventData.message);\n reject();\n break;\n\n default:\n reject();\n break;\n }\n }; // 更新布局参数\n\n\n LayoutController.prototype.updateLayoutCfg = function (cfg) {\n var _this = this;\n\n var _a = this,\n graph = _a.graph,\n layoutMethods = _a.layoutMethods;\n\n var layoutCfg = mix({}, this.layoutCfg, cfg);\n this.layoutCfg = layoutCfg;\n\n if (!(layoutMethods === null || layoutMethods === void 0 ? void 0 : layoutMethods.length)) {\n this.layout();\n return;\n }\n\n this.data = this.setDataFromGraph();\n this.stopWorker();\n\n if (cfg.workerEnabled && this.layoutWithWorker(this.data)) {\n // 如果启用布局web worker并且浏览器支持web worker,用web worker布局。否则回退到不用web worker布局。\n return;\n }\n\n graph.emit('beforelayout');\n var start = Promise.resolve();\n\n if (layoutMethods.length === 1) {\n start = start.then(function () {\n return __awaiter(_this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n return [4\n /*yield*/\n , this.updateLayoutMethod(layoutMethods[0], layoutCfg)];\n\n case 1:\n return [2\n /*return*/\n , _a.sent()];\n }\n });\n });\n });\n } else {\n layoutMethods === null || layoutMethods === void 0 ? void 0 : layoutMethods.forEach(function (layoutMethod, index) {\n var currentCfg = layoutCfg.pipes[index];\n start = start.then(function () {\n return __awaiter(_this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n return [4\n /*yield*/\n , this.updateLayoutMethod(layoutMethod, currentCfg)];\n\n case 1:\n return [2\n /*return*/\n , _a.sent()];\n }\n });\n });\n });\n });\n }\n\n start.then(function () {\n if (layoutCfg.onAllLayoutEnd) layoutCfg.onAllLayoutEnd();\n }).catch(function (error) {\n console.warn('layout failed', error);\n });\n };\n\n LayoutController.prototype.adjustPipesBox = function (data, adjust) {\n var _this = this;\n\n return new Promise(function (resolve) {\n var nodes = data.nodes;\n\n if (!(nodes === null || nodes === void 0 ? void 0 : nodes.length)) {\n resolve();\n }\n\n if (!LAYOUT_PIPES_ADJUST_NAMES.includes(adjust)) {\n console.warn(\"The adjust type \" + adjust + \" is not supported yet, please assign it with 'force', 'grid', or 'circular'.\");\n resolve();\n }\n\n var layoutCfg = {\n center: _this.layoutCfg.center,\n nodeSize: function nodeSize(d) {\n return Math.max(d.height, d.width);\n },\n preventOverlap: true,\n onLayoutEnd: function onLayoutEnd() {}\n }; // 计算出大单元\n\n var _a = _this.getLayoutBBox(nodes),\n groupNodes = _a.groupNodes,\n layoutNodes = _a.layoutNodes;\n\n var preNodes = clone(layoutNodes); // 根据大单元坐标的变化,调整这里面每个小单元nodes\n\n layoutCfg.onLayoutEnd = function () {\n layoutNodes === null || layoutNodes === void 0 ? void 0 : layoutNodes.forEach(function (ele, index) {\n var _a, _b, _c;\n\n var dx = ele.x - ((_a = preNodes[index]) === null || _a === void 0 ? void 0 : _a.x);\n var dy = ele.y - ((_b = preNodes[index]) === null || _b === void 0 ? void 0 : _b.y);\n (_c = groupNodes[index]) === null || _c === void 0 ? void 0 : _c.forEach(function (n) {\n n.x += dx;\n n.y += dy;\n });\n });\n resolve();\n };\n\n var layoutMethod = new Layout[adjust](layoutCfg);\n layoutMethod.layout({\n nodes: layoutNodes\n });\n });\n };\n\n LayoutController.prototype.hasGPUVersion = function (layoutName) {\n return GPU_LAYOUT_NAMES.includes(layoutName);\n };\n\n LayoutController.prototype.destroy = function () {\n this.destoryLayoutMethods();\n var worker = this.worker;\n\n if (worker) {\n worker.terminate();\n this.worker = null;\n }\n\n this.destroyed = true;\n this.graph.set('layout', undefined);\n this.layoutCfg = undefined;\n this.layoutType = undefined;\n this.layoutMethods = undefined;\n this.graph = null;\n };\n\n return LayoutController;\n}(AbstractLayout);\n\nexport default LayoutController;\n\nfunction updateLayoutPosition(data, layoutData) {\n var nodes = data.nodes;\n var layoutNodes = layoutData.nodes;\n var nodeLength = nodes.length;\n\n for (var i = 0; i < nodeLength; i++) {\n var node = nodes[i];\n node.x = layoutNodes[i].x;\n node.y = layoutNodes[i].y;\n }\n}\n\nfunction filterObject(collection, callback) {\n var result = {};\n\n if (collection && _typeof(collection) === 'object') {\n Object.keys(collection).forEach(function (key) {\n if (collection.hasOwnProperty(key) && callback(collection[key])) {\n result[key] = collection[key];\n }\n });\n return result;\n }\n\n return collection;\n}\n\nfunction updateGPUWorkerLayoutPosition(data, layoutData) {\n var nodes = data.nodes;\n var vertexEdgeData = layoutData.vertexEdgeData;\n var nodeLength = nodes.length;\n\n for (var i = 0; i < nodeLength; i++) {\n var node = nodes[i];\n var x = vertexEdgeData[4 * i];\n var y = vertexEdgeData[4 * i + 1];\n node.x = x;\n node.y = y;\n }\n}\n\nfunction addLayoutOrder(data, order) {\n var _a;\n\n if (!((_a = data === null || data === void 0 ? void 0 : data.nodes) === null || _a === void 0 ? void 0 : _a.length)) {\n return;\n }\n\n var nodes = data.nodes;\n nodes.forEach(function (node) {\n node.layoutOrder = order;\n });\n}","import { __awaiter, __extends, __generator } from \"tslib\";\nimport { Canvas as GCanvas } from '@antv/g-canvas';\nimport { Canvas as GSVGCanvas } from '@antv/g-svg';\nimport { ext } from '@antv/matrix-util';\nimport { clone, deepMix, each, isString, isNumber } from '@antv/util';\nimport { AbstractGraph } from '@antv/g6-core';\nimport Global from '../global';\nimport { LayoutController, EventController } from './controller';\nimport { createDom } from '@antv/dom-util';\nvar transform = ext.transform;\nvar SVG = 'svg';\n\nvar Graph = function (_super) {\n __extends(Graph, _super);\n\n function Graph(cfg) {\n var _this = _super.call(this, cfg) || this;\n\n var defaultNode = _this.get('defaultNode');\n\n if (!defaultNode) {\n _this.set('defaultNode', {\n type: 'circle'\n });\n }\n\n if (!defaultNode.type) {\n defaultNode.type = 'circle';\n\n _this.set('defaultNode', defaultNode);\n }\n\n _this.destroyed = false;\n return _this;\n }\n\n Graph.prototype.initLayoutController = function () {\n var layoutController = new LayoutController(this);\n this.set({\n layoutController: layoutController\n });\n };\n\n Graph.prototype.initEventController = function () {\n var eventController = new EventController(this);\n this.set({\n eventController: eventController\n });\n };\n\n Graph.prototype.initCanvas = function () {\n var container = this.get('container');\n\n if (typeof container === 'string') {\n container = document.getElementById(container);\n this.set('container', container);\n }\n\n if (!container) {\n throw new Error('invalid container');\n }\n\n var clientWidth = container.clientWidth,\n clientHeight = container.clientHeight;\n var width = this.get('width') || clientWidth;\n var height = this.get('height') || clientHeight;\n\n if (!this.get('width') && !this.get('height')) {\n this.set('width', clientWidth);\n this.set('height', clientHeight);\n }\n\n var renderer = this.get('renderer');\n var canvas;\n\n if (renderer === SVG) {\n canvas = new GSVGCanvas({\n container: container,\n width: width,\n height: height\n });\n } else {\n var canvasCfg = {\n container: container,\n width: width,\n height: height\n };\n var pixelRatio = this.get('pixelRatio');\n\n if (pixelRatio) {\n canvasCfg.pixelRatio = pixelRatio;\n }\n\n canvas = new GCanvas(canvasCfg);\n }\n\n this.set('canvas', canvas);\n };\n\n Graph.prototype.initPlugins = function () {\n var self = this;\n each(self.get('plugins'), function (plugin) {\n if (!plugin.destroyed && plugin.initPlugin) {\n plugin.initPlugin(self);\n }\n });\n };\n /**\n * 增加图片下载水印功能\n */\n\n\n Graph.prototype.downloadImageWatermark = function (watermarker, context, width, height) {\n return __awaiter(this, void 0, void 0, function () {\n var watermarkStr, watermarkbase64, img;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n watermarkStr = watermarker.style.backgroundImage;\n watermarkbase64 = watermarkStr.slice(5, watermarkStr.length - 2);\n img = new Image();\n img.src = watermarkbase64;\n return [4\n /*yield*/\n , new Promise(function (resolve) {\n img.onload = function () {\n var pat = context.createPattern(img, \"repeat\");\n context.rect(0, 0, width, height);\n context.fillStyle = pat;\n context.fill();\n resolve('');\n };\n })];\n\n case 1:\n _a.sent();\n\n return [2\n /*return*/\n ];\n }\n });\n });\n };\n /**\n * 用于生成图片 (异步callback)\n * @param {String} type 图片类型,可选值:\"image/png\" | \"image/jpeg\" | \"image/webp\" | \"image/bmp\"\n * @param {string} backgroundColor 图片背景色\n * @return {string} 图片 dataURL\n */\n\n\n Graph.prototype.asyncToDataUrl = function (type, backgroundColor, callback, widths, heights, vCanvasEl) {\n var _this = this;\n\n var watermarker = document.querySelector('.g6-graph-watermarker');\n var canvas = this.get('canvas');\n var renderer = canvas.getRenderer();\n var canvasDom = vCanvasEl || canvas.get('el');\n var dataURL = '';\n if (!type) type = 'image/png';\n setTimeout(function () {\n return __awaiter(_this, void 0, void 0, function () {\n var cloneNode, svgDocType, svgDoc, svgData, imageData, context, width, height, compositeOperation, pixelRatio;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (!(renderer === 'svg')) return [3\n /*break*/\n , 1];\n cloneNode = canvasDom.cloneNode(true);\n svgDocType = document.implementation.createDocumentType('svg', '-//W3C//DTD SVG 1.1//EN', 'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd');\n svgDoc = document.implementation.createDocument('http://www.w3.org/2000/svg', 'svg', svgDocType);\n svgDoc.replaceChild(cloneNode, svgDoc.documentElement);\n svgData = new XMLSerializer().serializeToString(svgDoc);\n dataURL = \"data:image/svg+xml;charset=utf8,\" + encodeURIComponent(svgData);\n return [3\n /*break*/\n , 4];\n\n case 1:\n imageData = void 0;\n context = canvasDom.getContext('2d');\n width = widths || this.get('width');\n height = heights || this.get('height');\n compositeOperation = void 0;\n if (!watermarker) return [3\n /*break*/\n , 3];\n return [4\n /*yield*/\n , this.downloadImageWatermark(watermarker, context, width, height)];\n\n case 2:\n _a.sent();\n\n _a.label = 3;\n\n case 3:\n if (backgroundColor) {\n pixelRatio = typeof window !== 'undefined' ? window.devicePixelRatio : 1;\n\n try {\n imageData = context.getImageData(0, 0, width * pixelRatio, height * pixelRatio);\n compositeOperation = context.globalCompositeOperation;\n context.globalCompositeOperation = 'destination-over';\n context.fillStyle = backgroundColor;\n context.fillRect(0, 0, width, height);\n } catch (error) {\n console.error('Download image failed. Out of memory at ImageData creation');\n }\n }\n\n dataURL = canvasDom.toDataURL(type);\n\n if (backgroundColor) {\n context.clearRect(0, 0, width, height);\n context.putImageData(imageData, 0, 0);\n context.globalCompositeOperation = compositeOperation;\n }\n\n _a.label = 4;\n\n case 4:\n if (callback) callback(dataURL);\n return [2\n /*return*/\n ];\n }\n });\n });\n }, 16);\n };\n /**\n * 返回可见区域的图的 dataUrl,用于生成图片\n * @param {String} type 图片类型,可选值:\"image/png\" | \"image/jpeg\" | \"image/webp\" | \"image/bmp\"\n * @param {string} backgroundColor 图片背景色\n * @return {string} 图片 dataURL\n */\n\n\n Graph.prototype.toDataURL = function (type, backgroundColor) {\n var canvas = this.get('canvas');\n var renderer = canvas.getRenderer();\n var canvasDom = canvas.get('el');\n if (!type) type = 'image/png';\n var dataURL = '';\n\n if (renderer === 'svg') {\n var cloneNode = canvasDom.cloneNode(true);\n var svgDocType = document.implementation.createDocumentType('svg', '-//W3C//DTD SVG 1.1//EN', 'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd');\n var svgDoc = document.implementation.createDocument('http://www.w3.org/2000/svg', 'svg', svgDocType);\n svgDoc.replaceChild(cloneNode, svgDoc.documentElement);\n var svgData = new XMLSerializer().serializeToString(svgDoc);\n dataURL = \"data:image/svg+xml;charset=utf8,\" + encodeURIComponent(svgData);\n } else {\n var imageData = void 0;\n var context = canvasDom.getContext('2d');\n var width = this.get('width');\n var height = this.get('height');\n var compositeOperation = void 0;\n\n if (backgroundColor) {\n var pixelRatio = typeof window !== 'undefined' ? window.devicePixelRatio : 1;\n\n try {\n imageData = context.getImageData(0, 0, width * pixelRatio, height * pixelRatio);\n compositeOperation = context.globalCompositeOperation;\n context.globalCompositeOperation = 'destination-over';\n context.fillStyle = backgroundColor;\n context.fillRect(0, 0, width, height);\n } catch (error) {\n console.error('Download image failed. Out of memory at ImageData creation');\n }\n }\n\n dataURL = canvasDom.toDataURL(type);\n\n if (backgroundColor) {\n context.clearRect(0, 0, width, height);\n context.putImageData(imageData, 0, 0);\n context.globalCompositeOperation = compositeOperation;\n }\n }\n\n return dataURL;\n };\n /**\n * 返回整个图(包括超出可见区域的部分)的 dataUrl,用于生成图片\n * @param {Function} callback 异步生成 dataUrl 完成后的回调函数,在这里处理生成的 dataUrl 字符串\n * @param {String} type 图片类型,可选值:\"image/png\" | \"image/jpeg\" | \"image/webp\" | \"image/bmp\"\n * @param {Object} imageConfig 图片配置项,包括背景色和上下左右的 padding\n */\n\n\n Graph.prototype.toFullDataURL = function (callback, type, imageConfig) {\n var bbox = this.get('group').getCanvasBBox();\n var height = bbox.height;\n var width = bbox.width;\n var renderer = this.get('renderer');\n var vContainerDOM = createDom('<id=\"virtual-image\"></div>');\n var backgroundColor = imageConfig ? imageConfig.backgroundColor : undefined;\n var padding = imageConfig ? imageConfig.padding : undefined;\n if (!padding) padding = [0, 0, 0, 0];else if (isNumber(padding)) padding = [padding, padding, padding, padding];\n var vHeight = height + padding[0] + padding[2];\n var vWidth = width + padding[1] + padding[3];\n var canvasOptions = {\n container: vContainerDOM,\n height: vHeight,\n width: vWidth,\n quickHit: true\n };\n var vCanvas = renderer === 'svg' ? new GSVGCanvas(canvasOptions) : new GCanvas(canvasOptions);\n var group = this.get('group');\n var vGroup = group.clone();\n var matrix = clone(vGroup.getMatrix());\n if (!matrix) matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var centerX = (bbox.maxX + bbox.minX) / 2;\n var centerY = (bbox.maxY + bbox.minY) / 2;\n matrix = transform(matrix, [['t', -centerX, -centerY], ['t', width / 2 + padding[3], height / 2 + padding[0]]]);\n vGroup.resetMatrix();\n vGroup.setMatrix(matrix);\n vCanvas.add(vGroup);\n var vCanvasEl = vCanvas.get('el');\n var dataURL = '';\n if (!type) type = 'image/png';\n setTimeout(function () {\n if (renderer === 'svg') {\n var cloneNode = vCanvasEl.cloneNode(true);\n var svgDocType = document.implementation.createDocumentType('svg', '-//W3C//DTD SVG 1.1//EN', 'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd');\n var svgDoc = document.implementation.createDocument('http://www.w3.org/2000/svg', 'svg', svgDocType);\n svgDoc.replaceChild(cloneNode, svgDoc.documentElement);\n var svgData = new XMLSerializer().serializeToString(svgDoc);\n dataURL = \"data:image/svg+xml;charset=utf8,\" + encodeURIComponent(svgData);\n } else {\n var imageData = void 0;\n var context = vCanvasEl.getContext('2d');\n var compositeOperation = void 0;\n\n if (backgroundColor) {\n var pixelRatio = typeof window !== 'undefined' ? window.devicePixelRatio : 1;\n\n try {\n imageData = context.getImageData(0, 0, vWidth * pixelRatio, vHeight * pixelRatio);\n compositeOperation = context.globalCompositeOperation;\n context.globalCompositeOperation = 'destination-over';\n context.fillStyle = backgroundColor;\n context.fillRect(0, 0, vWidth, vHeight);\n } catch (error) {\n console.error('Download image failed. Out of memory at ImageData creation');\n }\n }\n\n dataURL = vCanvasEl.toDataURL(type);\n\n if (backgroundColor) {\n context.clearRect(0, 0, vWidth, vHeight);\n context.putImageData(imageData, 0, 0);\n context.globalCompositeOperation = compositeOperation;\n }\n }\n\n if (callback) callback(dataURL);\n }, 16);\n };\n /**\n * 导出包含全图的图片\n * @param {String} name 图片的名称\n * @param {String} type 图片类型,可选值:\"image/png\" | \"image/jpeg\" | \"image/webp\" | \"image/bmp\"\n * @param {Object} imageConfig 图片配置项,包括背景色和上下左右的 padding\n */\n\n\n Graph.prototype.downloadFullImage = function (name, type, imageConfig) {\n var _this = this;\n\n var bbox = this.get('group').getCanvasBBox();\n var height = bbox.height;\n var width = bbox.width;\n var renderer = this.get('renderer');\n var vContainerDOM = createDom('<id=\"virtual-image\"></div>');\n var watermarker = document.querySelector('.g6-graph-watermarker');\n var backgroundColor = imageConfig ? imageConfig.backgroundColor : undefined;\n var padding = imageConfig ? imageConfig.padding : undefined;\n if (!padding) padding = [0, 0, 0, 0];else if (isNumber(padding)) padding = [padding, padding, padding, padding];\n var vHeight = height + padding[0] + padding[2];\n var vWidth = width + padding[1] + padding[3];\n\n if (watermarker) {\n var _a = this.get('graphWaterMarker').cfg || {},\n wmWidth = _a.width,\n wmHeight = _a.height;\n\n vHeight = Math.ceil(vHeight / wmHeight) * wmHeight;\n vWidth = Math.ceil(vWidth / wmWidth) * wmWidth;\n }\n\n var canvasOptions = {\n container: vContainerDOM,\n height: vHeight,\n width: vWidth\n };\n var vCanvas = renderer === 'svg' ? new GSVGCanvas(canvasOptions) : new GCanvas(canvasOptions);\n var group = this.get('group');\n var vGroup = group.clone();\n var matrix = clone(vGroup.getMatrix());\n if (!matrix) matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var centerX = (bbox.maxX + bbox.minX) / 2;\n var centerY = (bbox.maxY + bbox.minY) / 2;\n matrix = transform(matrix, [['t', -centerX, -centerY], ['t', width / 2 + padding[3], height / 2 + padding[0]]]);\n vGroup.resetMatrix();\n vGroup.setMatrix(matrix);\n vCanvas.add(vGroup);\n var vCanvasEl = vCanvas.get('el');\n if (!type) type = 'image/png';\n this.asyncToDataUrl(type, backgroundColor, function (dataURL) {\n var link = document.createElement('a');\n var fileName = (name || 'graph') + (renderer === 'svg' ? '.svg' : \".\" + type.split('/')[1]);\n\n _this.dataURLToImage(dataURL, renderer, link, fileName);\n\n var e = document.createEvent('MouseEvents');\n e.initEvent('click', false, false);\n link.dispatchEvent(e);\n }, vWidth, vHeight, vCanvasEl);\n };\n /**\n * 画布导出图片,图片仅包含画布可见区域部分内容\n * @param {String} name 图片的名称\n * @param {String} type 图片类型,可选值:\"image/png\" | \"image/jpeg\" | \"image/webp\" | \"image/bmp\"\n * @param {string} backgroundColor 图片背景色\n */\n\n\n Graph.prototype.downloadImage = function (name, type, backgroundColor) {\n var _this = this;\n\n var self = this;\n\n if (self.isAnimating()) {\n self.stopAnimate();\n }\n\n var canvas = self.get('canvas');\n var renderer = canvas.getRenderer();\n if (!type) type = 'image/png';\n var fileName = (name || 'graph') + (renderer === 'svg' ? '.svg' : type.split('/')[1]);\n var link = document.createElement('a');\n self.asyncToDataUrl(type, backgroundColor, function (dataURL) {\n _this.dataURLToImage(dataURL, renderer, link, fileName);\n\n var e = document.createEvent('MouseEvents');\n e.initEvent('click', false, false);\n link.dispatchEvent(e);\n });\n };\n\n Graph.prototype.dataURLToImage = function (dataURL, renderer, link, fileName) {\n if (!dataURL || dataURL === 'data:') {\n console.error('Download image failed. The graph is too large or there is invalid attribute values in graph items');\n return;\n }\n\n if (typeof window !== 'undefined') {\n if (window.Blob && window.URL && renderer !== 'svg') {\n var arr = dataURL.split(',');\n var mime = '';\n\n if (arr && arr.length > 0) {\n var match = arr[0].match(/:(.*?);/); // eslint-disable-next-line prefer-destructuring\n\n if (match && match.length >= 2) mime = match[1];\n }\n\n var bstr = atob(arr[1]);\n var n = bstr.length;\n var u8arr = new Uint8Array(n);\n\n while (n--) {\n u8arr[n] = bstr.charCodeAt(n);\n }\n\n var blobObj_1 = new Blob([u8arr], {\n type: mime\n });\n\n if (window.navigator.msSaveBlob) {\n window.navigator.msSaveBlob(blobObj_1, fileName);\n } else {\n link.addEventListener('click', function () {\n link.download = fileName;\n link.href = window.URL.createObjectURL(blobObj_1);\n });\n }\n } else {\n link.addEventListener('click', function () {\n link.download = fileName;\n link.href = dataURL;\n });\n }\n }\n };\n /**\n * 添加插件\n * @param {object} plugin 插件实例\n */\n\n\n Graph.prototype.addPlugin = function (plugin) {\n var self = this;\n\n if (plugin.destroyed) {\n return;\n }\n\n self.get('plugins').push(plugin);\n plugin.initPlugin(self);\n };\n /**\n * 添加插件\n * @param {object} plugin 插件实例\n */\n\n\n Graph.prototype.removePlugin = function (plugin) {\n var plugins = this.get('plugins');\n var index = plugins.indexOf(plugin);\n\n if (index >= 0) {\n plugin.destroyPlugin();\n plugins.splice(index, 1);\n }\n };\n /**\n * 设置图片水印\n * @param {string} imgURL 图片水印的url地址\n * @param {WaterMarkerConfig} config 文本水印的配置项\n */\n\n\n Graph.prototype.setImageWaterMarker = function (imgURL, config) {\n if (imgURL === void 0) {\n imgURL = Global.waterMarkerImage;\n }\n\n var container = this.get('container');\n\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n if (!container.style.position) {\n container.style.position = 'relative';\n }\n\n var canvas = this.get('graphWaterMarker');\n var waterMarkerConfig = deepMix({}, Global.imageWaterMarkerConfig, config);\n var width = waterMarkerConfig.width,\n height = waterMarkerConfig.height,\n compatible = waterMarkerConfig.compatible,\n image = waterMarkerConfig.image;\n\n if (!canvas) {\n var canvasCfg = {\n container: container,\n width: width,\n height: height,\n capture: false\n };\n var pixelRatio = this.get('pixelRatio');\n\n if (pixelRatio) {\n canvasCfg.pixelRatio = pixelRatio;\n }\n\n canvas = new GCanvas(canvasCfg);\n this.set('graphWaterMarker', canvas);\n }\n\n canvas.get('el').style.display = 'none';\n var ctx = canvas.get('context');\n var rotate = image.rotate,\n x = image.x,\n y = image.y; // 旋转20度\n\n ctx.rotate(-rotate * Math.PI / 180);\n var img = new Image();\n img.crossOrigin = 'anonymous';\n img.src = imgURL;\n\n img.onload = function () {\n ctx.drawImage(img, x, y, image.width, image.height); // 恢复旋转角度\n\n ctx.rotate(rotate * Math.PI / 180); // 默认按照现代浏览器处理\n\n if (!compatible) {\n var box = document.querySelector('.g6-graph-watermarker');\n\n if (!box) {\n box = document.createElement('div');\n box.className = 'g6-graph-watermarker';\n }\n\n box.className = 'g6-graph-watermarker';\n\n if (!canvas.destroyed) {\n box.style.cssText = \"background-image: url(\" + canvas.get('el').toDataURL('image/png') + \");background-repeat:repeat;position:absolute;top:0;bottom:0;left:0;right:0;pointer-events:none;z-index:-1;\";\n container.appendChild(box);\n }\n } else {\n // 当需要兼容不支持 pointer-events属性的浏览器时,将 compatible 设置为 true\n container.style.cssText = \"background-image: url(\" + canvas.get('el').toDataURL('image/png') + \");background-repeat:repeat;\";\n }\n };\n };\n /**\n * 设置文本水印\n * @param {string[]} texts 水印的文本内容\n * @param {WaterMarkerConfig} config 文本水印的配置项\n */\n\n\n Graph.prototype.setTextWaterMarker = function (texts, config) {\n var container = this.get('container');\n\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n if (!container.style.position) {\n container.style.position = 'relative';\n }\n\n var canvas = this.get('graphWaterMarker');\n var waterMarkerConfig = deepMix({}, Global.textWaterMarkerConfig, config);\n var width = waterMarkerConfig.width,\n height = waterMarkerConfig.height,\n compatible = waterMarkerConfig.compatible,\n text = waterMarkerConfig.text;\n\n if (!canvas) {\n var canvasCfg = {\n container: container,\n width: width,\n height: height,\n capture: false\n };\n var pixelRatio = this.get('pixelRatio');\n\n if (pixelRatio) {\n canvasCfg.pixelRatio = pixelRatio;\n }\n\n canvas = new GCanvas(canvasCfg);\n this.set('graphWaterMarker', canvas);\n }\n\n canvas.get('el').style.display = 'none';\n var ctx = canvas.get('context');\n var rotate = text.rotate,\n fill = text.fill,\n fontFamily = text.fontFamily,\n fontSize = text.fontSize,\n baseline = text.baseline,\n x = text.x,\n y = text.y,\n lineHeight = text.lineHeight; // 旋转20度\n\n ctx.rotate(-rotate * Math.PI / 180); // 设置文字样式\n\n ctx.font = fontSize + \"px \" + fontFamily; // 设置文字颜色\n\n ctx.fillStyle = fill;\n ctx.textBaseline = baseline;\n\n for (var i = texts.length - 1; i >= 0; i--) {\n // 将文字绘制到画布\n ctx.fillText(texts[i], x, y + i * lineHeight);\n } // 恢复旋转角度\n\n\n ctx.rotate(rotate * Math.PI / 180); // 默认按照现代浏览器处理\n\n if (!compatible) {\n var box = document.querySelector('.g6-graph-watermarker');\n\n if (!box) {\n box = document.createElement('div');\n box.className = 'g6-graph-watermarker';\n }\n\n box.style.cssText = \"background-image: url(\" + canvas.get('el').toDataURL('image/png') + \");background-repeat:repeat;position:absolute;top:0;bottom:0;left:0;right:0;pointer-events:none;z-index:99;\";\n container.appendChild(box);\n } else {\n // 当需要兼容不支持 pointer-events属性的浏览器时,将 compatible 设置为 true\n container.style.cssText = \"background-image: url(\" + canvas.get('el').toDataURL('image/png') + \");background-repeat:repeat;\";\n }\n };\n /**\n * 销毁画布\n */\n\n\n Graph.prototype.destroy = function () {\n var _a, _b, _c, _d;\n\n each(this.get('plugins'), function (plugin) {\n plugin.destroyPlugin();\n }); // destroy tooltip doms, removed when upgrade G6 4.0\n\n var tooltipDOMs = this.get('tooltips');\n\n if (tooltipDOMs) {\n for (var i = 0; i < tooltipDOMs.length; i++) {\n var container = tooltipDOMs[i];\n if (!container) continue;\n var parent_1 = container.parentElement;\n if (!parent_1) continue;\n parent_1.removeChild(container);\n }\n }\n\n (_a = this.get('eventController')) === null || _a === void 0 ? void 0 : _a.destroy();\n (_b = this.get('layoutController')) === null || _b === void 0 ? void 0 : _b.destroy(); // this.get('eventController').destroy();\n // this.get('itemController').destroy();\n // this.get('modeController').destroy();\n // this.get('viewController').destroy();\n // this.get('stateController').destroy();\n // this.get('canvas').destroy();\n\n (_c = this.get('graphWaterMarker')) === null || _c === void 0 ? void 0 : _c.destroy();\n (_d = document.querySelector('.g6-graph-watermarker')) === null || _d === void 0 ? void 0 : _d.remove();\n\n _super.prototype.destroy.call(this);\n };\n\n return Graph;\n}(AbstractGraph);\n\nexport default Graph;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nimport { modifyCSS, createDom } from '@antv/dom-util';\nimport Base from '../base'; // 网格背景图片\n\nvar GRID_PNG = 'url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDAiIGhlaWdodD0iNDAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PHBhdHRlcm4gaWQ9ImdyaWQiIHdpZHRoPSI0MCIgaGVpZ2h0PSI0MCIgcGF0dGVyblVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+PHBhdGggZD0iTSAwIDEwIEwgNDAgMTAgTSAxMCAwIEwgMTAgNDAgTSAwIDIwIEwgNDAgMjAgTSAyMCAwIEwgMjAgNDAgTSAwIDMwIEwgNDAgMzAgTSAzMCAwIEwgMzAgNDAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2UwZTBlMCIgb3BhY2l0eT0iMC4yIiBzdHJva2Utd2lkdGg9IjEiLz48cGF0aCBkPSJNIDQwIDAgTCAwIDAgMCA0MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZTBlMGUwIiBzdHJva2Utd2lkdGg9IjEiLz48L3BhdHRlcm4+PC9kZWZzPjxyZWN0IHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JpZCkiLz48L3N2Zz4=)';\n\nvar Grid = function (_super) {\n __extends(Grid, _super);\n\n function Grid(config) {\n return _super.call(this, config) || this;\n }\n\n Grid.prototype.getDefaultCfgs = function () {\n return {\n img: GRID_PNG,\n follow: true\n };\n };\n\n Grid.prototype.init = function () {\n var graph = this.get('graph');\n var graphContainer = graph.get('container');\n var canvas = graph.get('canvas').get('el');\n var img = this.get('img') || GRID_PNG;\n var container = createDom(\"<div class='g6-grid-container' style=\\\"position:absolute;overflow:hidden;z-index: -1;\\\"></div>\");\n var gridContainer = createDom(\"<div\\n class='g6-grid'\\n style='position:absolute;\\n background-image: \" + img + \";\\n user-select: none\\n '></div>\");\n this.set('container', container);\n this.set('gridContainer', gridContainer);\n this.positionInit();\n container.appendChild(gridContainer);\n graphContainer.insertBefore(container, canvas);\n };\n /** 定位信息初始化 */\n\n\n Grid.prototype.positionInit = function () {\n var graph = this.get('graph');\n var minZoom = graph.get('minZoom');\n var width = graph.get('width');\n var height = graph.get('height');\n modifyCSS(this.get('container'), {\n width: width + \"px\",\n height: height + \"px\"\n }); // 网格 40*40 需保证 (gridContainerWidth / 2) % 40 = 0 才能让网格线对齐左上角 故 * 80\n\n var gridContainerWidth = width * 80 / minZoom;\n var gridContainerHeight = height * 80 / minZoom;\n modifyCSS(this.get('gridContainer'), {\n width: gridContainerWidth + \"px\",\n height: gridContainerHeight + \"px\",\n left: \"-\" + gridContainerWidth / 2 + \"px\",\n top: \"-\" + gridContainerHeight / 2 + \"px\"\n });\n }; // class-methods-use-this\n\n\n Grid.prototype.getEvents = function () {\n return {\n viewportchange: 'updateGrid'\n };\n };\n /**\n * viewport change 事件的响应函数\n * @param param\n */\n\n\n Grid.prototype.updateGrid = function (param) {\n var gridContainer = this.get('gridContainer');\n var matrix = param.matrix;\n if (!matrix) matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var isFollow = this.get('follow');\n var transform = \"matrix(\" + matrix[0] + \", \" + matrix[1] + \", \" + matrix[3] + \", \" + matrix[4] + \", \" + (isFollow ? matrix[6] : '0') + \", \" + (isFollow ? matrix[7] : '0') + \")\";\n modifyCSS(gridContainer, {\n transform: transform\n });\n };\n\n Grid.prototype.getContainer = function () {\n return this.get('container');\n };\n\n Grid.prototype.destroy = function () {\n var graph = this.get('graph');\n var graphContainer = graph.get('container');\n var container = this.get('container');\n graphContainer.removeChild(container);\n };\n\n return Grid;\n}(Base);\n\nexport default Grid;","import { __extends } from \"tslib\";\nimport Hierarchy from '@antv/hierarchy';\nimport { each, isObject, isString } from '@antv/util';\nimport Util from '../util';\nimport Graph from './graph';\nvar radialLayout = Util.radialLayout,\n traverseTree = Util.traverseTree;\n\nvar TreeGraph = function (_super) {\n __extends(TreeGraph, _super);\n\n function TreeGraph(cfg) {\n var _this = _super.call(this, cfg) || this;\n\n _this.layoutAnimating = false; // 用于缓存动画结束后需要删除的节点\n\n _this.set('removeList', []);\n\n _this.set('layoutMethod', _this.getLayout());\n\n return _this;\n }\n /**\n * 通过 Layout 配置获取布局配置\n */\n\n\n TreeGraph.prototype.getLayout = function () {\n var layout = this.get('layout');\n\n if (!layout) {\n return null;\n }\n\n if (typeof layout === 'function') {\n return layout;\n }\n\n if (!layout.type) {\n layout.type = 'dendrogram';\n }\n\n if (!layout.direction) {\n layout.direction = 'TB';\n }\n\n if (layout.radial) {\n return function (data) {\n var layoutData = Hierarchy[layout.type](data, layout);\n radialLayout(layoutData);\n return layoutData;\n };\n }\n\n return function (data) {\n return Hierarchy[layout.type](data, layout);\n };\n };\n /**\n * 返回指定节点在树图数据中的索引\n * @param children 树图数据\n * @param child 树图中某一个 Item 的数据\n */\n\n\n TreeGraph.indexOfChild = function (children, id) {\n var index = -1; // eslint-disable-next-line consistent-return\n\n each(children, function (former, i) {\n if (id === former.id) {\n index = i;\n return false;\n }\n });\n return index;\n };\n\n TreeGraph.prototype.getDefaultCfg = function () {\n var cfg = _super.prototype.getDefaultCfg.call(this); // 树图默认打开动画\n\n\n cfg.animate = true;\n return cfg;\n };\n /**\n * 向🌲树中添加数据\n * @param treeData 树图数据\n * @param parent 父节点实例\n * @param animate 是否开启动画\n */\n\n\n TreeGraph.prototype.innerAddChild = function (treeData, parent, animate) {\n var self = this;\n var model = treeData.data;\n\n if (model) {\n // model 中应存储真实的数据,特别是真实的 children\n model.x = treeData.x;\n model.y = treeData.y;\n model.depth = treeData.depth;\n }\n\n var node = self.addItem('node', model, false);\n\n if (parent) {\n node.set('parent', parent);\n\n if (animate) {\n var origin_1 = parent.get('originAttrs');\n\n if (origin_1) {\n node.set('originAttrs', origin_1);\n } else {\n var parentModel = parent.getModel();\n node.set('originAttrs', {\n x: parentModel.x,\n y: parentModel.y\n });\n }\n }\n\n var childrenList = parent.get('children');\n\n if (!childrenList) {\n parent.set('children', [node]);\n } else {\n childrenList.push(node);\n }\n\n self.addItem('edge', {\n source: parent.get('id'),\n target: node.get('id'),\n id: parent.get('id') + \":\" + node.get('id')\n }, false);\n } // 渲染到视图上应参考布局的children, 避免多绘制了收起的节点\n\n\n each(treeData.children || [], function (child) {\n self.innerAddChild(child, node, animate);\n });\n self.emit('afteraddchild', {\n item: node,\n parent: parent\n });\n return node;\n };\n /**\n * 将数据上的变更转换到视图上\n * @param data\n * @param parent\n * @param animate\n */\n\n\n TreeGraph.prototype.innerUpdateChild = function (data, parent, animate) {\n var self = this;\n var current = self.findById(data.id); // 若子树不存在,整体添加即可\n\n if (!current) {\n self.innerAddChild(data, parent, animate);\n return;\n } // 更新新节点下所有子节点\n\n\n each(data.children || [], function (child) {\n self.innerUpdateChild(child, current, animate);\n }); // 用现在节点的children实例来删除移除的子节点\n\n var children = current.get('children');\n\n if (children) {\n var len = children.length;\n\n if (len > 0) {\n for (var i = children.length - 1; i >= 0; i--) {\n var child = children[i].getModel();\n\n if (TreeGraph.indexOfChild(data.children || [], child.id) === -1) {\n self.innerRemoveChild(child.id, {\n x: data.x,\n y: data.y\n }, animate); // 更新父节点下缓存的子节点 item 实例列表\n\n children.splice(i, 1);\n }\n }\n }\n }\n\n var oriX;\n var oriY;\n\n if (current.get('originAttrs')) {\n oriX = current.get('originAttrs').x;\n oriY = current.get('originAttrs').y;\n }\n\n var model = current.getModel();\n\n if (animate) {\n // 如果有动画,先缓存节点运动再更新节点\n current.set('originAttrs', {\n x: model.x,\n y: model.y\n });\n }\n\n current.set('model', data.data);\n\n if (oriX !== data.x || oriY !== data.y) {\n current.updatePosition({\n x: data.x,\n y: data.y\n });\n }\n };\n /**\n * 删除子节点Item对象\n * @param id\n * @param to\n * @param animate\n */\n\n\n TreeGraph.prototype.innerRemoveChild = function (id, to, animate) {\n var self = this;\n var node = self.findById(id);\n\n if (!node) {\n return;\n }\n\n each(node.get('children'), function (child) {\n self.innerRemoveChild(child.getModel().id, to, animate);\n });\n\n if (animate) {\n var model = node.getModel();\n node.set('to', to);\n node.set('originAttrs', {\n x: model.x,\n y: model.y\n });\n self.get('removeList').push(node);\n } else {\n self.removeItem(node, false);\n }\n };\n /**\n * 更新数据模型,差量更新并重新渲染\n * @param {object} data 数据模型\n */\n\n\n TreeGraph.prototype.changeData = function (data) {\n var self = this; // 更改数据源后,取消所有状态\n\n this.getNodes().map(function (node) {\n return self.clearItemStates(node);\n });\n this.getEdges().map(function (edge) {\n return self.clearItemStates(edge);\n });\n\n if (data) {\n self.data(data);\n self.render();\n } else {\n self.layout(this.get('fitView'));\n }\n };\n /**\n * 已更名为 updateLayout,为保持兼容暂且保留。\n * 更改并应用树布局算法\n * @param {object} layout 布局算法\n */\n\n\n TreeGraph.prototype.changeLayout = function (layout) {\n // eslint-disable-next-line no-console\n console.warn('Please call updateLayout instead of changeLayout. changeLayout will be discarded soon');\n var self = this;\n self.updateLayout(layout);\n };\n /**\n * 更改并应用树布局算法\n * @param {object} layout 布局算法\n */\n\n\n TreeGraph.prototype.updateLayout = function (layout) {\n var self = this;\n\n if (!layout) {\n // eslint-disable-next-line no-console\n console.warn('layout cannot be null');\n return;\n }\n\n self.set('layout', layout);\n self.set('layoutMethod', self.getLayout());\n self.layout();\n };\n /**\n * 已更名为 layout,为保持兼容暂且保留。\n * 根据目前的 data 刷新布局,更新到画布上。用于变更数据之后刷新视图。\n * @param {boolean} fitView 更新布局时是否需要适应窗口\n */\n\n\n TreeGraph.prototype.refreshLayout = function (fitView) {\n // eslint-disable-next-line no-console\n console.warn('Please call layout instead of refreshLayout. refreshLayout will be discarded soon');\n var self = this;\n self.layout(fitView);\n };\n /**\n * 根据目前的 data 刷新布局,更新到画布上。用于变更数据之后刷新视图。\n * @param {boolean} fitView 更新布局时是否需要适应窗口\n */\n\n\n TreeGraph.prototype.layout = function (fitView) {\n var self = this;\n var data = self.get('data');\n var layoutMethod = self.get('layoutMethod');\n var layoutData = layoutMethod ? layoutMethod(data, self.get('layout')) : data;\n var animate = self.get('animate');\n self.emit('beforerefreshlayout', {\n data: data,\n layoutData: layoutData\n });\n self.emit('beforelayout');\n self.innerUpdateChild(layoutData, undefined, animate);\n\n if (fitView) {\n var viewController = self.get('viewController');\n viewController.fitView();\n }\n\n if (!animate) {\n // 如果没有动画,目前仅更新了节点的位置,刷新一下边的样式\n self.refresh();\n self.paint();\n } else {\n self.layoutAnimate(layoutData);\n }\n\n self.emit('afterrefreshlayout', {\n data: data,\n layoutData: layoutData\n });\n self.emit('afterlayout');\n };\n /**\n * 添加子树到对应 id 的节点\n * @param {TreeGraphData} data 子树数据模型\n * @param {string} parent 子树的父节点id\n */\n\n\n TreeGraph.prototype.addChild = function (data, parent) {\n var self = this;\n self.emit('beforeaddchild', {\n model: data,\n parent: parent\n }); // 将数据添加到源数据中,走changeData方法\n\n if (!isString(parent)) {\n parent = parent.get('id');\n }\n\n var parentData = self.findDataById(parent);\n\n if (parentData) {\n if (!parentData.children) {\n parentData.children = [];\n }\n\n parentData.children.push(data);\n self.changeData();\n }\n };\n /**\n * 更新某个节点下的所有子节点\n * @param {TreeGraphData[]} data 子树数据模型集合\n * @param {string} parent 子树的父节点id\n */\n\n\n TreeGraph.prototype.updateChildren = function (data, parentId) {\n var self = this; // 如果没有父节点或找不到该节点,是全量的更新,直接重置data\n\n if (!parentId || !self.findById(parentId)) {\n console.warn(\"Update children failed! There is no node with id '\" + parentId + \"'\");\n return;\n }\n\n var parentModel = self.findDataById(parentId);\n parentModel.children = data;\n self.changeData();\n };\n /**\n * 更新源数据,差量更新子树\n * @param {TreeGraphData} data 子树数据模型\n * @param {string} parentId 子树的父节点id\n */\n\n\n TreeGraph.prototype.updateChild = function (data, parentId) {\n var self = this; // 如果没有父节点或找不到该节点,是全量的更新,直接重置data\n\n if (!parentId || !self.findById(parentId)) {\n self.changeData(data);\n return;\n }\n\n var parentModel = self.findDataById(parentId);\n var current = self.findById(data.id);\n\n if (!parentModel.children) {\n // 当 current 不存在时,children 为空数组\n parentModel.children = [];\n } // 如果不存在该节点,则添加\n\n\n if (!current) {\n parentModel.children.push(data);\n } else {\n var index = TreeGraph.indexOfChild(parentModel.children, data.id);\n parentModel.children[index] = data;\n }\n\n self.changeData();\n };\n /**\n * 删除子树\n * @param {string} id 子树根节点id\n */\n\n\n TreeGraph.prototype.removeChild = function (id) {\n var self = this;\n var node = self.findById(id);\n\n if (!node) {\n return;\n }\n\n var parent = node.get('parent');\n\n if (parent && !parent.destroyed) {\n var parentNode = self.findDataById(parent.get('id'));\n var siblings = parentNode && parentNode.children || [];\n var model = node.getModel();\n var index = TreeGraph.indexOfChild(siblings, model.id);\n siblings.splice(index, 1);\n }\n\n self.changeData();\n };\n /**\n * 根据id获取对应的源数据\n * @param {string} id 元素id\n * @param {TreeGraphData | undefined} parent 从哪个节点开始寻找,为空时从根节点开始查找\n * @return {TreeGraphData} 对应源数据\n */\n\n\n TreeGraph.prototype.findDataById = function (id, parent) {\n var self = this;\n\n if (!parent) {\n parent = self.get('data');\n }\n\n if (id === parent.id) {\n return parent;\n }\n\n var result = null; // eslint-disable-next-line consistent-return\n\n each(parent.children || [], function (child) {\n if (child.id === id) {\n result = child;\n return false;\n }\n\n result = self.findDataById(id, child);\n\n if (result) {\n return false;\n }\n });\n return result;\n };\n /**\n * 布局动画接口,用于数据更新时做节点位置更新的动画\n * @param {TreeGraphData} data 更新的数据\n * @param {function} onFrame 定义节点位置更新时如何移动\n */\n\n\n TreeGraph.prototype.layoutAnimate = function (data, onFrame) {\n var self = this;\n var animateCfg = this.get('animateCfg');\n self.emit('beforeanimate', {\n data: data\n }); // 如果边中没有指定锚点,但是本身有锚点控制,在动画过程中保持锚点不变\n\n self.getEdges().forEach(function (edge) {\n var model = edge.get('model');\n\n if (!model.sourceAnchor) {\n model.sourceAnchor = edge.get('sourceAnchorIndex');\n }\n });\n this.get('canvas').animate(function (ratio) {\n traverseTree(data, function (child) {\n var node = self.findById(child.id); // 只有当存在node的时候才执行\n\n if (node) {\n var origin_2 = node.get('originAttrs');\n var model = node.get('model');\n\n if (!origin_2) {\n origin_2 = {\n x: model.x,\n y: model.y\n };\n node.set('originAttrs', origin_2);\n }\n\n if (onFrame) {\n var attrs = onFrame(node, ratio, origin_2, data);\n node.set('model', Object.assign(model, attrs));\n } else {\n model.x = origin_2.x + (child.x - origin_2.x) * ratio;\n model.y = origin_2.y + (child.y - origin_2.y) * ratio;\n }\n }\n\n return true;\n });\n each(self.get('removeList'), function (node) {\n var model = node.getModel();\n var from = node.get('originAttrs');\n var to = node.get('to');\n model.x = from.x + (to.x - from.x) * ratio;\n model.y = from.y + (to.y - from.y) * ratio;\n });\n self.refreshPositions();\n }, {\n duration: animateCfg.duration,\n easing: animateCfg.ease,\n callback: function callback() {\n each(self.getNodes(), function (node) {\n node.set('originAttrs', null);\n });\n each(self.get('removeList'), function (node) {\n self.removeItem(node);\n });\n self.set('removeList', []);\n\n if (animateCfg.callback) {\n animateCfg.callback();\n }\n\n self.emit('afteranimate', {\n data: data\n });\n },\n delay: animateCfg.delay\n });\n };\n /**\n * 立即停止布局动画\n */\n\n\n TreeGraph.prototype.stopLayoutAnimate = function () {\n this.get('canvas').stopAnimate();\n this.emit('layoutanimateend', {\n data: this.get('data')\n });\n this.layoutAnimating = false;\n };\n /**\n * 是否在布局动画\n * @return {boolean} 是否有布局动画\n */\n\n\n TreeGraph.prototype.isLayoutAnimating = function () {\n return this.layoutAnimating;\n };\n /**\n * 根据data接口的数据渲染视图\n */\n\n\n TreeGraph.prototype.render = function () {\n var self = this;\n var data = self.get('data');\n\n if (!data || !isObject(data) || !Object.keys(data).length) {\n throw new Error('data must be defined first');\n }\n\n self.clear();\n self.emit('beforerender');\n self.layout(this.get('fitView'));\n self.emit('afterrender');\n };\n /**\n * 导出图数据\n * @return {object} data\n */\n\n\n TreeGraph.prototype.save = function () {\n return this.get('data');\n };\n\n return TreeGraph;\n}(Graph);\n\nexport default TreeGraph;","import { wrapBehavior, each, deepMix } from '@antv/util';\n\nvar PluginBase = function () {\n /**\n * 插件基类的构造函数\n * @param cfgs 插件的配置项\n */\n function PluginBase(cfgs) {\n this._cfgs = deepMix(this.getDefaultCfgs(), cfgs);\n this._events = {};\n this.destroyed = false;\n }\n /**\n * 获取默认的插件配置\n */\n\n\n PluginBase.prototype.getDefaultCfgs = function () {\n return {};\n };\n /**\n * 初始化插件\n * @param graph IGraph 实例\n */\n\n\n PluginBase.prototype.initPlugin = function (graph) {\n var self = this;\n self.set('graph', graph);\n var events = self.getEvents();\n var bindEvents = {};\n each(events, function (v, k) {\n var event = wrapBehavior(self, v);\n bindEvents[k] = event;\n graph.on(k, event);\n });\n this._events = bindEvents;\n this.init();\n };\n /**\n * 获取插件中的事件和事件处理方法,供子类实现\n */\n\n\n PluginBase.prototype.getEvents = function () {\n return {};\n };\n /**\n * 获取配置项中的某个值\n * @param key 键值\n */\n\n\n PluginBase.prototype.get = function (key) {\n var _a;\n\n return (_a = this._cfgs) === null || _a === void 0 ? void 0 : _a[key];\n };\n /**\n * 将指定的值存储到 cfgs 中\n * @param key 键值\n * @param val 设置的值\n */\n\n\n PluginBase.prototype.set = function (key, val) {\n this._cfgs[key] = val;\n };\n /**\n * 销毁方法,供子类复写\n */\n\n\n PluginBase.prototype.destroy = function () {};\n /**\n * 销毁插件\n */\n\n\n PluginBase.prototype.destroyPlugin = function () {\n this.destroy();\n var graph = this.get('graph');\n var events = this._events;\n each(events, function (v, k) {\n graph.off(k, v);\n });\n this._events = null;\n this._cfgs = null;\n this.destroyed = true;\n };\n\n return PluginBase;\n}();\n\nexport default PluginBase;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nimport { modifyCSS, createDom } from '@antv/dom-util';\nimport { isString } from '@antv/util';\nimport insertCss from 'insert-css';\nimport Base from '../base';\ntypeof document !== 'undefined' && insertCss(\"\\n .g6-component-contextmenu {\\n border: 1px solid #e2e2e2;\\n border-radius: 4px;\\n font-size: 12px;\\n color: #545454;\\n background-color: rgba(255, 255, 255, 0.9);\\n padding: 10px 8px;\\n box-shadow: rgb(174, 174, 174) 0px 0px 10px;\\n }\\n .g6-contextmenu-ul {\\n padding: 0;\\n margin: 0;\\n list-style: none;\\n }\\n\\n\");\n\nvar Menu = function (_super) {\n __extends(Menu, _super);\n\n function Menu(config) {\n return _super.call(this, config) || this;\n }\n\n Menu.prototype.getDefaultCfgs = function () {\n return {\n offsetX: 6,\n offsetY: 6,\n handleMenuClick: undefined,\n // 指定菜单内容,function(e) {...}\n getContent: function getContent(e) {\n return \"\\n <ul class='g6-contextmenu-ul'>\\n <li>\\u83DC\\u5355\\u98791</li>\\n <li>\\u83DC\\u5355\\u98792</li>\\n </ul>\\n \";\n },\n shouldBegin: function shouldBegin(e) {\n return true;\n },\n // 菜单隐藏事件\n onHide: function onHide() {\n return true;\n },\n itemTypes: ['node', 'edge', 'combo'],\n trigger: 'contextmenu'\n };\n }; // class-methods-use-this\n\n\n Menu.prototype.getEvents = function () {\n if (this.get('trigger') === 'click') {\n return {\n click: 'onMenuShow'\n };\n }\n\n return {\n contextmenu: 'onMenuShow'\n };\n };\n\n Menu.prototype.init = function () {\n var className = this.get('className');\n var menu = createDom(\"<div class=\" + (className || 'g6-component-contextmenu') + \"></div>\");\n modifyCSS(menu, {\n top: '0px',\n position: 'absolute',\n visibility: 'hidden'\n });\n var container = this.get('container');\n\n if (!container) {\n container = this.get('graph').get('container');\n }\n\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n container.appendChild(menu);\n this.set('menu', menu);\n };\n\n Menu.prototype.onMenuShow = function (e) {\n var self = this;\n e.preventDefault();\n var itemTypes = this.get('itemTypes');\n\n if (!e.item) {\n if (itemTypes.indexOf('canvas') === -1) {\n self.onMenuHide();\n return;\n }\n } else {\n if (e.item && e.item.getType && itemTypes.indexOf(e.item.getType()) === -1) {\n self.onMenuHide();\n return;\n }\n }\n\n var shouldBegin = this.get('shouldBegin');\n if (!shouldBegin(e)) return;\n var menuDom = this.get('menu');\n var getContent = this.get('getContent');\n var graph = this.get('graph');\n var menu = getContent(e, graph);\n\n if (isString(menu)) {\n menuDom.innerHTML = menu;\n } else {\n menuDom.innerHTML = menu.outerHTML;\n } // 清除之前监听的事件\n\n\n this.removeMenuEventListener();\n var handleMenuClick = this.get('handleMenuClick');\n\n if (handleMenuClick) {\n var handleMenuClickWrapper = function handleMenuClickWrapper(evt) {\n handleMenuClick(evt.target, e.item, graph);\n };\n\n this.set('handleMenuClickWrapper', handleMenuClickWrapper);\n menuDom.addEventListener('click', handleMenuClickWrapper);\n }\n\n var width = graph.get('width');\n var height = graph.get('height');\n var bbox = menuDom.getBoundingClientRect();\n var offsetX = this.get('offsetX') || 0;\n var offsetY = this.get('offsetY') || 0;\n var graphTop = graph.getContainer().offsetTop;\n var graphLeft = graph.getContainer().offsetLeft;\n var x = e.canvasX + graphLeft + offsetX;\n var y = e.canvasY + graphTop + offsetY; // when the menu is (part of) out of the canvas\n\n if (x + bbox.width > width) {\n x = e.canvasX - bbox.width - offsetX + graphLeft;\n }\n\n if (y + bbox.height > height) {\n y = e.canvasY - bbox.height - offsetY + graphTop;\n }\n\n modifyCSS(menuDom, {\n top: y + \"px\",\n left: x + \"px\",\n visibility: 'visible'\n }); // 左键单击会触发 body 上监听的 click 事件,导致菜单展示出来后又立即被隐藏了,需要过滤掉\n\n var triggeredByFirstClick = this.get('trigger') === 'click';\n\n var handler = function handler(evt) {\n if (triggeredByFirstClick) {\n triggeredByFirstClick = false;\n return;\n }\n\n self.onMenuHide();\n }; // 如果在页面中其他任意地方进行click, 隐去菜单\n\n\n document.body.addEventListener('click', handler);\n this.set('handler', handler);\n };\n\n Menu.prototype.removeMenuEventListener = function () {\n var handleMenuClickWrapper = this.get('handleMenuClickWrapper');\n var handler = this.get('handler');\n\n if (handleMenuClickWrapper) {\n var menuDom = this.get('menu');\n menuDom.removeEventListener('click', handleMenuClickWrapper);\n this.set('handleMenuClickWrapper', null);\n }\n\n if (handler) {\n document.body.removeEventListener('click', handler);\n }\n };\n\n Menu.prototype.onMenuHide = function () {\n var menuDom = this.get('menu');\n\n if (menuDom) {\n modifyCSS(menuDom, {\n visibility: 'hidden'\n });\n } // 隐藏菜单后需要移除事件监听\n\n\n this.removeMenuEventListener();\n };\n\n Menu.prototype.destroy = function () {\n var menu = this.get('menu');\n this.removeMenuEventListener();\n\n if (menu) {\n var container = this.get('container');\n\n if (!container) {\n container = this.get('graph').get('container');\n }\n\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n container.removeChild(menu);\n }\n };\n\n return Menu;\n}(Base);\n\nexport default Menu;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { Canvas as GCanvas } from '@antv/g-canvas';\nimport { Canvas as GSVGCanvas } from '@antv/g-svg';\nimport { isString, isNil, each, debounce } from '@antv/util';\nimport { createDom, modifyCSS } from '@antv/dom-util';\nimport { ext } from '@antv/matrix-util';\nimport Base from '../base';\nvar max = Math.max;\nvar transform = ext.transform;\nvar DEFAULT_MODE = 'default';\nvar KEYSHAPE_MODE = 'keyShape';\nvar DELEGATE_MODE = 'delegate';\nvar SVG = 'svg';\n\nvar MiniMap = function (_super) {\n __extends(MiniMap, _super);\n\n function MiniMap(config) {\n var _this = _super.call(this, config) || this;\n /**\n * 主图更新的监听函数,使用 debounce 减少渲染频率\n * e.g. 拖拽节点只会在松手后的 100ms 后执行 updateCanvas\n * e.g. render 时大量 addItem 也只会执行一次 updateCanvas\n */\n\n\n _this.handleUpdateCanvas = debounce(function (event) {\n var self = _this;\n if (self.destroyed) return;\n self.updateCanvas();\n }, 100, false);\n return _this;\n }\n\n MiniMap.prototype.getDefaultCfgs = function () {\n return {\n container: null,\n className: 'g6-minimap',\n viewportClassName: 'g6-minimap-viewport',\n // Minimap 中默认展示和主图一样的内容,KeyShape 只展示节点和边的 key shape 部分,delegate表示展示自定义的rect,用户可自定义样式\n type: 'default',\n padding: 50,\n size: [200, 120],\n delegateStyle: {\n fill: '#40a9ff',\n stroke: '#096dd9'\n },\n refresh: true\n };\n };\n\n MiniMap.prototype.getEvents = function () {\n return {\n beforepaint: 'updateViewport',\n beforeanimate: 'disableRefresh',\n afteranimate: 'enableRefresh',\n viewportchange: 'disableOneRefresh'\n };\n }; // 若是正在进行动画,不刷新缩略图\n\n\n MiniMap.prototype.disableRefresh = function () {\n this.set('refresh', false);\n };\n\n MiniMap.prototype.enableRefresh = function () {\n this.set('refresh', true);\n this.updateCanvas();\n };\n\n MiniMap.prototype.disableOneRefresh = function () {\n this.set('viewportChange', true);\n };\n\n MiniMap.prototype.initViewport = function () {\n var _this = this;\n\n var cfgs = this._cfgs;\n var size = cfgs.size,\n graph = cfgs.graph;\n if (this.destroyed) return;\n var canvas = this.get('canvas');\n var containerDOM = canvas.get('container');\n var viewport = createDom(\"\\n <div\\n class=\" + cfgs.viewportClassName + \"\\n style='position:absolute;\\n left:0;\\n top:0;\\n box-sizing:border-box;\\n outline: 2px solid #1980ff'\\n draggable=true>\\n </div>\");\n var isFireFox = navigator.userAgent.toLowerCase().indexOf('firefox') > -1; // 计算拖拽水平方向距离\n\n var x = 0; // 计算拖拽垂直方向距离\n\n var y = 0; // 是否在拖拽minimap的视口\n\n var dragging = false; // 缓存viewport当前对于画布的x\n\n var left = 0; // 缓存viewport当前对于画布的y\n\n var top = 0; // 缓存viewport当前宽度\n\n var width = 0; // 缓存viewport当前高度\n\n var height = 0;\n var ratio = 0;\n var zoom = 0;\n viewport.addEventListener('dragstart', function (e) {\n var _a, _b;\n\n if (e.dataTransfer) {\n var img = new Image();\n img.src = \"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' %3E%3Cpath /%3E%3C/svg%3E\";\n (_b = (_a = e.dataTransfer).setDragImage) === null || _b === void 0 ? void 0 : _b.call(_a, img, 0, 0);\n\n try {\n e.dataTransfer.setData('text/html', 'view-port-minimap');\n } catch (_c) {\n // support IE\n e.dataTransfer.setData('text', 'view-port-minimap');\n }\n }\n\n cfgs.refresh = false;\n\n if (e.target !== viewport) {\n return;\n } // 如果视口已经最大了,不需要拖拽\n\n\n var style = viewport.style;\n left = parseInt(style.left, 10);\n top = parseInt(style.top, 10);\n width = parseInt(style.width, 10);\n height = parseInt(style.height, 10);\n\n if (width > size[0] || height > size[1]) {\n return;\n }\n\n zoom = graph.getZoom();\n ratio = _this.get('ratio');\n dragging = true;\n x = e.clientX;\n y = e.clientY;\n }, false);\n viewport.addEventListener(isFireFox ? 'dragover' : 'drag', function (e) {\n if (!dragging || isNil(e.clientX) || isNil(e.clientY)) {\n return;\n }\n\n var dx = x - e.clientX;\n var dy = y - e.clientY; // 若视口移动到最左边或最右边了,仅移动到边界\n\n if (left - dx < 0 || left - dx + width >= size[0]) {\n dx = 0;\n } // 若视口移动到最上或最下边了,仅移动到边界\n\n\n if (top - dy < 0 || top - dy + height >= size[1]) {\n dy = 0;\n }\n\n left -= dx;\n top -= dy; // 先移动视口,避免移动到边上以后出现视口闪烁\n\n modifyCSS(viewport, {\n left: left + \"px\",\n top: top + \"px\"\n }); // graph 移动需要偏移量 dx/dy * 缩放比例才会得到正确的移动距离\n\n graph.translate(dx * zoom / ratio, dy * zoom / ratio);\n x = e.clientX;\n y = e.clientY;\n }, false);\n viewport.addEventListener('dragend', function () {\n dragging = false;\n cfgs.refresh = true;\n }, false);\n this.set('viewport', viewport);\n containerDOM.appendChild(viewport);\n };\n /**\n * 更新 viewport 视图\n */\n\n\n MiniMap.prototype.updateViewport = function () {\n if (this.destroyed) return;\n var ratio = this.get('ratio');\n var dx = this.get('dx');\n var dy = this.get('dy');\n var totaldx = this.get('totaldx');\n var totaldy = this.get('totaldy');\n var graph = this.get('graph');\n var size = this.get('size');\n var graphWidth = graph.get('width');\n var graphHeight = graph.get('height');\n var topLeft = graph.getPointByCanvas(0, 0);\n var bottomRight = graph.getPointByCanvas(graphWidth, graphHeight);\n var viewport = this.get('viewport');\n\n if (!viewport) {\n this.initViewport();\n } // viewport宽高,左上角点的计算\n\n\n var width = (bottomRight.x - topLeft.x) * ratio;\n var height = (bottomRight.y - topLeft.y) * ratio;\n var left = topLeft.x * ratio + totaldx;\n var top = topLeft.y * ratio + totaldy;\n var right = left + width;\n var bottom = top + height;\n\n if (left < 0) {\n width += left;\n left = 0;\n }\n\n if (right > size[0]) {\n width = width - (right - size[0]);\n }\n\n if (top < 0) {\n height += top;\n top = 0;\n }\n\n if (bottom > size[1]) {\n height = height - (bottom - size[1]);\n } // 缓存目前缩放比,在移动 minimap 视窗时就不用再计算大图的移动量\n\n\n this.set('ratio', ratio);\n var correctLeft = left + \"px\";\n var correctTop = top + \"px\";\n modifyCSS(viewport, {\n left: correctLeft,\n top: correctTop,\n width: width + \"px\",\n height: height + \"px\"\n });\n };\n /**\n * 将主图上的图形完全复制到小图\n */\n\n\n MiniMap.prototype.updateGraphShapes = function () {\n var graph = this._cfgs.graph;\n var canvas = this.get('canvas');\n var graphGroup = graph.get('group');\n if (graphGroup.destroyed) return;\n var clonedGroup = graphGroup.clone();\n clonedGroup.resetMatrix();\n canvas.clear();\n canvas.add(clonedGroup); // 当 renderer 是 svg,由于渲染引擎的 bug,这里需要将 visible 为 false 的元素手动隐藏\n\n var renderer = graph.get('renderer');\n\n if (renderer === SVG) {\n // 递归更新子元素\n this.updateVisible(clonedGroup);\n }\n }; // svg 在 canvas.add(clonedGroup) 之后会出现 visible 为 false 的元素被展示出来,需要递归更新\n\n\n MiniMap.prototype.updateVisible = function (ele) {\n var _this = this;\n\n if (!ele.isGroup() && !ele.get('visible')) {\n ele.hide();\n } else {\n var children = ele.get('children');\n if (!children || !children.length) return;\n children.forEach(function (child) {\n if (!child.get('visible')) child.hide();\n\n _this.updateVisible(child);\n });\n }\n }; // 仅在 minimap 上绘制 keyShape\n // FIXME 如果用户自定义绘制了其他内容,minimap上就无法画出\n\n\n MiniMap.prototype.updateKeyShapes = function () {\n var _this = this;\n\n var graph = this._cfgs.graph;\n var canvas = this.get('canvas');\n var group = canvas.get('children')[0] || canvas.addGroup();\n each(graph.getEdges(), function (edge) {\n _this.updateOneEdgeKeyShape(edge, group);\n });\n each(graph.getNodes(), function (node) {\n _this.updateOneNodeKeyShape(node, group);\n });\n var combos = graph.getCombos();\n\n if (combos && combos.length) {\n var comboGroup_1 = group.find(function (e) {\n return e.get('name') === 'comboGroup';\n }) || group.addGroup({\n name: 'comboGroup'\n });\n setTimeout(function () {\n if (_this.destroyed) return;\n each(combos, function (combo) {\n _this.updateOneComboKeyShape(combo, comboGroup_1);\n });\n comboGroup_1 === null || comboGroup_1 === void 0 ? void 0 : comboGroup_1.sort();\n comboGroup_1 === null || comboGroup_1 === void 0 ? void 0 : comboGroup_1.toBack();\n\n _this.updateCanvas();\n }, 250);\n }\n\n this.clearDestroyedShapes();\n };\n /**\n * 增加/更新单个元素的 keyShape\n * @param item ICombo 实例\n */\n\n\n MiniMap.prototype.updateOneComboKeyShape = function (item, comboGroup) {\n if (this.destroyed) return;\n var itemMap = this.get('itemMap') || {}; // 差量更新 minimap 上的一个节点,对应主图的 item\n\n var mappedItem = itemMap[item.get('id')];\n var bbox = item.getBBox(); // 计算了节点父组矩阵的 bbox\n\n var cKeyShape = item.get('keyShape').clone();\n var keyShapeStyle = cKeyShape.attr();\n var attrs = {\n x: bbox.centerX,\n y: bbox.centerY\n };\n\n if (!mappedItem) {\n mappedItem = cKeyShape;\n comboGroup.add(mappedItem);\n } else {\n attrs = Object.assign(keyShapeStyle, attrs);\n }\n\n var shapeType = mappedItem.get('type');\n\n if (shapeType === 'rect' || shapeType === 'image') {\n attrs.x = bbox.minX;\n attrs.y = bbox.minY;\n }\n\n mappedItem.attr(attrs);\n if (!item.isVisible()) mappedItem.hide();else mappedItem.show();\n mappedItem.exist = true;\n var zIndex = item.getModel().depth;\n if (!isNaN(zIndex)) mappedItem.set('zIndex', zIndex);\n itemMap[item.get('id')] = mappedItem;\n this.set('itemMap', itemMap);\n };\n /**\n * 增加/更新单个元素的 keyShape\n * @param item INode 实例\n */\n\n\n MiniMap.prototype.updateOneNodeKeyShape = function (item, group) {\n var itemMap = this.get('itemMap') || {}; // 差量更新 minimap 上的一个节点,对应主图的 item\n\n var mappedItem = itemMap[item.get('id')];\n var bbox = item.getBBox(); // 计算了节点父组矩阵的 bbox\n\n var cKeyShape = item.get('keyShape').clone();\n var keyShapeStyle = cKeyShape.attr();\n var attrs = {\n x: bbox.centerX,\n y: bbox.centerY\n };\n\n if (!mappedItem) {\n mappedItem = cKeyShape;\n group.add(mappedItem);\n } else {\n attrs = Object.assign(keyShapeStyle, attrs);\n }\n\n var shapeType = mappedItem.get('type');\n\n if (shapeType === 'rect' || shapeType === 'image') {\n attrs.x = bbox.minX;\n attrs.y = bbox.minY;\n }\n\n mappedItem.attr(attrs);\n if (!item.isVisible()) mappedItem.hide();else mappedItem.show();\n mappedItem.exist = true;\n var zIndex = item.getModel().depth;\n if (!isNaN(zIndex)) mappedItem.set('zIndex', zIndex);\n itemMap[item.get('id')] = mappedItem;\n this.set('itemMap', itemMap);\n };\n /**\n * Minimap 中展示自定义的rect,支持用户自定义样式和节点大小\n */\n\n\n MiniMap.prototype.updateDelegateShapes = function () {\n var _this = this;\n\n var graph = this._cfgs.graph;\n var canvas = this.get('canvas');\n var group = canvas.get('children')[0] || canvas.addGroup(); // 差量更新 minimap 上的节点和边\n\n each(graph.getEdges(), function (edge) {\n _this.updateOneEdgeKeyShape(edge, group);\n });\n each(graph.getNodes(), function (node) {\n _this.updateOneNodeDelegateShape(node, group);\n });\n var combos = graph.getCombos();\n\n if (combos && combos.length) {\n var comboGroup_2 = group.find(function (e) {\n return e.get('name') === 'comboGroup';\n }) || group.addGroup({\n name: 'comboGroup'\n });\n setTimeout(function () {\n if (_this.destroyed) return;\n each(combos, function (combo) {\n _this.updateOneComboKeyShape(combo, comboGroup_2);\n });\n comboGroup_2 === null || comboGroup_2 === void 0 ? void 0 : comboGroup_2.sort();\n comboGroup_2 === null || comboGroup_2 === void 0 ? void 0 : comboGroup_2.toBack();\n\n _this.updateCanvas();\n }, 250);\n }\n\n this.clearDestroyedShapes();\n };\n\n MiniMap.prototype.clearDestroyedShapes = function () {\n var itemMap = this.get('itemMap') || {};\n var keys = Object.keys(itemMap);\n if (!keys || keys.length === 0) return;\n\n for (var i = keys.length - 1; i >= 0; i--) {\n var shape = itemMap[keys[i]];\n var exist = shape.exist;\n shape.exist = false;\n\n if (!exist) {\n shape.remove();\n delete itemMap[keys[i]];\n }\n }\n };\n /**\n * 设置只显示 edge 的 keyShape\n * @param item IEdge 实例\n */\n\n\n MiniMap.prototype.updateOneEdgeKeyShape = function (item, group) {\n var itemMap = this.get('itemMap') || {}; // 差量更新 minimap 上的一个节点,对应主图的 item\n\n var mappedItem = itemMap[item.get('id')];\n\n if (mappedItem) {\n var path = item.get('keyShape').attr('path');\n mappedItem.attr('path', path);\n } else {\n mappedItem = item.get('keyShape').clone();\n group.add(mappedItem);\n }\n\n if (!item.isVisible()) mappedItem.hide();else mappedItem.show();\n mappedItem.exist = true;\n itemMap[item.get('id')] = mappedItem;\n this.set('itemMap', itemMap);\n };\n /**\n * Minimap 中展示自定义的 rect,支持用户自定义样式和节点大小\n * 增加/更新单个元素\n * @param item INode 实例\n */\n\n\n MiniMap.prototype.updateOneNodeDelegateShape = function (item, group) {\n var delegateStyle = this.get('delegateStyle');\n var itemMap = this.get('itemMap') || {}; // 差量更新 minimap 上的一个节点,对应主图的 item\n\n var mappedItem = itemMap[item.get('id')];\n var bbox = item.getBBox(); // 计算了节点父组矩阵的 bbox\n\n if (mappedItem) {\n var attrs = {\n x: bbox.minX,\n y: bbox.minY,\n width: bbox.width,\n height: bbox.height\n };\n mappedItem.attr(attrs);\n } else {\n mappedItem = group.addShape('rect', {\n attrs: __assign({\n x: bbox.minX,\n y: bbox.minY,\n width: bbox.width,\n height: bbox.height\n }, delegateStyle),\n name: 'minimap-node-shape'\n });\n }\n\n if (!item.isVisible()) mappedItem.hide();else mappedItem.show();\n mappedItem.exist = true;\n itemMap[item.get('id')] = mappedItem;\n this.set('itemMap', itemMap);\n };\n\n MiniMap.prototype.init = function () {\n this.initContainer();\n this.get('graph').on('afterupdateitem', this.handleUpdateCanvas);\n this.get('graph').on('afteritemstatechange', this.handleUpdateCanvas);\n this.get('graph').on('afteradditem', this.handleUpdateCanvas);\n this.get('graph').on('afterremoveitem', this.handleUpdateCanvas);\n this.get('graph').on('afterrender', this.handleUpdateCanvas);\n this.get('graph').on('afterlayout', this.handleUpdateCanvas);\n };\n /**\n * 初始化 Minimap 的容器\n */\n\n\n MiniMap.prototype.initContainer = function () {\n var self = this;\n var graph = self.get('graph');\n var size = self.get('size');\n var className = self.get('className');\n var parentNode = self.get('container');\n var container = createDom(\"<div class='\" + className + \"' style='width: \" + size[0] + \"px; height: \" + size[1] + \"px; overflow: hidden'></div>\");\n\n if (isString(parentNode)) {\n parentNode = document.getElementById(parentNode);\n }\n\n if (parentNode) {\n parentNode.appendChild(container);\n } else {\n graph.get('container').appendChild(container);\n }\n\n self.set('container', container);\n var containerDOM = createDom('<div class=\"g6-minimap-container\" style=\"position: relative;\"></div>');\n container.appendChild(containerDOM);\n containerDOM.addEventListener('dragenter', function (e) {\n e.preventDefault();\n });\n containerDOM.addEventListener('dragover', function (e) {\n e.preventDefault();\n });\n var canvas;\n var renderer = graph.get('renderer');\n\n if (renderer === SVG) {\n canvas = new GSVGCanvas({\n container: containerDOM,\n width: size[0],\n height: size[1]\n });\n } else {\n canvas = new GCanvas({\n container: containerDOM,\n width: size[0],\n height: size[1]\n });\n }\n\n self.set('canvas', canvas);\n self.updateCanvas();\n };\n\n MiniMap.prototype.updateCanvas = function () {\n if (this.destroyed) return; // 如果是在动画,则不刷新视图\n\n var isRefresh = this.get('refresh');\n\n if (!isRefresh) {\n return;\n }\n\n var graph = this.get('graph');\n\n if (graph.get('destroyed')) {\n return;\n } // 如果是视口变换,也不刷新视图,但是需要重置视口大小和位置\n\n\n if (this.get('viewportChange')) {\n this.set('viewportChange', false);\n this.updateViewport();\n }\n\n var size = this.get('size'); // 用户定义的 minimap size\n\n var canvas = this.get('canvas'); // minimap 的 canvas\n\n var type = this.get('type'); // minimap 的类型\n\n var padding = this.get('padding'); // 用户额定义的 minimap 的 padding\n\n if (canvas.destroyed) {\n return;\n }\n\n switch (type) {\n case DEFAULT_MODE:\n this.updateGraphShapes();\n break;\n\n case KEYSHAPE_MODE:\n this.updateKeyShapes();\n break;\n\n case DELEGATE_MODE:\n // 得到的节点直接带有 x 和 y,每个节点不存在父 group,即每个节点位置不由父 group 控制\n this.updateDelegateShapes();\n break;\n\n default:\n break;\n }\n\n var group = canvas.get('children')[0];\n if (!group) return;\n group.resetMatrix(); // 该 bbox 是准确的,不计算 matrix 的包围盒\n\n var bbox = group.getCanvasBBox();\n var graphBBox = graph.get('canvas').getCanvasBBox(); // 主图的 bbox\n\n var graphZoom = graph.getZoom() || 1;\n var width = graphBBox.width / graphZoom;\n var height = graphBBox.height / graphZoom;\n\n if (Number.isFinite(bbox.width)) {\n // 刷新后bbox可能会变,需要重置画布矩阵以缩放到合适的大小\n width = max(bbox.width, width);\n height = max(bbox.height, height);\n }\n\n width += 2 * padding;\n height += 2 * padding;\n var ratio = Math.min(size[0] / width, size[1] / height);\n var matrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var minX = 0;\n var minY = 0; // 平移到左上角\n\n if (Number.isFinite(bbox.minX)) {\n minX = -bbox.minX;\n }\n\n if (Number.isFinite(bbox.minY)) {\n minY = -bbox.minY;\n } // 缩放到适合视口后, 平移到画布中心\n\n\n var dx = (size[0] - (width - 2 * padding) * ratio) / 2;\n var dy = (size[1] - (height - 2 * padding) * ratio) / 2;\n matrix = transform(matrix, [['t', minX, minY], ['s', ratio, ratio], ['t', dx, dy] // 移动到画布中心\n ]);\n group.setMatrix(matrix); // 更新minimap视口\n\n this.set('ratio', ratio);\n this.set('totaldx', dx + minX * ratio);\n this.set('totaldy', dy + minY * ratio);\n this.set('dx', dx);\n this.set('dy', dy);\n this.updateViewport();\n };\n /**\n * 获取minimap的画布\n * @return {GCanvas} G的canvas实例\n */\n\n\n MiniMap.prototype.getCanvas = function () {\n return this.get('canvas');\n };\n /**\n * 获取minimap的窗口\n * @return {HTMLElement} 窗口的dom实例\n */\n\n\n MiniMap.prototype.getViewport = function () {\n return this.get('viewport');\n };\n /**\n * 获取minimap的容器dom\n * @return {HTMLElement} dom\n */\n\n\n MiniMap.prototype.getContainer = function () {\n return this.get('container');\n };\n\n MiniMap.prototype.destroy = function () {\n this.get('canvas').destroy();\n var container = this.get('container');\n container.parentNode.removeChild(container);\n };\n\n return MiniMap;\n}(Base);\n\nexport default MiniMap;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nimport Base from '../base';\n\nfunction getEucliDis(pointA, pointB, eps) {\n var vx = pointA.x - pointB.x;\n var vy = pointA.y - pointB.y;\n\n if (!eps || Math.abs(vx) > eps || Math.abs(vy) > eps) {\n return Math.sqrt(vx * vx + vy * vy);\n }\n\n return eps;\n}\n\nfunction getDotProduct(ei, ej) {\n return ei.x * ej.x + ei.y * ej.y;\n}\n\nfunction projectPointToEdge(p, e) {\n var k = (e.source.y - e.target.y) / (e.source.x - e.target.x);\n var x = (k * k * e.source.x + k * (p.y - e.source.y) + p.x) / (k * k + 1);\n var y = k * (x - e.source.x) + e.source.y;\n return {\n x: x,\n y: y\n };\n}\n\nvar Bundling = function (_super) {\n __extends(Bundling, _super);\n\n function Bundling(config) {\n return _super.call(this, config) || this;\n }\n\n Bundling.prototype.getDefaultCfgs = function () {\n return {\n edgeBundles: [],\n edgePoints: [],\n K: 0.1,\n lambda: 0.1,\n divisions: 1,\n divRate: 2,\n cycles: 6,\n iterations: 90,\n iterRate: 0.6666667,\n bundleThreshold: 0.6,\n eps: 1e-6,\n onLayoutEnd: function onLayoutEnd() {},\n onTick: function onTick() {}\n };\n };\n\n Bundling.prototype.init = function () {\n var graph = this.get('graph');\n var onTick = this.get('onTick');\n\n var tick = function tick() {\n if (onTick) {\n onTick();\n }\n\n graph.refreshPositions();\n };\n\n this.set('tick', tick);\n };\n\n Bundling.prototype.bundling = function (data) {\n var self = this;\n self.set('data', data); // 如果正在布局,忽略布局请求\n\n if (self.isTicking()) {\n return;\n }\n\n var edges = data.edges || [];\n var nodes = data.nodes || [];\n var nodeIdMap = {};\n var error = false;\n nodes.forEach(function (node) {\n if (node.x === null || !node.y === null || node.x === undefined || !node.y === undefined) {\n error = true;\n }\n\n nodeIdMap[node.id] = node;\n });\n if (error) throw new Error('please layout the graph or assign x and y for nodes first');\n self.set('nodeIdMap', nodeIdMap); // subdivide each edges\n\n var divisions = self.get('divisions');\n var divRate = self.get('divRate');\n var edgePoints = self.divideEdges(divisions);\n self.set('edgePoints', edgePoints); // compute the bundles\n\n var edgeBundles = self.getEdgeBundles();\n self.set('edgeBundles', edgeBundles); // iterations\n\n var C = self.get('cycles');\n var iterations = self.get('iterations');\n var iterRate = self.get('iterRate');\n var lambda = self.get('lambda');\n\n for (var i = 0; i < C; i++) {\n var _loop_1 = function _loop_1(j) {\n var forces = [];\n edges.forEach(function (e, k) {\n if (e.source === e.target) return;\n var source = nodeIdMap[e.source];\n var target = nodeIdMap[e.target];\n forces[k] = self.getEdgeForces({\n source: source,\n target: target\n }, k, divisions, lambda);\n\n for (var p = 0; p < divisions + 1; p++) {\n edgePoints[k][p].x += forces[k][p].x;\n edgePoints[k][p].y += forces[k][p].y;\n }\n });\n };\n\n for (var j = 0; j < iterations; j++) {\n _loop_1(j);\n } // parameters for nex cycle\n\n\n lambda = lambda / 2;\n divisions *= divRate;\n iterations *= iterRate;\n edgePoints = self.divideEdges(divisions);\n self.set('edgePoints', edgePoints);\n } // change the edges according to edgePoints\n\n\n edges.forEach(function (e, i) {\n if (e.source === e.target) return;\n e.type = 'polyline';\n e.controlPoints = edgePoints[i].slice(1, edgePoints[i].length - 1);\n });\n var graph = self.get('graph');\n graph.refresh();\n };\n\n Bundling.prototype.updateBundling = function (cfg) {\n var self = this;\n var data = cfg.data;\n\n if (data) {\n self.set('data', data);\n }\n\n if (self.get('ticking')) {\n self.set('ticking', false);\n }\n\n Object.keys(cfg).forEach(function (key) {\n self.set(key, cfg[key]);\n });\n\n if (cfg.onTick) {\n var graph_1 = this.get('graph');\n self.set('tick', function () {\n cfg.onTick();\n graph_1.refresh();\n });\n }\n\n self.bundling(data);\n };\n\n Bundling.prototype.divideEdges = function (divisions) {\n var self = this;\n var edges = self.get('data').edges;\n var nodeIdMap = self.get('nodeIdMap');\n var edgePoints = self.get('edgePoints');\n if (!edgePoints || edgePoints === undefined) edgePoints = [];\n edges.forEach(function (edge, i) {\n if (!edgePoints[i] || edgePoints[i] === undefined) {\n edgePoints[i] = [];\n }\n\n var source = nodeIdMap[edge.source];\n var target = nodeIdMap[edge.target];\n\n if (divisions === 1) {\n edgePoints[i].push({\n x: source.x,\n y: source.y\n }); // source\n\n edgePoints[i].push({\n x: 0.5 * (source.x + target.x),\n y: 0.5 * (source.y + target.y)\n }); // mid\n\n edgePoints[i].push({\n x: target.x,\n y: target.y\n }); // target\n } else {\n var edgeLength = 0;\n\n if (!edgePoints[i] || edgePoints[i] === []) {\n // it is a straight line\n edgeLength = getEucliDis({\n x: source.x,\n y: source.y\n }, {\n x: target.x,\n y: target.y\n });\n } else {\n edgeLength = self.getEdgeLength(edgePoints[i]);\n }\n\n var divisionLength_1 = edgeLength / (divisions + 1);\n var currentDivisonLength_1 = divisionLength_1;\n var newEdgePoints_1 = [{\n x: source.x,\n y: source.y\n }]; // source\n\n edgePoints[i].forEach(function (ep, j) {\n if (j === 0) return;\n var oriDivisionLength = getEucliDis(ep, edgePoints[i][j - 1]);\n\n while (oriDivisionLength > currentDivisonLength_1) {\n var ratio = currentDivisonLength_1 / oriDivisionLength;\n var edgePoint = {\n x: edgePoints[i][j - 1].x,\n y: edgePoints[i][j - 1].y\n };\n edgePoint.x += ratio * (ep.x - edgePoints[i][j - 1].x);\n edgePoint.y += ratio * (ep.y - edgePoints[i][j - 1].y);\n newEdgePoints_1.push(edgePoint);\n oriDivisionLength -= currentDivisonLength_1;\n currentDivisonLength_1 = divisionLength_1;\n }\n\n currentDivisonLength_1 -= oriDivisionLength;\n });\n newEdgePoints_1.push({\n x: target.x,\n y: target.y\n }); // target\n\n edgePoints[i] = newEdgePoints_1;\n }\n });\n return edgePoints;\n };\n /**\n * 计算边的长度\n * @param points\n */\n\n\n Bundling.prototype.getEdgeLength = function (points) {\n var length = 0;\n points.forEach(function (p, i) {\n if (i === 0) return;\n length += getEucliDis(p, points[i - 1]);\n });\n return length;\n };\n\n Bundling.prototype.getEdgeBundles = function () {\n var self = this;\n var data = self.get('data');\n var edges = data.edges || [];\n var bundleThreshold = self.get('bundleThreshold');\n var nodeIdMap = self.get('nodeIdMap');\n var edgeBundles = self.get('edgeBundles');\n if (!edgeBundles) edgeBundles = [];\n edges.forEach(function (e, i) {\n if (!edgeBundles[i] || edgeBundles[i] === undefined) {\n edgeBundles[i] = [];\n }\n });\n edges.forEach(function (ei, i) {\n var iSource = nodeIdMap[ei.source];\n var iTarget = nodeIdMap[ei.target];\n edges.forEach(function (ej, j) {\n if (j <= i) return;\n var jSource = nodeIdMap[ej.source];\n var jTarget = nodeIdMap[ej.target];\n var score = self.getBundleScore({\n source: iSource,\n target: iTarget\n }, {\n source: jSource,\n target: jTarget\n });\n\n if (score >= bundleThreshold) {\n edgeBundles[i].push(j);\n edgeBundles[j].push(i);\n }\n });\n });\n return edgeBundles;\n };\n\n Bundling.prototype.getBundleScore = function (ei, ej) {\n var self = this;\n ei.vx = ei.target.x - ei.source.x;\n ei.vy = ei.target.y - ei.source.y;\n ej.vx = ej.target.x - ej.source.x;\n ej.vy = ej.target.y - ej.source.y;\n ei.length = getEucliDis({\n x: ei.source.x,\n y: ei.source.y\n }, {\n x: ei.target.x,\n y: ei.target.y\n });\n ej.length = getEucliDis({\n x: ej.source.x,\n y: ej.source.y\n }, {\n x: ej.target.x,\n y: ej.target.y\n }); // angle score\n\n var aScore = self.getAngleScore(ei, ej); // scale score\n\n var sScore = self.getScaleScore(ei, ej); // position score\n\n var pScore = self.getPositionScore(ei, ej); // visibility socre\n\n var vScore = self.getVisibilityScore(ei, ej);\n return aScore * sScore * pScore * vScore;\n };\n\n Bundling.prototype.getAngleScore = function (ei, ej) {\n var dotProduct = getDotProduct({\n x: ei.vx,\n y: ei.vy\n }, {\n x: ej.vx,\n y: ej.vy\n });\n return dotProduct / (ei.length * ej.length);\n };\n\n Bundling.prototype.getScaleScore = function (ei, ej) {\n var aLength = (ei.length + ej.length) / 2;\n var score = 2 / (aLength / Math.min(ei.length, ej.length) + Math.max(ei.length, ej.length) / aLength);\n return score;\n };\n\n Bundling.prototype.getPositionScore = function (ei, ej) {\n var aLength = (ei.length + ej.length) / 2;\n var iMid = {\n x: (ei.source.x + ei.target.x) / 2,\n y: (ei.source.y + ei.target.y) / 2\n };\n var jMid = {\n x: (ej.source.x + ej.target.x) / 2,\n y: (ej.source.y + ej.target.y) / 2\n };\n var distance = getEucliDis(iMid, jMid);\n return aLength / (aLength + distance);\n };\n\n Bundling.prototype.getVisibilityScore = function (ei, ej) {\n var vij = this.getEdgeVisibility(ei, ej);\n var vji = this.getEdgeVisibility(ej, ei);\n return vij < vji ? vij : vji;\n };\n\n Bundling.prototype.getEdgeVisibility = function (ei, ej) {\n var ps = projectPointToEdge(ej.source, ei);\n var pt = projectPointToEdge(ej.target, ei);\n var pMid = {\n x: (ps.x + pt.x) / 2,\n y: (ps.y + pt.y) / 2\n };\n var iMid = {\n x: (ei.source.x + ei.target.x) / 2,\n y: (ei.source.y + ei.target.y) / 2\n };\n return Math.max(0, 1 - 2 * getEucliDis(pMid, iMid) / getEucliDis(ps, pt));\n };\n\n Bundling.prototype.getEdgeForces = function (e, eidx, divisions, lambda) {\n var self = this;\n var edgePoints = self.get('edgePoints');\n var K = self.get('K');\n var kp = K / (getEucliDis(e.source, e.target) * (divisions + 1));\n var edgePointForces = [{\n x: 0,\n y: 0\n }];\n\n for (var i = 1; i < divisions; i++) {\n var force = {\n x: 0,\n y: 0\n };\n var spring = self.getSpringForce({\n pre: edgePoints[eidx][i - 1],\n cur: edgePoints[eidx][i],\n next: edgePoints[eidx][i + 1]\n }, kp);\n var electrostatic = self.getElectrostaticForce(i, eidx);\n force.x = lambda * (spring.x + electrostatic.x);\n force.y = lambda * (spring.y + electrostatic.y);\n edgePointForces.push(force);\n }\n\n edgePointForces.push({\n x: 0,\n y: 0\n });\n return edgePointForces;\n };\n\n Bundling.prototype.getSpringForce = function (divisions, kp) {\n var x = divisions.pre.x + divisions.next.x - 2 * divisions.cur.x;\n var y = divisions.pre.y + divisions.next.y - 2 * divisions.cur.y;\n x *= kp;\n y *= kp;\n return {\n x: x,\n y: y\n };\n };\n\n Bundling.prototype.getElectrostaticForce = function (pidx, eidx) {\n var self = this;\n var eps = self.get('eps');\n var edgeBundles = self.get('edgeBundles');\n var edgePoints = self.get('edgePoints');\n var edgeBundle = edgeBundles[eidx];\n var resForce = {\n x: 0,\n y: 0\n };\n edgeBundle.forEach(function (eb) {\n var force = {\n x: edgePoints[eb][pidx].x - edgePoints[eidx][pidx].x,\n y: edgePoints[eb][pidx].y - edgePoints[eidx][pidx].y\n };\n\n if (Math.abs(force.x) > eps || Math.abs(force.y) > eps) {\n var length_1 = getEucliDis(edgePoints[eb][pidx], edgePoints[eidx][pidx]);\n var diff = 1 / length_1;\n resForce.x += force.x * diff;\n resForce.y += force.y * diff;\n }\n });\n return resForce;\n };\n\n Bundling.prototype.isTicking = function () {\n return this.get('ticking');\n };\n\n Bundling.prototype.getSimulation = function () {\n return this.get('forceSimulation');\n };\n\n Bundling.prototype.destroy = function () {\n if (this.get('ticking')) {\n this.getSimulation().stop();\n }\n\n _super.prototype.destroy.call(this);\n };\n\n return Bundling;\n}(Base);\n\nexport default Bundling;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { clone } from '@antv/util';\nimport Base from '../base';\nvar DELTA = 0.05;\nvar lensDelegateStyle = {\n stroke: '#000',\n strokeOpacity: 0.8,\n lineWidth: 2,\n fillOpacity: 0.1,\n fill: '#ccc'\n};\n\nvar Fisheye = function (_super) {\n __extends(Fisheye, _super);\n\n function Fisheye(config) {\n return _super.call(this, config) || this;\n }\n\n Fisheye.prototype.getDefaultCfgs = function () {\n return {\n trigger: 'mousemove',\n d: 1.5,\n r: 300,\n delegateStyle: clone(lensDelegateStyle),\n showLabel: false,\n maxD: 5,\n minD: 0,\n scaleRBy: 'unset',\n scaleDBy: 'unset',\n showDPercent: true\n };\n }; // class-methods-use-this\n\n\n Fisheye.prototype.getEvents = function () {\n var events;\n\n switch (this.get('trigger')) {\n case 'click':\n events = {\n click: 'magnify'\n };\n break;\n\n case 'drag':\n events = {\n click: 'createDelegate'\n };\n break;\n\n default:\n events = {\n mousemove: 'magnify'\n };\n break;\n }\n\n return events;\n };\n\n Fisheye.prototype.init = function () {\n var self = this;\n var r = self.get('r');\n self.set('cachedMagnifiedModels', []);\n self.set('cachedOriginPositions', {});\n self.set('r2', r * r);\n var d = self.get('d');\n self.set('molecularParam', (d + 1) * r);\n }; // Create the delegate when the trigger is drag\n\n\n Fisheye.prototype.createDelegate = function (e) {\n var _this = this;\n\n var self = this;\n var lensDelegate = self.get('delegate');\n\n if (!lensDelegate || lensDelegate.destroyed) {\n self.magnify(e);\n lensDelegate = self.get('delegate'); // drag to move the lens\n\n lensDelegate.on('dragstart', function (evt) {\n self.set('delegateCenterDiff', {\n x: lensDelegate.attr('x') - evt.x,\n y: lensDelegate.attr('y') - evt.y\n });\n });\n lensDelegate.on('drag', function (evt) {\n self.magnify(evt);\n }); // 绑定调整范围(r)和缩放系数(d)的监听\n // 由于 drag 用于改变 lens 位置, 因此在此模式下, drag 不能用于调整 r 和 d\n // scaling d\n\n if (this.get('scaleDBy') === 'wheel') {\n lensDelegate.on('mousewheel', function (evt) {\n _this.scaleDByWheel(evt);\n });\n } // scaling r\n\n\n if (this.get('scaleRBy') === 'wheel') {\n lensDelegate.on('mousewheel', function (evt) {\n self.scaleRByWheel(evt);\n });\n }\n }\n };\n /**\n * Scale the range by wheel\n * @param e mouse wheel event\n */\n\n\n Fisheye.prototype.scaleRByWheel = function (e) {\n var self = this;\n if (!e || !e.originalEvent) return;\n if (e.preventDefault) e.preventDefault();\n var graph = self.get('graph');\n var ratio;\n var lensDelegate = self.get('delegate');\n var lensCenter = lensDelegate ? {\n x: lensDelegate.attr('x'),\n y: lensDelegate.attr('y')\n } : undefined;\n var mousePos = lensCenter || graph.getPointByClient(e.clientX, e.clientY);\n\n if (e.originalEvent.wheelDelta < 0) {\n ratio = 1 - DELTA;\n } else {\n ratio = 1 / (1 - DELTA);\n }\n\n var maxR = self.get('maxR');\n var minR = self.get('minR');\n var r = self.get('r');\n\n if (r > (maxR || graph.get('height')) && ratio > 1 || r < (minR || graph.get('height') * 0.05) && ratio < 1) {\n ratio = 1;\n }\n\n r *= ratio;\n self.set('r', r);\n self.set('r2', r * r);\n var d = self.get('d');\n self.set('molecularParam', (d + 1) * r);\n self.set('delegateCenterDiff', undefined);\n self.magnify(e, mousePos);\n };\n /**\n * Scale the range by dragging\n * @param e mouse event\n */\n\n\n Fisheye.prototype.scaleRByDrag = function (e) {\n var self = this;\n if (!e) return;\n var dragPrePos = self.get('dragPrePos');\n var graph = self.get('graph');\n var ratio;\n var mousePos = graph.getPointByClient(e.clientX, e.clientY);\n\n if (e.x - dragPrePos.x < 0) {\n ratio = 1 - DELTA;\n } else {\n ratio = 1 / (1 - DELTA);\n }\n\n var maxR = self.get('maxR');\n var minR = self.get('minR');\n var r = self.get('r');\n\n if (r > (maxR || graph.get('height')) && ratio > 1 || r < (minR || graph.get('height') * 0.05) && ratio < 1) {\n ratio = 1;\n }\n\n r *= ratio;\n self.set('r', r);\n self.set('r2', r * r);\n var d = self.get('d');\n self.set('molecularParam', (d + 1) * r);\n self.magnify(e, mousePos);\n self.set('dragPrePos', {\n x: e.x,\n y: e.y\n });\n };\n /**\n * Scale the magnifying factor by wheel\n * @param e mouse wheel event\n */\n\n\n Fisheye.prototype.scaleDByWheel = function (evt) {\n var self = this;\n if (!evt && !evt.originalEvent) return;\n if (evt.preventDefault) evt.preventDefault();\n var delta = 0;\n\n if (evt.originalEvent.wheelDelta < 0) {\n delta = -0.1;\n } else {\n delta = 0.1;\n }\n\n var d = self.get('d');\n var newD = d + delta;\n var maxD = self.get('maxD');\n var minD = self.get('minD');\n\n if (newD < maxD && newD > minD) {\n self.set('d', newD);\n var r = self.get('r');\n self.set('molecularParam', (newD + 1) * r);\n var lensDelegate = self.get('delegate');\n var lensCenter = lensDelegate ? {\n x: lensDelegate.attr('x'),\n y: lensDelegate.attr('y')\n } : undefined;\n self.set('delegateCenterDiff', undefined);\n self.magnify(evt, lensCenter);\n }\n };\n /**\n * Scale the magnifying factor by dragging\n * @param e mouse event\n */\n\n\n Fisheye.prototype.scaleDByDrag = function (e) {\n var self = this;\n var dragPrePos = self.get('dragPrePos');\n var delta = e.x - dragPrePos.x > 0 ? 0.1 : -0.1;\n var d = self.get('d');\n var newD = d + delta;\n var maxD = self.get('maxD');\n var minD = self.get('minD');\n\n if (newD < maxD && newD > minD) {\n self.set('d', newD);\n var r = self.get('r');\n self.set('molecularParam', (newD + 1) * r);\n self.magnify(e);\n }\n\n self.set('dragPrePos', {\n x: e.x,\n y: e.y\n });\n };\n /**\n * Response function for mousemove, click, or drag to magnify\n * @param e mouse event\n */\n\n\n Fisheye.prototype.magnify = function (e, mousePos) {\n var self = this;\n self.restoreCache();\n var graph = self.get('graph');\n var cachedMagnifiedModels = self.get('cachedMagnifiedModels');\n var cachedOriginPositions = self.get('cachedOriginPositions');\n var showLabel = self.get('showLabel');\n var r = self.get('r');\n var r2 = self.get('r2');\n var d = self.get('d');\n var molecularParam = self.get('molecularParam');\n var nodes = graph.getNodes();\n var nodeLength = nodes.length;\n var mCenter = mousePos ? {\n x: mousePos.x,\n y: mousePos.y\n } : {\n x: e.x,\n y: e.y\n };\n\n if (self.get('dragging') && (self.get('trigger') === 'mousemove' || self.get('trigger') === 'click')) {\n mCenter = self.get('cacheCenter');\n }\n\n var delegateCenterDiff = self.get('delegateCenterDiff');\n\n if (delegateCenterDiff) {\n mCenter.x += delegateCenterDiff.x;\n mCenter.y += delegateCenterDiff.y;\n }\n\n self.updateDelegate(mCenter, r);\n\n for (var i = 0; i < nodeLength; i++) {\n var model = nodes[i].getModel();\n var x = model.x,\n y = model.y;\n if (isNaN(x) || isNaN(y)) continue; // the square of the distance between the node and the magnified center\n\n var dist2 = (x - mCenter.x) * (x - mCenter.x) + (y - mCenter.y) * (y - mCenter.y);\n\n if (!isNaN(dist2) && dist2 < r2 && dist2 !== 0) {\n var dist = Math.sqrt(dist2); // (r * (d + 1) * (dist / r)) / (d * (dist / r) + 1);\n\n var magnifiedDist = molecularParam * dist / (d * dist + r);\n var cos = (x - mCenter.x) / dist;\n var sin = (y - mCenter.y) / dist;\n model.x = cos * magnifiedDist + mCenter.x;\n model.y = sin * magnifiedDist + mCenter.y;\n\n if (!cachedOriginPositions[model.id]) {\n cachedOriginPositions[model.id] = {\n x: x,\n y: y,\n texts: []\n };\n }\n\n cachedMagnifiedModels.push(model);\n\n if (showLabel && 2 * dist < r) {\n var node = nodes[i];\n var nodeGroup = node.getContainer();\n var shapes = nodeGroup.getChildren();\n var shapeLength = shapes.length;\n\n for (var j = 0; j < shapeLength; j++) {\n var shape = shapes[j];\n\n if (shape.get('type') === 'text') {\n cachedOriginPositions[model.id].texts.push({\n visible: shape.get('visible'),\n shape: shape\n });\n shape.set('visible', true);\n }\n }\n }\n }\n }\n\n graph.refreshPositions();\n };\n /**\n * Restore the cache nodes while magnifying\n */\n\n\n Fisheye.prototype.restoreCache = function () {\n var self = this;\n var cachedMagnifiedModels = self.get('cachedMagnifiedModels');\n var cachedOriginPositions = self.get('cachedOriginPositions');\n var cacheLength = cachedMagnifiedModels.length;\n\n for (var i = 0; i < cacheLength; i++) {\n var node = cachedMagnifiedModels[i];\n var id = node.id;\n var ori = cachedOriginPositions[id];\n node.x = ori.x;\n node.y = ori.y;\n var textLength = ori.texts.length;\n\n for (var j = 0; j < textLength; j++) {\n var text = ori.texts[j];\n text.shape.set('visible', text.visible);\n }\n }\n\n self.set('cachedMagnifiedModels', []);\n self.set('cachedOriginPositions', {});\n };\n /**\n * Adjust part of the parameters, including trigger, d, r, maxR, minR, maxD, minD, scaleRBy, and scaleDBy\n * @param {FisheyeConfig} cfg\n */\n\n\n Fisheye.prototype.updateParams = function (cfg) {\n var self = this;\n var r = cfg.r,\n d = cfg.d,\n trigger = cfg.trigger,\n minD = cfg.minD,\n maxD = cfg.maxD,\n minR = cfg.minR,\n maxR = cfg.maxR,\n scaleDBy = cfg.scaleDBy,\n scaleRBy = cfg.scaleRBy;\n\n if (!isNaN(cfg.r)) {\n self.set('r', r);\n self.set('r2', r * r);\n }\n\n if (!isNaN(d)) {\n self.set('d', d);\n }\n\n if (!isNaN(maxD)) {\n self.set('maxD', maxD);\n }\n\n if (!isNaN(minD)) {\n self.set('minD', minD);\n }\n\n if (!isNaN(maxR)) {\n self.set('maxR', maxR);\n }\n\n if (!isNaN(minR)) {\n self.set('minR', minR);\n }\n\n var nd = self.get('d');\n var nr = self.get('r');\n self.set('molecularParam', (nd + 1) * nr);\n\n if (trigger === 'mousemove' || trigger === 'click' || trigger === 'drag') {\n self.set('trigger', trigger);\n }\n\n if (scaleDBy === 'drag' || scaleDBy === 'wheel' || scaleDBy === 'unset') {\n self.set('scaleDBy', scaleDBy);\n self.get('delegate').remove();\n self.get('delegate').destroy();\n var dPercentText = self.get('dPercentText');\n\n if (dPercentText) {\n dPercentText.remove();\n dPercentText.destroy();\n }\n }\n\n if (scaleRBy === 'drag' || scaleRBy === 'wheel' || scaleRBy === 'unset') {\n self.set('scaleRBy', scaleRBy);\n self.get('delegate').remove();\n self.get('delegate').destroy();\n var dPercentText = self.get('dPercentText');\n\n if (dPercentText) {\n dPercentText.remove();\n dPercentText.destroy();\n }\n }\n };\n /**\n * Update the delegate shape of the lens\n * @param {Point} mCenter the center of the shape\n * @param {number} r the radius of the shape\n */\n\n\n Fisheye.prototype.updateDelegate = function (mCenter, r) {\n var _this = this;\n\n var self = this;\n var graph = self.get('graph');\n var lensDelegate = self.get('delegate');\n\n if (!lensDelegate || lensDelegate.destroyed) {\n // 拖动多个\n var parent_1 = graph.get('group');\n var attrs = self.get('delegateStyle') || lensDelegateStyle; // model上的x, y是相对于图形中心的, delegateShape是g实例, x,y是绝对坐标\n\n lensDelegate = parent_1.addShape('circle', {\n attrs: __assign({\n r: r / 1.5,\n x: mCenter.x,\n y: mCenter.y\n }, attrs),\n name: 'lens-shape',\n draggable: true\n });\n\n if (this.get('trigger') !== 'drag') {\n // 调整范围 r 的监听\n if (this.get('scaleRBy') === 'wheel') {\n // 使用滚轮调整 r\n lensDelegate.on('mousewheel', function (evt) {\n self.scaleRByWheel(evt);\n });\n } else if (this.get('scaleRBy') === 'drag') {\n // 使用拖拽调整 r\n lensDelegate.on('dragstart', function (e) {\n self.set('dragging', true);\n self.set('cacheCenter', {\n x: e.x,\n y: e.y\n });\n self.set('dragPrePos', {\n x: e.x,\n y: e.y\n });\n });\n lensDelegate.on('drag', function (evt) {\n self.scaleRByDrag(evt);\n });\n lensDelegate.on('dragend', function (e) {\n self.set('dragging', false);\n });\n } // 调整缩放系数 d 的监听\n\n\n if (this.get('scaleDBy') === 'wheel') {\n // 使用滚轮调整 d\n lensDelegate.on('mousewheel', function (evt) {\n _this.scaleDByWheel(evt);\n });\n } else if (this.get('scaleDBy') === 'drag') {\n // 使用拖拽调整 d\n lensDelegate.on('dragstart', function (evt) {\n self.set('dragging', true);\n self.set('cacheCenter', {\n x: evt.x,\n y: evt.y\n });\n self.set('dragPrePos', {\n x: evt.x,\n y: evt.y\n });\n });\n lensDelegate.on('drag', function (evt) {\n _this.scaleDByDrag(evt);\n });\n lensDelegate.on('dragend', function (evt) {\n self.set('dragging', false);\n });\n }\n }\n } else {\n lensDelegate.attr({\n x: mCenter.x,\n y: mCenter.y,\n r: r / 1.5\n });\n } // 绘制缩放系数百分比文本\n\n\n if (self.get('showDPercent')) {\n var percent = Math.round((self.get('d') - self.get('minD')) / (self.get('maxD') - self.get('minD')) * 100);\n var dPercentText = self.get('dPercentText');\n var textY = mCenter.y + r / 1.5 + 16;\n\n if (!dPercentText || dPercentText.destroyed) {\n var parent_2 = graph.get('group');\n dPercentText = parent_2.addShape('text', {\n attrs: {\n text: percent + \"%\",\n x: mCenter.x,\n y: textY,\n fill: '#aaa',\n stroke: '#fff',\n lineWidth: 1,\n fontSize: 12\n }\n });\n self.set('dPercentText', dPercentText);\n } else {\n dPercentText.attr({\n text: percent + \"%\",\n x: mCenter.x,\n y: textY\n });\n }\n }\n\n self.set('delegate', lensDelegate);\n };\n /**\n * Clear the fisheye lens\n */\n\n\n Fisheye.prototype.clear = function () {\n var graph = this.get('graph');\n this.restoreCache();\n graph.refreshPositions();\n var lensDelegate = this.get('delegate');\n\n if (lensDelegate && !lensDelegate.destroyed) {\n lensDelegate.remove();\n lensDelegate.destroy();\n }\n\n var dPercentText = this.get('dPercentText');\n\n if (dPercentText && !dPercentText.destroyed) {\n dPercentText.remove();\n dPercentText.destroy();\n }\n };\n /**\n * Destroy the component\n */\n\n\n Fisheye.prototype.destroy = function () {\n this.clear();\n };\n\n return Fisheye;\n}(Base);\n\nexport default Fisheye;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nimport { modifyCSS, createDom } from '@antv/dom-util';\nimport { clone, isString } from '@antv/util';\nimport Base from '../base';\nimport insertCss from 'insert-css';\nvar DELTA = 0.05;\ntypeof document !== 'undefined' && insertCss(\"\\n .g6-component-toolbar {\\n position: absolute;\\n list-style-type: none;\\n padding: 6px;\\n left: 0px;\\n top: 0px;\\n background-color: rgba(255, 255, 255, 0.9);\\n border: 1px solid #e2e2e2;\\n border-radius: 4px;\\n font-size: 12px;\\n color: #545454;\\n margin: 0;\\n }\\n .g6-component-toolbar li {\\n float: left;\\n text-align: center;\\n width: 35px;\\n height: 24px;\\n cursor: pointer;\\n\\t\\tlist-style-type:none;\\n list-style: none;\\n margin-left: 0px;\\n }\\n .g6-component-toolbar li .icon {\\n opacity: 0.7;\\n }\\n .g6-component-toolbar li .icon:hover {\\n opacity: 1;\\n }\\n\");\n\nvar getEventPath = function getEventPath(evt) {\n if (!evt) {\n return [];\n }\n\n if (evt.composedPath) {\n return evt.composedPath();\n }\n\n var path = [];\n var el = evt.target;\n\n while (el) {\n path.push(el);\n\n if (el.tagName === 'HTML') {\n path.push(document, window);\n return path;\n }\n\n el = el.parentElement;\n }\n\n return path;\n};\n\nvar ToolBar = function (_super) {\n __extends(ToolBar, _super);\n\n function ToolBar(config) {\n return _super.call(this, config) || this;\n }\n\n ToolBar.prototype.getDefaultCfgs = function () {\n return {\n handleClick: undefined,\n // 指定菜单内容,function(e) {...}\n getContent: function getContent(graph) {\n return \"\\n <ul class='g6-component-toolbar'>\\n <li code='redo'>\\n <svg class=\\\"icon\\\" viewBox=\\\"0 0 1024 1024\\\" version=\\\"1.1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"24\\\" height=\\\"24\\\">\\n <path d=\\\"M256 682.666667c0-102.741333 66.730667-213.333333 213.333333-213.333334 107.008 0 190.762667 56.576 230.570667 125.354667L611.968 682.666667H853.333333v-241.365334l-91.562666 91.562667C704.768 448.469333 601.130667 384 469.333333 384c-196.096 0-298.666667 150.229333-298.666666 298.666667h85.333333z\\\" fill=\\\"\\\" p-id=\\\"2041\\\"></path>\\n </svg>\\n </li>\\n <li code='undo'>\\n <svg class=\\\"icon\\\" viewBox=\\\"0 0 1024 1024\\\" version=\\\"1.1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"24\\\" height=\\\"24\\\">\\n <path d=\\\"M170.666667 682.666667h241.365333l-87.936-87.978667C363.904 525.909333 447.658667 469.333333 554.666667 469.333333c146.602667 0 213.333333 110.592 213.333333 213.333334h85.333333c0-148.437333-102.570667-298.666667-298.666666-298.666667-131.797333 0-235.392 64.469333-292.48 148.821333L170.666667 441.301333V682.666667z\\\" fill=\\\"\\\" p-id=\\\"2764\\\"></path>\\n </svg>\\n </li>\\n <li code='zoomOut'>\\n <svg class=\\\"icon\\\" viewBox=\\\"0 0 1024 1024\\\" version=\\\"1.1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"24\\\" height=\\\"24\\\">\\n <path d=\\\"M658.432 428.736a33.216 33.216 0 0 1-33.152 33.152H525.824v99.456a33.216 33.216 0 0 1-66.304 0V461.888H360.064a33.152 33.152 0 0 1 0-66.304H459.52V296.128a33.152 33.152 0 0 1 66.304 0V395.52H625.28c18.24 0 33.152 14.848 33.152 33.152z m299.776 521.792a43.328 43.328 0 0 1-60.864-6.912l-189.248-220.992a362.368 362.368 0 0 1-215.36 70.848 364.8 364.8 0 1 1 364.8-364.736 363.072 363.072 0 0 1-86.912 235.968l192.384 224.64a43.392 43.392 0 0 1-4.8 61.184z m-465.536-223.36a298.816 298.816 0 0 0 298.432-298.432 298.816 298.816 0 0 0-298.432-298.432A298.816 298.816 0 0 0 194.24 428.8a298.816 298.816 0 0 0 298.432 298.432z\\\"></path>\\n </svg>\\n </li>\\n <li code='zoomIn'>\\n <svg class=\\\"icon\\\" viewBox=\\\"0 0 1024 1024\\\" version=\\\"1.1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"24\\\" height=\\\"24\\\">\\n <path d=\\\"M639.936 416a32 32 0 0 1-32 32h-256a32 32 0 0 1 0-64h256a32 32 0 0 1 32 32z m289.28 503.552a41.792 41.792 0 0 1-58.752-6.656l-182.656-213.248A349.76 349.76 0 0 1 480 768 352 352 0 1 1 832 416a350.4 350.4 0 0 1-83.84 227.712l185.664 216.768a41.856 41.856 0 0 1-4.608 59.072zM479.936 704c158.784 0 288-129.216 288-288S638.72 128 479.936 128a288.32 288.32 0 0 0-288 288c0 158.784 129.216 288 288 288z\\\" p-id=\\\"3853\\\"></path>\\n </svg>\\n </li>\\n <li code='realZoom'>\\n <svg class=\\\"icon\\\" viewBox=\\\"0 0 1024 1024\\\" version=\\\"1.1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"20\\\" height=\\\"24\\\">\\n <path d=\\\"M384 320v384H320V320h64z m256 0v384H576V320h64zM512 576v64H448V576h64z m0-192v64H448V384h64z m355.968 576H92.032A28.16 28.16 0 0 1 64 931.968V28.032C64 12.608 76.608 0 95.168 0h610.368L896 192v739.968a28.16 28.16 0 0 1-28.032 28.032zM704 64v128h128l-128-128z m128 192h-190.464V64H128v832h704V256z\\\"></path>\\n </svg>\\n </li>\\n <li code='autoZoom'>\\n <svg class=\\\"icon\\\" viewBox=\\\"0 0 1024 1024\\\" version=\\\"1.1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"20\\\" height=\\\"24\\\">\\n <path d=\\\"M684.288 305.28l0.128-0.64-0.128-0.64V99.712c0-19.84 15.552-35.904 34.496-35.712a35.072 35.072 0 0 1 34.56 35.776v171.008h170.944c19.648 0 35.84 15.488 35.712 34.432a35.072 35.072 0 0 1-35.84 34.496h-204.16l-0.64-0.128a32.768 32.768 0 0 1-20.864-7.552c-1.344-1.024-2.816-1.664-3.968-2.816-0.384-0.32-0.512-0.768-0.832-1.088a33.472 33.472 0 0 1-9.408-22.848zM305.28 64a35.072 35.072 0 0 0-34.56 35.776v171.008H99.776A35.072 35.072 0 0 0 64 305.216c0 18.944 15.872 34.496 35.84 34.496h204.16l0.64-0.128a32.896 32.896 0 0 0 20.864-7.552c1.344-1.024 2.816-1.664 3.904-2.816 0.384-0.32 0.512-0.768 0.768-1.088a33.024 33.024 0 0 0 9.536-22.848l-0.128-0.64 0.128-0.704V99.712A35.008 35.008 0 0 0 305.216 64z m618.944 620.288h-204.16l-0.64 0.128-0.512-0.128c-7.808 0-14.72 3.2-20.48 7.68-1.28 1.024-2.752 1.664-3.84 2.752-0.384 0.32-0.512 0.768-0.832 1.088a33.664 33.664 0 0 0-9.408 22.912l0.128 0.64-0.128 0.704v204.288c0 19.712 15.552 35.904 34.496 35.712a35.072 35.072 0 0 0 34.56-35.776V753.28h170.944c19.648 0 35.84-15.488 35.712-34.432a35.072 35.072 0 0 0-35.84-34.496z m-593.92 11.52c-0.256-0.32-0.384-0.768-0.768-1.088-1.088-1.088-2.56-1.728-3.84-2.688a33.088 33.088 0 0 0-20.48-7.68l-0.512 0.064-0.64-0.128H99.84a35.072 35.072 0 0 0-35.84 34.496 35.072 35.072 0 0 0 35.712 34.432H270.72v171.008c0 19.84 15.552 35.84 34.56 35.776a35.008 35.008 0 0 0 34.432-35.712V720l-0.128-0.64 0.128-0.704a33.344 33.344 0 0 0-9.472-22.848zM512 374.144a137.92 137.92 0 1 0 0.128 275.84A137.92 137.92 0 0 0 512 374.08z\\\"></path>\\n </svg>\\n </li>\\n </ul>\\n \";\n },\n zoomSensitivity: 2\n };\n };\n\n ToolBar.prototype.init = function () {\n var _this = this;\n\n var graph = this.get('graph');\n var getContent = this.get('getContent');\n var toolBar = getContent(graph);\n var toolBarDOM = toolBar;\n\n if (isString(toolBar)) {\n toolBarDOM = createDom(toolBar);\n }\n\n var className = this.get('className');\n toolBarDOM.setAttribute('class', className || 'g6-component-toolbar');\n var container = this.get('container');\n\n if (!container) {\n container = this.get('graph').get('container');\n }\n\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n container.appendChild(toolBarDOM);\n this.set('toolBar', toolBarDOM);\n var handleClick = this.get('handleClick');\n toolBarDOM.addEventListener('click', function (evt) {\n var current = getEventPath(evt).filter(function (p) {\n return p.nodeName === 'LI';\n });\n\n if (current.length === 0) {\n return;\n }\n\n var code = current[0].getAttribute('code');\n\n if (!code) {\n return;\n }\n\n if (handleClick) {\n handleClick(code, graph);\n } else {\n _this.handleDefaultOperator(code, graph);\n }\n });\n var pos = this.get('position');\n\n if (pos) {\n modifyCSS(toolBarDOM, {\n top: pos.y + \"px\",\n left: pos.x + \"px\"\n });\n }\n\n this.bindUndoRedo();\n };\n\n ToolBar.prototype.bindUndoRedo = function () {\n var graph = this.get('graph');\n var undoDom = document.querySelector('.g6-component-toolbar li[code=\"undo\"]');\n var undoDomIcon = document.querySelector('.g6-component-toolbar li[code=\"undo\"] svg');\n var redoDom = document.querySelector('.g6-component-toolbar li[code=\"redo\"]');\n var redoDomIcon = document.querySelector('.g6-component-toolbar li[code=\"redo\"] svg');\n\n if (!undoDom || !undoDomIcon || !redoDom || !redoDomIcon) {\n return;\n }\n\n graph.on('stackchange', function (evt) {\n var undoStack = evt.undoStack,\n redoStack = evt.redoStack;\n var undoStackLen = undoStack.length;\n var redoStackLen = redoStack.length; // undo 不可用\n\n if (undoStackLen === 1) {\n undoDom.setAttribute('style', 'cursor: not-allowed');\n undoDomIcon.setAttribute('style', 'opacity: 0.4');\n } else {\n undoDom.removeAttribute('style');\n undoDomIcon.removeAttribute('style');\n } // redo 不可用\n\n\n if (redoStackLen === 0) {\n redoDom.setAttribute('style', 'cursor: not-allowed');\n redoDomIcon.setAttribute('style', 'opacity: 0.4');\n } else {\n redoDom.removeAttribute('style');\n redoDomIcon.removeAttribute('style');\n }\n });\n };\n /**\n * undo 操作\n */\n\n\n ToolBar.prototype.undo = function () {\n var graph = this.get('graph');\n var undoStack = graph.getUndoStack();\n\n if (!undoStack || undoStack.length === 1) {\n return;\n }\n\n var currentData = undoStack.pop();\n\n if (currentData) {\n var action = currentData.action;\n graph.pushStack(action, clone(currentData.data), 'redo');\n var data_1 = currentData.data.before;\n\n if (action === 'add') {\n data_1 = currentData.data.after;\n }\n\n if (!data_1) return;\n\n switch (action) {\n case 'visible':\n {\n Object.keys(data_1).forEach(function (key) {\n var array = data_1[key];\n if (!array) return;\n array.forEach(function (model) {\n var item = graph.findById(model.id);\n\n if (model.visible) {\n graph.showItem(item, false);\n } else {\n graph.hideItem(item, false);\n }\n });\n });\n break;\n }\n\n case 'render':\n case 'update':\n Object.keys(data_1).forEach(function (key) {\n var array = data_1[key];\n if (!array) return;\n array.forEach(function (model) {\n graph.updateItem(model.id, model, false);\n });\n });\n break;\n\n case 'changedata':\n graph.changeData(data_1, false);\n break;\n\n case 'delete':\n {\n Object.keys(data_1).forEach(function (key) {\n var array = data_1[key];\n if (!array) return;\n array.forEach(function (model) {\n var itemType = model.itemType;\n delete model.itemType;\n graph.addItem(itemType, model, false);\n });\n });\n break;\n }\n\n case 'add':\n Object.keys(data_1).forEach(function (key) {\n var array = data_1[key];\n if (!array) return;\n array.forEach(function (model) {\n graph.removeItem(model.id, false);\n });\n });\n break;\n\n case 'updateComboTree':\n Object.keys(data_1).forEach(function (key) {\n var array = data_1[key];\n if (!array) return;\n array.forEach(function (model) {\n graph.updateComboTree(model.id, model.parentId, false);\n });\n });\n break;\n\n default:\n }\n }\n };\n /**\n * redo 操作\n */\n\n\n ToolBar.prototype.redo = function () {\n var graph = this.get('graph');\n var redoStack = graph.getRedoStack();\n\n if (!redoStack || redoStack.length === 0) {\n return;\n }\n\n var currentData = redoStack.pop();\n\n if (currentData) {\n var action = currentData.action;\n var data_2 = currentData.data.after;\n graph.pushStack(action, clone(currentData.data));\n\n if (action === 'delete') {\n data_2 = currentData.data.before;\n }\n\n if (!data_2) return;\n\n switch (action) {\n case 'visible':\n {\n Object.keys(data_2).forEach(function (key) {\n var array = data_2[key];\n if (!array) return;\n array.forEach(function (model) {\n var item = graph.findById(model.id);\n\n if (model.visible) {\n graph.showItem(item, false);\n } else {\n graph.hideItem(item, false);\n }\n });\n });\n break;\n }\n\n case 'render':\n case 'update':\n Object.keys(data_2).forEach(function (key) {\n var array = data_2[key];\n if (!array) return;\n array.forEach(function (model) {\n graph.updateItem(model.id, model, false);\n });\n });\n break;\n\n case 'changedata':\n graph.changeData(data_2, false);\n break;\n\n case 'delete':\n if (data_2.edges) {\n data_2.edges.forEach(function (model) {\n graph.removeItem(model.id, false);\n });\n }\n\n if (data_2.nodes) {\n data_2.nodes.forEach(function (model) {\n graph.removeItem(model.id, false);\n });\n }\n\n if (data_2.combos) {\n data_2.combos.forEach(function (model) {\n graph.removeItem(model.id, false);\n });\n }\n\n break;\n\n case 'add':\n {\n Object.keys(data_2).forEach(function (key) {\n var array = data_2[key];\n if (!array) return;\n array.forEach(function (model) {\n var itemType = model.itemType;\n delete model.itemType;\n graph.addItem(itemType, model, false);\n });\n });\n break;\n }\n\n case 'updateComboTree':\n Object.keys(data_2).forEach(function (key) {\n var array = data_2[key];\n if (!array) return;\n array.forEach(function (model) {\n graph.updateComboTree(model.id, model.parentId, false);\n });\n });\n break;\n\n default:\n }\n }\n };\n /**\n * 根据 Toolbar 上不同类型对图进行操作\n * @param code 操作类型编码\n * @param graph Graph 实例\n */\n\n\n ToolBar.prototype.handleDefaultOperator = function (code, graph) {\n var currentZoom = graph.getZoom();\n\n switch (code) {\n case 'redo':\n this.redo();\n break;\n\n case 'undo':\n this.undo();\n break;\n\n case 'zoomOut':\n {\n var ratioOut = 1 / (1 - DELTA * this.get('zoomSensitivity'));\n var maxZoom = this.get('maxZoom') || graph.get('maxZoom');\n\n if (ratioOut * currentZoom > maxZoom) {\n return;\n }\n\n graph.zoomTo(currentZoom * ratioOut);\n break;\n }\n\n case 'zoomIn':\n {\n var ratioIn = 1 - DELTA * this.get('zoomSensitivity');\n var minZoom = this.get('minZoom') || graph.get('minZoom');\n\n if (ratioIn * currentZoom < minZoom) {\n return;\n }\n\n graph.zoomTo(currentZoom * ratioIn);\n break;\n }\n\n case 'realZoom':\n graph.zoomTo(1);\n break;\n\n case 'autoZoom':\n graph.fitView([20, 20]);\n break;\n\n default:\n }\n };\n\n ToolBar.prototype.destroy = function () {\n var toolBar = this.get('toolBar');\n\n if (toolBar) {\n var container = this.get('container');\n\n if (!container) {\n container = this.get('graph').get('container');\n }\n\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n container.removeChild(toolBar);\n }\n\n var handleClick = this.get('handleClick');\n\n if (handleClick) {\n toolBar.removeEventListener('click', handleClick);\n }\n };\n\n return ToolBar;\n}(Base);\n\nexport default ToolBar;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nimport { modifyCSS, createDom } from '@antv/dom-util';\nimport { isArray, isString } from '@antv/util';\nimport insertCss from 'insert-css';\nimport Base from '../base';\ntypeof document !== 'undefined' && insertCss(\"\\n .g6-component-tooltip {\\n border: 1px solid #e2e2e2;\\n border-radius: 4px;\\n font-size: 12px;\\n color: #545454;\\n background-color: rgba(255, 255, 255, 0.9);\\n padding: 10px 8px;\\n box-shadow: rgb(174, 174, 174) 0px 0px 10px;\\n }\\n .tooltip-type {\\n padding: 0;\\n margin: 0;\\n }\\n .tooltip-id {\\n color: #531dab;\\n }\\n\");\n\nvar Tooltip = function (_super) {\n __extends(Tooltip, _super);\n\n function Tooltip(config) {\n return _super.call(this, config) || this;\n }\n\n Tooltip.prototype.getDefaultCfgs = function () {\n return {\n offsetX: 6,\n offsetY: 6,\n // 指定菜单内容,function(e) {...}\n getContent: function getContent(e) {\n return \"\\n <h4 class='tooltip-type'>\\u7C7B\\u578B\\uFF1A\" + e.item.getType() + \"</h4>\\n <span class='tooltip-id'>ID\\uFF1A\" + e.item.getID() + \"</span>\\n \";\n },\n shouldBegin: function shouldBegin(e) {\n return true;\n },\n itemTypes: ['node', 'edge', 'combo'],\n trigger: 'mouseenter',\n fixToNode: undefined\n };\n }; // class-methods-use-this\n\n\n Tooltip.prototype.getEvents = function () {\n if (this.get('trigger') === 'click') {\n return {\n 'node:click': 'onClick',\n 'edge:click': 'onClick',\n 'combo:click': 'onClick',\n 'canvas:click': 'onMouseLeave',\n afterremoveitem: 'onMouseLeave',\n contextmenu: 'onMouseLeave',\n drag: 'onMouseLeave'\n };\n }\n\n return {\n 'node:mouseenter': 'onMouseEnter',\n 'node:mouseleave': 'onMouseLeave',\n 'node:mousemove': 'onMouseMove',\n 'edge:mouseenter': 'onMouseEnter',\n 'edge:mouseleave': 'onMouseLeave',\n 'edge:mousemove': 'onMouseMove',\n 'combo:mouseenter': 'onMouseEnter',\n 'combo:mouseleave': 'onMouseLeave',\n 'combo:mousemove': 'onMouseMove',\n afterremoveitem: 'onMouseLeave',\n contextmenu: 'onMouseLeave',\n 'node:drag': 'onMouseLeave'\n };\n };\n\n Tooltip.prototype.init = function () {\n var self = this;\n var className = self.get('className') || 'g6-component-tooltip';\n var tooltip = createDom(\"<div class=\" + className + \"></div>\");\n var container = self.get('container');\n\n if (!container) {\n container = self.get('graph').get('container');\n }\n\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n modifyCSS(tooltip, {\n position: 'absolute',\n visibility: 'hidden',\n display: 'none'\n });\n container.appendChild(tooltip);\n\n if (self.get('trigger') !== 'click') {\n tooltip.addEventListener('mouseenter', function (e) {\n modifyCSS(tooltip, {\n visibility: 'visible',\n display: 'unset'\n });\n });\n tooltip.addEventListener('mouseleave', function (e) {\n self.hideTooltip();\n });\n }\n\n self.set('tooltip', tooltip);\n };\n\n Tooltip.prototype.onClick = function (e) {\n var itemTypes = this.get('itemTypes');\n if (e.item && e.item.getType && itemTypes.indexOf(e.item.getType()) === -1) return;\n var item = e.item;\n var graph = this.get('graph'); // 若与上一次同一 item,隐藏该 tooltip\n\n if (this.currentTarget === item) {\n this.currentTarget = null;\n this.hideTooltip();\n graph.emit('tooltipchange', {\n item: e.item,\n action: 'hide'\n });\n } else {\n this.currentTarget = item;\n this.showTooltip(e);\n graph.emit('tooltipchange', {\n item: e.item,\n action: 'show'\n });\n }\n };\n\n Tooltip.prototype.onMouseEnter = function (e) {\n var itemTypes = this.get('itemTypes');\n if (e.item && e.item.getType && itemTypes.indexOf(e.item.getType()) === -1) return;\n var item = e.item;\n var graph = this.get('graph');\n this.currentTarget = item;\n this.showTooltip(e);\n graph.emit('tooltipchange', {\n item: e.item,\n action: 'show'\n });\n };\n\n Tooltip.prototype.onMouseMove = function (e) {\n var itemTypes = this.get('itemTypes');\n if (e.item && e.item.getType && itemTypes.indexOf(e.item.getType()) === -1) return;\n\n if (!this.currentTarget || e.item !== this.currentTarget) {\n return;\n }\n\n this.showTooltip(e);\n };\n\n Tooltip.prototype.onMouseLeave = function () {\n this.hideTooltip();\n var graph = this.get('graph');\n graph.emit('tooltipchange', {\n item: this.currentTarget,\n action: 'hide'\n });\n this.currentTarget = null;\n };\n\n Tooltip.prototype.showTooltip = function (e) {\n if (!e.item) {\n return;\n }\n\n var itemTypes = this.get('itemTypes');\n if (e.item.getType && itemTypes.indexOf(e.item.getType()) === -1) return;\n var container = this.get('tooltip');\n var getContent = this.get('getContent');\n var tooltip = getContent(e);\n\n if (isString(tooltip)) {\n container.innerHTML = tooltip;\n } else {\n container.innerHTML = tooltip.outerHTML;\n }\n\n this.updatePosition(e);\n };\n\n Tooltip.prototype.hideTooltip = function () {\n var tooltip = this.get('tooltip');\n\n if (tooltip) {\n modifyCSS(tooltip, {\n visibility: 'hidden',\n display: 'none'\n });\n }\n };\n\n Tooltip.prototype.updatePosition = function (e) {\n var shouldBegin = this.get('shouldBegin');\n var tooltip = this.get('tooltip');\n\n if (!shouldBegin(e)) {\n modifyCSS(tooltip, {\n visibility: 'hidden',\n display: 'none'\n });\n return;\n }\n\n var graph = this.get('graph');\n var width = graph.get('width');\n var height = graph.get('height');\n var offsetX = this.get('offsetX') || 0;\n var offsetY = this.get('offsetY') || 0; // const mousePos = graph.getPointByClient(e.clientX, e.clientY);\n\n var point = graph.getPointByClient(e.clientX, e.clientY);\n var fixToNode = this.get('fixToNode');\n var item = e.item;\n\n if (item.getType && item.getType() === 'node' && fixToNode && isArray(fixToNode) && fixToNode.length >= 2) {\n var itemBBox = item.getBBox();\n point = {\n x: itemBBox.minX + itemBBox.width * fixToNode[0],\n y: itemBBox.minY + itemBBox.height * fixToNode[1]\n };\n }\n\n var _a = graph.getCanvasByPoint(point.x, point.y),\n x = _a.x,\n y = _a.y;\n\n var graphContainer = graph.getContainer();\n var res = {\n x: x + graphContainer.offsetLeft + offsetX,\n y: y + graphContainer.offsetTop + offsetY\n }; // 先修改为 visible 方可正确计算 bbox\n\n modifyCSS(tooltip, {\n visibility: 'visible',\n display: 'unset'\n });\n var bbox = tooltip.getBoundingClientRect();\n\n if (x + bbox.width + offsetX > width) {\n res.x -= bbox.width + offsetX;\n }\n\n if (y + bbox.height + offsetY > height) {\n res.y -= bbox.height + offsetY;\n }\n\n modifyCSS(tooltip, {\n left: res.x + \"px\",\n top: res.y + \"px\"\n });\n };\n\n Tooltip.prototype.hide = function () {\n this.onMouseLeave();\n };\n\n Tooltip.prototype.destroy = function () {\n var tooltip = this.get('tooltip');\n\n if (tooltip) {\n var container = this.get('container');\n\n if (!container) {\n container = this.get('graph').get('container');\n }\n\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n container.removeChild(tooltip);\n }\n };\n\n return Tooltip;\n}(Base);\n\nexport default Tooltip;","var methodCache = {};\n/**\n * 获取计算 ticks 的方法\n * @param key 键值\n * @returns 计算 ticks 的方法\n */\nexport function getTickMethod(key) {\n return methodCache[key];\n}\n/**\n * 注册计算 ticks 的方法\n * @param key 键值\n * @param method 方法\n */\nexport function registerTickMethod(key, method) {\n methodCache[key] = method;\n}\n//# sourceMappingURL=register.js.map","import { assign, isEmpty, isFunction, isNil, isNumber, isObject, isString, map } from '@antv/util';\nimport { getTickMethod } from './tick-method/register';\nvar Scale = /** @class */ (function () {\n function Scale(cfg) {\n /**\n * 度量的类型\n */\n this.type = 'base';\n /**\n * 是否分类类型的度量\n */\n this.isCategory = false;\n /**\n * 是否线性度量,有linear, time 度量\n */\n this.isLinear = false;\n /**\n * 是否连续类型的度量,linear,time,log, pow, quantile, quantize 都支持\n */\n this.isContinuous = false;\n /**\n * 是否是常量的度量,传入和传出一致\n */\n this.isIdentity = false;\n this.values = [];\n this.range = [0, 1];\n this.ticks = [];\n this.__cfg__ = cfg;\n this.initCfg();\n this.init();\n }\n // 对于原始值的必要转换,如分类、时间字段需转换成数值,用transform/map命名可能更好\n Scale.prototype.translate = function (v) {\n return v;\n };\n /** 重新初始化 */\n Scale.prototype.change = function (cfg) {\n // 覆盖配置项,而不替代\n assign(this.__cfg__, cfg);\n this.init();\n };\n Scale.prototype.clone = function () {\n return this.constructor(this.__cfg__);\n };\n /** 获取坐标轴需要的ticks */\n Scale.prototype.getTicks = function () {\n var _this = this;\n return map(this.ticks, function (tick, idx) {\n if (isObject(tick)) {\n // 仅当符合Tick类型时才有意义\n return tick;\n }\n return {\n text: _this.getText(tick, idx),\n tickValue: tick,\n value: _this.scale(tick),\n };\n });\n };\n /** 获取Tick的格式化结果 */\n Scale.prototype.getText = function (value, key) {\n var formatter = this.formatter;\n var res = formatter ? formatter(value, key) : value;\n if (isNil(res) || !isFunction(res.toString)) {\n return '';\n }\n return res.toString();\n };\n // 获取配置项中的值,当前 scale 上的值可能会被修改\n Scale.prototype.getConfig = function (key) {\n return this.__cfg__[key];\n };\n // scale初始化\n Scale.prototype.init = function () {\n assign(this, this.__cfg__);\n this.setDomain();\n if (isEmpty(this.getConfig('ticks'))) {\n this.ticks = this.calculateTicks();\n }\n };\n // 子类上覆盖某些属性,不能直接在类上声明,否则会被覆盖\n Scale.prototype.initCfg = function () { };\n Scale.prototype.setDomain = function () { };\n Scale.prototype.calculateTicks = function () {\n var tickMethod = this.tickMethod;\n var ticks = [];\n if (isString(tickMethod)) {\n var method = getTickMethod(tickMethod);\n if (!method) {\n throw new Error('There is no method to to calculate ticks!');\n }\n ticks = method(this);\n }\n else if (isFunction(tickMethod)) {\n ticks = tickMethod(this);\n }\n return ticks;\n };\n // range 的最小值\n Scale.prototype.rangeMin = function () {\n return this.range[0];\n };\n // range 的最大值\n Scale.prototype.rangeMax = function () {\n return this.range[1];\n };\n /** 定义域转 0~1 */\n Scale.prototype.calcPercent = function (value, min, max) {\n if (isNumber(value)) {\n return (value - min) / (max - min);\n }\n return NaN;\n };\n /** 0~1转定义域 */\n Scale.prototype.calcValue = function (percent, min, max) {\n return min + percent * (max - min);\n };\n return Scale;\n}());\nexport default Scale;\n//# sourceMappingURL=base.js.map","import { __extends, __spreadArrays } from \"tslib\";\nimport { isNil, isNumber } from '@antv/util';\nimport Base from '../base';\n/**\n * 分类度量\n * @class\n */\nvar Category = /** @class */ (function (_super) {\n __extends(Category, _super);\n function Category() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'cat';\n _this.isCategory = true;\n return _this;\n }\n Category.prototype.buildIndexMap = function () {\n if (!this.translateIndexMap) {\n this.translateIndexMap = new Map();\n // 重新构建缓存\n for (var i = 0; i < this.values.length; i++) {\n this.translateIndexMap.set(this.values[i], i);\n }\n }\n };\n Category.prototype.translate = function (value) {\n // 按需构建 map\n this.buildIndexMap();\n // 找得到\n var idx = this.translateIndexMap.get(value);\n if (idx === undefined) {\n idx = isNumber(value) ? value : NaN;\n }\n return idx;\n };\n Category.prototype.scale = function (value) {\n var order = this.translate(value);\n // 分类数据允许 0.5 范围内调整\n // if (order < this.min - 0.5 || order > this.max + 0.5) {\n // return NaN;\n // }\n var percent = this.calcPercent(order, this.min, this.max);\n return this.calcValue(percent, this.rangeMin(), this.rangeMax());\n };\n Category.prototype.invert = function (scaledValue) {\n var domainRange = this.max - this.min;\n var percent = this.calcPercent(scaledValue, this.rangeMin(), this.rangeMax());\n var idx = Math.round(domainRange * percent) + this.min;\n if (idx < this.min || idx > this.max) {\n return NaN;\n }\n return this.values[idx];\n };\n Category.prototype.getText = function (value) {\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n var v = value;\n // value为index\n if (isNumber(value) && !this.values.includes(value)) {\n v = this.values[v];\n }\n return _super.prototype.getText.apply(this, __spreadArrays([v], args));\n };\n // 复写属性\n Category.prototype.initCfg = function () {\n this.tickMethod = 'cat';\n };\n // 设置 min, max\n Category.prototype.setDomain = function () {\n // 用户有可能设置 min\n if (isNil(this.getConfig('min'))) {\n this.min = 0;\n }\n if (isNil(this.getConfig('max'))) {\n var size = this.values.length;\n this.max = size > 1 ? size - 1 : size;\n }\n // scale.init 的时候清除缓存\n if (this.translateIndexMap) {\n this.translateIndexMap = undefined;\n }\n };\n return Category;\n}(Base));\nexport default Category;\n//# sourceMappingURL=base.js.map","const token = /d{1,4}|M{1,4}|YY(?:YY)?|S{1,3}|Do|ZZ|Z|([HhMsDm])\\1?|[aA]|\"[^\"]*\"|'[^']*'/g;\nconst twoDigitsOptional = \"[1-9]\\\\d?\";\nconst twoDigits = \"\\\\d\\\\d\";\nconst threeDigits = \"\\\\d{3}\";\nconst fourDigits = \"\\\\d{4}\";\nconst word = \"[^\\\\s]+\";\nconst literal = /\\[([^]*?)\\]/gm;\n\ntype DateInfo = {\n year: number;\n month: number;\n day: number;\n hour: number;\n minute: number;\n second: number;\n millisecond: number;\n isPm: number | null;\n timezoneOffset: number | null;\n};\n\nexport type I18nSettings = {\n amPm: [string, string];\n dayNames: Days;\n dayNamesShort: Days;\n monthNames: Months;\n monthNamesShort: Months;\n DoFn(dayOfMonth: number): string;\n};\n\nexport type I18nSettingsOptional = Partial<I18nSettings>;\n\nexport type Days = [string, string, string, string, string, string, string];\nexport type Months = [\n string,\n string,\n string,\n string,\n string,\n string,\n string,\n string,\n string,\n string,\n string,\n string\n];\n\nfunction shorten<T extends string[]>(arr: T, sLen: number): string[] {\n const newArr: string[] = [];\n for (let i = 0, len = arr.length; i < len; i++) {\n newArr.push(arr[i].substr(0, sLen));\n }\n return newArr;\n}\n\nconst monthUpdate = (\n arrName: \"monthNames\" | \"monthNamesShort\" | \"dayNames\" | \"dayNamesShort\"\n) => (v: string, i18n: I18nSettings): number | null => {\n const lowerCaseArr = i18n[arrName].map(v => v.toLowerCase());\n const index = lowerCaseArr.indexOf(v.toLowerCase());\n if (index > -1) {\n return index;\n }\n return null;\n};\n\nexport function assign<A>(a: A): A;\nexport function assign<A, B>(a: A, b: B): A & B;\nexport function assign<A, B, C>(a: A, b: B, c: C): A & B & C;\nexport function assign<A, B, C, D>(a: A, b: B, c: C, d: D): A & B & C & D;\nexport function assign(origObj: any, ...args: any[]): any {\n for (const obj of args) {\n for (const key in obj) {\n // @ts-ignore ex\n origObj[key] = obj[key];\n }\n }\n return origObj;\n}\n\nconst dayNames: Days = [\n \"Sunday\",\n \"Monday\",\n \"Tuesday\",\n \"Wednesday\",\n \"Thursday\",\n \"Friday\",\n \"Saturday\"\n];\nconst monthNames: Months = [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\"\n];\n\nconst monthNamesShort: Months = shorten(monthNames, 3) as Months;\nconst dayNamesShort: Days = shorten(dayNames, 3) as Days;\n\nconst defaultI18n: I18nSettings = {\n dayNamesShort,\n dayNames,\n monthNamesShort,\n monthNames,\n amPm: [\"am\", \"pm\"],\n DoFn(dayOfMonth: number) {\n return (\n dayOfMonth +\n [\"th\", \"st\", \"nd\", \"rd\"][\n dayOfMonth % 10 > 3\n ? 0\n : ((dayOfMonth - (dayOfMonth % 10) !== 10 ? 1 : 0) * dayOfMonth) % 10\n ]\n );\n }\n};\nlet globalI18n = assign({}, defaultI18n);\nconst setGlobalDateI18n = (i18n: I18nSettingsOptional): I18nSettings =>\n (globalI18n = assign(globalI18n, i18n));\n\nconst regexEscape = (str: string): string =>\n str.replace(/[|\\\\{()[^$+*?.-]/g, \"\\\\$&\");\n\nconst pad = (val: string | number, len = 2): string => {\n val = String(val);\n while (val.length < len) {\n val = \"0\" + val;\n }\n return val;\n};\n\nconst formatFlags: Record<\n string,\n (dateObj: Date, i18n: I18nSettings) => string\n> = {\n D: (dateObj: Date): string => String(dateObj.getDate()),\n DD: (dateObj: Date): string => pad(dateObj.getDate()),\n Do: (dateObj: Date, i18n: I18nSettings): string =>\n i18n.DoFn(dateObj.getDate()),\n d: (dateObj: Date): string => String(dateObj.getDay()),\n dd: (dateObj: Date): string => pad(dateObj.getDay()),\n ddd: (dateObj: Date, i18n: I18nSettings): string =>\n i18n.dayNamesShort[dateObj.getDay()],\n dddd: (dateObj: Date, i18n: I18nSettings): string =>\n i18n.dayNames[dateObj.getDay()],\n M: (dateObj: Date): string => String(dateObj.getMonth() + 1),\n MM: (dateObj: Date): string => pad(dateObj.getMonth() + 1),\n MMM: (dateObj: Date, i18n: I18nSettings): string =>\n i18n.monthNamesShort[dateObj.getMonth()],\n MMMM: (dateObj: Date, i18n: I18nSettings): string =>\n i18n.monthNames[dateObj.getMonth()],\n YY: (dateObj: Date): string =>\n pad(String(dateObj.getFullYear()), 4).substr(2),\n YYYY: (dateObj: Date): string => pad(dateObj.getFullYear(), 4),\n h: (dateObj: Date): string => String(dateObj.getHours() % 12 || 12),\n hh: (dateObj: Date): string => pad(dateObj.getHours() % 12 || 12),\n H: (dateObj: Date): string => String(dateObj.getHours()),\n HH: (dateObj: Date): string => pad(dateObj.getHours()),\n m: (dateObj: Date): string => String(dateObj.getMinutes()),\n mm: (dateObj: Date): string => pad(dateObj.getMinutes()),\n s: (dateObj: Date): string => String(dateObj.getSeconds()),\n ss: (dateObj: Date): string => pad(dateObj.getSeconds()),\n S: (dateObj: Date): string =>\n String(Math.round(dateObj.getMilliseconds() / 100)),\n SS: (dateObj: Date): string =>\n pad(Math.round(dateObj.getMilliseconds() / 10), 2),\n SSS: (dateObj: Date): string => pad(dateObj.getMilliseconds(), 3),\n a: (dateObj: Date, i18n: I18nSettings): string =>\n dateObj.getHours() < 12 ? i18n.amPm[0] : i18n.amPm[1],\n A: (dateObj: Date, i18n: I18nSettings): string =>\n dateObj.getHours() < 12\n ? i18n.amPm[0].toUpperCase()\n : i18n.amPm[1].toUpperCase(),\n ZZ(dateObj: Date): string {\n const offset = dateObj.getTimezoneOffset();\n return (\n (offset > 0 ? \"-\" : \"+\") +\n pad(Math.floor(Math.abs(offset) / 60) * 100 + (Math.abs(offset) % 60), 4)\n );\n },\n Z(dateObj: Date): string {\n const offset = dateObj.getTimezoneOffset();\n return (\n (offset > 0 ? \"-\" : \"+\") +\n pad(Math.floor(Math.abs(offset) / 60), 2) +\n \":\" +\n pad(Math.abs(offset) % 60, 2)\n );\n }\n};\n\ntype ParseInfo = [\n keyof DateInfo,\n string,\n ((v: string, i18n: I18nSettings) => number | null)?,\n string?\n];\nconst monthParse = (v: string): number => +v - 1;\nconst emptyDigits: ParseInfo = [null, twoDigitsOptional];\nconst emptyWord: ParseInfo = [null, word];\nconst amPm: ParseInfo = [\n \"isPm\",\n word,\n (v: string, i18n: I18nSettings): number | null => {\n const val = v.toLowerCase();\n if (val === i18n.amPm[0]) {\n return 0;\n } else if (val === i18n.amPm[1]) {\n return 1;\n }\n return null;\n }\n];\nconst timezoneOffset: ParseInfo = [\n \"timezoneOffset\",\n \"[^\\\\s]*?[\\\\+\\\\-]\\\\d\\\\d:?\\\\d\\\\d|[^\\\\s]*?Z?\",\n (v: string): number | null => {\n const parts = (v + \"\").match(/([+-]|\\d\\d)/gi);\n\n if (parts) {\n const minutes = +parts[1] * 60 + parseInt(parts[2], 10);\n return parts[0] === \"+\" ? minutes : -minutes;\n }\n\n return 0;\n }\n];\nconst parseFlags: Record<string, ParseInfo> = {\n D: [\"day\", twoDigitsOptional],\n DD: [\"day\", twoDigits],\n Do: [\"day\", twoDigitsOptional + word, (v: string): number => parseInt(v, 10)],\n M: [\"month\", twoDigitsOptional, monthParse],\n MM: [\"month\", twoDigits, monthParse],\n YY: [\n \"year\",\n twoDigits,\n (v: string): number => {\n const now = new Date();\n const cent = +(\"\" + now.getFullYear()).substr(0, 2);\n return +(\"\" + (+v > 68 ? cent - 1 : cent) + v);\n }\n ],\n h: [\"hour\", twoDigitsOptional, undefined, \"isPm\"],\n hh: [\"hour\", twoDigits, undefined, \"isPm\"],\n H: [\"hour\", twoDigitsOptional],\n HH: [\"hour\", twoDigits],\n m: [\"minute\", twoDigitsOptional],\n mm: [\"minute\", twoDigits],\n s: [\"second\", twoDigitsOptional],\n ss: [\"second\", twoDigits],\n YYYY: [\"year\", fourDigits],\n S: [\"millisecond\", \"\\\\d\", (v: string): number => +v * 100],\n SS: [\"millisecond\", twoDigits, (v: string): number => +v * 10],\n SSS: [\"millisecond\", threeDigits],\n d: emptyDigits,\n dd: emptyDigits,\n ddd: emptyWord,\n dddd: emptyWord,\n MMM: [\"month\", word, monthUpdate(\"monthNamesShort\")],\n MMMM: [\"month\", word, monthUpdate(\"monthNames\")],\n a: amPm,\n A: amPm,\n ZZ: timezoneOffset,\n Z: timezoneOffset\n};\n\n// Some common format strings\nconst globalMasks: { [key: string]: string } = {\n default: \"ddd MMM DD YYYY HH:mm:ss\",\n shortDate: \"M/D/YY\",\n mediumDate: \"MMM D, YYYY\",\n longDate: \"MMMM D, YYYY\",\n fullDate: \"dddd, MMMM D, YYYY\",\n isoDate: \"YYYY-MM-DD\",\n isoDateTime: \"YYYY-MM-DDTHH:mm:ssZ\",\n shortTime: \"HH:mm\",\n mediumTime: \"HH:mm:ss\",\n longTime: \"HH:mm:ss.SSS\"\n};\nconst setGlobalDateMasks = (masks: {\n [key: string]: string;\n}): { [key: string]: string } => assign(globalMasks, masks);\n\n/***\n * Format a date\n * @method format\n * @param {Date|number} dateObj\n * @param {string} mask Format of the date, i.e. 'mm-dd-yy' or 'shortDate'\n * @returns {string} Formatted date string\n */\nconst format = (\n dateObj: Date,\n mask: string = globalMasks[\"default\"],\n i18n: I18nSettingsOptional = {}\n): string => {\n if (typeof dateObj === \"number\") {\n dateObj = new Date(dateObj);\n }\n\n if (\n Object.prototype.toString.call(dateObj) !== \"[object Date]\" ||\n isNaN(dateObj.getTime())\n ) {\n throw new Error(\"Invalid Date pass to format\");\n }\n\n mask = globalMasks[mask] || mask;\n\n const literals: string[] = [];\n\n // Make literals inactive by replacing them with @@@\n mask = mask.replace(literal, function($0, $1) {\n literals.push($1);\n return \"@@@\";\n });\n\n const combinedI18nSettings: I18nSettings = assign(\n assign({}, globalI18n),\n i18n\n );\n // Apply formatting rules\n mask = mask.replace(token, $0 =>\n formatFlags[$0](dateObj, combinedI18nSettings)\n );\n // Inline literal values back into the formatted value\n return mask.replace(/@@@/g, () => literals.shift());\n};\n\n/**\n * Parse a date string into a Javascript Date object /\n * @method parse\n * @param {string} dateStr Date string\n * @param {string} format Date parse format\n * @param {i18n} I18nSettingsOptional Full or subset of I18N settings\n * @returns {Date|null} Returns Date object. Returns null what date string is invalid or doesn't match format\n */\nfunction parse(\n dateStr: string,\n format: string,\n i18n: I18nSettingsOptional = {}\n): Date | null {\n if (typeof format !== \"string\") {\n throw new Error(\"Invalid format in fecha parse\");\n }\n\n // Check to see if the format is actually a mask\n format = globalMasks[format] || format;\n\n // Avoid regular expression denial of service, fail early for really long strings\n // https://www.owasp.org/index.php/Regular_expression_Denial_of_Service_-_ReDoS\n if (dateStr.length > 1000) {\n return null;\n }\n\n // Default to the beginning of the year.\n const today = new Date();\n const dateInfo: DateInfo = {\n year: today.getFullYear(),\n month: 0,\n day: 1,\n hour: 0,\n minute: 0,\n second: 0,\n millisecond: 0,\n isPm: null,\n timezoneOffset: null\n };\n const parseInfo: ParseInfo[] = [];\n const literals: string[] = [];\n\n // Replace all the literals with @@@. Hopefully a string that won't exist in the format\n let newFormat = format.replace(literal, ($0, $1) => {\n literals.push(regexEscape($1));\n return \"@@@\";\n });\n const specifiedFields: { [field: string]: boolean } = {};\n const requiredFields: { [field: string]: boolean } = {};\n\n // Change every token that we find into the correct regex\n newFormat = regexEscape(newFormat).replace(token, $0 => {\n const info = parseFlags[$0];\n const [field, regex, , requiredField] = info;\n\n // Check if the person has specified the same field twice. This will lead to confusing results.\n if (specifiedFields[field]) {\n throw new Error(`Invalid format. ${field} specified twice in format`);\n }\n\n specifiedFields[field] = true;\n\n // Check if there are any required fields. For instance, 12 hour time requires AM/PM specified\n if (requiredField) {\n requiredFields[requiredField] = true;\n }\n\n parseInfo.push(info);\n return \"(\" + regex + \")\";\n });\n\n // Check all the required fields are present\n Object.keys(requiredFields).forEach(field => {\n if (!specifiedFields[field]) {\n throw new Error(\n `Invalid format. ${field} is required in specified format`\n );\n }\n });\n\n // Add back all the literals after\n newFormat = newFormat.replace(/@@@/g, () => literals.shift());\n\n // Check if the date string matches the format. If it doesn't return null\n const matches = dateStr.match(new RegExp(newFormat, \"i\"));\n if (!matches) {\n return null;\n }\n\n const combinedI18nSettings: I18nSettings = assign(\n assign({}, globalI18n),\n i18n\n );\n\n // For each match, call the parser function for that date part\n for (let i = 1; i < matches.length; i++) {\n const [field, , parser] = parseInfo[i - 1];\n const value = parser\n ? parser(matches[i], combinedI18nSettings)\n : +matches[i];\n\n // If the parser can't make sense of the value, return null\n if (value == null) {\n return null;\n }\n\n dateInfo[field] = value;\n }\n\n if (dateInfo.isPm === 1 && dateInfo.hour != null && +dateInfo.hour !== 12) {\n dateInfo.hour = +dateInfo.hour + 12;\n } else if (dateInfo.isPm === 0 && +dateInfo.hour === 12) {\n dateInfo.hour = 0;\n }\n\n const dateWithoutTZ: Date = new Date(\n dateInfo.year,\n dateInfo.month,\n dateInfo.day,\n dateInfo.hour,\n dateInfo.minute,\n dateInfo.second,\n dateInfo.millisecond\n );\n\n const validateFields: [\n \"month\" | \"day\" | \"hour\" | \"minute\" | \"second\",\n \"getMonth\" | \"getDate\" | \"getHours\" | \"getMinutes\" | \"getSeconds\"\n ][] = [\n [\"month\", \"getMonth\"],\n [\"day\", \"getDate\"],\n [\"hour\", \"getHours\"],\n [\"minute\", \"getMinutes\"],\n [\"second\", \"getSeconds\"]\n ];\n for (let i = 0, len = validateFields.length; i < len; i++) {\n // Check to make sure the date field is within the allowed range. Javascript dates allows values\n // outside the allowed range. If the values don't match the value was invalid\n if (\n specifiedFields[validateFields[i][0]] &&\n dateInfo[validateFields[i][0]] !== dateWithoutTZ[validateFields[i][1]]()\n ) {\n return null;\n }\n }\n\n if (dateInfo.timezoneOffset == null) {\n return dateWithoutTZ;\n }\n\n return new Date(\n Date.UTC(\n dateInfo.year,\n dateInfo.month,\n dateInfo.day,\n dateInfo.hour,\n dateInfo.minute - dateInfo.timezoneOffset,\n dateInfo.second,\n dateInfo.millisecond\n )\n );\n}\nexport default {\n format,\n parse,\n defaultI18n,\n setGlobalDateI18n,\n setGlobalDateMasks\n};\nexport { format, parse, defaultI18n, setGlobalDateI18n, setGlobalDateMasks };\n","import { isDate, isString, last } from '@antv/util';\nimport fecha from 'fecha';\nimport * as fecha1 from 'fecha';\nimport bisector from './bisector';\nvar FORMAT_METHOD = 'format';\nexport function timeFormat(time, mask) {\n var method = fecha1[FORMAT_METHOD] || fecha[FORMAT_METHOD];\n return method(time, mask);\n}\n/**\n * 转换成时间戳\n * @param value 时间值\n */\nexport function toTimeStamp(value) {\n if (isString(value)) {\n if (value.indexOf('T') > 0) {\n value = new Date(value).getTime();\n }\n else {\n // new Date('2010/01/10') 和 new Date('2010-01-10') 的差别在于:\n // 如果仅有年月日时,前者是带有时区的: Fri Jan 10 2020 02:40:13 GMT+0800 (中国标准时间)\n // 后者会格式化成 Sun Jan 10 2010 08:00:00 GMT+0800 (中国标准时间)\n value = new Date(value.replace(/-/gi, '/')).getTime();\n }\n }\n if (isDate(value)) {\n value = value.getTime();\n }\n return value;\n}\nvar SECOND = 1000;\nvar MINUTE = 60 * SECOND;\nvar HOUR = 60 * MINUTE;\nvar DAY = 24 * HOUR;\nvar MONTH = DAY * 31;\nvar YEAR = DAY * 365;\nexport { SECOND, MINUTE, HOUR, DAY, MONTH, YEAR };\nvar intervals = [\n ['HH:mm:ss', SECOND],\n ['HH:mm:ss', SECOND * 10],\n ['HH:mm:ss', SECOND * 30],\n ['HH:mm', MINUTE],\n ['HH:mm', MINUTE * 10],\n ['HH:mm', MINUTE * 30],\n ['HH', HOUR],\n ['HH', HOUR * 6],\n ['HH', HOUR * 12],\n ['YYYY-MM-DD', DAY],\n ['YYYY-MM-DD', DAY * 4],\n ['YYYY-WW', DAY * 7],\n ['YYYY-MM', MONTH],\n ['YYYY-MM', MONTH * 4],\n ['YYYY-MM', MONTH * 6],\n ['YYYY', DAY * 380],\n];\nexport function getTickInterval(min, max, tickCount) {\n var target = (max - min) / tickCount;\n var idx = bisector(function (o) { return o[1]; })(intervals, target) - 1;\n var interval = intervals[idx];\n if (idx < 0) {\n interval = intervals[0];\n }\n else if (idx >= intervals.length) {\n interval = last(intervals);\n }\n return interval;\n}\n//# sourceMappingURL=time.js.map","import { isNil } from '@antv/util';\n/**\n * 二分右侧查找\n * https://github.com/d3/d3-array/blob/master/src/bisector.js\n */\nexport default function (getter) {\n /**\n * x: 目标值\n * lo: 起始位置\n * hi: 结束位置\n */\n return function (a, x, _lo, _hi) {\n var lo = isNil(_lo) ? 0 : _lo;\n var hi = isNil(_hi) ? a.length : _hi;\n while (lo < hi) {\n var mid = (lo + hi) >>> 1;\n if (getter(a[mid]) > x) {\n hi = mid;\n }\n else {\n lo = mid + 1;\n }\n }\n return lo;\n };\n}\n//# sourceMappingURL=bisector.js.map","import { __extends } from \"tslib\";\nimport { each, isNumber } from '@antv/util';\nimport { timeFormat, toTimeStamp } from '../util/time';\nimport Category from './base';\n/**\n * 时间分类度量\n * @class\n */\nvar TimeCat = /** @class */ (function (_super) {\n __extends(TimeCat, _super);\n function TimeCat() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'timeCat';\n return _this;\n }\n /**\n * @override\n */\n TimeCat.prototype.translate = function (value) {\n value = toTimeStamp(value);\n var index = this.values.indexOf(value);\n if (index === -1) {\n if (isNumber(value) && value < this.values.length) {\n index = value;\n }\n else {\n index = NaN;\n }\n }\n return index;\n };\n /**\n * 由于时间类型数据需要转换一下,所以复写 getText\n * @override\n */\n TimeCat.prototype.getText = function (value, tickIndex) {\n var index = this.translate(value);\n if (index > -1) {\n var result = this.values[index];\n var formatter = this.formatter;\n result = formatter ? formatter(result, tickIndex) : timeFormat(result, this.mask);\n return result;\n }\n return value;\n };\n TimeCat.prototype.initCfg = function () {\n this.tickMethod = 'time-cat';\n this.mask = 'YYYY-MM-DD';\n this.tickCount = 7; // 一般时间数据会显示 7, 14, 30 天的数字\n };\n TimeCat.prototype.setDomain = function () {\n var values = this.values;\n // 针对时间分类类型,会将时间统一转换为时间戳\n each(values, function (v, i) {\n values[i] = toTimeStamp(v);\n });\n values.sort(function (v1, v2) {\n return v1 - v2;\n });\n _super.prototype.setDomain.call(this);\n };\n return TimeCat;\n}(Category));\nexport default TimeCat;\n//# sourceMappingURL=time.js.map","import { __extends } from \"tslib\";\nimport { filter, getRange, head, isNil, last } from '@antv/util';\nimport Base from '../base';\n/**\n * 连续度量的基类\n * @class\n */\nvar Continuous = /** @class */ (function (_super) {\n __extends(Continuous, _super);\n function Continuous() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.isContinuous = true;\n return _this;\n }\n Continuous.prototype.scale = function (value) {\n if (isNil(value)) {\n return NaN;\n }\n var rangeMin = this.rangeMin();\n var rangeMax = this.rangeMax();\n var max = this.max;\n var min = this.min;\n if (max === min) {\n return rangeMin;\n }\n var percent = this.getScalePercent(value);\n return rangeMin + percent * (rangeMax - rangeMin);\n };\n Continuous.prototype.init = function () {\n _super.prototype.init.call(this);\n // init 完成后保证 min, max 包含 ticks 的范围\n var ticks = this.ticks;\n var firstTick = head(ticks);\n var lastTick = last(ticks);\n if (firstTick < this.min) {\n this.min = firstTick;\n }\n if (lastTick > this.max) {\n this.max = lastTick;\n }\n // strict-limit 方式\n if (!isNil(this.minLimit)) {\n this.min = firstTick;\n }\n if (!isNil(this.maxLimit)) {\n this.max = lastTick;\n }\n };\n Continuous.prototype.setDomain = function () {\n var _a = getRange(this.values), min = _a.min, max = _a.max;\n if (isNil(this.min)) {\n this.min = min;\n }\n if (isNil(this.max)) {\n this.max = max;\n }\n if (this.min > this.max) {\n this.min = min;\n this.max = max;\n }\n };\n Continuous.prototype.calculateTicks = function () {\n var _this = this;\n var ticks = _super.prototype.calculateTicks.call(this);\n if (!this.nice) {\n ticks = filter(ticks, function (tick) {\n return tick >= _this.min && tick <= _this.max;\n });\n }\n return ticks;\n };\n // 计算原始值值占的百分比\n Continuous.prototype.getScalePercent = function (value) {\n var max = this.max;\n var min = this.min;\n return (value - min) / (max - min);\n };\n Continuous.prototype.getInvertPercent = function (value) {\n return (value - this.rangeMin()) / (this.rangeMax() - this.rangeMin());\n };\n return Continuous;\n}(Base));\nexport default Continuous;\n//# sourceMappingURL=base.js.map","import { __extends } from \"tslib\";\nimport Continuous from './base';\n/**\n * 线性度量\n * @class\n */\nvar Linear = /** @class */ (function (_super) {\n __extends(Linear, _super);\n function Linear() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'linear';\n _this.isLinear = true;\n return _this;\n }\n Linear.prototype.invert = function (value) {\n var percent = this.getInvertPercent(value);\n return this.min + percent * (this.max - this.min);\n };\n Linear.prototype.initCfg = function () {\n this.tickMethod = 'wilkinson-extended';\n this.nice = false;\n };\n return Linear;\n}(Continuous));\nexport default Linear;\n//# sourceMappingURL=linear.js.map","import { __extends } from \"tslib\";\nimport { getLogPositiveMin, log } from '../util/math';\nimport Continuous from './base';\n/**\n * Log 度量,处理非均匀分布\n */\nvar Log = /** @class */ (function (_super) {\n __extends(Log, _super);\n function Log() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'log';\n return _this;\n }\n /**\n * @override\n */\n Log.prototype.invert = function (value) {\n var base = this.base;\n var max = log(base, this.max);\n var rangeMin = this.rangeMin();\n var range = this.rangeMax() - rangeMin;\n var min;\n var positiveMin = this.positiveMin;\n if (positiveMin) {\n if (value === 0) {\n return 0;\n }\n min = log(base, positiveMin / base);\n var appendPercent = (1 / (max - min)) * range; // 0 到 positiveMin的占比\n if (value < appendPercent) {\n // 落到 0 - positiveMin 之间\n return (value / appendPercent) * positiveMin;\n }\n }\n else {\n min = log(base, this.min);\n }\n var percent = (value - rangeMin) / range;\n var tmp = percent * (max - min) + min;\n return Math.pow(base, tmp);\n };\n Log.prototype.initCfg = function () {\n this.tickMethod = 'log';\n this.base = 10;\n this.tickCount = 6;\n this.nice = true;\n };\n // 设置\n Log.prototype.setDomain = function () {\n _super.prototype.setDomain.call(this);\n var min = this.min;\n if (min < 0) {\n throw new Error('When you use log scale, the minimum value must be greater than zero!');\n }\n if (min === 0) {\n this.positiveMin = getLogPositiveMin(this.values, this.base, this.max);\n }\n };\n // 根据当前值获取占比\n Log.prototype.getScalePercent = function (value) {\n var max = this.max;\n var min = this.min;\n if (max === min) {\n return 0;\n }\n // 如果值小于等于0,则按照0处理\n if (value <= 0) {\n return 0;\n }\n var base = this.base;\n var positiveMin = this.positiveMin;\n // 如果min == 0, 则根据比0大的最小值,计算比例关系。这个最小值作为坐标轴上的第二个tick,第一个是0但是不显示\n if (positiveMin) {\n min = (positiveMin * 1) / base;\n }\n var percent;\n // 如果数值小于次小值,那么就计算 value / 次小值 占整体的比例\n if (value < positiveMin) {\n percent = value / positiveMin / (log(base, max) - log(base, min));\n }\n else {\n percent = (log(base, value) - log(base, min)) / (log(base, max) - log(base, min));\n }\n return percent;\n };\n return Log;\n}(Continuous));\nexport default Log;\n//# sourceMappingURL=log.js.map","import { __extends } from \"tslib\";\nimport { calBase } from '../util/math';\nimport Continuous from './base';\n/**\n * Pow 度量,处理非均匀分布\n */\nvar Pow = /** @class */ (function (_super) {\n __extends(Pow, _super);\n function Pow() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'pow';\n return _this;\n }\n /**\n * @override\n */\n Pow.prototype.invert = function (value) {\n var percent = this.getInvertPercent(value);\n var exponent = this.exponent;\n var max = calBase(exponent, this.max);\n var min = calBase(exponent, this.min);\n var tmp = percent * (max - min) + min;\n var factor = tmp >= 0 ? 1 : -1;\n return Math.pow(tmp, exponent) * factor;\n };\n Pow.prototype.initCfg = function () {\n this.tickMethod = 'pow';\n this.exponent = 2;\n this.tickCount = 5;\n this.nice = true;\n };\n // 获取度量计算时,value占的定义域百分比\n Pow.prototype.getScalePercent = function (value) {\n var max = this.max;\n var min = this.min;\n if (max === min) {\n return 0;\n }\n var exponent = this.exponent;\n var percent = (calBase(exponent, value) - calBase(exponent, min)) / (calBase(exponent, max) - calBase(exponent, min));\n return percent;\n };\n return Pow;\n}(Continuous));\nexport default Pow;\n//# sourceMappingURL=pow.js.map","import { __extends } from \"tslib\";\nimport { each, isDate, isNil, isNumber, isString } from '@antv/util';\nimport { timeFormat, toTimeStamp } from '../util/time';\nimport Linear from './linear';\n/**\n * 时间度量\n * @class\n */\nvar Time = /** @class */ (function (_super) {\n __extends(Time, _super);\n function Time() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'time';\n return _this;\n }\n /**\n * @override\n */\n Time.prototype.getText = function (value, index) {\n var numberValue = this.translate(value);\n var formatter = this.formatter;\n return formatter ? formatter(numberValue, index) : timeFormat(numberValue, this.mask);\n };\n /**\n * @override\n */\n Time.prototype.scale = function (value) {\n var v = value;\n if (isString(v) || isDate(v)) {\n v = this.translate(v);\n }\n return _super.prototype.scale.call(this, v);\n };\n /**\n * 将时间转换成数字\n * @override\n */\n Time.prototype.translate = function (v) {\n return toTimeStamp(v);\n };\n Time.prototype.initCfg = function () {\n this.tickMethod = 'time-pretty';\n this.mask = 'YYYY-MM-DD';\n this.tickCount = 7;\n this.nice = false;\n };\n Time.prototype.setDomain = function () {\n var values = this.values;\n // 是否设置了 min, max,而不是直接取 this.min, this.max\n var minConfig = this.getConfig('min');\n var maxConfig = this.getConfig('max');\n // 如果设置了 min,max 则转换成时间戳\n if (!isNil(minConfig) || !isNumber(minConfig)) {\n this.min = this.translate(this.min);\n }\n if (!isNil(maxConfig) || !isNumber(maxConfig)) {\n this.max = this.translate(this.max);\n }\n // 没有设置 min, max 时\n if (values && values.length) {\n // 重新计算最大最小值\n var timeStamps_1 = [];\n var min_1 = Infinity; // 最小值\n var secondMin_1 = min_1; // 次小值\n var max_1 = 0;\n // 使用一个循环,计算min,max,secondMin\n each(values, function (v) {\n var timeStamp = toTimeStamp(v);\n if (isNaN(timeStamp)) {\n throw new TypeError(\"Invalid Time: \" + v + \" in time scale!\");\n }\n if (min_1 > timeStamp) {\n secondMin_1 = min_1;\n min_1 = timeStamp;\n }\n else if (secondMin_1 > timeStamp) {\n secondMin_1 = timeStamp;\n }\n if (max_1 < timeStamp) {\n max_1 = timeStamp;\n }\n timeStamps_1.push(timeStamp);\n });\n // 存在多个值时,设置最小间距\n if (values.length > 1) {\n this.minTickInterval = secondMin_1 - min_1;\n }\n if (isNil(minConfig)) {\n this.min = min_1;\n }\n if (isNil(maxConfig)) {\n this.max = max_1;\n }\n }\n };\n return Time;\n}(Linear));\nexport default Time;\n//# sourceMappingURL=time.js.map","import { __extends } from \"tslib\";\nimport { each, head, last } from '@antv/util';\nimport Continuous from './base';\n/**\n * 分段度量\n */\nvar Quantize = /** @class */ (function (_super) {\n __extends(Quantize, _super);\n function Quantize() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'quantize';\n return _this;\n }\n Quantize.prototype.invert = function (value) {\n var ticks = this.ticks;\n var length = ticks.length;\n var percent = this.getInvertPercent(value);\n var minIndex = Math.floor(percent * (length - 1));\n // 最后一个\n if (minIndex >= length - 1) {\n return last(ticks);\n }\n // 超出左边界, 则取第一个\n if (minIndex < 0) {\n return head(ticks);\n }\n var minTick = ticks[minIndex];\n var nextTick = ticks[minIndex + 1];\n // 比当前值小的 tick 在度量上的占比\n var minIndexPercent = minIndex / (length - 1);\n var maxIndexPercent = (minIndex + 1) / (length - 1);\n return minTick + (percent - minIndexPercent) / (maxIndexPercent - minIndexPercent) * (nextTick - minTick);\n };\n Quantize.prototype.initCfg = function () {\n this.tickMethod = 'r-pretty';\n this.tickCount = 5;\n this.nice = true;\n };\n Quantize.prototype.calculateTicks = function () {\n var ticks = _super.prototype.calculateTicks.call(this);\n if (!this.nice) { // 如果 nice = false ,补充 min, max\n if (last(ticks) !== this.max) {\n ticks.push(this.max);\n }\n if (head(ticks) !== this.min) {\n ticks.unshift(this.min);\n }\n }\n return ticks;\n };\n // 计算当前值在刻度中的占比\n Quantize.prototype.getScalePercent = function (value) {\n var ticks = this.ticks;\n // 超出左边界\n if (value < head(ticks)) {\n return 0;\n }\n // 超出右边界\n if (value > last(ticks)) {\n return 1;\n }\n var minIndex = 0;\n each(ticks, function (tick, index) {\n if (value >= tick) {\n minIndex = index;\n }\n else {\n return false;\n }\n });\n return minIndex / (ticks.length - 1);\n };\n return Quantize;\n}(Continuous));\nexport default Quantize;\n//# sourceMappingURL=quantize.js.map","import { __extends } from \"tslib\";\nimport Quantize from './quantize';\nvar Quantile = /** @class */ (function (_super) {\n __extends(Quantile, _super);\n function Quantile() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'quantile';\n return _this;\n }\n Quantile.prototype.initCfg = function () {\n this.tickMethod = 'quantile';\n this.tickCount = 5;\n this.nice = true;\n };\n return Quantile;\n}(Quantize));\nexport default Quantile;\n//# sourceMappingURL=quantile.js.map","import Scale from './base';\nvar map = {};\nfunction getClass(key) {\n return map[key];\n}\nfunction registerClass(key, cls) {\n if (getClass(key)) {\n throw new Error(\"type '\" + key + \"' existed.\");\n }\n map[key] = cls;\n}\nexport { Scale, getClass as getScale, registerClass as registerScale };\n//# sourceMappingURL=factory.js.map","import { __extends } from \"tslib\";\nimport { isNumber } from '@antv/util';\nimport Base from '../base';\n/**\n * identity scale原则上是定义域和值域一致,scale/invert方法也是一致的\n * 参考R的实现:https://github.com/r-lib/scales/blob/master/R/pal-identity.r\n * 参考d3的实现(做了下转型):https://github.com/d3/d3-scale/blob/master/src/identity.js\n */\nvar Identity = /** @class */ (function (_super) {\n __extends(Identity, _super);\n function Identity() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.type = 'identity';\n _this.isIdentity = true;\n return _this;\n }\n Identity.prototype.calculateTicks = function () {\n return this.values;\n };\n Identity.prototype.scale = function (value) {\n // 如果传入的值不等于 identity 的值,则直接返回,用于一维图时的 dodge\n if (this.values[0] !== value && isNumber(value)) {\n return value;\n }\n return this.range[0];\n };\n Identity.prototype.invert = function (value) {\n var range = this.range;\n if (value < range[0] || value > range[1]) {\n return NaN;\n }\n return this.values[0];\n };\n return Identity;\n}(Base));\nexport default Identity;\n//# sourceMappingURL=index.js.map","import { head, indexOf, size, last } from '@antv/util';\nexport var DEFAULT_Q = [1, 5, 2, 2.5, 4, 3];\nexport var ALL_Q = [1, 5, 2, 2.5, 4, 3, 1.5, 7, 6, 8, 9];\nvar eps = Number.EPSILON * 100;\nfunction mod(n, m) {\n return ((n % m) + m) % m;\n}\nfunction simplicity(q, Q, j, lmin, lmax, lstep) {\n var n = size(Q);\n var i = indexOf(Q, q);\n var v = 0;\n var m = mod(lmin, lstep);\n if ((m < eps || lstep - m < eps) && lmin <= 0 && lmax >= 0) {\n v = 1;\n }\n return 1 - i / (n - 1) - j + v;\n}\nfunction simplicityMax(q, Q, j) {\n var n = size(Q);\n var i = indexOf(Q, q);\n var v = 1;\n return 1 - i / (n - 1) - j + v;\n}\nfunction density(k, m, dMin, dMax, lMin, lMax) {\n var r = (k - 1) / (lMax - lMin);\n var rt = (m - 1) / (Math.max(lMax, dMax) - Math.min(dMin, lMin));\n return 2 - Math.max(r / rt, rt / r);\n}\nfunction densityMax(k, m) {\n if (k >= m) {\n return 2 - (k - 1) / (m - 1);\n }\n return 1;\n}\nfunction coverage(dMin, dMax, lMin, lMax) {\n var range = dMax - dMin;\n return 1 - (0.5 * (Math.pow((dMax - lMax), 2) + Math.pow((dMin - lMin), 2))) / Math.pow((0.1 * range), 2);\n}\nfunction coverageMax(dMin, dMax, span) {\n var range = dMax - dMin;\n if (span > range) {\n var half = (span - range) / 2;\n return 1 - Math.pow(half, 2) / Math.pow((0.1 * range), 2);\n }\n return 1;\n}\nfunction legibility() {\n return 1;\n}\n// 解决 js 计算精度问题\nfunction prettyNumber(n) {\n return n < 1e-15 ? n : parseFloat(n.toFixed(15));\n}\n/**\n * An Extension of Wilkinson's Algorithm for Position Tick Labels on Axes\n * https://www.yuque.com/preview/yuque/0/2019/pdf/185317/1546999150858-45c3b9c2-4e86-4223-bf1a-8a732e8195ed.pdf\n * @param dMin 最小值\n * @param dMax 最大值\n * @param m tick个数\n * @param onlyLoose 是否允许扩展min、max,不绝对强制,例如[3, 97]\n * @param Q nice numbers集合\n * @param w 四个优化组件的权重\n */\nexport default function extended(dMin, dMax, m, onlyLoose, Q, w) {\n if (m === void 0) { m = 5; }\n if (onlyLoose === void 0) { onlyLoose = true; }\n if (Q === void 0) { Q = DEFAULT_Q; }\n if (w === void 0) { w = [0.25, 0.2, 0.5, 0.05]; }\n // nan 也会导致异常\n if (Number.isNaN(dMin) || Number.isNaN(dMax) || typeof dMin !== 'number' || typeof dMax !== 'number' || !m) {\n return {\n min: 0,\n max: 0,\n ticks: [],\n };\n }\n // js 极大值极小值问题,差值小于 1e-15 会导致计算出错\n if (dMax - dMin < 1e-15 || m === 1) {\n return {\n min: dMin,\n max: dMax,\n ticks: [dMin],\n };\n }\n var best = {\n score: -2,\n lmin: 0,\n lmax: 0,\n lstep: 0,\n };\n var j = 1;\n while (j < Infinity) {\n for (var i = 0; i < Q.length; i += 1) {\n var q = Q[i];\n var sm = simplicityMax(q, Q, j);\n if (w[0] * sm + w[1] + w[2] + w[3] < best.score) {\n j = Infinity;\n break;\n }\n var k = 2;\n while (k < Infinity) {\n var dm = densityMax(k, m);\n if (w[0] * sm + w[1] + w[2] * dm + w[3] < best.score) {\n break;\n }\n var delta = (dMax - dMin) / (k + 1) / j / q;\n var z = Math.ceil(Math.log10(delta));\n while (z < Infinity) {\n var step = j * q * Math.pow(10, z);\n var cm = coverageMax(dMin, dMax, step * (k - 1));\n if (w[0] * sm + w[1] * cm + w[2] * dm + w[3] < best.score) {\n break;\n }\n var minStart = Math.floor(dMax / step) * j - (k - 1) * j;\n var maxStart = Math.ceil(dMin / step) * j;\n if (minStart <= maxStart) {\n var count = maxStart - minStart;\n for (var i_1 = 0; i_1 <= count; i_1 += 1) {\n var start = minStart + i_1;\n var lMin = start * (step / j);\n var lMax = lMin + step * (k - 1);\n var lStep = step;\n var s = simplicity(q, Q, j, lMin, lMax, lStep);\n var c = coverage(dMin, dMax, lMin, lMax);\n var g = density(k, m, dMin, dMax, lMin, lMax);\n var l = legibility();\n var score = w[0] * s + w[1] * c + w[2] * g + w[3] * l;\n if (score > best.score && (!onlyLoose || (lMin <= dMin && lMax >= dMax))) {\n best.lmin = lMin;\n best.lmax = lMax;\n best.lstep = lStep;\n best.score = score;\n }\n }\n }\n z += 1;\n }\n k += 1;\n }\n }\n j += 1;\n }\n var lmax = best.lmax, lmin = best.lmin, lstep = best.lstep;\n var tickCount = Math.floor((lmax - lmin) / lstep) + 1;\n var ticks = new Array(tickCount);\n for (var i = 0; i < tickCount; i++) {\n ticks[i] = prettyNumber(lmin + i * lstep);\n }\n return {\n min: Math.min(dMin, head(ticks)),\n max: Math.max(dMax, last(ticks)),\n ticks: ticks,\n };\n}\n//# sourceMappingURL=extended.js.map","import { filter, isNil, isNumber } from '@antv/util';\nimport extended from '../util/extended';\n/**\n * 计算分类 ticks\n * @param cfg 度量的配置项\n * @returns 计算后的 ticks\n */\nexport default function calculateCatTicks(cfg) {\n var values = cfg.values, tickInterval = cfg.tickInterval, tickCount = cfg.tickCount;\n var ticks = values;\n if (isNumber(tickInterval)) {\n return filter(ticks, function (__, i) { return i % tickInterval === 0; });\n }\n var min = cfg.min, max = cfg.max;\n if (isNil(min)) {\n min = 0;\n }\n if (isNil(max)) {\n max = values.length - 1;\n }\n if (isNumber(tickCount) && tickCount < max - min) {\n // 简单过滤,部分情况下小数的倍数也可以是整数\n // tslint:disable-next-line: no-shadowed-variable\n var ticks_1 = extended(min, max, tickCount, false, [1, 2, 5, 3, 4, 7, 6, 8, 9]).ticks;\n var valid = filter(ticks_1, function (tick) { return tick >= min && tick <= max; });\n return valid.map(function (index) { return values[index]; });\n }\n return values.slice(min, max + 1);\n}\n//# sourceMappingURL=cat.js.map","export default function d3Linear(cfg) {\n var min = cfg.min, max = cfg.max, nice = cfg.nice, tickCount = cfg.tickCount;\n var linear = new D3Linear();\n linear.domain([min, max]);\n if (nice) {\n linear.nice(tickCount);\n }\n return linear.ticks(tickCount);\n}\nvar DEFAULT_COUNT = 5;\nvar e10 = Math.sqrt(50);\nvar e5 = Math.sqrt(10);\nvar e2 = Math.sqrt(2);\n// https://github.com/d3/d3-scale\nvar D3Linear = /** @class */ (function () {\n function D3Linear() {\n this._domain = [0, 1];\n }\n D3Linear.prototype.domain = function (domain) {\n if (domain) {\n this._domain = Array.from(domain, Number);\n return this;\n }\n return this._domain.slice();\n };\n D3Linear.prototype.nice = function (count) {\n var _a, _b;\n if (count === void 0) { count = DEFAULT_COUNT; }\n var d = this._domain.slice();\n var i0 = 0;\n var i1 = this._domain.length - 1;\n var start = this._domain[i0];\n var stop = this._domain[i1];\n var step;\n if (stop < start) {\n _a = [stop, start], start = _a[0], stop = _a[1];\n _b = [i1, i0], i0 = _b[0], i1 = _b[1];\n }\n step = tickIncrement(start, stop, count);\n if (step > 0) {\n start = Math.floor(start / step) * step;\n stop = Math.ceil(stop / step) * step;\n step = tickIncrement(start, stop, count);\n }\n else if (step < 0) {\n start = Math.ceil(start * step) / step;\n stop = Math.floor(stop * step) / step;\n step = tickIncrement(start, stop, count);\n }\n if (step > 0) {\n d[i0] = Math.floor(start / step) * step;\n d[i1] = Math.ceil(stop / step) * step;\n this.domain(d);\n }\n else if (step < 0) {\n d[i0] = Math.ceil(start * step) / step;\n d[i1] = Math.floor(stop * step) / step;\n this.domain(d);\n }\n return this;\n };\n D3Linear.prototype.ticks = function (count) {\n if (count === void 0) { count = DEFAULT_COUNT; }\n return d3ArrayTicks(this._domain[0], this._domain[this._domain.length - 1], count || DEFAULT_COUNT);\n };\n return D3Linear;\n}());\nexport { D3Linear };\nfunction d3ArrayTicks(start, stop, count) {\n var reverse;\n var i = -1;\n var n;\n var ticks;\n var step;\n (stop = +stop), (start = +start), (count = +count);\n if (start === stop && count > 0) {\n return [start];\n }\n // tslint:disable-next-line\n if ((reverse = stop < start)) {\n (n = start), (start = stop), (stop = n);\n }\n // tslint:disable-next-line\n if ((step = tickIncrement(start, stop, count)) === 0 || !isFinite(step)) {\n return [];\n }\n if (step > 0) {\n start = Math.ceil(start / step);\n stop = Math.floor(stop / step);\n ticks = new Array((n = Math.ceil(stop - start + 1)));\n while (++i < n) {\n ticks[i] = (start + i) * step;\n }\n }\n else {\n start = Math.floor(start * step);\n stop = Math.ceil(stop * step);\n ticks = new Array((n = Math.ceil(start - stop + 1)));\n while (++i < n) {\n ticks[i] = (start - i) / step;\n }\n }\n if (reverse) {\n ticks.reverse();\n }\n return ticks;\n}\nfunction tickIncrement(start, stop, count) {\n var step = (stop - start) / Math.max(0, count);\n var power = Math.floor(Math.log(step) / Math.LN10);\n var error = step / Math.pow(10, power);\n return power >= 0\n ? (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1) * Math.pow(10, power)\n : -Math.pow(10, -power) / (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1);\n}\n//# sourceMappingURL=d3-linear.js.map","import { fixedBase } from '@antv/util';\nfunction snapMultiple(v, base, snapType) {\n var div;\n if (snapType === 'ceil') {\n div = Math.ceil(v / base);\n }\n else if (snapType === 'floor') {\n div = Math.floor(v / base);\n }\n else {\n div = Math.round(v / base);\n }\n return div * base;\n}\nexport default function intervalTicks(min, max, interval) {\n // 变成 interval 的倍数\n var minTick = snapMultiple(min, interval, 'floor');\n var maxTick = snapMultiple(max, interval, 'ceil');\n // 统一小数位数\n minTick = fixedBase(minTick, interval);\n maxTick = fixedBase(maxTick, interval);\n var ticks = [];\n for (var i = minTick; i <= maxTick; i = i + interval) {\n var tickValue = fixedBase(i, interval); // 防止浮点数加法出现问题\n ticks.push(tickValue);\n }\n return {\n min: minTick,\n max: maxTick,\n ticks: ticks\n };\n}\n//# sourceMappingURL=interval.js.map","import { isNil } from '@antv/util';\n/**\n * 按照给定的 minLimit/maxLimit/tickCount 均匀计算出刻度 ticks\n *\n * @param cfg Scale 配置项\n * @return ticks\n */\nexport default function strictLimit(cfg, defaultMin, defaultMax) {\n var _a;\n var minLimit = cfg.minLimit, maxLimit = cfg.maxLimit, min = cfg.min, max = cfg.max, _b = cfg.tickCount, tickCount = _b === void 0 ? 5 : _b;\n var tickMin = isNil(minLimit) ? (isNil(defaultMin) ? min : defaultMin) : minLimit;\n var tickMax = isNil(maxLimit) ? (isNil(defaultMax) ? max : defaultMax) : maxLimit;\n if (tickMin > tickMax) {\n _a = [tickMin, tickMax], tickMax = _a[0], tickMin = _a[1];\n }\n if (tickCount <= 2) {\n return [tickMin, tickMax];\n }\n var step = (tickMax - tickMin) / (tickCount - 1);\n var ticks = [];\n for (var i = 0; i < tickCount; i++) {\n ticks.push(tickMin + step * i);\n }\n return ticks;\n}\n//# sourceMappingURL=strict-limit.js.map","function prettyNumber(n) {\n return n < 1e-15 ? n : parseFloat(n.toFixed(15));\n}\nexport default function pretty(min, max, n) {\n if (n === void 0) { n = 5; }\n if (min === max) {\n return {\n max: max,\n min: min,\n ticks: [min],\n };\n }\n /*\n R pretty:\n https://svn.r-project.org/R/trunk/src/appl/pretty.c\n https://www.rdocumentation.org/packages/base/versions/3.5.2/topics/pretty\n */\n var h = 1.5; // high.u.bias\n var h5 = 0.5 + 1.5 * h; // u5.bias\n // 反正我也不会调参,跳过所有判断步骤\n var d = max - min;\n var c = d / n;\n // 当d非常小的时候触发,但似乎没什么用\n // const min_n = Math.floor(n / 3);\n // const shrink_sml = Math.pow(2, 5);\n // if (Math.log10(d) < -2) {\n // c = (_.max([ Math.abs(max), Math.abs(min) ]) * shrink_sml) / min_n;\n // }\n var base = Math.pow(10, Math.floor(Math.log10(c)));\n var unit = base;\n if (2 * base - c < h * (c - unit)) {\n unit = 2 * base;\n if (5 * base - c < h5 * (c - unit)) {\n unit = 5 * base;\n if (10 * base - c < h * (c - unit)) {\n unit = 10 * base;\n }\n }\n }\n var nu = Math.ceil(max / unit);\n var ns = Math.floor(min / unit);\n var hi = Math.max(nu * unit, max);\n var lo = Math.min(ns * unit, min);\n var size = Math.floor((hi - lo) / unit) + 1;\n var ticks = new Array(size);\n for (var i = 0; i < size; i++) {\n ticks[i] = prettyNumber(lo + i * unit);\n }\n return {\n min: lo,\n max: hi,\n ticks: ticks,\n };\n}\n//# sourceMappingURL=pretty.js.map","/**\n * 计算几分位 https://github.com/simple-statistics/simple-statistics/blob/master/src/quantile_sorted.js\n * @param x 数组\n * @param p 百分比\n */\nfunction quantileSorted(x, p) {\n var idx = x.length * p;\n /*if (x.length === 0) { // 当前场景这些条件不可能命中\n throw new Error('quantile requires at least one value.');\n } else if (p < 0 || p > 1) {\n throw new Error('quantiles must be between 0 and 1');\n } else */\n if (p === 1) {\n // If p is 1, directly return the last element\n return x[x.length - 1];\n }\n else if (p === 0) {\n // If p is 0, directly return the first element\n return x[0];\n }\n else if (idx % 1 !== 0) {\n // If p is not integer, return the next element in array\n return x[Math.ceil(idx) - 1];\n }\n else if (x.length % 2 === 0) {\n // If the list has even-length, we'll take the average of this number\n // and the next value, if there is one\n return (x[idx - 1] + x[idx]) / 2;\n }\n else {\n // Finally, in the simple case of an integer value\n // with an odd-length list, return the x value at the index.\n return x[idx];\n }\n}\nexport default function calculateTicks(cfg) {\n var tickCount = cfg.tickCount, values = cfg.values;\n if (!values || !values.length) {\n return [];\n }\n var sorted = values.slice().sort(function (a, b) {\n return a - b;\n });\n var ticks = [];\n for (var i = 0; i < tickCount; i++) {\n var p = i / (tickCount - 1);\n ticks.push(quantileSorted(sorted, p));\n }\n return ticks;\n}\n//# sourceMappingURL=quantile.js.map","import { DAY, HOUR, MINUTE, MONTH, SECOND, YEAR } from '../util/time';\nfunction getYear(date) {\n return new Date(date).getFullYear();\n}\nfunction createYear(year) {\n return new Date(year, 0, 1).getTime();\n}\nfunction getMonth(date) {\n return new Date(date).getMonth();\n}\nfunction diffMonth(min, max) {\n var minYear = getYear(min);\n var maxYear = getYear(max);\n var minMonth = getMonth(min);\n var maxMonth = getMonth(max);\n return (maxYear - minYear) * 12 + ((maxMonth - minMonth) % 12);\n}\nfunction creatMonth(year, month) {\n return new Date(year, month, 1).getTime();\n}\nfunction diffDay(min, max) {\n return Math.ceil((max - min) / DAY);\n}\nfunction diffHour(min, max) {\n return Math.ceil((max - min) / HOUR);\n}\nfunction diffMinus(min, max) {\n return Math.ceil((max - min) / (60 * 1000));\n}\n/**\n * 计算 time 的 ticks,对 month, year 进行 pretty 处理\n * @param cfg 度量的配置项\n * @returns 计算后的 ticks\n */\nexport default function timePretty(cfg) {\n var min = cfg.min, max = cfg.max, minTickInterval = cfg.minTickInterval, tickCount = cfg.tickCount;\n var tickInterval = cfg.tickInterval;\n var ticks = [];\n // 指定 tickInterval 后 tickCount 不生效,需要重新计算\n if (!tickInterval) {\n tickInterval = (max - min) / tickCount;\n // 如果设置了最小间距,则使用最小间距\n if (minTickInterval && tickInterval < minTickInterval) {\n tickInterval = minTickInterval;\n }\n }\n var minYear = getYear(min);\n // 如果间距大于 1 年,则将开始日期从整年开始\n if (tickInterval > YEAR) {\n var maxYear = getYear(max);\n var yearInterval = Math.ceil(tickInterval / YEAR);\n for (var i = minYear; i <= maxYear + yearInterval; i = i + yearInterval) {\n ticks.push(createYear(i));\n }\n }\n else if (tickInterval > MONTH) {\n // 大于月时\n var monthInterval = Math.ceil(tickInterval / MONTH);\n var mmMoth = getMonth(min);\n var dMonths = diffMonth(min, max);\n for (var i = 0; i <= dMonths + monthInterval; i = i + monthInterval) {\n ticks.push(creatMonth(minYear, i + mmMoth));\n }\n }\n else if (tickInterval > DAY) {\n // 大于天\n var date = new Date(min);\n var year = date.getFullYear();\n var month = date.getMonth();\n var mday = date.getDate();\n var day = Math.ceil(tickInterval / DAY);\n var ddays = diffDay(min, max);\n for (var i = 0; i < ddays + day; i = i + day) {\n ticks.push(new Date(year, month, mday + i).getTime());\n }\n }\n else if (tickInterval > HOUR) {\n // 大于小时\n var date = new Date(min);\n var year = date.getFullYear();\n var month = date.getMonth();\n var day = date.getDate();\n var hour = date.getHours();\n var hours = Math.ceil(tickInterval / HOUR);\n var dHours = diffHour(min, max);\n for (var i = 0; i <= dHours + hours; i = i + hours) {\n ticks.push(new Date(year, month, day, hour + i).getTime());\n }\n }\n else if (tickInterval > MINUTE) {\n // 大于分钟\n var dMinus = diffMinus(min, max);\n var minutes = Math.ceil(tickInterval / MINUTE);\n for (var i = 0; i <= dMinus + minutes; i = i + minutes) {\n ticks.push(min + i * MINUTE);\n }\n }\n else {\n // 小于分钟\n var interval = tickInterval;\n if (interval < SECOND) {\n interval = SECOND;\n }\n var minSecond = Math.floor(min / SECOND) * SECOND;\n var dSeconds = Math.ceil((max - min) / SECOND);\n var seconds = Math.ceil(interval / SECOND);\n for (var i = 0; i < dSeconds + seconds; i = i + seconds) {\n ticks.push(minSecond + i * SECOND);\n }\n }\n // 最好是能从算法能解决这个问题,但是如果指定了 tickInterval,计算 ticks,也只能这么算,所以\n // 打印警告提示\n if (ticks.length >= 512) {\n console.warn(\"Notice: current ticks length(\" + ticks.length + \") >= 512, may cause performance issues, even out of memory. Because of the configure \\\"tickInterval\\\"(in milliseconds, current is \" + tickInterval + \") is too small, increase the value to solve the problem!\");\n }\n return ticks;\n}\n//# sourceMappingURL=time-pretty.js.map","import cat from './cat';\nimport d3Linear from './d3-linear';\nimport linear from './linear';\nimport log from './log';\nimport pow from './pow';\nimport quantile from './quantile';\nimport rPretty from './r-prettry';\nimport { getTickMethod, registerTickMethod } from './register';\nimport time from './time';\nimport timeCat from './time-cat';\nimport timePretty from './time-pretty';\nregisterTickMethod('cat', cat);\nregisterTickMethod('time-cat', timeCat);\nregisterTickMethod('wilkinson-extended', linear);\nregisterTickMethod('r-pretty', rPretty);\nregisterTickMethod('time', time);\nregisterTickMethod('time-pretty', timePretty);\nregisterTickMethod('log', log);\nregisterTickMethod('pow', pow);\nregisterTickMethod('quantile', quantile);\nregisterTickMethod('d3-linear', d3Linear);\nexport { getTickMethod, registerTickMethod };\n//# sourceMappingURL=index.js.map","import { last } from '@antv/util';\nimport catTicks from './cat';\n/**\n * 计算时间分类的 ticks, 保头,保尾\n * @param cfg 度量的配置项\n * @returns 计算后的 ticks\n */\nexport default function calculateTimeCatTicks(cfg) {\n var ticks = catTicks(cfg);\n var lastValue = last(cfg.values);\n if (lastValue !== last(ticks)) {\n ticks.push(lastValue);\n }\n return ticks;\n}\n//# sourceMappingURL=time-cat.js.map","import { head, isNil, last } from '@antv/util';\nimport extended from '../util/extended';\nimport interval from '../util/interval';\nimport strictLimit from '../util/strict-limit';\n/**\n * 计算线性的 ticks,使用 wilkinson extended 方法\n * @param cfg 度量的配置项\n * @returns 计算后的 ticks\n */\nexport default function linear(cfg) {\n var min = cfg.min, max = cfg.max, tickCount = cfg.tickCount, nice = cfg.nice, tickInterval = cfg.tickInterval, minLimit = cfg.minLimit, maxLimit = cfg.maxLimit;\n var ticks = extended(min, max, tickCount, nice).ticks;\n if (!isNil(minLimit) || !isNil(maxLimit)) {\n return strictLimit(cfg, head(ticks), last(ticks));\n }\n if (tickInterval) {\n return interval(min, max, tickInterval).ticks;\n }\n return ticks;\n}\n//# sourceMappingURL=linear.js.map","import { head, isNil, last } from '@antv/util';\nimport interval from '../util/interval';\nimport pretty from '../util/pretty';\nimport strictLimit from '../util/strict-limit';\n/**\n * 计算线性的 ticks,使用 R's pretty 方法\n * @param cfg 度量的配置项\n * @returns 计算后的 ticks\n */\nexport default function linearPretty(cfg) {\n var min = cfg.min, max = cfg.max, tickCount = cfg.tickCount, tickInterval = cfg.tickInterval, minLimit = cfg.minLimit, maxLimit = cfg.maxLimit;\n var ticks = pretty(min, max, tickCount).ticks;\n if (!isNil(minLimit) || !isNil(maxLimit)) {\n return strictLimit(cfg, head(ticks), last(ticks));\n }\n if (tickInterval) {\n return interval(min, max, tickInterval).ticks;\n }\n return ticks;\n}\n//# sourceMappingURL=r-prettry.js.map","import { getTickInterval } from '../util/time';\nexport default function calculateTimeTicks(cfg) {\n var min = cfg.min, max = cfg.max, minTickInterval = cfg.minTickInterval;\n var tickInterval = cfg.tickInterval;\n var tickCount = cfg.tickCount;\n // 指定 tickInterval 后 tickCount 不生效,需要重新计算\n if (tickInterval) {\n tickCount = Math.ceil((max - min) / tickInterval);\n }\n else {\n tickInterval = getTickInterval(min, max, tickCount)[1];\n var count = (max - min) / tickInterval;\n var ratio = count / tickCount;\n if (ratio > 1) {\n tickInterval = tickInterval * Math.ceil(ratio);\n }\n // 如果设置了最小间距,则使用最小间距\n if (minTickInterval && tickInterval < minTickInterval) {\n tickInterval = minTickInterval;\n }\n }\n var ticks = [];\n for (var i = min; i < max + tickInterval; i += tickInterval) {\n ticks.push(i);\n }\n return ticks;\n}\n//# sourceMappingURL=time.js.map","import { getLogPositiveMin, log } from '../util/math';\n/**\n * 计算 log 的 ticks,考虑 min = 0 的场景\n * @param cfg 度量的配置项\n * @returns 计算后的 ticks\n */\nexport default function calculateLogTicks(cfg) {\n var base = cfg.base, tickCount = cfg.tickCount, min = cfg.min, max = cfg.max, values = cfg.values;\n var minTick;\n var maxTick = log(base, max);\n if (min > 0) {\n minTick = Math.floor(log(base, min));\n }\n else {\n var positiveMin = getLogPositiveMin(values, base, max);\n minTick = Math.floor(log(base, positiveMin));\n }\n var count = maxTick - minTick;\n var avg = Math.ceil(count / tickCount);\n var ticks = [];\n for (var i = minTick; i < maxTick + avg; i = i + avg) {\n ticks.push(Math.pow(base, i));\n }\n if (min <= 0) {\n // 最小值 <= 0 时显示 0\n ticks.unshift(0);\n }\n return ticks;\n}\n//# sourceMappingURL=log.js.map","import { calBase } from '../util/math';\nimport pretty from '../util/pretty';\n/**\n * 计算 Pow 的 ticks\n * @param cfg 度量的配置项\n * @returns 计算后的 ticks\n */\nexport default function calculatePowTicks(cfg) {\n var exponent = cfg.exponent, tickCount = cfg.tickCount;\n var max = Math.ceil(calBase(exponent, cfg.max));\n var min = Math.floor(calBase(exponent, cfg.min));\n var ticks = pretty(min, max, tickCount).ticks;\n return ticks.map(function (tick) {\n var factor = tick >= 0 ? 1 : -1;\n return Math.pow(tick, exponent) * factor;\n });\n}\n//# sourceMappingURL=pow.js.map","import { head, isNil, last } from '@antv/util';\nimport d3Linear from '../util/d3-linear';\nimport interval from '../util/interval';\nimport strictLimit from '../util/strict-limit';\nexport default function d3LinearTickMethod(cfg) {\n var min = cfg.min, max = cfg.max, tickInterval = cfg.tickInterval, minLimit = cfg.minLimit, maxLimit = cfg.maxLimit;\n var ticks = d3Linear(cfg);\n if (!isNil(minLimit) || !isNil(maxLimit)) {\n return strictLimit(cfg, head(ticks), last(ticks));\n }\n if (tickInterval) {\n return interval(min, max, tickInterval).ticks;\n }\n return ticks;\n}\n//# sourceMappingURL=d3-linear.js.map","var __spreadArray = this && this.__spreadArray || function (to, from) {\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++) {\n to[j] = from[i];\n }\n\n return to;\n};\n\nimport * as pathUtil from '@antv/path-util';\nimport { Category, Linear } from '@antv/scale';\nimport { map, each, isEqual, head, isArray } from '@antv/util';\n/**\n * 点数组转 path\n * @param points\n */\n\nfunction pointsToPath(points) {\n return map(points, function (p, idx) {\n var command = idx === 0 ? 'M' : 'L';\n var x = p[0],\n y = p[1];\n return [command, x, y];\n });\n}\n/**\n * 将点连接成路径 path\n * @param points\n */\n\n\nexport function getLinePath(points) {\n return pointsToPath(points);\n}\n/**\n * 将点连成平滑的曲线\n * @param points\n */\n\nexport function getSmoothLinePath(points) {\n if (points.length <= 2) {\n // 两点以内直接绘制成路径\n return getLinePath(points);\n }\n\n var data = [];\n each(points, function (p) {\n // 当前点和上一个点一样的时候,忽略掉\n if (!isEqual(p, data.slice(data.length - 2))) {\n data.push(p[0], p[1]);\n }\n });\n var path = pathUtil.catmullRom2Bezier(data, false);\n\n var _a = head(points),\n x = _a[0],\n y = _a[1];\n\n path.unshift(['M', x, y]);\n return path;\n}\n/**\n * 将数据转成 path,利用 scale 的归一化能力\n * @param data\n * @param width\n * @param height\n * @param smooth\n */\n\nexport function dataToPath(data, width, height, smooth) {\n if (smooth === void 0) {\n smooth = true;\n } // 利用 scale 来获取 y 上的映射\n\n\n var y = new Linear({\n values: data\n });\n var x = new Category({\n values: map(data, function (v, idx) {\n return idx;\n })\n });\n var points = map(data, function (v, idx) {\n return [x.scale(idx) * width, height - y.scale(v) * height];\n });\n return smooth ? getSmoothLinePath(points) : getLinePath(points);\n}\nexport function dataToRectPath(data, width, height, barWidth) {\n if (barWidth === void 0) {\n barWidth = 5;\n } // 利用 scale 来获取 y 上的映射\n\n\n var y = new Linear({\n values: data\n });\n var x = new Category({\n values: map(data, function (v, idx) {\n return idx;\n })\n });\n var points = map(data, function (v, idx) {\n return [x.scale(idx) * width, height - y.scale(v) * height];\n });\n var rectPoints = [];\n\n for (var i = 0; i < points.length; i++) {\n var point = points[i];\n var param = {\n x: point[0],\n y: point[1],\n y0: height,\n size: barWidth\n };\n var rectPoint = getRectPoints(param);\n rectPoints.push.apply(rectPoints, rectPoint);\n }\n\n return getRectPath(rectPoints);\n}\n/**\n * 获得 area 面积的横向连接线的 px 位置\n * @param data\n * @param width\n * @param height\n */\n\nexport function getAreaLineY(data, height) {\n var y = new Linear({\n values: data\n });\n var lineY = Math.max(0, y.min);\n return height - y.scale(lineY) * height;\n}\n/**\n * 线 path 转 area path\n * @param path\n * @param width\n * @param height\n */\n\nexport function linePathToAreaPath(path, width, height, data) {\n var areaPath = __spreadArray([], path);\n\n var lineYPx = getAreaLineY(data, height);\n areaPath.push(['L', width, lineYPx]);\n areaPath.push(['L', 0, lineYPx]);\n areaPath.push(['Z']);\n return areaPath;\n}\n/**\n * @ignore\n * 根据数据点生成矩形的四个关键点\n * @param pointInfo 数据点信息\n * @returns rect points 返回矩形四个顶点信息\n */\n\nexport function getRectPoints(pointInfo) {\n var x = pointInfo.x,\n y = pointInfo.y,\n y0 = pointInfo.y0,\n size = pointInfo.size; // 有 4 种情况,\n // 1. x, y 都不是数组\n // 2. y是数组,x不是\n // 3. x是数组,y不是\n // 4. x, y 都是数组\n\n var yMin;\n var yMax;\n\n if (isArray(y)) {\n yMin = y[0], yMax = y[1];\n } else {\n yMin = y0;\n yMax = y;\n }\n\n var xMin;\n var xMax;\n\n if (isArray(x)) {\n xMin = x[0], xMax = x[1];\n } else {\n xMin = x - size / 2;\n xMax = x + size / 2;\n }\n\n var points = [{\n x: xMin,\n y: yMin\n }, {\n x: xMin,\n y: yMax\n }]; // 矩形的四个关键点,结构如下(左下角顺时针连接)\n // 1 ---- 2\n // | |\n // 0 ---- 3\n\n points.push({\n x: xMax,\n y: yMax\n }, {\n x: xMax,\n y: yMin\n });\n return points;\n}\n/**\n * @ignore\n * 根据矩形关键点绘制 path\n * @param points 关键点数组\n * @param isClosed path 是否需要闭合\n * @returns 返回矩形的 path\n */\n\nexport function getRectPath(points, isClosed) {\n if (isClosed === void 0) {\n isClosed = true;\n }\n\n var path = [];\n var firstPoint = points[0];\n path.push(['M', firstPoint.x, firstPoint.y]);\n\n for (var i = 1, len = points.length; i < len; i++) {\n path.push(['L', points[i].x, points[i].y]);\n } // 对于 shape=\"line\" path 不应该闭合,否则会造成 lineCap 绘图属性失效\n\n\n if (isClosed) {\n path.push(['L', firstPoint.x, firstPoint.y]); // 需要闭合\n\n path.push(['z']);\n }\n\n return path;\n}","var __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { dataToPath, linePathToAreaPath, dataToRectPath } from './path';\nexport var LINE_STYLE = {\n stroke: '#C5C5C5',\n strokeOpacity: 0.85\n};\nexport var AREA_STYLE = {\n fill: '#CACED4',\n opacity: 0.85\n};\n/**\n * 缩略趋势图\n */\n\nvar Trend = function () {\n function Trend(cfg) {\n var _a = cfg.x,\n x = _a === void 0 ? 0 : _a,\n _b = cfg.y,\n y = _b === void 0 ? 0 : _b,\n _c = cfg.width,\n width = _c === void 0 ? 200 : _c,\n _d = cfg.height,\n height = _d === void 0 ? 26 : _d,\n _e = cfg.smooth,\n smooth = _e === void 0 ? true : _e,\n _f = cfg.isArea,\n isArea = _f === void 0 ? false : _f,\n _g = cfg.data,\n data = _g === void 0 ? [] : _g,\n lineStyle = cfg.lineStyle,\n areaStyle = cfg.areaStyle,\n group = cfg.group,\n _h = cfg.interval,\n interval = _h === void 0 ? null : _h;\n this.group = group;\n this.x = x;\n this.y = y;\n this.width = width;\n this.height = height;\n this.data = data;\n this.smooth = smooth;\n this.isArea = isArea;\n this.lineStyle = Object.assign({}, LINE_STYLE, lineStyle);\n this.areaStyle = Object.assign({}, AREA_STYLE, areaStyle);\n this.intervalConfig = interval;\n this.renderLine();\n }\n /**\n * 构造\n * @private\n */\n\n\n Trend.prototype.renderLine = function () {\n var _a = this,\n x = _a.x,\n y = _a.y,\n width = _a.width,\n height = _a.height,\n barWidth = _a.barWidth,\n data = _a.data,\n smooth = _a.smooth,\n isArea = _a.isArea,\n lineStyle = _a.lineStyle,\n areaStyle = _a.areaStyle;\n\n var trendGroup = this.group.addGroup({\n name: 'trend-group'\n });\n\n if (data) {\n var path = dataToPath(data, width, height, smooth); // 线\n\n trendGroup.addShape('path', {\n attrs: __assign({\n path: path\n }, lineStyle)\n }); // 在 line 的基础上,绘制面积图\n\n if (isArea) {\n var areaPath = linePathToAreaPath(path, width, height, data);\n trendGroup.addShape('path', {\n attrs: __assign({\n path: areaPath\n }, areaStyle)\n });\n }\n } // 绘制柱状图📊\n\n\n if (this.intervalConfig) {\n trendGroup.addShape('path', {\n attrs: __assign({\n path: dataToRectPath(this.intervalConfig.data, width, height, this.intervalConfig.style.barWidth)\n }, this.intervalConfig.style)\n });\n } // 统一移动到对应的位置\n\n\n trendGroup.move(x, y);\n };\n\n Trend.prototype.destory = function () {\n this.group.destroy();\n };\n\n return Trend;\n}();\n\nexport default Trend;","var __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { isNumber } from '@antv/util';\nvar DEFAULT_STYLE = {\n fill: '#1890ff',\n stroke: '#1890ff',\n type: 'trend',\n radius: 2,\n opacity: 1,\n cursor: 'ew-resize',\n // 高亮的颜色\n highLightFill: '#0050b3'\n};\nvar SIMPLE_DEFAULT_STYLE = {\n fill: '#fff',\n stroke: '#1890ff',\n radius: 2,\n opacity: 1,\n cursor: 'ew-resize'\n};\n\nvar Handler = function () {\n function Handler(cfg) {\n var group = cfg.group,\n name = cfg.name,\n type = cfg.type,\n _a = cfg.x,\n x = _a === void 0 ? 0 : _a,\n _b = cfg.y,\n y = _b === void 0 ? 0 : _b,\n _c = cfg.width,\n width = _c === void 0 ? 2 : _c,\n _d = cfg.height,\n height = _d === void 0 ? 24 : _d,\n _e = cfg.style,\n style = _e === void 0 ? {} : _e;\n this.group = group;\n this.name = name;\n this.handleType = type;\n this.x = x;\n this.y = y;\n this.width = width;\n this.height = height;\n\n if (type === 'trend') {\n this.style = __assign(__assign({}, DEFAULT_STYLE), style);\n } else if (type === 'simple') {\n this.style = __assign(__assign({}, SIMPLE_DEFAULT_STYLE), style);\n }\n\n this.renderHandle();\n }\n /**\n * 设置位置 x\n * @param x\n */\n\n\n Handler.prototype.setX = function (x) {\n this.setXY(x, undefined);\n };\n /**\n * 设置位置 y\n * @param y\n */\n\n\n Handler.prototype.setY = function (y) {\n this.setXY(undefined, y);\n };\n\n Handler.prototype.setXY = function (x, y) {\n if (isNumber(x)) {\n this.x = x;\n }\n\n if (isNumber(y)) {\n this.y = y;\n }\n\n this.updateXY();\n };\n /**\n * 初始化组件\n * @private\n */\n\n\n Handler.prototype.renderHandle = function () {\n var _a = this,\n width = _a.width,\n height = _a.height,\n style = _a.style,\n name = _a.name;\n\n var fill = style.fill,\n stroke = style.stroke,\n radius = style.radius,\n opacity = style.opacity,\n cursor = style.cursor;\n this.handleGroup = this.group.addGroup(); // 趋势图时的 handle\n\n if (this.handleType === 'trend') {\n // 垂直线\n this.verticalLine = this.handleGroup.addShape('rect', {\n attrs: {\n x: 0,\n y: 0,\n width: width,\n height: height,\n fill: fill,\n stroke: stroke,\n radius: radius,\n opacity: opacity,\n cursor: cursor\n },\n name: name + \"-handler\"\n });\n this.topCircle = this.handleGroup.addShape('circle', {\n attrs: {\n x: width / 2,\n y: 0,\n r: 2 * width,\n fill: fill,\n stroke: stroke,\n radius: radius,\n opacity: opacity,\n cursor: cursor\n },\n name: name + \"-handler\"\n });\n this.bottomCircle = this.handleGroup.addShape('circle', {\n attrs: {\n x: width / 2,\n y: height,\n r: 2 * width,\n fill: fill,\n stroke: stroke,\n radius: radius,\n opacity: opacity,\n cursor: cursor\n },\n name: name + \"-handler\"\n });\n } else if (this.handleType === 'simple') {\n this.topCircle = this.handleGroup.addShape('circle', {\n attrs: {\n x: width / 2,\n y: height / 2,\n r: 2 * width,\n fill: fill,\n stroke: stroke,\n radius: radius,\n opacity: opacity,\n cursor: cursor,\n lineWidth: 2\n },\n name: name + \"-handler\"\n });\n } // 移动到对应的位置\n\n\n this.updateXY();\n\n if (this.handleType === 'trend') {\n this.bindTrendEvents();\n } else if (this.handleType === 'simple') {\n this.bindSimpleEvents();\n }\n };\n\n Handler.prototype.bindSimpleEvents = function () {\n var _this = this;\n\n var name = this.name;\n this.handleGroup.on(name + \"-handler:mouseenter\", function () {\n var highLightFill = _this.style.highLightFill;\n\n _this.topCircle.attr('fill', highLightFill);\n });\n this.handleGroup.on(name + \"-handler:mouseleave\", function () {\n var fill = _this.style.fill;\n\n _this.topCircle.attr('fill', fill);\n });\n };\n\n Handler.prototype.bindTrendEvents = function () {\n var _this = this;\n\n var name = this.name;\n this.handleGroup.on(name + \"-handler:mouseenter\", function () {\n var highLightFill = _this.style.highLightFill;\n\n _this.verticalLine.attr('fill', highLightFill);\n\n _this.topCircle.attr('fill', highLightFill);\n\n _this.bottomCircle.attr('fill', highLightFill);\n });\n this.handleGroup.on(name + \"-handler:mouseleave\", function () {\n var fill = _this.style.fill;\n\n _this.verticalLine.attr('fill', fill);\n\n _this.topCircle.attr('fill', fill);\n\n _this.bottomCircle.attr('fill', fill);\n });\n };\n\n Handler.prototype.show = function () {\n this.handleGroup.show();\n };\n\n Handler.prototype.hide = function () {\n this.handleGroup.hide();\n };\n\n Handler.prototype.updateXY = function () {\n this.handleGroup.setMatrix([1, 0, 0, 0, 1, 0, this.x, this.y, 1]);\n };\n\n return Handler;\n}();\n\nexport default Handler;","/**\n * 基于 G 的按钮组件\n */\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { deepMix } from '@antv/util';\nimport { PLAY_PAUSE_BTN } from './constant';\n\nvar Button = function () {\n function Button(cfg) {\n this.config = deepMix({}, cfg);\n this.init();\n }\n\n Button.prototype.update = function (cfg) {\n this.config = deepMix({}, this.config, cfg);\n this.updateElement();\n this.renderMarker();\n };\n\n Button.prototype.init = function () {\n this.initElement();\n this.renderMarker();\n };\n\n Button.prototype.initElement = function () {\n var _a = this.config,\n group = _a.group,\n style = _a.style;\n var _b = style.scale,\n scale = _b === void 0 ? 1 : _b,\n _c = style.offsetX,\n offsetX = _c === void 0 ? 0 : _c,\n _d = style.offsetY,\n offsetY = _d === void 0 ? 0 : _d;\n var x = this.config.x + offsetX;\n var y = this.config.y + offsetY;\n var buttonGroup = group.addGroup({\n name: PLAY_PAUSE_BTN\n });\n this.startMarkerGroup = buttonGroup.addGroup({\n name: PLAY_PAUSE_BTN\n });\n this.circle = group.addShape('circle', {\n attrs: __assign({\n x: x,\n y: y,\n r: this.config.r * scale\n }, style),\n name: PLAY_PAUSE_BTN\n });\n this.startMarker = this.startMarkerGroup.addShape('path', {\n attrs: {\n path: this.getStartMarkerPath(x, y, scale),\n fill: style.stroke || '#aaa'\n }\n });\n this.pauseMarkerGroup = buttonGroup.addGroup({\n name: PLAY_PAUSE_BTN\n });\n var width = 0.25 * this.config.r * scale;\n var height = 0.5 * this.config.r * Math.sqrt(3) * scale;\n this.pauseLeftMarker = this.pauseMarkerGroup.addShape('rect', {\n attrs: {\n x: x - 0.375 * this.config.r * scale,\n y: y - height / 2,\n width: width,\n height: height,\n fill: style.stroke || '#aaa',\n lineWidth: 0\n }\n });\n this.pauseRightMarker = this.pauseMarkerGroup.addShape('rect', {\n attrs: {\n x: x + 1 / 8 * this.config.r * scale,\n y: y - height / 2,\n width: width,\n height: height,\n fill: style.stroke || '#aaa',\n lineWidth: 0\n }\n });\n };\n\n Button.prototype.updateElement = function () {\n var _a = this.config.style,\n _b = _a.scale,\n scale = _b === void 0 ? 1 : _b,\n _c = _a.offsetX,\n offsetX = _c === void 0 ? 0 : _c,\n _d = _a.offsetY,\n offsetY = _d === void 0 ? 0 : _d;\n var x = this.config.x + offsetX;\n var y = this.config.y + offsetY;\n this.circle.attr('x', x);\n this.circle.attr('y', y);\n this.circle.attr('r', this.config.r * scale);\n this.startMarker.attr('path', this.getStartMarkerPath(x, y, scale));\n var width = 0.25 * this.config.r * scale;\n var height = 0.5 * this.config.r * Math.sqrt(3) * scale;\n this.pauseLeftMarker.attr('x', x - (1 / 4 + 1 / 8) * this.config.r * scale);\n this.pauseLeftMarker.attr('y', y - height / 2);\n this.pauseLeftMarker.attr('width', width);\n this.pauseLeftMarker.attr('height', height);\n this.pauseRightMarker.attr('x', x + 1 / 8 * this.config.r * scale);\n this.pauseRightMarker.attr('y', y - height / 2);\n this.pauseRightMarker.attr('width', width);\n this.pauseRightMarker.attr('height', height);\n };\n\n Button.prototype.renderMarker = function () {\n if (this.config.isPlay) {\n this.startMarkerGroup.hide();\n this.pauseMarkerGroup.show();\n } else {\n this.startMarkerGroup.show();\n this.pauseMarkerGroup.hide();\n }\n };\n /** 获取播放键 marker path */\n\n\n Button.prototype.getStartMarkerPath = function (x, y, scale) {\n var sideLength = 0.5 * this.config.r * Math.sqrt(3) * scale;\n return [['M', x - sideLength / Math.sqrt(3) / 2, y - sideLength / 2], ['L', x + sideLength / Math.sqrt(3), y], ['L', x - sideLength / Math.sqrt(3) / 2, y + sideLength / 2]];\n };\n\n return Button;\n}();\n\nexport default Button;","export var TIMELINE_START = 'timebarstartplay';\nexport var TIMELINE_END = 'timebarendplay';\nexport var VALUE_CHANGE = 'valuechange';\nexport var TIMEBAR_CONFIG_CHANGE = 'timebarConfigChanged';\nexport var PLAY_PAUSE_BTN = 'playPauseBtn';\nexport var NEXT_STEP_BTN = 'nextStepBtn';\nexport var PRE_STEP_BTN = 'preStepBtn';","var __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { deepMix } from '@antv/util';\nimport { ext } from '@antv/matrix-util';\nimport Button from './timeButton';\nimport { TIMEBAR_CONFIG_CHANGE, PRE_STEP_BTN, NEXT_STEP_BTN } from './constant';\nvar transform = ext.transform;\nvar DEFAULT_RECT_FILL = '#aaa';\nvar DEFAULT_RECT_STROKE = 'green';\nvar DEFAULT_PLAYBTN_STYLE = {\n fill: '#aaa',\n fillOpacity: 0.35,\n stroke: '#aaa'\n};\nvar DEFAULT_PREBTN_STYLE = {\n fill: '#fff'\n};\nvar DEFAULT_NEXTBTN_STYLE = {\n fill: 'green'\n};\nvar DEFAULT_SPEED_CONTROLLER_STYLE = {\n pointer: {\n fill: '#aaa',\n lineWidth: 0\n },\n scroller: {\n stroke: '#aaa',\n fill: '#aaa',\n lineWidth: 1,\n lineAppendWidth: 5,\n cursor: 'pointer'\n },\n text: {\n fill: '#aaa',\n textBaseline: 'top'\n }\n};\nvar DEFAULT_TIMETYPE_CONTROLLER_STYLE = {\n check: {\n stroke: 'green',\n lineWidth: 3\n },\n box: {\n fill: '#fff',\n stroke: '#aaa',\n lineWidth: 2,\n radius: 3,\n width: 12,\n height: 12\n },\n text: {\n fill: '#aaa',\n fontSize: 12,\n textBaseline: 'top'\n }\n};\nvar DEFAULT_CONTROLLER_CONFIG = {\n speed: 1,\n loop: false,\n fill: '#fff',\n stroke: '#fff',\n hideTimeTypeController: false,\n preBtnStyle: {\n fill: '#aaa',\n stroke: '#aaa'\n },\n nextBtnStyle: {\n fill: '#aaa',\n stroke: '#aaa'\n },\n playBtnStyle: {\n fill: '#aaa',\n stroke: '#aaa',\n fillOpacity: 0.05\n },\n speedControllerStyle: DEFAULT_SPEED_CONTROLLER_STYLE,\n timeTypeControllerStyle: DEFAULT_TIMETYPE_CONTROLLER_STYLE\n};\nvar SPEED_CONTROLLER_OFFSET = 110;\nvar TOGGLE_MODEL_OFFSET = 50;\n\nvar ControllerBtn = function () {\n function ControllerBtn(cfg) {\n this.controllerCfg = deepMix({}, DEFAULT_CONTROLLER_CONFIG, cfg);\n this.group = cfg.group;\n this.controllerGroup = this.group.addGroup({\n name: 'controller-group'\n });\n this.speedAxisY = [];\n this.currentSpeed = this.controllerCfg.speed;\n this.currentType = 'range';\n this.fontFamily = cfg.fontFamily || 'Arial, sans-serif';\n this.init();\n }\n\n ControllerBtn.prototype.init = function () {\n this.renderPlayButton();\n };\n /** 获取播放键 marker path */\n\n\n ControllerBtn.prototype.getNextMarkerPath = function (x, y, len) {\n return [['M', x, y - len], ['L', x + len, y], ['L', x, y + len], ['Z', x, y - len], ['M', x, y], ['L', x - len, y - len], ['L', x - len, y + len], ['Z']];\n };\n\n ControllerBtn.prototype.getPreMarkerPath = function (x, y, len) {\n return [['M', x, y - len], ['L', x - len, y], ['L', x, y + len], ['L', x, y - len], ['M', x, y], ['L', x + len, y - len], ['L', x + len, y + len], ['Z']];\n };\n\n ControllerBtn.prototype.renderPlayButton = function () {\n var controllerCfg = this.controllerCfg;\n var width = controllerCfg.width,\n height = controllerCfg.height,\n x = controllerCfg.x,\n y = controllerCfg.y,\n hideTimeTypeController = controllerCfg.hideTimeTypeController,\n _a = controllerCfg.fill,\n fill = _a === void 0 ? DEFAULT_RECT_FILL : _a,\n _b = controllerCfg.stroke,\n stroke = _b === void 0 ? DEFAULT_RECT_STROKE : _b;\n\n var playBtnStyle = __assign(__assign({}, DEFAULT_PLAYBTN_STYLE), controllerCfg.playBtnStyle || {});\n\n var preBtnStyle = __assign(__assign({}, DEFAULT_PREBTN_STYLE), controllerCfg.preBtnStyle || {});\n\n var nextBtnStyle = __assign(__assign({}, DEFAULT_NEXTBTN_STYLE), controllerCfg.nextBtnStyle || {});\n\n var r = height / 2 - 5;\n var realY = y + 10; // 绘制最外层的矩形包围框\n\n var container = this.controllerGroup.addShape('rect', {\n attrs: {\n x: x,\n y: realY,\n width: width,\n height: height,\n stroke: stroke,\n fill: fill\n },\n name: 'container-rect'\n });\n\n if (this.playButton) {\n this.playButton.update({\n x: width / 2,\n y: realY,\n r: r\n });\n } else {\n this.playButton = new Button({\n group: this.controllerGroup,\n x: width / 2,\n y: realY + r + 5,\n r: r,\n isPlay: this.isPlay,\n style: playBtnStyle\n });\n } // 后退按钮\n\n\n var prePaddingX = preBtnStyle.offsetX || 0;\n var prePaddingY = preBtnStyle.offsetY || 0;\n var preR = (preBtnStyle.scale || 1) * r;\n this.controllerGroup.addShape('path', {\n attrs: __assign({\n path: this.getPreMarkerPath(width / 2 - 5 * r + prePaddingX, realY + r + 5 + prePaddingY, preR * 0.5)\n }, preBtnStyle),\n name: PRE_STEP_BTN\n }); // 前进按钮\n\n var nxtPaddingX = nextBtnStyle.offsetX || 0;\n var nxtPaddingY = nextBtnStyle.offsetY || 0;\n var nxtR = (nextBtnStyle.scale || 1) * r;\n this.controllerGroup.addShape('path', {\n attrs: __assign({\n path: this.getNextMarkerPath(width / 2 + 5 * r + nxtPaddingX, realY + r + 5 + nxtPaddingY, nxtR * 0.5)\n }, nextBtnStyle),\n name: NEXT_STEP_BTN\n });\n container.toBack(); // 调节speed的按钮\n\n this.renderSpeedBtn();\n\n if (!hideTimeTypeController) {\n this.renderToggleTime();\n }\n\n this.bindEvent(); // 根据配置的 scale、offsetX,offsetY 缩放和移动控制栏\n\n var _c = this.controllerCfg.scale,\n scale = _c === void 0 ? 1 : _c;\n var currentBBox = this.controllerGroup.getCanvasBBox();\n var centerX = (currentBBox.maxX + currentBBox.minX) / 2;\n var centerY = (currentBBox.maxY + currentBBox.minY) / 2;\n var matrix = transform([1, 0, 0, 0, 1, 0, 0, 0, 1], [['t', -centerX, -centerY], ['s', scale, scale], ['t', centerX, centerY]]);\n this.controllerGroup.setMatrix(matrix);\n };\n\n ControllerBtn.prototype.renderSpeedBtn = function () {\n var _a = this.controllerCfg,\n y = _a.y,\n width = _a.width,\n hideTimeTypeController = _a.hideTimeTypeController;\n\n var speedControllerStyle = __assign(__assign({}, DEFAULT_SPEED_CONTROLLER_STYLE), this.controllerCfg.speedControllerStyle || {});\n\n var _b = speedControllerStyle.scroller,\n scroller = _b === void 0 ? {} : _b,\n _c = speedControllerStyle.text,\n text = _c === void 0 ? {} : _c,\n _d = speedControllerStyle.pointer,\n pointer = _d === void 0 ? {} : _d,\n _e = speedControllerStyle.scale,\n scale = _e === void 0 ? 1 : _e,\n _f = speedControllerStyle.offsetX,\n offsetX = _f === void 0 ? 0 : _f,\n _g = speedControllerStyle.offsetY,\n offsetY = _g === void 0 ? 0 : _g;\n var speedGroup = this.controllerGroup.addGroup({\n name: 'speed-group'\n });\n this.speedGroup = speedGroup;\n var speedNum = [];\n var maxSpeed = 5;\n this.speedAxisY = [19, 22, 26, 32, 39]; // 增加speed刻度\n\n for (var i = 0; i < 5; i++) {\n var axisY = y + this.speedAxisY[i]; // 灰色刻度\n\n var startX = width - (!hideTimeTypeController ? SPEED_CONTROLLER_OFFSET : TOGGLE_MODEL_OFFSET);\n speedGroup.addShape('line', {\n attrs: __assign({\n x1: startX,\n x2: startX + 15,\n y1: axisY,\n y2: axisY\n }, scroller),\n speed: maxSpeed,\n name: 'speed-rect'\n });\n this.speedAxisY[i] = axisY;\n speedNum.push(maxSpeed);\n maxSpeed = maxSpeed - 1;\n } // 速度文本\n\n\n this.speedText = speedGroup.addShape('text', {\n attrs: __assign({\n x: width - (!hideTimeTypeController ? SPEED_CONTROLLER_OFFSET : TOGGLE_MODEL_OFFSET) + 20,\n y: this.speedAxisY[0] + 4,\n text: \"1.0X\",\n fontFamily: this.fontFamily || 'Arial, sans-serif'\n }, text)\n });\n this.speedPoint = speedGroup.addShape('path', {\n attrs: __assign({\n path: this.getPointerPath(width - (!hideTimeTypeController ? SPEED_CONTROLLER_OFFSET : TOGGLE_MODEL_OFFSET), 0),\n matrix: [1, 0, 0, 0, 1, 0, 0, this.speedAxisY[4], 1]\n }, pointer)\n }); // 根据配置在 speedControllerStyle 中的 scale offsetX offsetY 缩放和移动速度控制器\n\n var currentBBox = this.speedGroup.getCanvasBBox();\n var centerX = (currentBBox.maxX + currentBBox.minX) / 2;\n var centerY = (currentBBox.maxY + currentBBox.minY) / 2;\n var matrix = this.speedGroup.getMatrix() || [1, 0, 0, 0, 1, 0, 0, 0, 1];\n matrix = transform(matrix, [['t', -centerX, -centerY], ['s', scale, scale], ['t', centerX + offsetX * scale, centerY + offsetY * scale]]);\n this.speedGroup.setMatrix(matrix);\n };\n\n ControllerBtn.prototype.getPointerPath = function (x, y) {\n return [['M', x, y], ['L', x - 10, y - 4], ['L', x - 10, y + 4], ['Z']];\n };\n\n ControllerBtn.prototype.renderToggleTime = function () {\n var _a;\n\n var width = this.controllerCfg.width;\n\n var timeTypeControllerStyle = __assign(__assign({}, DEFAULT_TIMETYPE_CONTROLLER_STYLE), this.controllerCfg.timeTypeControllerStyle || {});\n\n var _b = timeTypeControllerStyle.scale,\n scale = _b === void 0 ? 1 : _b,\n _c = timeTypeControllerStyle.offsetX,\n offsetX = _c === void 0 ? 0 : _c,\n _d = timeTypeControllerStyle.offsetY,\n offsetY = _d === void 0 ? 0 : _d,\n _e = timeTypeControllerStyle.box,\n box = _e === void 0 ? {} : _e,\n _f = timeTypeControllerStyle.check,\n check = _f === void 0 ? {} : _f,\n _g = timeTypeControllerStyle.text,\n text = _g === void 0 ? {} : _g;\n this.toggleGroup = this.controllerGroup.addGroup({\n name: 'toggle-group'\n });\n this.toggleGroup.addShape('rect', {\n attrs: __assign({\n x: width - TOGGLE_MODEL_OFFSET,\n y: this.speedAxisY[0] + 3.5\n }, box),\n isChecked: false,\n name: 'toggle-model'\n });\n this.checkedIcon = this.toggleGroup.addShape('path', {\n attrs: __assign({\n path: [['M', width - TOGGLE_MODEL_OFFSET + 3, this.speedAxisY[1] + 6], ['L', width - TOGGLE_MODEL_OFFSET + 7, this.speedAxisY[1] + 10], ['L', width - TOGGLE_MODEL_OFFSET + 12, this.speedAxisY[1] + 4]]\n }, check),\n capture: false\n });\n this.checkedIcon.hide();\n this.checkedText = this.toggleGroup.addShape('text', {\n attrs: __assign({\n text: ((_a = this.controllerCfg) === null || _a === void 0 ? void 0 : _a.timePointControllerText) || '单一时间',\n x: width - TOGGLE_MODEL_OFFSET + 15,\n y: this.speedAxisY[0] + 4,\n fontFamily: typeof window !== 'undefined' ? window.getComputedStyle(document.body, null).getPropertyValue('font-family') || 'Arial, sans-serif' : 'Arial, sans-serif'\n }, text)\n }); // 根据配置在 timeTypeControllerStyle 中的 scale offsetX offsetY 缩放和移动速度控制器\n\n var currentBBox = this.toggleGroup.getCanvasBBox();\n var centerX = (currentBBox.maxX + currentBBox.minX) / 2;\n var centerY = (currentBBox.maxY + currentBBox.minY) / 2;\n var matrix = this.toggleGroup.getMatrix() || [1, 0, 0, 0, 1, 0, 0, 0, 1];\n matrix = transform(matrix, [['t', -centerX, -centerY], ['s', scale, scale], ['t', centerX + offsetX * scale, centerY + offsetY * scale]]);\n this.toggleGroup.setMatrix(matrix);\n };\n\n ControllerBtn.prototype.bindEvent = function () {\n var _this = this;\n\n this.speedGroup.on('speed-rect:click', function (evt) {\n var currentPointerY = evt.target.attr('y1');\n\n var pointerMatrix = _this.speedPoint.attr('matrix');\n\n var currentYIdx = _this.speedAxisY.indexOf(pointerMatrix[7] || 0);\n\n var targetYIdx = _this.speedAxisY.indexOf(currentPointerY);\n\n var yDiff = _this.speedAxisY[targetYIdx] - _this.speedAxisY[currentYIdx];\n pointerMatrix = transform(pointerMatrix, [['t', 0, yDiff]]);\n\n _this.speedPoint.setMatrix(pointerMatrix);\n\n _this.currentSpeed = _this.speedAxisY.length - targetYIdx;\n\n _this.speedText.attr('text', _this.currentSpeed + \".0X\");\n\n _this.group.emit(TIMEBAR_CONFIG_CHANGE, {\n speed: _this.currentSpeed,\n type: _this.currentType\n });\n });\n this.speedGroup.on('mousewheel', function (evt) {\n evt.preventDefault();\n var pointerMatrix = _this.speedPoint.attr('matrix') || [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var currentPointerY = pointerMatrix[7];\n\n var currentYIdx = _this.speedAxisY.indexOf(currentPointerY);\n\n if (currentYIdx === -1) {\n // 找到最近的一个 y\n var minDist_1 = Infinity;\n\n _this.speedAxisY.forEach(function (y, idx) {\n var dist = Math.abs(y - currentPointerY);\n\n if (minDist_1 > dist) {\n minDist_1 = dist;\n currentYIdx = idx;\n }\n });\n }\n\n if (evt.originalEvent.deltaY > 0) currentYIdx = Math.max(0, currentYIdx - 1);else currentYIdx = Math.min(_this.speedAxisY.length - 1, currentYIdx + 1);\n var yDiff = _this.speedAxisY[currentYIdx] - currentPointerY;\n pointerMatrix = transform(pointerMatrix, [['t', 0, yDiff]]);\n\n _this.speedPoint.setMatrix(pointerMatrix);\n\n _this.currentSpeed = _this.speedAxisY.length - currentYIdx;\n\n _this.speedText.attr('text', _this.currentSpeed + \".0X\");\n\n _this.group.emit(TIMEBAR_CONFIG_CHANGE, {\n speed: _this.currentSpeed,\n type: _this.currentType\n });\n });\n\n if (this.toggleGroup) {\n this.toggleGroup.on('toggle-model:click', function (evt) {\n var _a, _b;\n\n var isChecked = evt.target.get('isChecked');\n\n if (!isChecked) {\n _this.checkedIcon.show();\n\n _this.checkedText.attr('text', ((_a = _this.controllerCfg) === null || _a === void 0 ? void 0 : _a.timeRangeControllerText) || '时间范围');\n\n _this.currentType = 'single';\n } else {\n _this.checkedIcon.hide();\n\n _this.checkedText.attr('text', ((_b = _this.controllerCfg) === null || _b === void 0 ? void 0 : _b.timePointControllerText) || '单一时间');\n\n _this.currentType = 'range';\n }\n\n evt.target.set('isChecked', !isChecked);\n\n _this.group.emit(TIMEBAR_CONFIG_CHANGE, {\n type: _this.currentType,\n speed: _this.currentSpeed\n });\n });\n }\n };\n\n ControllerBtn.prototype.destroy = function () {\n this.speedGroup.off('speed-rect:click');\n\n if (this.toggleGroup) {\n this.toggleGroup.off('toggle-model:click');\n this.toggleGroup.destroy();\n }\n\n this.speedGroup.destroy();\n };\n\n return ControllerBtn;\n}();\n\nexport default ControllerBtn;","var __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { get, size, assign, each } from '@antv/util';\nimport Trend from './trend';\nimport Handler from './handler';\nimport { isString } from '@antv/util';\nimport ControllerBtn from './controllerBtn';\nimport { VALUE_CHANGE, TIMELINE_START, TIMEBAR_CONFIG_CHANGE, PLAY_PAUSE_BTN, NEXT_STEP_BTN, PRE_STEP_BTN, TIMELINE_END } from './constant';\n/**\n * 一些默认的样式配置\n */\n\nexport var BACKGROUND_STYLE = {\n fill: '#416180',\n opacity: 0.05\n};\nvar SIMPLE_BACKGROUND_STYLE = {\n fill: '#416180',\n opacity: 0.15,\n radius: 5\n};\nexport var FOREGROUND_STYLE = {\n fill: '#5B8FF9',\n opacity: 0.3,\n cursor: 'grab'\n};\nexport var DEFAULT_HANDLER_WIDTH = 2;\nexport var HANDLER_STYLE = {\n width: DEFAULT_HANDLER_WIDTH,\n height: 24\n};\nexport var TEXT_STYLE = {\n textBaseline: 'middle',\n fill: '#000',\n opacity: 0.45\n};\nexport var TICK_LABEL_STYLE = {\n textAlign: 'center',\n textBaseline: 'top',\n fill: '#607889',\n opacity: 0.35\n};\nexport var TICK_LINE_STYLE = {\n lineWidth: 1,\n stroke: '#ccc'\n};\n\nvar TrendTimeBar = function () {\n function TrendTimeBar(cfg) {\n var _this = this;\n\n this.prevX = 0;\n\n this.onMouseDown = function (handler) {\n return function (e) {\n // 1. 记录点击的滑块\n _this.currentHandler = handler;\n var event = e.originalEvent; // 2. 存储当前点击位置\n\n event.stopPropagation();\n event.preventDefault(); // 兼容移动端获取数据\n\n _this.prevX = get(event, 'touches.0.pageX', event.pageX); // 3. 开始滑动的时候,绑定 move 和 up 事件\n\n var containerDOM = _this.canvas.get('container');\n\n containerDOM.addEventListener('mousemove', _this.onMouseMove);\n containerDOM.addEventListener('mouseup', _this.onMouseUp);\n containerDOM.addEventListener('mouseleave', _this.onMouseUp); // 移动端事件\n\n containerDOM.addEventListener('touchmove', _this.onMouseMove);\n containerDOM.addEventListener('touchend', _this.onMouseUp);\n containerDOM.addEventListener('touchcancel', _this.onMouseUp);\n };\n };\n\n this.onMouseMove = function (e) {\n // 滑动过程中,计算偏移,更新滑块,然后 emit 数据出去\n e.stopPropagation();\n e.preventDefault();\n var x = get(e, 'touches.0.pageX', e.pageX); // 横向的 slider 只处理 x\n\n var offsetX = x - _this.prevX;\n\n var offsetXRange = _this.adjustOffsetRange(offsetX / _this.width); // 更新 start end range 范围\n\n\n _this.updateStartEnd(offsetXRange); // 更新 ui\n\n\n _this.updateUI();\n\n _this.prevX = x;\n };\n\n this.onMouseUp = function () {\n // 结束之后,取消绑定的事件\n if (_this.currentHandler) {\n _this.currentHandler = undefined;\n }\n\n var containerDOM = _this.canvas.get('container');\n\n if (containerDOM) {\n containerDOM.removeEventListener('mousemove', _this.onMouseMove);\n containerDOM.removeEventListener('mouseup', _this.onMouseUp); // 防止滑动到 canvas 外部之后,状态丢失\n\n containerDOM.removeEventListener('mouseleave', _this.onMouseUp); // 移动端事件\n\n containerDOM.removeEventListener('touchmove', _this.onMouseMove);\n containerDOM.removeEventListener('touchend', _this.onMouseUp);\n containerDOM.removeEventListener('touchcancel', _this.onMouseUp);\n }\n };\n\n var _a = cfg.x,\n x = _a === void 0 ? 0 : _a,\n _b = cfg.y,\n y = _b === void 0 ? 0 : _b,\n _c = cfg.width,\n width = _c === void 0 ? 100 : _c,\n height = cfg.height,\n _d = cfg.padding,\n padding = _d === void 0 ? 10 : _d,\n trendCfg = cfg.trendCfg,\n _e = cfg.controllerCfg,\n controllerCfg = _e === void 0 ? {\n speed: 1\n } : _e,\n _f = cfg.backgroundStyle,\n backgroundStyle = _f === void 0 ? {} : _f,\n _g = cfg.foregroundStyle,\n foregroundStyle = _g === void 0 ? {} : _g,\n _h = cfg.handlerStyle,\n handlerStyle = _h === void 0 ? {} : _h,\n _j = cfg.textStyle,\n textStyle = _j === void 0 ? {} : _j,\n // 缩略轴的初始位置\n _k = cfg.start,\n // 缩略轴的初始位置\n start = _k === void 0 ? 0 : _k,\n _l = cfg.end,\n end = _l === void 0 ? 1 : _l,\n _m = cfg.minText,\n minText = _m === void 0 ? '' : _m,\n _o = cfg.maxText,\n maxText = _o === void 0 ? '' : _o,\n group = cfg.group,\n graph = cfg.graph,\n canvas = cfg.canvas,\n _p = cfg.tick,\n tick = _p === void 0 ? {\n tickLabelStyle: {},\n tickLineStyle: {},\n tickLabelFormatter: function tickLabelFormatter(d) {\n return d;\n },\n ticks: []\n } : _p,\n type = cfg.type;\n this.graph = graph;\n this.canvas = canvas;\n this.group = group;\n this.timeBarType = type; // position size\n\n this.x = x;\n this.y = y;\n this.width = width;\n this.height = height;\n this.padding = padding;\n this.ticks = tick.ticks;\n this.trendCfg = trendCfg;\n this.controllerCfg = controllerCfg;\n this.currentSpeed = controllerCfg.speed || 1;\n this.tickLabelFormatter = tick.tickLabelFormatter; // style\n\n if (type === 'trend') {\n this.backgroundStyle = __assign(__assign({}, BACKGROUND_STYLE), backgroundStyle);\n } else if (type === 'simple') {\n this.backgroundStyle = __assign(__assign({}, SIMPLE_BACKGROUND_STYLE), backgroundStyle);\n }\n\n this.foregroundStyle = __assign(__assign({}, FOREGROUND_STYLE), foregroundStyle);\n this.handlerStyle = __assign(__assign({}, HANDLER_STYLE), handlerStyle);\n this.textStyle = __assign(__assign({}, TEXT_STYLE), textStyle);\n this.tickLabelStyle = __assign(__assign({}, TICK_LABEL_STYLE), tick.tickLabelStyle);\n this.tickLineStyle = __assign(__assign({}, TICK_LINE_STYLE), tick.tickLineStyle);\n this.currentMode = 'range'; // 初始信息\n\n this.start = start;\n this.end = end;\n this.minText = minText;\n this.maxText = maxText; // 初始化 fontFamily,如果有浏览器,取 body 上的字体,防止文字更新时局部渲染造成的重影\n\n this.fontFamily = typeof window !== 'undefined' ? window.getComputedStyle(document.body, null).getPropertyValue('font-family') || 'Arial, sans-serif' : 'Arial, sans-serif';\n this.renderSlider();\n }\n /**\n * 更新配置\n * @param cfg\n */\n\n\n TrendTimeBar.prototype.update = function (cfg) {\n var x = cfg.x,\n y = cfg.y,\n width = cfg.width,\n height = cfg.height,\n minText = cfg.minText,\n maxText = cfg.maxText,\n start = cfg.start,\n end = cfg.end; // start、end 只能是 0~1 范围\n\n this.start = Math.min(1, Math.max(start, 0));\n this.end = Math.min(1, Math.max(end, 0)); // 如果传了则更新,没有传则不更新\n // @ts-ignore\n\n assign(this, {\n x: x,\n y: y,\n width: width,\n height: height,\n minText: minText,\n maxText: maxText\n }); // 更新 ui,不自动绘制\n\n this.updateUI();\n };\n\n TrendTimeBar.prototype.setText = function (minText, maxText) {\n this.minTextShape.attr('text', minText);\n this.maxTextShape.attr('text', maxText);\n };\n /**\n * 初始化组件结构\n * @private\n */\n\n\n TrendTimeBar.prototype.renderSlider = function () {\n var _this = this;\n\n var _a = this,\n width = _a.width,\n height = _a.height,\n timeBarType = _a.timeBarType; // 趋势图数据\n\n\n if (timeBarType === 'trend' && size(get(this.trendCfg, 'data'))) {\n var trendComponent = new Trend(__assign(__assign({\n x: this.x,\n y: this.y,\n width: width,\n height: height\n }, this.trendCfg), {\n group: this.group\n }));\n this.trendComponent = trendComponent;\n }\n\n var sliderGroup = this.group.addGroup({\n name: 'slider-group'\n }); // 1. 背景\n\n sliderGroup.addShape('rect', {\n attrs: __assign({\n x: 0,\n y: 0,\n width: width,\n height: height\n }, this.backgroundStyle)\n });\n var textGroup = this.group.addGroup(); // 2. 左右文字\n\n if (timeBarType === 'trend') {\n this.minTextShape = textGroup.addShape('text', {\n attrs: __assign({\n x: 0,\n y: height / 2 + this.y,\n textAlign: 'right',\n text: this.minText,\n silent: false,\n fontFamily: this.fontFamily || 'Arial, sans-serif'\n }, this.textStyle),\n capture: false\n });\n this.maxTextShape = textGroup.addShape('text', {\n attrs: __assign({\n y: height / 2 + this.y,\n textAlign: 'left',\n text: this.maxText,\n silent: false,\n fontFamily: this.fontFamily || 'Arial, sans-serif'\n }, this.textStyle),\n capture: false\n });\n } else {\n this.minTextShape = textGroup.addShape('text', {\n attrs: __assign({\n x: 0,\n y: this.y - 10,\n textAlign: 'center',\n text: this.minText,\n silent: false,\n fontFamily: this.fontFamily || 'Arial, sans-serif'\n }, this.textStyle),\n capture: false\n });\n this.maxTextShape = textGroup.addShape('text', {\n attrs: __assign({\n y: this.y - 10,\n textAlign: 'center',\n text: this.maxText,\n silent: false,\n fontFamily: this.fontFamily || 'Arial, sans-serif'\n }, this.textStyle),\n capture: false\n });\n } // 3. 前景 选中背景框\n\n\n this.foregroundShape = this.group.addGroup().addShape('rect', {\n attrs: __assign({\n x: 0,\n y: this.y,\n height: height\n }, this.foregroundStyle)\n });\n this.foregroundShape.on('mousedown', function (e) {\n e.target.attr('cursor', 'grabbing');\n });\n this.foregroundShape.on('mouseup', function (e) {\n e.target.attr('cursor', _this.foregroundStyle.cursor || 'grab');\n }); // 滑块相关的大小信息\n\n var handlerWidth = get(this.handlerStyle, 'width', 2);\n var handlerHeight = get(this.handlerStyle, 'height', 24);\n var minHandleGroup = this.group.addGroup({\n name: 'minHandlerShape'\n }); // 4. 左右滑块\n\n this.minHandlerShape = new Handler({\n name: 'minHandlerShape',\n group: minHandleGroup,\n type: timeBarType,\n x: this.x,\n y: this.y,\n width: handlerWidth,\n height: handlerHeight,\n style: this.handlerStyle\n });\n var maxHandleGroup = this.group.addGroup({\n name: 'maxHandlerShape'\n });\n this.maxHandlerShape = new Handler({\n name: 'maxHandlerShape',\n group: maxHandleGroup,\n type: timeBarType,\n x: this.x,\n y: this.y,\n width: handlerWidth,\n height: handlerHeight,\n style: this.handlerStyle\n }); // 缩略图下面的时间刻度\n\n var tickData = this.ticks;\n var interval = width / (tickData.length - 1);\n this.tickPosList = [];\n\n if (this.textList && this.textList.length) {\n this.textList.forEach(function (text) {\n text.destroy();\n });\n }\n\n var lastX = -Infinity;\n this.textList = tickData.map(function (data, index) {\n _this.tickPosList.push(_this.x + index * interval);\n\n var label;\n\n if (_this.tickLabelFormatter) {\n label = _this.tickLabelFormatter(data);\n\n if (!isString(label) && label) {\n // return true\n label = data.date;\n }\n } else {\n label = data.date;\n } // 文本刻度\n\n\n var text = _this.group.addShape('text', {\n attrs: __assign({\n x: _this.x + index * interval,\n y: _this.y + height + 5,\n text: label,\n fontFamily: _this.fontFamily || 'Arial, sans-serif'\n }, _this.tickLabelStyle)\n }); // 文本刻度上面的竖线\n\n\n var line = _this.group.addShape('line', {\n attrs: __assign({\n x1: _this.x + index * interval,\n y1: _this.y + height + 2,\n x2: _this.x + index * interval,\n y2: _this.y + height + 6\n }, _this.tickLineStyle)\n });\n\n line.toBack();\n var bbox = text.getBBox(); // 抽样,标签与标签间距不小于 10\n\n if (bbox.minX > lastX) {\n text.show();\n line.show();\n lastX = bbox.minX + bbox.width + 10;\n } else {\n text.hide();\n line.hide();\n }\n\n return text;\n }); // 渲染播放、快进和后退的控制按钮\n\n this.controllerBtnGroup = new ControllerBtn(__assign({\n group: this.group,\n x: this.x,\n y: this.y + height + 25,\n width: width,\n height: 35\n }, this.controllerCfg)); // 初始化 minText 和 maxText,方便计算它们的 bbox\n\n this.updateStartEnd(0); // 根据 start end 更新 ui 的位置信息\n\n this.updateUI(); // 移动到对应的位置\n\n sliderGroup.move(this.x, this.y); // 绑定事件鼠标事件\n\n this.bindEvents();\n };\n /**\n * 绑定事件:\n * - 点击\n * - 滑动\n * - 拖拽\n * - 滚动\n * @private\n */\n\n\n TrendTimeBar.prototype.bindEvents = function () {\n var _this = this; // 1. 左滑块的滑动\n\n\n var minHandleShapeGroup = this.group.find(function (group) {\n return group.get('name') === 'minHandlerShape';\n });\n\n if (minHandleShapeGroup) {\n minHandleShapeGroup.on('minHandlerShape-handler:mousedown', this.onMouseDown(this.minHandlerShape));\n minHandleShapeGroup.on('minHandlerShape-handler:touchstart', this.onMouseDown(this.minHandlerShape));\n }\n\n var maxHandleShapeGroup = this.group.find(function (group) {\n return group.get('name') === 'maxHandlerShape';\n }); // 2. 右滑块的滑动\n\n if (maxHandleShapeGroup) {\n maxHandleShapeGroup.on('maxHandlerShape-handler:mousedown', this.onMouseDown(this.maxHandlerShape));\n maxHandleShapeGroup.on('maxHandlerShape-handler:touchstart', this.onMouseDown(this.maxHandlerShape));\n } // 3. 前景选中区域\n\n\n this.foregroundShape.on('mousedown', this.onMouseDown(this.foregroundShape));\n this.foregroundShape.on('touchstart', this.onMouseDown(this.foregroundShape)); // 播放区按钮控制\n\n /** 播放/暂停事件 */\n\n this.group.on(PLAY_PAUSE_BTN + \":click\", function () {\n _this.isPlay = !_this.isPlay;\n _this.currentHandler = _this.maxHandlerShape;\n\n _this.changePlayStatus();\n }); // 处理前进一步的事件\n\n this.group.on(NEXT_STEP_BTN + \":click\", function () {\n _this.currentHandler = _this.maxHandlerShape;\n\n _this.updateStartEnd(0.01);\n\n _this.updateUI();\n }); // 处理后退一步的事件\n\n this.group.on(PRE_STEP_BTN + \":click\", function () {\n _this.currentHandler = _this.maxHandlerShape;\n\n _this.updateStartEnd(-0.01);\n\n _this.updateUI();\n });\n this.group.on(TIMEBAR_CONFIG_CHANGE, function (_a) {\n var type = _a.type,\n speed = _a.speed;\n _this.currentSpeed = speed;\n _this.currentMode = type;\n\n if (type === 'single') {\n _this.minHandlerShape.hide();\n\n _this.foregroundShape.hide();\n\n _this.minTextShape.hide();\n } else if (type === 'range') {\n _this.minHandlerShape.show();\n\n _this.foregroundShape.show();\n\n _this.minTextShape.show();\n }\n });\n };\n /** 输入当前圆点位置,输出离哪个 tick 的位置最近 */\n\n\n TrendTimeBar.prototype.adjustTickIndex = function (timeSelectX) {\n for (var i = 0; i < this.tickPosList.length - 1; i++) {\n if (this.tickPosList[i] <= timeSelectX && timeSelectX <= this.tickPosList[i + 1]) {\n return Math.abs(this.tickPosList[i] - timeSelectX) < Math.abs(timeSelectX - this.tickPosList[i + 1]) ? i : i + 1;\n }\n }\n\n return 0;\n };\n /**\n * 调整 offsetRange,因为一些范围的限制\n * @param offsetRange\n */\n\n\n TrendTimeBar.prototype.adjustOffsetRange = function (offsetRange) {\n // 针对不同的滑动组件,处理的方式不同\n switch (this.currentHandler) {\n case this.minHandlerShape:\n {\n var min = 0 - this.start;\n var max = 1 - this.start;\n return Math.min(max, Math.max(min, offsetRange));\n }\n\n case this.maxHandlerShape:\n {\n var min = 0 - this.end;\n var max = 1 - this.end;\n return Math.min(max, Math.max(min, offsetRange));\n }\n\n case this.foregroundShape:\n {\n var min = 0 - this.start;\n var max = 1 - this.end;\n return Math.min(max, Math.max(min, offsetRange));\n }\n\n default:\n return 0;\n }\n };\n /**\n * 更新起始、结束的控制块位置、文本、范围值(原始值)\n * @param offsetRange\n */\n\n\n TrendTimeBar.prototype.updateStartEnd = function (offsetRange) {\n var minData = this.ticks[this.adjustTickIndex(this.start * this.width)];\n var maxData = this.ticks[this.adjustTickIndex(this.end * this.width)];\n\n if (!this.currentHandler) {\n this.minText = this.tickLabelFormatter ? this.tickLabelFormatter(minData) : minData.date;\n this.maxText = this.tickLabelFormatter ? this.tickLabelFormatter(maxData) : maxData.date;\n return;\n } // 操作不同的组件,反馈不一样\n\n\n switch (this.currentHandler) {\n case this.minHandlerShape:\n // 拖动最小滑块时使用当前最大值设置最大值的文本,以便恢复到默认值\n this.maxText = this.maxTextShape.attr('text');\n this.start += offsetRange;\n this.minText = this.tickLabelFormatter ? this.tickLabelFormatter(minData) : minData.date;\n break;\n\n case this.maxHandlerShape:\n // 拖动最大滑块时使用当前最小值设置最小值的文本,以便恢复到默认值\n this.minText = this.minTextShape.attr('text');\n this.end += offsetRange;\n this.maxText = this.tickLabelFormatter ? this.tickLabelFormatter(maxData) : maxData.date;\n break;\n\n case this.foregroundShape:\n this.start += offsetRange;\n this.end += offsetRange;\n this.minText = this.tickLabelFormatter ? this.tickLabelFormatter(minData) : minData.date;\n this.maxText = this.tickLabelFormatter ? this.tickLabelFormatter(maxData) : maxData.date;\n break;\n\n default:\n break;\n }\n };\n /**\n * 根据移动的比例来更新 ui,更新范围(0-1 范围的比例值)\n * @private\n */\n\n\n TrendTimeBar.prototype.updateUI = function () {\n var _this = this;\n\n if (this.start < 0) {\n this.start = 0;\n }\n\n if (this.end > 1) {\n this.end = 1;\n }\n\n var min = this.x + this.start * this.width;\n var max = this.x + this.end * this.width; // 1. foreground\n\n this.foregroundShape.attr('x', min);\n this.foregroundShape.attr('width', max - min); // 滑块相关的大小信息\n\n var handlerWidth = get(this.handlerStyle, 'width', DEFAULT_HANDLER_WIDTH); // 设置文本\n\n this.setText(this.minText, this.maxText);\n\n var _a = this.dodgeText([min, max]),\n minAttrs = _a[0],\n maxAttrs = _a[1]; // 2. 左侧滑块和文字位置\n\n\n this.minHandlerShape.setX(min - handlerWidth / 2);\n each(minAttrs, function (v, k) {\n return _this.minTextShape.attr(k, v);\n }); // 3. 右侧滑块和文字位置\n\n this.maxHandlerShape.setX(max - handlerWidth / 2);\n each(maxAttrs, function (v, k) {\n return _this.maxTextShape.attr(k, v);\n });\n\n if (this.currentMode === 'range') {\n // 因为存储的 start、end 可能不一定是按大小存储的,所以排序一下,对外是 end >= start\n this.graph.emit(VALUE_CHANGE, {\n value: [this.start, this.end].sort()\n });\n } else if (this.currentMode === 'single') {\n this.graph.emit(VALUE_CHANGE, {\n value: [this.end, this.end]\n });\n }\n };\n /**\n * 调整 text 的位置,自动躲避\n * 根据位置,调整返回新的位置\n * @param range\n */\n\n\n TrendTimeBar.prototype.dodgeText = function (range) {\n var _a, _b;\n\n var TEXTPADDING = 2;\n var handlerWidth = get(this.handlerStyle, 'width', DEFAULT_HANDLER_WIDTH);\n var minTextShape = this.minTextShape;\n var maxTextShape = this.maxTextShape;\n var min = range[0],\n max = range[1];\n var sorted = false; // 如果交换了位置,则对应的 min max 也交换\n\n if (min > max) {\n _a = [max, min], min = _a[0], max = _a[1];\n _b = [maxTextShape, minTextShape], minTextShape = _b[0], maxTextShape = _b[1];\n sorted = true;\n } // 避让规则,优先显示在两侧,只有显示不下的时候,才显示在中间\n\n\n var minBBox = minTextShape.getBBox();\n var maxBBox = maxTextShape.getBBox();\n var minAttrs = null;\n var maxAttrs = null;\n\n if (this.timeBarType === 'trend') {\n minAttrs = min - minBBox.width < this.x + TEXTPADDING ? {\n x: min + handlerWidth / 2 + TEXTPADDING,\n textAlign: 'left'\n } : {\n x: min - handlerWidth / 2 - TEXTPADDING,\n textAlign: 'right'\n };\n maxAttrs = max + maxBBox.width > this.x + this.width ? {\n x: max - handlerWidth / 2 - TEXTPADDING,\n textAlign: 'right'\n } : {\n x: max + handlerWidth / 2 + TEXTPADDING,\n textAlign: 'left'\n };\n } else if (this.timeBarType === 'simple') {\n minAttrs = minBBox.width > min - TEXTPADDING ? {\n x: min + handlerWidth / 2 + TEXTPADDING,\n textAlign: 'center'\n } : {\n x: min - handlerWidth / 2 - TEXTPADDING,\n textAlign: 'center'\n };\n maxAttrs = maxBBox.width > this.width - max - TEXTPADDING ? {\n x: max - handlerWidth / 2 - TEXTPADDING,\n textAlign: 'center'\n } : {\n x: max + handlerWidth / 2 + TEXTPADDING,\n textAlign: 'center'\n };\n }\n\n return !sorted ? [minAttrs, maxAttrs] : [maxAttrs, minAttrs];\n };\n\n TrendTimeBar.prototype.startPlay = function () {\n var _this = this;\n\n return typeof window !== 'undefined' ? window.requestAnimationFrame(function () {\n var _a = _this,\n ticks = _a.ticks,\n width = _a.width;\n var speed = _this.currentSpeed;\n var tickInterval = width / ticks.length;\n var offsetX = tickInterval / ((10 - speed) * 1000 / 60);\n\n var offsetXRange = _this.adjustOffsetRange(offsetX / _this.width);\n\n _this.updateStartEnd(offsetXRange);\n\n _this.updateUI();\n\n if (_this.isPlay) {\n _this.playHandler = _this.startPlay();\n }\n }) : undefined;\n };\n\n TrendTimeBar.prototype.changePlayStatus = function (isSync) {\n if (isSync === void 0) {\n isSync = true;\n }\n\n this.controllerBtnGroup.playButton.update({\n isPlay: this.isPlay\n });\n\n if (this.isPlay) {\n // 开始播放\n this.playHandler = this.startPlay();\n this.graph.emit(TIMELINE_START, null);\n } else {\n // 结束播放\n if (this.playHandler) {\n if (typeof window !== 'undefined') window.cancelAnimationFrame(this.playHandler);\n\n if (isSync) {\n this.graph.emit(TIMELINE_END, null);\n }\n }\n }\n };\n\n TrendTimeBar.prototype.destory = function () {\n this.graph.off(VALUE_CHANGE);\n var group = this.group;\n var minHandleShapeGroup = group.find(function (g) {\n return g.get('name') === 'minHandlerShape';\n });\n\n if (minHandleShapeGroup) {\n minHandleShapeGroup.off('minHandlerShape-handler:mousedown');\n minHandleShapeGroup.off('minHandlerShape-handler:touchstart');\n minHandleShapeGroup.destroy();\n }\n\n var maxHandleShapeGroup = group.find(function (g) {\n return g.get('name') === 'maxHandlerShape';\n }); // 2. 右滑块的滑动\n\n if (maxHandleShapeGroup) {\n maxHandleShapeGroup.off('maxHandlerShape-handler:mousedown');\n maxHandleShapeGroup.off('maxHandlerShape-handler:touchstart');\n maxHandleShapeGroup.destroy();\n } // 3. 前景选中区域\n\n\n this.foregroundShape.off('mousedown');\n this.foregroundShape.off('touchstart');\n this.foregroundShape.destroy();\n group.off(PLAY_PAUSE_BTN + \":click\");\n group.off(NEXT_STEP_BTN + \":click\");\n group.off(PRE_STEP_BTN + \":click\");\n group.off(TIMEBAR_CONFIG_CHANGE);\n group.destroy();\n\n if (this.trendComponent) {\n this.trendComponent.destory();\n }\n };\n\n return TrendTimeBar;\n}();\n\nexport default TrendTimeBar;","import { isString } from '@antv/util';\nimport { createDom, modifyCSS } from '@antv/dom-util';\nexport var BACKGROUND_STYLE = {\n opacity: 0.5,\n fill: '#000'\n};\nexport var ARROW_STYLE = {\n opacity: 0.5,\n fill: '#000',\n r: 5\n};\nexport var TEXT_STYLE = {\n fill: '#fff',\n fontSize: 12\n};\n/**\n * 缩略趋势图\n */\n\nvar TimeBarTooltip = function () {\n function TimeBarTooltip(cfg) {\n var _a = cfg.x,\n x = _a === void 0 ? 0 : _a,\n _b = cfg.y,\n y = _b === void 0 ? 0 : _b,\n container = cfg.container,\n text = cfg.text,\n _c = cfg.padding,\n padding = _c === void 0 ? [4, 4, 4, 4] : _c,\n _d = cfg.className,\n className = _d === void 0 ? 'g6-component-timebar-tooltip' : _d,\n _e = cfg.backgroundColor,\n backgroundColor = _e === void 0 ? '#000' : _e,\n _f = cfg.textColor,\n textColor = _f === void 0 ? '#fff' : _f,\n _g = cfg.opacity,\n opacity = _g === void 0 ? 0.8 : _g,\n _h = cfg.fontSize,\n fontSize = _h === void 0 ? 12 : _h;\n this.container = container;\n this.className = className;\n this.backgroundColor = backgroundColor;\n this.textColor = textColor;\n this.x = x;\n this.y = y;\n this.text = text;\n this.padding = padding;\n this.opacity = opacity;\n this.fontSize = fontSize;\n this.render();\n }\n /**\n * 首次渲染\n * @private\n */\n\n\n TimeBarTooltip.prototype.render = function () {\n var self = this;\n var className = self.className,\n x = self.x,\n y = self.y,\n backgroundColor = self.backgroundColor,\n textColor = self.textColor,\n text = self.text,\n padding = self.padding,\n opacity = self.opacity,\n fontSize = self.fontSize;\n var parentNode = self.container;\n var container = createDom(\"<div class='\" + className + \"' style=\\\"position: absolute; width: fit-content; height: fit-content; opacity: \" + opacity + \"\\\"></div>\");\n\n if (isString(parentNode)) {\n parentNode = document.getElementById(parentNode);\n }\n\n parentNode.appendChild(container);\n self.parentHeight = parentNode.offsetHeight;\n self.parentWidth = parentNode.offsetWidth;\n modifyCSS(container, {\n visibility: 'hidden',\n top: 0,\n left: 0\n });\n var background = createDom(\"\\n <div style='position: absolute; white-space:nowrap; background-color: \" + backgroundColor + \"; font-size: \" + fontSize + \"px; border-radius: 4px; width: fit-content; height: fit-content; color: \" + textColor + \"; padding: \" + padding[0] + \"px \" + padding[1] + \"px \" + padding[2] + \"px \" + padding[3] + \"px'></div>\");\n background.innerHTML = text;\n container.appendChild(background);\n self.backgroundDOM = background;\n var arrow = createDom(\"<div style='position: absolute; width: 0px; height: 0px; border-left: 5px solid transparent; border-right: 5px solid transparent; border-top: 10px solid \" + backgroundColor + \"'></div>\");\n container.appendChild(arrow);\n self.arrowDOM = arrow;\n self.container = container;\n };\n\n TimeBarTooltip.prototype.show = function (cfg) {\n var self = this;\n var text = cfg.text,\n x = cfg.x,\n y = cfg.y,\n clientX = cfg.clientX,\n clientY = cfg.clientY;\n self.backgroundDOM.innerHTML = text;\n var backgroundWidth = self.backgroundDOM.offsetWidth;\n var backgroundHeight = self.backgroundDOM.offsetHeight;\n var arrowWidth = self.arrowDOM.offsetWidth;\n var arrowHeight = self.arrowDOM.offsetHeight;\n modifyCSS(self.container, {\n top: -backgroundHeight - arrowHeight + \"px\",\n left: x + \"px\",\n visibility: 'visible'\n });\n modifyCSS(self.backgroundDOM, {\n marginLeft: -backgroundWidth / 2 + \"px\"\n });\n modifyCSS(self.arrowDOM, {\n marginLeft: -arrowWidth / 2 + \"px\",\n top: backgroundHeight + \"px\"\n });\n var left = x - backgroundWidth / 2;\n var right = x + backgroundWidth / 2;\n\n if (left < 0) {\n modifyCSS(self.backgroundDOM, {\n marginLeft: -backgroundWidth / 2 - left + \"px\"\n });\n } else if (right > self.parentWidth) {\n modifyCSS(self.backgroundDOM, {\n marginLeft: -backgroundWidth / 2 - right + self.parentWidth + 12 + \"px\"\n });\n }\n };\n\n TimeBarTooltip.prototype.hide = function () {\n modifyCSS(this.container, {\n top: 0,\n left: 0,\n visibility: 'hidden'\n });\n };\n\n return TimeBarTooltip;\n}();\n\nexport default TimeBarTooltip;","var __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { isString } from '@antv/util';\nimport TimeBarTooltip from './timeBarTooltip';\nimport ControllerBtn from './controllerBtn';\nimport { VALUE_CHANGE, TIMELINE_START, TIMELINE_END, PLAY_PAUSE_BTN, NEXT_STEP_BTN, PRE_STEP_BTN, TIMEBAR_CONFIG_CHANGE } from './constant';\nvar DEFAULT_SELECTEDTICK_STYLE = {\n fill: '#5B8FF9'\n};\nvar DEFAULT_UNSELECTEDTICK_STYLE = {\n fill: '#e6e8e9'\n};\n\nvar TimeBarSlice = function () {\n function TimeBarSlice(cfgs) {\n this.frameCount = 0;\n this.fontFamily = 'Arial, sans-serif';\n var graph = cfgs.graph,\n canvas = cfgs.canvas,\n group = cfgs.group,\n width = cfgs.width,\n height = cfgs.height,\n padding = cfgs.padding,\n data = cfgs.data,\n start = cfgs.start,\n end = cfgs.end,\n _a = cfgs.x,\n x = _a === void 0 ? 0 : _a,\n _b = cfgs.y,\n y = _b === void 0 ? 0 : _b,\n tickLabelFormatter = cfgs.tickLabelFormatter,\n _c = cfgs.selectedTickStyle,\n selectedTickStyle = _c === void 0 ? DEFAULT_SELECTEDTICK_STYLE : _c,\n _d = cfgs.unselectedTickStyle,\n unselectedTickStyle = _d === void 0 ? DEFAULT_UNSELECTEDTICK_STYLE : _d,\n tooltipBackgroundColor = cfgs.tooltipBackgroundColor,\n tooltipFomatter = cfgs.tooltipFomatter;\n this.graph = graph;\n this.group = group;\n this.sliceGroup = group.addGroup({\n name: 'slice-group'\n });\n this.canvas = canvas;\n this.width = width;\n this.height = height;\n this.padding = padding;\n this.data = data;\n this.start = start;\n this.end = end;\n this.tickLabelFormatter = tickLabelFormatter;\n this.selectedTickStyle = selectedTickStyle;\n this.unselectedTickStyle = unselectedTickStyle;\n this.x = x;\n this.y = y;\n this.tooltipBackgroundColor = tooltipBackgroundColor;\n this.tooltipFomatter = tooltipFomatter; // 初始化 fontFamily,如果有浏览器,取 body 上的字体,防止文字更新时局部渲染造成的重影\n\n this.fontFamily = typeof window !== 'undefined' ? window.getComputedStyle(document.body, null).getPropertyValue('font-family') || 'Arial, sans-serif' : 'Arial, sans-serif';\n this.renderSlices();\n this.initEvent();\n }\n\n TimeBarSlice.prototype.renderSlices = function () {\n var _this = this;\n\n var _a = this,\n width = _a.width,\n height = _a.height,\n padding = _a.padding,\n data = _a.data,\n start = _a.start,\n end = _a.end,\n tickLabelFormatter = _a.tickLabelFormatter,\n selectedTickStyle = _a.selectedTickStyle,\n unselectedTickStyle = _a.unselectedTickStyle;\n\n var realWidth = width - 2 * padding;\n var fontSize = 10;\n var labelLineHeight = 4;\n var labelAreaHeight = 3 * padding + labelLineHeight + fontSize;\n var ticksAreaHeight = height - labelAreaHeight - 2 * padding;\n var gap = 2;\n var ticksLength = data.length;\n var tickWidth = (realWidth - gap * (ticksLength - 1)) / ticksLength;\n this.tickWidth = tickWidth;\n var sliceGroup = this.sliceGroup;\n var tickRects = [];\n var labels = [];\n var startTickId = Math.round(ticksLength * start);\n var endTickId = Math.round(ticksLength * end);\n this.startTickRectId = startTickId;\n this.endTickRectId = endTickId;\n data.forEach(function (d, i) {\n // draw the tick rects\n var selected = i >= startTickId && i <= endTickId;\n var tickStyle = selected ? selectedTickStyle : unselectedTickStyle;\n var rect = sliceGroup.addShape('rect', {\n attrs: __assign({\n x: padding + i * (tickWidth + gap),\n y: padding,\n width: tickWidth,\n height: ticksAreaHeight\n }, tickStyle),\n draggable: true,\n name: \"tick-rect-\" + i\n }); // draw the pick tick rects\n\n var pickRect = sliceGroup.addShape('rect', {\n attrs: {\n x: padding + i * tickWidth + gap * (2 * i - 1) / 2,\n y: padding,\n width: i === 0 || i === ticksLength - 1 ? tickWidth + gap / 2 : tickWidth + gap,\n height: ticksAreaHeight,\n fill: '#fff',\n opacity: 0\n },\n draggable: true,\n name: \"pick-rect-\" + i\n });\n pickRect.toFront();\n var rectBBox = rect.getBBox();\n var centerX = (rectBBox.minX + rectBBox.maxX) / 2;\n tickRects.push({\n rect: rect,\n pickRect: pickRect,\n value: d.date,\n x: centerX,\n y: rectBBox.minY\n });\n var label;\n\n if (tickLabelFormatter) {\n label = tickLabelFormatter(d);\n\n if (!isString(label) && label) {\n // return true\n label = d.date;\n }\n } else if (i % Math.round(ticksLength / 10) === 0) {\n label = d.date;\n }\n\n if (label) {\n labels.push(label); // draw tick lines\n\n var lineStartY = rectBBox.maxY + padding * 2;\n sliceGroup.addShape('line', {\n attrs: {\n stroke: '#BFBFBF',\n x1: centerX,\n y1: lineStartY,\n x2: centerX,\n y2: lineStartY + labelLineHeight\n }\n });\n var labelStartY = lineStartY + labelLineHeight + padding;\n var text = sliceGroup.addShape('text', {\n attrs: {\n fill: '#8c8c8c',\n stroke: '#fff',\n lineWidth: 1,\n x: centerX,\n y: labelStartY,\n textAlign: 'center',\n text: label,\n textBaseline: 'top',\n fontSize: 10,\n fontFamily: _this.fontFamily || 'Arial, sans-serif'\n },\n capture: false\n });\n var textBBox = text.getBBox();\n\n if (textBBox.maxX > width) {\n text.attr('textAlign', 'right');\n } else if (textBBox.minX < 0) {\n text.attr('textAlign', 'left');\n } // draw tick labels\n\n }\n });\n this.tickRects = tickRects; // 渲染播放、快进和后退的控制按钮\n\n var group = this.group;\n this.currentSpeed = 1;\n this.controllerBtnGroup = new ControllerBtn({\n group: group,\n x: this.x,\n y: this.y + height + 5,\n width: width,\n height: 40,\n hideTimeTypeController: true,\n speed: this.currentSpeed,\n fontFamily: this.fontFamily || 'Arial, sans-serif'\n });\n };\n\n TimeBarSlice.prototype.initEvent = function () {\n var _this = this;\n\n var sliceGroup = this.sliceGroup;\n sliceGroup.on('click', function (e) {\n var targetRect = e.target;\n if (targetRect.get('type') !== 'rect' || !targetRect.get('name')) return;\n var id = parseInt(targetRect.get('name').split('-')[2], 10);\n\n if (!isNaN(id)) {\n var tickRects_1 = _this.tickRects; // cancel the selected ticks\n\n var unselectedTickStyle_1 = _this.unselectedTickStyle;\n tickRects_1.forEach(function (tickRect) {\n tickRect.rect.attr(unselectedTickStyle_1);\n });\n var selectedTickStyle = _this.selectedTickStyle;\n tickRects_1[id].rect.attr(selectedTickStyle);\n _this.startTickRectId = id;\n _this.endTickRectId = id;\n var ticksLength = tickRects_1.length;\n var start = id / ticksLength;\n\n _this.graph.emit(VALUE_CHANGE, {\n value: [start, start]\n });\n }\n });\n sliceGroup.on('dragstart', function (e) {\n var tickRects = _this.tickRects; // cancel the selected ticks\n\n var unselectedTickStyle = _this.unselectedTickStyle;\n tickRects.forEach(function (tickRect) {\n tickRect.rect.attr(unselectedTickStyle);\n });\n var targetRect = e.target;\n var id = parseInt(targetRect.get('name').split('-')[2], 10);\n var selectedTickStyle = _this.selectedTickStyle;\n tickRects[id].rect.attr(selectedTickStyle);\n _this.startTickRectId = id;\n var ticksLength = tickRects.length;\n var start = id / ticksLength;\n\n _this.graph.emit(VALUE_CHANGE, {\n value: [start, start]\n });\n\n _this.dragging = true;\n });\n sliceGroup.on('dragover', function (e) {\n if (!_this.dragging) return;\n if (e.target.get('type') !== 'rect') return;\n var id = parseInt(e.target.get('name').split('-')[2], 10);\n var startTickRectId = _this.startTickRectId;\n var tickRects = _this.tickRects;\n var selectedTickStyle = _this.selectedTickStyle;\n var unselectedTickStyle = _this.unselectedTickStyle;\n\n for (var i = 0; i < tickRects.length; i++) {\n var style = i >= startTickRectId && i <= id ? selectedTickStyle : unselectedTickStyle;\n tickRects[i].rect.attr(style);\n }\n\n var ticksLength = tickRects.length;\n _this.endTickRectId = id;\n var start = startTickRectId / ticksLength;\n var end = id / ticksLength;\n\n _this.graph.emit(VALUE_CHANGE, {\n value: [start, end]\n });\n });\n sliceGroup.on('drop', function (e) {\n if (!_this.dragging) return;\n _this.dragging = false;\n if (e.target.get('type') !== 'rect') return;\n var startTickRectId = _this.startTickRectId;\n var id = parseInt(e.target.get('name').split('-')[2], 10);\n if (id < startTickRectId) return;\n var selectedTickStyle = _this.selectedTickStyle;\n var tickRects = _this.tickRects;\n tickRects[id].rect.attr(selectedTickStyle);\n _this.endTickRectId = id;\n var ticksLength = tickRects.length;\n var start = startTickRectId / ticksLength;\n var end = id / ticksLength;\n\n _this.graph.emit(VALUE_CHANGE, {\n value: [start, end]\n });\n }); // tooltip\n\n var _a = this,\n tooltipBackgroundColor = _a.tooltipBackgroundColor,\n tooltipFomatter = _a.tooltipFomatter,\n canvas = _a.canvas;\n\n var tooltip = new TimeBarTooltip({\n container: canvas.get('container'),\n backgroundColor: tooltipBackgroundColor\n });\n var tickRects = this.tickRects;\n tickRects.forEach(function (tickRect) {\n var pickRect = tickRect.pickRect;\n pickRect.on('mouseenter', function (e) {\n var rect = e.target;\n if (rect.get('type') !== 'rect') return;\n var id = parseInt(rect.get('name').split('-')[2], 10);\n var clientPoint = canvas.getClientByPoint(tickRects[id].x, tickRects[id].y);\n tooltip.show({\n x: tickRects[id].x,\n y: tickRects[id].y,\n clientX: clientPoint.x,\n clientY: clientPoint.y,\n text: tooltipFomatter ? tooltipFomatter(tickRects[id].value) : tickRects[id].value\n });\n });\n pickRect.on('mouseleave', function (e) {\n tooltip.hide();\n });\n }); // play controller events\n\n var group = this.group; // 播放区按钮控制\n\n /** 播放/暂停事件 */\n\n group.on(PLAY_PAUSE_BTN + \":click\", function () {\n _this.isPlay = !_this.isPlay;\n\n _this.changePlayStatus();\n }); // 处理前进一步的事件\n\n group.on(NEXT_STEP_BTN + \":click\", function () {\n _this.updateStartEnd(1);\n }); // 处理后退一步的事件\n\n group.on(PRE_STEP_BTN + \":click\", function () {\n _this.updateStartEnd(-1);\n });\n group.on(TIMEBAR_CONFIG_CHANGE, function (_a) {\n var type = _a.type,\n speed = _a.speed;\n _this.currentSpeed = speed;\n });\n };\n\n TimeBarSlice.prototype.changePlayStatus = function (isSync) {\n if (isSync === void 0) {\n isSync = true;\n }\n\n this.controllerBtnGroup.playButton.update({\n isPlay: this.isPlay\n });\n\n if (this.isPlay) {\n // 开始播放\n this.playHandler = this.startPlay();\n this.graph.emit(TIMELINE_START, null);\n } else {\n // 结束播放\n if (this.playHandler) {\n if (typeof window !== 'undefined') window.cancelAnimationFrame(this.playHandler);\n\n if (isSync) {\n this.graph.emit(TIMELINE_END, null);\n }\n }\n }\n };\n\n TimeBarSlice.prototype.startPlay = function () {\n var _this = this;\n\n return typeof window !== 'undefined' ? window.requestAnimationFrame(function () {\n var speed = _this.currentSpeed; // 一分钟刷新一次\n\n if (_this.frameCount % (60 / speed) === 0) {\n _this.frameCount = 0;\n\n _this.updateStartEnd(1);\n }\n\n _this.frameCount++;\n\n if (_this.isPlay) {\n _this.playHandler = _this.startPlay();\n }\n }) : undefined;\n };\n\n TimeBarSlice.prototype.updateStartEnd = function (sign) {\n var self = this;\n var tickRects = this.tickRects;\n var ticksLength = tickRects.length;\n var unselectedTickStyle = this.unselectedTickStyle;\n var selectedTickStyle = this.selectedTickStyle;\n var previousEndTickRectId = self.endTickRectId;\n\n if (sign > 0) {\n self.endTickRectId++;\n } else {\n tickRects[self.endTickRectId].rect.attr(unselectedTickStyle);\n self.endTickRectId--;\n } // 若此时 start 与 end 不同,范围前进/后退/播放\n\n\n if (previousEndTickRectId !== self.startTickRectId) {\n if (self.endTickRectId < self.startTickRectId) {\n self.startTickRectId = self.endTickRectId;\n }\n } else {\n // 否则是单帧的前进/后退/播放\n for (var i = self.startTickRectId; i <= self.endTickRectId - 1; i++) {\n tickRects[i].rect.attr(unselectedTickStyle);\n }\n\n self.startTickRectId = self.endTickRectId;\n }\n\n if (tickRects[self.endTickRectId]) {\n tickRects[self.endTickRectId].rect.attr(selectedTickStyle);\n var start = self.startTickRectId / ticksLength;\n var end = self.endTickRectId / ticksLength;\n this.graph.emit(VALUE_CHANGE, {\n value: [start, end]\n });\n }\n };\n\n TimeBarSlice.prototype.destory = function () {\n this.graph.off(VALUE_CHANGE);\n var group = this.sliceGroup;\n group.off('click');\n group.off('dragstart');\n group.off('dragover');\n group.off('drop');\n this.tickRects.forEach(function (tickRect) {\n var pickRect = tickRect.pickRect;\n pickRect.off('mouseenter');\n pickRect.off('mouseleave');\n });\n this.tickRects.length = 0;\n group.off(PLAY_PAUSE_BTN + \":click\");\n group.off(NEXT_STEP_BTN + \":click\");\n group.off(PRE_STEP_BTN + \":click\");\n group.off(TIMEBAR_CONFIG_CHANGE);\n this.sliceGroup.destroy();\n };\n\n return TimeBarSlice;\n}();\n\nexport default TimeBarSlice;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nvar __rest = this && this.__rest || function (s, e) {\n var t = {};\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n }\n\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n};\n/**\n * 基于 G 的时间轴组件\n */\n\n\nimport { Canvas as GCanvas } from '@antv/g-canvas';\nimport { Canvas as GSVGCanvas } from '@antv/g-svg';\nimport { createDom, modifyCSS } from '@antv/dom-util';\nimport Base from '../base';\nimport TrendTimeBar from './trendTimeBar';\nimport TimeBarSlice from './timeBarSlice';\nimport { VALUE_CHANGE } from './constant';\nimport { isString, throttle } from '@antv/util'; // simple 版本默认高度\n\nvar DEFAULT_SIMPLE_HEIGHT = 4; // trend 版本默认高度\n\nvar DEFAULT_TREND_HEIGHT = 26;\n\nvar TimeBar = function (_super) {\n __extends(TimeBar, _super);\n\n function TimeBar(config) {\n return _super.call(this, config) || this;\n }\n\n TimeBar.prototype.getDefaultCfgs = function () {\n return {\n container: null,\n className: 'g6-component-timebar',\n padding: 10,\n type: 'trend',\n trend: {\n data: [],\n isArea: false,\n smooth: true\n },\n controllerCfg: {\n speed: 1,\n loop: false\n },\n slider: {\n start: 0.1,\n end: 0.9,\n minText: 'min',\n maxText: 'max'\n },\n tick: {\n start: 0.1,\n end: 0.9,\n data: []\n },\n textStyle: {},\n filterEdge: false\n };\n };\n /**\n * 初始化 TimeBar 的容器\n */\n\n\n TimeBar.prototype.initContainer = function () {\n var graph = this.get('graph');\n var _a = this._cfgs,\n width = _a.width,\n height = _a.height;\n var className = this.get('className') || 'g6-component-timebar';\n var container = this.get('container');\n var graphContainer = this.get('graph').get('container');\n var timeBarContainer;\n\n if (!container) {\n timeBarContainer = createDom(\"<div class='\" + className + \"'></div>\");\n modifyCSS(timeBarContainer, {\n position: 'relative'\n });\n } else {\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n timeBarContainer = container;\n }\n\n graphContainer.appendChild(timeBarContainer);\n this.set('timeBarContainer', timeBarContainer);\n var canvas;\n var renderer = graph.get('renderer');\n\n if (renderer === 'SVG') {\n canvas = new GSVGCanvas({\n container: timeBarContainer,\n width: width,\n height: height\n });\n } else {\n canvas = new GCanvas({\n container: timeBarContainer,\n width: width,\n height: height\n });\n }\n\n this.set('canvas', canvas);\n };\n\n TimeBar.prototype.init = function () {\n this.initContainer();\n var canvas = this.get('canvas');\n var timeBarGroup = canvas.addGroup({\n name: 'timebar-group'\n });\n this.set('timeBarGroup', timeBarGroup);\n this.renderTrend();\n this.initEvent();\n var fontFamily = typeof window !== 'undefined' ? window.getComputedStyle(document.body, null).getPropertyValue('font-family') || 'Arial, sans-serif' : 'Arial, sans-serif';\n this.set('fontFamily', fontFamily);\n };\n\n TimeBar.prototype.renderTrend = function () {\n var _a = this._cfgs,\n width = _a.width,\n x = _a.x,\n y = _a.y,\n padding = _a.padding,\n type = _a.type,\n trend = _a.trend,\n slider = _a.slider,\n controllerCfg = _a.controllerCfg,\n textStyle = _a.textStyle,\n tick = _a.tick,\n backgroundStyle = _a.backgroundStyle,\n foregroundStyle = _a.foregroundStyle;\n\n var data = trend.data,\n other = __rest(trend, [\"data\"]);\n\n var realWidth = width - 2 * padding;\n var defaultHeight = type === 'trend' ? DEFAULT_TREND_HEIGHT : DEFAULT_SIMPLE_HEIGHT;\n var graph = this.get('graph');\n var group = this.get('timeBarGroup');\n var canvas = this.get('canvas');\n var timebar = null;\n\n if (type === 'trend' || type === 'simple') {\n timebar = new TrendTimeBar(__assign(__assign({\n graph: graph,\n canvas: canvas,\n group: group,\n type: type,\n x: x + padding,\n y: type === 'trend' ? y + padding : y + padding + 15,\n width: realWidth,\n height: defaultHeight,\n padding: padding,\n backgroundStyle: backgroundStyle,\n foregroundStyle: foregroundStyle,\n trendCfg: __assign(__assign({}, other), {\n data: data.map(function (d) {\n return d.value;\n })\n })\n }, slider), {\n tick: {\n ticks: data,\n tickLabelFormatter: tick.tickLabelFormatter,\n tickLabelStyle: tick.tickLabelStyle,\n tickLineStyle: tick.tickLineStyle\n },\n handlerStyle: __assign(__assign({}, slider.handlerStyle), {\n height: slider.height || defaultHeight\n }),\n controllerCfg: controllerCfg,\n textStyle: textStyle\n }));\n } else if (type === 'tick') {\n // 刻度时间轴\n timebar = new TimeBarSlice(__assign({\n graph: graph,\n canvas: canvas,\n group: group,\n x: x + padding,\n y: y + padding\n }, tick));\n }\n\n this.set('timebar', timebar);\n };\n\n TimeBar.prototype.filterData = function (evt) {\n var _a;\n\n var value = evt.value;\n var trendData = null;\n var type = this._cfgs.type;\n\n if (type === 'trend' || type === 'simple') {\n trendData = this._cfgs.trend.data;\n } else if (type === 'tick') {\n trendData = this._cfgs.tick.data;\n }\n\n if (!trendData || trendData.length === 0) {\n console.warn('请配置 TimeBar 组件的数据');\n return;\n }\n\n var rangeChange = this.get('rangeChange');\n var graph = this.get('graph');\n var min = Math.round(trendData.length * value[0]);\n var max = Math.round(trendData.length * value[1]);\n max = max >= trendData.length ? trendData.length - 1 : max;\n min = min >= trendData.length ? trendData.length - 1 : min;\n var tickLabelFormatter = (_a = this._cfgs.tick) === null || _a === void 0 ? void 0 : _a.tickLabelFormatter;\n var minText = tickLabelFormatter ? tickLabelFormatter(trendData[min]) : trendData[min].date;\n var maxText = tickLabelFormatter ? tickLabelFormatter(trendData[max]) : trendData[max].date;\n\n if (type !== 'tick') {\n var timebar = this.get('timebar');\n timebar.setText(minText, maxText);\n }\n\n if (rangeChange) {\n rangeChange(graph, minText, maxText);\n } else {\n // 自动过滤数据,并渲染 graph\n if (!this.cacheGraphData || this.cacheGraphData.nodes && this.cacheGraphData.nodes.length === 0) {\n this.cacheGraphData = graph.get('data'); // graph.save() as GraphData;\n } // 过滤不在 min 和 max 范围内的节点\n\n\n var filterData = this.cacheGraphData.nodes.filter(function (d) {\n return d.date >= trendData[min].date && d.date <= trendData[max].date;\n });\n var nodeIds_1 = filterData.map(function (node) {\n return node.id;\n });\n var fileterEdges = [];\n\n if (this.cacheGraphData.edges) {\n // 过滤 source 或 target 不在 min 和 max 范围内的边\n fileterEdges = this.cacheGraphData.edges.filter(function (edge) {\n return nodeIds_1.includes(edge.source) && nodeIds_1.includes(edge.target);\n });\n\n if (this.get('filterEdge')) {\n fileterEdges = fileterEdges.filter(function (edge) {\n return edge.date >= trendData[min].date && edge.date <= trendData[max].date;\n });\n }\n }\n\n graph.changeData({\n nodes: filterData,\n edges: fileterEdges\n });\n }\n };\n\n TimeBar.prototype.initEvent = function () {\n var _this = this;\n\n var start = 0;\n var end = 0;\n var type = this._cfgs.type;\n\n if (!type || type === 'trend' || type === 'simple') {\n start = this._cfgs.slider.start;\n end = this._cfgs.slider.end;\n } else if (type === 'tick') {\n start = this._cfgs.tick.start;\n end = this._cfgs.tick.end;\n }\n\n var graph = this.get('graph');\n graph.on('afterrender', function (e) {\n _this.filterData({\n value: [start, end]\n });\n }); // 时间轴的值发生改变的事件\n\n graph.on(VALUE_CHANGE, throttle(function (e) {\n _this.filterData(e);\n }, 200, {\n trailing: true,\n leading: true\n }));\n };\n\n TimeBar.prototype.destroy = function () {\n var timebar = this.get('timebar');\n\n if (timebar && timebar.destory) {\n timebar.destory();\n }\n\n _super.prototype.destroy.call(this);\n\n var timeBarContainer = this.get('timeBarContainer');\n\n if (timeBarContainer) {\n var container = this.get('container');\n\n if (!container) {\n container = this.get('graph').get('container');\n }\n\n if (isString(container)) {\n container = document.getElementById(container);\n }\n\n container.removeChild(timeBarContainer);\n }\n };\n\n return TimeBar;\n}(Base);\n\nexport default TimeBar;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nimport Base from '../base';\nimport { isString, isNil } from '@antv/util';\nimport { modifyCSS, createDom } from '@antv/dom-util';\nimport { Util } from '@antv/g6-core';\nimport { mat3 } from '@antv/matrix-util';\nvar applyMatrix = Util.applyMatrix;\n\nfunction getImgNaturalDimension(img, callback) {\n var nWidth, nHeight;\n\n if (img.naturalWidth) {\n // 现代浏览器\n nWidth = img.naturalWidth;\n nHeight = img.naturalHeight;\n } else {\n // IE6/7/8\n var image_1 = new Image();\n image_1.src = img.src;\n\n image_1.onload = function () {\n if (callback) callback(image_1.width, image_1.height);\n };\n }\n\n return [nWidth, nHeight];\n}\n\nvar ImageMiniMap = function (_super) {\n __extends(ImageMiniMap, _super);\n\n function ImageMiniMap(config) {\n return _super.call(this, config) || this;\n }\n\n ImageMiniMap.prototype.getDefaultCfgs = function () {\n return {\n container: null,\n className: 'g6-minimap',\n viewportClassName: 'g6-minimap-viewport',\n width: 200,\n delegateStyle: {\n fill: '#40a9ff',\n stroke: '#096dd9'\n },\n refresh: true\n };\n };\n\n ImageMiniMap.prototype.getEvents = function () {\n return {\n beforepaint: 'updateViewport',\n beforeanimate: 'disableRefresh',\n afteranimate: 'enableRefresh',\n viewportchange: 'disableOneRefresh'\n };\n }; // 若是正在进行动画,不刷新缩略图\n\n\n ImageMiniMap.prototype.disableRefresh = function () {\n this.set('refresh', false);\n };\n\n ImageMiniMap.prototype.enableRefresh = function () {\n this.set('refresh', true);\n this.updateCanvas();\n };\n\n ImageMiniMap.prototype.disableOneRefresh = function () {\n this.set('viewportChange', true);\n };\n\n ImageMiniMap.prototype.initViewport = function () {\n var _this = this;\n\n var cfgs = this._cfgs; // cWidth and cHeight are the width and height of the minimap's container\n\n var graph = cfgs.graph;\n if (this.destroyed) return;\n var containerDOM = this.get('container');\n\n if (isString(containerDOM)) {\n containerDOM = document.getElementById(containerDOM);\n }\n\n var viewport = createDom(\"<div class=\" + cfgs.viewportClassName + \"\\n style='position:absolute;\\n left:0;\\n top:0;\\n box-sizing:border-box;\\n border: 2px solid #1980ff'>\\n </div>\"); // 计算拖拽水平方向距离\n\n var x = 0; // 计算拖拽垂直方向距离\n\n var y = 0; // 是否在拖拽minimap的视口\n\n var dragging = false; // 缓存viewport当前对于画布的x\n\n var left = 0; // 缓存viewport当前对于画布的y\n\n var top = 0; // 缓存viewport当前宽度\n\n var width = 0; // 缓存viewport当前高度\n\n var height = 0;\n var ratio = 0;\n var zoom = 0;\n containerDOM.addEventListener('mousedown', function (e) {\n cfgs.refresh = false;\n\n if (e.target !== viewport) {\n return;\n } // 如果视口已经最大了,不需要拖拽\n\n\n var style = viewport.style;\n width = parseInt(style.width, 10);\n height = parseInt(style.height, 10);\n\n var cWidth = _this.get('width');\n\n var cHeight = _this.get('height');\n\n if (width > cWidth || height > cHeight) {\n return;\n }\n\n zoom = graph.getZoom();\n ratio = _this.get('ratio');\n dragging = true;\n x = e.clientX;\n y = e.clientY;\n }, false);\n containerDOM.addEventListener('mousemove', function (e) {\n if (!dragging || isNil(e.clientX) || isNil(e.clientY)) {\n return;\n }\n\n var cWidth = _this.get('width');\n\n var cHeight = _this.get('height');\n\n var style = viewport.style;\n left = parseInt(style.left, 10);\n top = parseInt(style.top, 10);\n width = parseInt(style.width, 10);\n height = parseInt(style.height, 10);\n var dx = x - e.clientX;\n var dy = y - e.clientY; // 若视口移动到最左边或最右边了,仅移动到边界\n\n if (left - dx < 0) {\n dx = left;\n } else if (left - dx + width >= cWidth) {\n dx = 0;\n } // 若视口移动到最上或最下边了,仅移动到边界\n\n\n if (top - dy < 0) {\n dy = top;\n } else if (top - dy + height >= cHeight) {\n dy = 0;\n }\n\n left -= dx;\n top -= dy; // 先移动视口,避免移动到边上以后出现视口闪烁\n\n modifyCSS(viewport, {\n left: left + \"px\",\n top: top + \"px\"\n }); // graph 移动需要偏移量 dx/dy * 缩放比例才会得到正确的移动距离\n\n graph.translate(dx * zoom / ratio, dy * zoom / ratio);\n x = e.clientX;\n y = e.clientY;\n }, false);\n containerDOM.addEventListener('mouseleave', function () {\n dragging = false;\n cfgs.refresh = true;\n }, false);\n containerDOM.addEventListener('mouseup', function () {\n dragging = false;\n cfgs.refresh = true;\n }, false);\n this.set('viewport', viewport);\n containerDOM.appendChild(viewport);\n };\n /**\n * 更新 viewport 视图\n */\n\n\n ImageMiniMap.prototype.updateViewport = function () {\n if (this.destroyed) return;\n var ratio = this.get('ratio');\n var cWidth = this.get('width');\n var cHeight = this.get('height');\n var graph = this.get('graph');\n var graphWidth = graph.get('width');\n var graphHeight = graph.get('height');\n var aspectRatio = graphWidth / graphHeight;\n var graphGroup = graph.getGroup(); // 主图的 bbox(矩阵变换相关的 bbox)\n\n var graphCanvasBBox = graphGroup.getCanvasBBox(); // 扩展 graphBBox 到和 graphWidth / graphHeight 等比\n\n var graphCanvasBBoxMean = [(graphCanvasBBox.minX + graphCanvasBBox.maxX) / 2, (graphCanvasBBox.minY + graphCanvasBBox.maxY) / 2];\n var graphCanvasBBoxSize = [graphCanvasBBox.maxX - graphCanvasBBox.minX, graphCanvasBBox.maxY - graphCanvasBBox.minY];\n var expandedGraphCanvasBBox = {\n centerX: graphCanvasBBoxMean[0],\n centerY: graphCanvasBBoxMean[1],\n width: 0,\n height: 0,\n minX: 0,\n minY: 0\n };\n\n if (graphCanvasBBox[0] / graphCanvasBBox[1] > aspectRatio) {\n expandedGraphCanvasBBox.width = graphCanvasBBoxSize[0];\n expandedGraphCanvasBBox.height = expandedGraphCanvasBBox.width / aspectRatio;\n } else {\n expandedGraphCanvasBBox.height = graphCanvasBBoxSize[1];\n expandedGraphCanvasBBox.width = expandedGraphCanvasBBox.height * aspectRatio;\n }\n\n expandedGraphCanvasBBox.minX = graphCanvasBBoxMean[0] - expandedGraphCanvasBBox.width / 2;\n expandedGraphCanvasBBox.minY = graphCanvasBBoxMean[1] - expandedGraphCanvasBBox.height / 2;\n var graphMatrix = graphGroup.getMatrix();\n if (!graphMatrix) graphMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var invertGraphMatrix = mat3.invert([1, 0, 0, 0, 1, 0, 0, 0, 1], graphMatrix);\n var minXY = applyMatrix({\n x: expandedGraphCanvasBBox.minX,\n y: expandedGraphCanvasBBox.minY\n }, invertGraphMatrix); // 扩展 graphBBox 后的 bbox 的左上角对应的 canvas container 坐标\n\n var topLeft = graph.getCanvasByPoint(minXY.x, minXY.y);\n var viewport = this.get('viewport');\n\n if (!viewport) {\n this.initViewport();\n } // Viewport 与 minimap container 的比例 = Graph container 与 expandedGraphBBox 比例\n\n\n var vpToMc = graphWidth / expandedGraphCanvasBBox.width; // viewport 宽高 = vpToMc * minimap container 宽高\n\n var width = vpToMc * cWidth;\n var height = vpToMc * cHeight; // vierport 左上角到 minimap container 的距离 / minimap container 宽高\n // = 主图 expandedBBox 左上角 canvas container 坐标距离 / expandedBBox 宽高\n\n var left = cWidth * -topLeft.x / expandedGraphCanvasBBox.width;\n var top = cHeight * -topLeft.y / expandedGraphCanvasBBox.height;\n var right = left + width;\n var bottom = top + height;\n\n if (left < 0) {\n width += left;\n left = 0;\n }\n\n if (right > cWidth) {\n width = width - (right - cWidth);\n }\n\n if (top < 0) {\n height += top;\n top = 0;\n }\n\n if (bottom > cHeight) {\n height = height - (bottom - cHeight);\n } // 缓存目前缩放比,在移动 minimap 视窗时就不用再计算大图的移动量\n\n\n this.set('ratio', ratio);\n var correctLeft = left + \"px\";\n var correctTop = top + \"px\";\n modifyCSS(viewport, {\n left: correctLeft,\n top: correctTop,\n width: width + \"px\",\n height: height + \"px\"\n });\n };\n\n ImageMiniMap.prototype.init = function () {\n this.initContainer();\n };\n /**\n * 初始化 Minimap 的容器\n */\n\n\n ImageMiniMap.prototype.initContainer = function () {\n var self = this;\n var graph = self.get('graph');\n var graphWidth = graph.get('width');\n var graphHeight = graph.get('height');\n var aspectRatio = graphHeight / graphWidth;\n var className = self.get('className');\n var parentNode = self.get('container'); // size of the minimap's container\n\n var cWidth = self.get('width');\n var cHeight = self.get('height');\n\n if (!cWidth && !cHeight) {\n cWidth = 200;\n }\n\n if (cWidth) {\n cHeight = aspectRatio * cWidth;\n self.set('height', cHeight);\n } else {\n cWidth = 1 / aspectRatio * cHeight;\n self.set('width', cWidth);\n }\n\n var container = createDom(\"<div class='\" + className + \"' style='width: \" + cWidth + \"px; height: \" + cHeight + \"px; overflow: hidden; position: relative;'></div>\");\n\n if (isString(parentNode)) {\n parentNode = document.getElementById(parentNode);\n }\n\n if (parentNode) {\n parentNode.appendChild(container);\n } else {\n graph.get('container').appendChild(container);\n }\n\n self.set('container', container);\n var containerDOM = createDom(\"<div class=\\\"g6-minimap-container\\\" style=\\\"position: relative; width: 100%; height: 100%; text-align: center; display: table;\\\"></div>\");\n container.appendChild(containerDOM);\n var span = createDom(\"<span style=\\\"display: table-cell; vertical-align: middle; \\\"></span>\");\n containerDOM.appendChild(span);\n self.set('containerDOM', containerDOM);\n self.set('containerSpan', span);\n var img = createDom(\"<img alt=\\\"\\\" src=\\\"\" + this.get('graphImg') + \"\\\" style=\\\"display: inline-block; user-select: none;\\\" draggable=\\\"false\\\" />\");\n self.set('imgDOM', img);\n self.updateImgSize();\n span.appendChild(img);\n self.updateCanvas();\n };\n\n ImageMiniMap.prototype.updateImgSize = function () {\n var self = this;\n var imgDOM = self.get('imgDOM');\n var cWidth = self.get('width');\n var cHeight = self.get('height');\n\n imgDOM.onload = function () {\n var naturalSize = getImgNaturalDimension(imgDOM);\n\n if (naturalSize[0] > naturalSize[1]) {\n imgDOM.width = cWidth;\n } else {\n imgDOM.height = cHeight;\n }\n };\n };\n\n ImageMiniMap.prototype.updateCanvas = function () {\n // 如果是在动画,则不刷新视图\n var isRefresh = this.get('refresh');\n\n if (!isRefresh) {\n return;\n }\n\n var graph = this.get('graph');\n\n if (graph.get('destroyed')) {\n return;\n } // 如果是视口变换,也不刷新视图,但是需要重置视口大小和位置\n\n\n if (this.get('viewportChange')) {\n this.set('viewportChange', false);\n this.updateViewport();\n }\n\n var cWidth = this.get('width');\n var graphBBox = graph.get('canvas').getCanvasBBox();\n var width = graphBBox.width;\n var ratio = cWidth / width; // // 更新minimap视口\n\n this.set('ratio', ratio);\n this.updateViewport();\n };\n /**\n * 获取minimap的窗口\n * @return {HTMLElement} 窗口的dom实例\n */\n\n\n ImageMiniMap.prototype.getViewport = function () {\n return this.get('viewport');\n };\n /**\n * 获取minimap的容器dom\n * @return {HTMLElement} dom\n */\n\n\n ImageMiniMap.prototype.getContainer = function () {\n return this.get('container');\n };\n\n ImageMiniMap.prototype.updateGraphImg = function (img) {\n var self = this;\n var oriImgDOM = self.get('imgDOM');\n oriImgDOM.remove();\n self.set('graphImg', img);\n var imgDOM = createDom(\"<img alt=\\\"\\\" src=\\\"\" + img + \"\\\" style=\\\"display: inline-block;\\\" ondragstart=\\\"return false;\\\" onselectstart=\\\"return false;\\\"/>\");\n self.set('imgDOM', imgDOM);\n imgDOM.src = img;\n self.updateImgSize();\n var span = self.get('containerSpan');\n span.appendChild(imgDOM);\n self.updateCanvas();\n };\n\n ImageMiniMap.prototype.destroy = function () {\n var container = this.get('container');\n container.parentNode.removeChild(container);\n };\n\n return ImageMiniMap;\n}(Base);\n\nexport default ImageMiniMap;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { clone } from '@antv/util';\nimport { Util } from '@antv/g6-core';\nimport Base from '../base';\nvar distance = Util.distance;\nvar DELTA = 0.05;\nvar lensDelegateStyle = {\n stroke: '#000',\n strokeOpacity: 0.8,\n lineWidth: 2,\n fillOpacity: 1,\n fill: '#fff'\n};\n\nvar EdgeFilterLens = function (_super) {\n __extends(EdgeFilterLens, _super);\n\n function EdgeFilterLens(config) {\n return _super.call(this, config) || this;\n }\n\n EdgeFilterLens.prototype.getDefaultCfgs = function () {\n return {\n type: 'both',\n trigger: 'mousemove',\n r: 60,\n delegateStyle: clone(lensDelegateStyle),\n showLabel: 'edge',\n scaleRBy: 'wheel'\n };\n }; // class-methods-use-this\n\n\n EdgeFilterLens.prototype.getEvents = function () {\n var events;\n\n switch (this.get('trigger')) {\n case 'click':\n events = {\n click: 'filter'\n };\n break;\n\n case 'drag':\n events = {\n click: 'createDelegate'\n };\n break;\n\n default:\n events = {\n mousemove: 'filter'\n };\n break;\n }\n\n return events;\n };\n\n EdgeFilterLens.prototype.init = function () {\n var self = this;\n var showLabel = self.get('showLabel');\n var showNodeLabel = showLabel === 'node' || showLabel === 'both';\n var showEdgeLabel = showLabel === 'edge' || showLabel === 'both';\n self.set('showNodeLabel', showNodeLabel);\n self.set('showEdgeLabel', showEdgeLabel);\n var shouldShow = self.get('shouldShow');\n if (!shouldShow) self.set('shouldShow', function () {\n return true;\n });\n }; // Create the delegate when the trigger is drag\n\n\n EdgeFilterLens.prototype.createDelegate = function (e) {\n var self = this;\n var lensDelegate = self.get('delegate');\n\n if (!lensDelegate || lensDelegate.destroyed) {\n self.filter(e);\n lensDelegate = self.get('delegate'); // drag to move the lens\n\n lensDelegate.on('dragstart', function (evt) {});\n lensDelegate.on('drag', function (evt) {\n self.filter(evt);\n }); // 绑定调整范围(r)\n // 由于 drag 用于改变 lens 位置,因此在此模式下,drag 不能用于调整 r\n // scaling r\n\n if (this.get('scaleRBy') === 'wheel') {\n lensDelegate.on('mousewheel', function (evt) {\n self.scaleRByWheel(evt);\n });\n }\n }\n };\n /**\n * Scale the range by wheel\n * @param e mouse wheel event\n */\n\n\n EdgeFilterLens.prototype.scaleRByWheel = function (e) {\n var self = this;\n if (!e || !e.originalEvent) return;\n if (e.preventDefault) e.preventDefault();\n var graph = self.get('graph');\n var ratio;\n var lensDelegate = self.get('delegate');\n var lensCenter = lensDelegate ? {\n x: lensDelegate.attr('x'),\n y: lensDelegate.attr('y')\n } : undefined;\n var mousePos = lensCenter || graph.getPointByClient(e.clientX, e.clientY);\n\n if (e.originalEvent.wheelDelta < 0) {\n ratio = 1 - DELTA;\n } else {\n ratio = 1 / (1 - DELTA);\n }\n\n var maxR = self.get('maxR');\n var minR = self.get('minR');\n var r = self.get('r');\n\n if (r > (maxR || graph.get('height')) && ratio > 1 || r < (minR || graph.get('height') * 0.05) && ratio < 1) {\n ratio = 1;\n }\n\n r *= ratio;\n self.set('r', r);\n self.filter(e);\n };\n /**\n * Response function for mousemove, click, or drag to filter out the edges\n * @param e mouse event\n */\n\n\n EdgeFilterLens.prototype.filter = function (e) {\n var self = this;\n var graph = self.get('graph');\n var nodes = graph.getNodes();\n var hitNodesMap = {};\n var r = self.get('r');\n var type = self.get('type');\n var fCenter = {\n x: e.x,\n y: e.y\n };\n self.updateDelegate(fCenter, r);\n var shouldShow = self.get('shouldShow');\n var vShapes = self.get('vShapes');\n\n if (vShapes) {\n vShapes.forEach(function (shape) {\n shape.remove();\n shape.destroy();\n });\n }\n\n vShapes = [];\n nodes.forEach(function (node) {\n var model = node.getModel();\n var x = model.x,\n y = model.y;\n\n if (distance({\n x: x,\n y: y\n }, fCenter) < r) {\n hitNodesMap[model.id] = node;\n }\n });\n var edges = graph.getEdges();\n var hitEdges = [];\n edges.forEach(function (edge) {\n var model = edge.getModel();\n var sourceId = model.source;\n var targetId = model.target;\n\n if (shouldShow(model)) {\n if (type === 'only-source' || type === 'one') {\n if (hitNodesMap[sourceId] && !hitNodesMap[targetId]) hitEdges.push(edge);\n } else if (type === 'only-target' || type === 'one') {\n if (hitNodesMap[targetId] && !hitNodesMap[sourceId]) hitEdges.push(edge);\n } else if (type === 'both' && hitNodesMap[sourceId] && hitNodesMap[targetId]) {\n hitEdges.push(edge);\n }\n }\n });\n var showNodeLabel = self.get('showNodeLabel');\n var showEdgeLabel = self.get('showEdgelabel'); // copy the shapes in hitEdges\n\n var group = graph.get('group');\n hitEdges.forEach(function (edge) {\n var shapes = edge.get('group').get('children');\n shapes.forEach(function (shape) {\n var shapeType = shape.get('type');\n var vShape = group.addShape(shapeType, {\n attrs: shape.attr()\n });\n vShapes.push(vShape);\n\n if (showNodeLabel && shapeType === 'text') {\n vShape.set('visible', true);\n }\n });\n }); // copy the shape sof hitNodes\n\n Object.keys(hitNodesMap).forEach(function (key) {\n var node = hitNodesMap[key];\n var clonedGroup = node.get('group').clone();\n group.add(clonedGroup);\n vShapes.push(clonedGroup);\n\n if (showEdgeLabel) {\n var shapes = clonedGroup.get('children');\n\n for (var j = 0; j < shapes.length; j++) {\n var shape = shapes[j];\n\n if (shape.get('type') === 'text') {\n shape.set('visible', true);\n }\n }\n }\n });\n self.set('vShapes', vShapes);\n };\n /**\n * Adjust part of the parameters, including trigger, type, r, maxR, minR, shouldShow, showLabel, and scaleRBy\n * @param {EdgeFilterLensConfig} cfg\n */\n\n\n EdgeFilterLens.prototype.updateParams = function (cfg) {\n var self = this;\n var r = cfg.r,\n trigger = cfg.trigger,\n minR = cfg.minR,\n maxR = cfg.maxR,\n scaleRBy = cfg.scaleRBy,\n showLabel = cfg.showLabel,\n shouldShow = cfg.shouldShow;\n\n if (!isNaN(cfg.r)) {\n self.set('r', r);\n }\n\n if (!isNaN(maxR)) {\n self.set('maxR', maxR);\n }\n\n if (!isNaN(minR)) {\n self.set('minR', minR);\n }\n\n if (trigger === 'mousemove' || trigger === 'click') {\n self.set('trigger', trigger);\n }\n\n if (scaleRBy === 'wheel' || scaleRBy === 'unset') {\n self.set('scaleRBy', scaleRBy);\n self.get('delegate').remove();\n self.get('delegate').destroy();\n var dPercentText = self.get('dPercentText');\n\n if (dPercentText) {\n dPercentText.remove();\n dPercentText.destroy();\n }\n }\n\n if (showLabel === 'node' || showLabel === 'both') {\n self.set('showNodeLabel', true);\n }\n\n if (showLabel === 'edge' || showLabel === 'both') {\n self.set('showEdgeLabel', true);\n }\n\n if (shouldShow) {\n self.set('shouldShow', shouldShow);\n }\n };\n /**\n * Update the delegate shape of the lens\n * @param {Point} mCenter the center of the shape\n * @param {number} r the radius of the shape\n */\n\n\n EdgeFilterLens.prototype.updateDelegate = function (mCenter, r) {\n var self = this;\n var graph = self.get('graph');\n var lensDelegate = self.get('delegate');\n\n if (!lensDelegate || lensDelegate.destroyed) {\n // 拖动多个\n var parent_1 = graph.get('group');\n var attrs = self.get('delegateStyle') || lensDelegateStyle; // model上的x, y是相对于图形中心的,delegateShape是g实例,x,y是绝对坐标\n\n lensDelegate = parent_1.addShape('circle', {\n attrs: __assign({\n r: r,\n x: mCenter.x,\n y: mCenter.y\n }, attrs),\n name: 'lens-shape',\n draggable: true\n });\n\n if (this.get('trigger') !== 'drag') {\n // 调整范围 r 的监听\n if (this.get('scaleRBy') === 'wheel') {\n // 使用滚轮调整 r\n lensDelegate.on('mousewheel', function (evt) {\n self.scaleRByWheel(evt);\n });\n }\n }\n } else {\n lensDelegate.attr({\n x: mCenter.x,\n y: mCenter.y,\n r: r\n });\n }\n\n self.set('delegate', lensDelegate);\n };\n /**\n * Clear the filtering\n */\n\n\n EdgeFilterLens.prototype.clear = function () {\n var self = this;\n var vShapes = self.get('vShapes');\n\n if (vShapes) {\n vShapes.forEach(function (shape) {\n shape.remove();\n shape.destroy();\n });\n }\n\n vShapes = [];\n self.set('vShapes', vShapes);\n var lensDelegate = self.get('delegate');\n\n if (lensDelegate && !lensDelegate.destroyed) {\n lensDelegate.remove();\n lensDelegate.destroy();\n }\n };\n /**\n * Destroy the component\n */\n\n\n EdgeFilterLens.prototype.destroy = function () {\n this.clear();\n };\n\n return EdgeFilterLens;\n}(Base);\n\nexport default EdgeFilterLens;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nimport { each, mix } from '@antv/util';\nimport { Util } from '@antv/g6-core';\nimport Base from '../base';\nvar pointLineDistance = Util.pointLineDistance; // 对齐线样式\n\nvar alignLineStyle = {\n stroke: '#FA8C16',\n lineWidth: 1\n};\n\nvar SnapLine = function (_super) {\n __extends(SnapLine, _super);\n\n function SnapLine(props) {\n return _super.call(this, props) || this;\n }\n\n SnapLine.prototype.getDefaultCfgs = function () {\n return {\n line: alignLineStyle,\n\n /**\n * item align type\n * @type {String|True|False}\n */\n itemAlignType: 'center',\n\n /**\n * tolerance to item force align\n * @type {String|True|False}\n */\n tolerance: 5,\n horizontalLines: {},\n verticalLines: {},\n alignLines: []\n };\n };\n\n SnapLine.prototype.init = function () {}; // class-methods-use-this\n\n\n SnapLine.prototype.getEvents = function () {\n return {\n 'node:dragstart': 'onDragStart',\n 'node:drag': 'onDrag',\n 'node:dragend': 'onDragEnd'\n };\n };\n\n SnapLine.prototype.onDragStart = function () {\n this.initBoxLine();\n };\n\n SnapLine.prototype.onDrag = function (e) {\n var item = e.item; // 计算辅助线位置,拖动过程中更新辅助线\n\n var delegateShape = item.get('delegateShape') || item;\n var bbox = delegateShape.getBBox();\n var model = item.getModel();\n var dx = model.x - bbox.x;\n var dy = model.y - bbox.y;\n this.show({\n x: bbox.minX + dx,\n y: bbox.minY + dy\n }, {\n width: bbox.width,\n height: bbox.height\n });\n };\n\n SnapLine.prototype.onDragEnd = function () {\n // 拖动结束时候删除辅助线\n this.destory();\n };\n /**\n * 每次开始拖动之前,计算出所有节点在水平和垂直方向上,左中右三条中线,并缓存起来\n *\n * @param {object} item Node节点\n * @memberof AlignLine\n */\n\n\n SnapLine.prototype.initBoxLine = function () {\n var _a = this._cfgs,\n horizontalLines = _a.horizontalLines,\n verticalLines = _a.verticalLines,\n itemAlignType = _a.itemAlignType;\n var graph = this.get('graph');\n var nodes = graph.getNodes();\n nodes.forEach(function (item) {\n var bbox = item.getBBox();\n var nodeId = item.get('id'); // 设置水平方向辅助线\n\n if (itemAlignType === true || itemAlignType === 'horizontal') {\n // tltr: top left top right\n // lcrc: left center right center\n // blbr: bottom left bottom right\n horizontalLines[nodeId + \"tltr\"] = [bbox.minX, bbox.minY, bbox.maxX, bbox.minY, item];\n horizontalLines[nodeId + \"lcrc\"] = [bbox.minX, bbox.centerY, bbox.maxX, bbox.centerY, item];\n horizontalLines[nodeId + \"blbr\"] = [bbox.minX, bbox.maxY, bbox.maxX, bbox.maxY, item];\n } else if (itemAlignType === 'center') {\n horizontalLines[nodeId + \"lcrc\"] = [bbox.minX, bbox.centerY, bbox.maxX, bbox.centerY, item];\n } // 设置垂直方向辅助线\n\n\n if (itemAlignType === true || itemAlignType === 'vertical') {\n // tlbl: top left bottom left\n // tcbc: top center bottom center\n // trbr: top right bottom right\n verticalLines[nodeId + \"tlbl\"] = [bbox.minX, bbox.minY, bbox.minX, bbox.maxY, item];\n verticalLines[nodeId + \"tcbc\"] = [bbox.centerX, bbox.minY, bbox.centerX, bbox.maxY, item];\n verticalLines[nodeId + \"trbr\"] = [bbox.maxX, bbox.minY, bbox.maxX, bbox.maxY, item];\n } else if (itemAlignType === 'center') {\n verticalLines[nodeId + \"tcbc\"] = [bbox.centerX, bbox.minY, bbox.centerX, bbox.maxY, item];\n }\n });\n };\n /**\n * 显示AlignLine\n *\n * @param {object} point 起始点\n * @param {object} bbox BBox\n * @returns\n * @memberof AlignLine\n */\n\n\n SnapLine.prototype.show = function (point, bbox) {\n var originPoint = mix({}, point);\n this.itemAlign(point, bbox, originPoint);\n return point;\n };\n /**\n * 拖动拖出中添加辅助线\n *\n * @param {object} point 起始点\n * @param {object} bbox 代理形状的bbox\n * @param {object} originPoint 原始点,同point\n * @memberof AlignLine\n */\n\n\n SnapLine.prototype.itemAlign = function (point, bbox, originPoint) {\n var _this = this;\n\n var _a = this._cfgs,\n horizontalLines = _a.horizontalLines,\n verticalLines = _a.verticalLines,\n tolerance = _a.tolerance;\n var tc = {\n x: originPoint.x + bbox.width / 2,\n y: originPoint.y\n };\n var cc = {\n x: originPoint.x + bbox.width / 2,\n y: originPoint.y + bbox.height / 2\n };\n var bc = {\n x: originPoint.x + bbox.width / 2,\n y: originPoint.y + bbox.height\n };\n var lc = {\n x: originPoint.x,\n y: originPoint.y + bbox.height / 2\n };\n var rc = {\n x: originPoint.x + bbox.width,\n y: originPoint.y + bbox.height / 2\n };\n var horizontalDis = [];\n var verticalDis = [];\n var alignCfg = null;\n this.clearAlignLine();\n each(horizontalLines, function (line) {\n if (line[4].isVisible) {\n horizontalDis.push(_this.getLineDisObject(line, tc));\n horizontalDis.push(_this.getLineDisObject(line, cc));\n horizontalDis.push(_this.getLineDisObject(line, bc));\n }\n });\n each(verticalLines, function (line) {\n if (line[4].isVisible) {\n verticalDis.push(_this.getLineDisObject(line, lc));\n verticalDis.push(_this.getLineDisObject(line, cc));\n verticalDis.push(_this.getLineDisObject(line, rc));\n }\n });\n horizontalDis.sort(function (a, b) {\n return a.dis - b.dis;\n });\n verticalDis.sort(function (a, b) {\n return a.dis - b.dis;\n });\n\n if (horizontalDis.length !== 0 && horizontalDis[0].dis < tolerance) {\n point.y = horizontalDis[0].line[1] - horizontalDis[0].point.y + originPoint.y;\n alignCfg = {\n type: 'item',\n horizontals: [horizontalDis[0]]\n };\n\n for (var i = 1; i < 3; i++) {\n if (horizontalDis[0].dis === horizontalDis[i].dis) {\n alignCfg.horizontals.push(horizontalDis[i]);\n }\n }\n }\n\n if (verticalDis.length !== 0 && verticalDis[0].dis < tolerance) {\n point.x = verticalDis[0].line[0] - verticalDis[0].point.x + originPoint.x;\n\n if (!alignCfg) {\n alignCfg = {\n type: 'item',\n verticals: [verticalDis[0]]\n };\n } else {\n alignCfg.verticals = [verticalDis[0]];\n }\n\n for (var i = 1; i < 3; i++) {\n if (verticalDis[0].dis === verticalDis[i].dis) {\n alignCfg.verticals.push(verticalDis[i]);\n }\n }\n }\n\n if (alignCfg) {\n alignCfg.bbox = bbox;\n this.addAlignLine(alignCfg);\n }\n };\n /**\n * 根据配置项添加辅助线\n *\n * @param {object} cfg\n * @memberof AlignLine\n */\n\n\n SnapLine.prototype.addAlignLine = function (cfg) {\n var bbox = cfg.bbox,\n type = cfg.type,\n horizontals = cfg.horizontals,\n verticals = cfg.verticals;\n var _a = this._cfgs,\n lineStyle = _a.line,\n alignLines = _a.alignLines;\n var graph = this.get('graph');\n var group = graph.get('group');\n\n if (type === 'item') {\n if (horizontals) {\n each(horizontals, function (horizontal) {\n var refLine = horizontal.line,\n refPoint = horizontal.point;\n var lineCenterX = (refLine[0] + refLine[2]) / 2;\n var x1;\n var x2;\n\n if (refPoint.x < lineCenterX) {\n x1 = refPoint.x - bbox.width / 2;\n x2 = Math.max(refLine[0], refLine[2]);\n } else {\n x1 = refPoint.x + bbox.width / 2;\n x2 = Math.min(refLine[0], refLine[2]);\n }\n\n var lineAttrs = mix({\n x1: x1,\n y1: refLine[1],\n x2: x2,\n y2: refLine[1]\n }, lineStyle);\n var line = group.addShape('line', {\n attrs: lineAttrs,\n capture: false\n });\n alignLines.push(line);\n });\n }\n\n if (verticals) {\n each(verticals, function (vertical) {\n var refLine = vertical.line,\n refPoint = vertical.point;\n var lineCenterY = (refLine[1] + refLine[3]) / 2;\n var y1;\n var y2;\n\n if (refPoint.y < lineCenterY) {\n y1 = refPoint.y - bbox.height / 2;\n y2 = Math.max(refLine[1], refLine[3]);\n } else {\n y1 = refPoint.y + bbox.height / 2;\n y2 = Math.min(refLine[1], refLine[3]);\n }\n\n var lineAtts = mix({\n x1: refLine[0],\n y1: y1,\n x2: refLine[0],\n y2: y2\n }, lineStyle);\n var line = group.addShape('line', {\n attrs: lineAtts,\n capture: false\n });\n alignLines.push(line);\n });\n }\n }\n };\n /**\n * 获取点到线的距离\n *\n * @param {array} line [x1, y1, x2, y2] 线的四个点\n * @param {object} point 点的x和y坐标点 {x, y}\n * @returns\n * @memberof AlignLine\n */\n\n\n SnapLine.prototype.getLineDisObject = function (line, point) {\n return {\n line: line,\n point: point,\n dis: pointLineDistance(line, point)\n };\n };\n\n SnapLine.prototype.getContainer = function () {\n return this.get('container');\n };\n /**\n * 拖动过程中,清楚上次绘制的线\n *\n * @memberof AlignLine\n */\n\n\n SnapLine.prototype.clearAlignLine = function () {\n var alignLines = this._cfgs.alignLines;\n each(alignLines, function (line) {\n line.remove();\n });\n alignLines.length = 0;\n };\n /**\n * 拖动结束时候,情况缓存的节点的辅助线,同时删除绘制的线\n *\n * @memberof AlignLine\n */\n\n\n SnapLine.prototype.destory = function () {\n var _a = this._cfgs,\n horizontalLines = _a.horizontalLines,\n verticalLines = _a.verticalLines;\n var graph = this.get('graph');\n var nodes = graph.getNodes();\n nodes.forEach(function (node) {\n var itemId = node.get('id');\n delete horizontalLines[itemId + \"tltr\"];\n delete horizontalLines[itemId + \"lcrc\"];\n delete horizontalLines[itemId + \"blbr\"];\n delete verticalLines[itemId + \"tlbl\"];\n delete verticalLines[itemId + \"tcbc\"];\n delete verticalLines[itemId + \"trbr\"];\n });\n this.clearAlignLine();\n };\n\n return SnapLine;\n}(Base);\n\nexport default SnapLine;","var __extends = this && this.__extends || function () {\n var _extendStatics = function extendStatics(d, b) {\n _extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) {\n if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n }\n };\n\n return _extendStatics(d, b);\n };\n\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n\n _extendStatics(d, b);\n\n function __() {\n this.constructor = d;\n }\n\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\n\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n }\n\n return t;\n };\n\n return __assign.apply(this, arguments);\n};\n\nimport { modifyCSS, createDom } from '@antv/dom-util';\nimport Base from '../base';\nimport { isArray, isNumber, uniqueId } from '@antv/util';\nimport { Util } from '@antv/g6-core';\nimport { Canvas } from '@antv/g-canvas';\nvar ALLOW_EVENTS = ['click', 'mouseenter'];\n\nvar Legend = function (_super) {\n __extends(Legend, _super);\n\n function Legend(config) {\n return _super.call(this, config) || this;\n }\n\n Legend.prototype.getDefaultCfgs = function () {\n return {\n data: {},\n position: 'top',\n padding: 8,\n margin: 8,\n offsetX: 0,\n offsetY: 0,\n layout: 'horizontal',\n flipPage: false,\n containerStyle: {},\n align: undefined,\n horiSep: 8,\n vertiSep: 8,\n filter: {\n enable: false,\n trigger: 'click'\n }\n };\n };\n\n Legend.prototype.init = function () {\n this.formatArray('padding');\n this.formatArray('margin');\n var filter = this.get('filter') || {};\n var multiple = filter.multiple;\n if (multiple && filter.trigger === 'mouseenter') this.set('multiple', false);\n var align = this.get('align');\n\n if (!align) {\n var positions = this.get('position').split('-');\n if (positions.includes('left')) align = 'left';\n if (positions.includes('right')) align = 'right';else align = 'center';\n this.set('align', align);\n }\n\n var graph = this.get('graph');\n var graphContainer = graph.get('container');\n var container = createDom(\"<div class='g6-legend-container' style=\\\"position: absolute;\\\"></div>\");\n graphContainer.appendChild(container);\n this.set('container', container);\n var size = this.render();\n modifyCSS(container, this.getContainerPos(size));\n this.bindEvents();\n };\n\n Legend.prototype.getContainerPos = function (size) {\n if (size === void 0) {\n size = [0, 0];\n }\n\n var self = this;\n var graph = self.get('graph');\n var offsetX = this.get('offsetX');\n var offsetY = this.get('offsetY');\n var margin = this.get('margin');\n var positions = this.get('position').split('-');\n var posIdxMap = {\n 'top': 0,\n 'right': 1,\n 'bottom': 2,\n 'left': 3\n };\n var x = 0,\n y = 0;\n var containerCSS = {\n left: (graph.getWidth() - size[0]) / 2 + x,\n top: (graph.getHeight() - size[1]) / 2 + y\n };\n positions.forEach(function (pos) {\n var marginValue = margin[posIdxMap[pos]];\n var key = pos;\n\n switch (pos) {\n case 'top':\n marginValue += y;\n break;\n\n case 'left':\n marginValue += x;\n break;\n\n case 'bottom':\n marginValue = graph.getHeight() - size[1] - marginValue + y;\n key = 'top';\n break;\n\n default:\n marginValue = graph.getWidth() - size[0] - marginValue + x;\n key = 'left';\n break;\n }\n\n containerCSS[key] = marginValue;\n });\n containerCSS.top += offsetY + graph.getContainer().offsetTop;\n containerCSS.left += offsetX + graph.getContainer().offsetLeft;\n Object.keys(containerCSS).forEach(function (key) {\n containerCSS[key] = containerCSS[key] + \"px\";\n });\n return containerCSS;\n }; // class-methods-use-this\n\n\n Legend.prototype.bindEvents = function () {\n var self = this;\n var filter = self.get('filter');\n if (!filter || !filter.enable) return;\n var trigger = filter.trigger || 'click';\n\n if (!ALLOW_EVENTS.includes(trigger)) {\n console.warn('Trigger for legend filterling must be \\'click\\' or \\'mouseenter\\', \\'click\\' will take effect by default.');\n trigger = 'click';\n }\n\n var lc = self.get('legendCanvas');\n\n if (trigger === 'mouseenter') {\n lc.on('node-container:mouseenter', function (e) {\n return self.filterData(e);\n });\n lc.on('node-container:mouseleave', function (e) {\n self.clearFilter();\n self.clearActiveLegend();\n });\n } else {\n lc.on('node-container:click', function (e) {\n return self.filterData(e);\n });\n lc.on('click', function (e) {\n if (e.target && e.target.isCanvas && e.target.isCanvas()) {\n self.clearFilter();\n self.clearActiveLegend();\n }\n });\n }\n };\n /**\n * 更新 legend 数据,开放给用户控制\n * @param param\n */\n\n\n Legend.prototype.changeData = function (data) {\n this.set('data', data);\n var size = this.render();\n modifyCSS(this.get('container'), this.getContainerPos(size));\n };\n\n Legend.prototype.activateLegend = function (shape) {\n var filter = this.get('filter');\n var multiple = filter === null || filter === void 0 ? void 0 : filter.multiple;\n if (!multiple) this.clearActiveLegend();\n var shapeGroup = shape.get('parent'); // 若被高亮元素已经处于 active 状态,则取消它的 active 状态\n // 并根据目前是否有其他 active 状态的元素决定是否要设置为 inactive 状态\n\n if (shapeGroup.get('active')) {\n shapeGroup.set('active', false);\n if (this.findLegendItemsByState('active').length) shapeGroup.set('inactive', true);\n } else {\n shapeGroup.set('inactive', false);\n shapeGroup.set('active', true);\n } // 当目前有元素为 active 状态时,将非 active 的元素设置为 inactive\n\n\n if (this.findLegendItemsByState('active').length) {\n this.findLegendItemsByState('active', 'all', false).forEach(function (subGroup) {\n subGroup.set('inactive', true);\n });\n } else {\n this.clearActiveLegend();\n } // 设置样式\n\n\n var stateStyles = (filter === null || filter === void 0 ? void 0 : filter.lengedStateStyles) || {};\n var legendInactive = (stateStyles === null || stateStyles === void 0 ? void 0 : stateStyles.inactive) || {\n opacity: 0.5,\n 'text-shape': {\n opacity: 0.5\n }\n };\n var legendTextInactive = legendInactive['text-shape'] || {};\n this.findLegendItemsByState('inactive').forEach(function (subGroup) {\n var _a = subGroup.get('children'),\n keyShape = _a[0],\n text = _a[1];\n\n keyShape.attr(__assign(__assign({}, keyShape.get('oriAttrs')), legendInactive));\n text.attr(__assign(__assign({}, text.get('oriAttrs')), legendTextInactive));\n });\n var legendActive = (stateStyles === null || stateStyles === void 0 ? void 0 : stateStyles.active) || {\n stroke: '#000',\n lineWidth: 2,\n 'text-shape': {\n fontWeight: 'bold'\n }\n };\n var legendTextActive = legendActive['text-shape'] || {};\n this.findLegendItemsByState('active').forEach(function (subGroup) {\n var _a = subGroup.get('children'),\n keyShape = _a[0],\n text = _a[1];\n\n keyShape.attr(__assign(__assign({}, keyShape.get('oriAttrs')), legendActive));\n text.attr(__assign(__assign({}, text.get('oriAttrs')), legendTextActive));\n });\n };\n\n Legend.prototype.findLegendItemsByState = function (stateName, type, value) {\n if (type === void 0) {\n type = 'all';\n }\n\n if (value === void 0) {\n value = true;\n }\n\n var group = this.get('legendCanvas').find(function (e) {\n return e.get('name') === 'root';\n });\n var nodeGroup = group.find(function (e) {\n return e.get('name') === 'node-group';\n });\n var edgeGroup = group.find(function (e) {\n return e.get('name') === 'edge-group';\n });\n if (type === 'node') return nodeGroup.get('children').filter(function (g) {\n return !!g.get(stateName) === value;\n });\n if (type === 'edge') return edgeGroup.get('children').filter(function (g) {\n return !!g.get(stateName) === value;\n });\n return nodeGroup.get('children').filter(function (g) {\n return !!g.get(stateName) === value;\n }).concat(edgeGroup.get('children').filter(function (g) {\n return !!g.get(stateName) === value;\n }));\n };\n\n Legend.prototype.clearActiveLegend = function () {\n var lg = this.get('legendCanvas');\n var group = lg.find(function (e) {\n return e.get('name') === 'root';\n });\n var groups = [group.find(function (e) {\n return e.get('name') === 'node-group';\n }), group.find(function (e) {\n return e.get('name') === 'edge-group';\n })];\n groups.forEach(function (itemGroup) {\n itemGroup.get('children').forEach(function (subGroup) {\n subGroup.set('active', false);\n subGroup.set('inactive', false);\n\n var _a = subGroup.get('children'),\n keyShape = _a[0],\n text = _a[1];\n\n keyShape.attr(keyShape.get('oriAttrs'));\n text.attr(text.get('oriAttrs'));\n });\n });\n };\n /**\n * 高亮和置灰图例,并过滤主图元素\n * @param param\n */\n\n\n Legend.prototype.filterData = function (e) {\n var filter = this.get('filter');\n var filterFunctions = filter === null || filter === void 0 ? void 0 : filter.filterFunctions;\n if (!filter || !filterFunctions) return;\n var lc = this.get('legendCanvas');\n var graph = this.get('graph');\n var activeState = filter.graphActiveState || 'active';\n var inactiveState = filter.graphInactiveState || 'inactive';\n var multiple = filter.multiple;\n this.clearFilter();\n if (!multiple) this.clearActiveLegend(); // 设置 legend 的高亮状态\n\n this.activateLegend(e.target);\n var group = lc.find(function (e) {\n return e.get('name') === 'root';\n });\n var nodeGroup = group.find(function (e) {\n return e.get('name') === 'node-group';\n });\n var edgeGroup = group.find(function (e) {\n return e.get('name') === 'edge-group';\n });\n var activeNodeLegend = nodeGroup.get('children').filter(function (e) {\n return e.get('active');\n });\n var activeEdgeLegend = edgeGroup.get('children').filter(function (e) {\n return e.get('active');\n });\n var activeCount = 0;\n var typeFuncs = ['getNodes', 'getEdges'];\n typeFuncs.forEach(function (typeFunc) {\n graph[typeFunc]().forEach(function (graphItem) {\n var active = false;\n var activeLegend = typeFunc === 'getNodes' ? activeNodeLegend : activeEdgeLegend;\n activeLegend.forEach(function (itemGroup) {\n var func = filterFunctions[itemGroup.get('id')];\n active = active || func(graphItem.getModel());\n });\n\n if (active) {\n graph.setItemState(graphItem, inactiveState, false);\n graph.setItemState(graphItem, activeState, true);\n activeCount++;\n } else {\n graph.setItemState(graphItem, activeState, false);\n graph.setItemState(graphItem, inactiveState, true);\n }\n });\n });\n if (!activeCount) typeFuncs.forEach(function (typeFunc) {\n graph[typeFunc]().forEach(function (graphItem) {\n graph.clearItemStates(graphItem, [inactiveState]);\n });\n });\n };\n /**\n * 清除主图相关状态\n * @param param\n */\n\n\n Legend.prototype.clearFilter = function () {\n // 清除 legend 的高亮状态\n var graph = this.get('graph');\n var filter = this.get('filter');\n if (!filter) return;\n var activeState = filter.graphActiveState || 'active';\n var inactiveState = filter.graphInactiveState || 'inactive';\n graph.getNodes().forEach(function (node) {\n graph.clearItemStates(node, [activeState, inactiveState]);\n });\n graph.getEdges().forEach(function (edge) {\n graph.clearItemStates(edge, [activeState, inactiveState]);\n });\n };\n /**\n * 渲染 legend 图\n * @param param\n */\n\n\n Legend.prototype.render = function () {\n var _this = this;\n\n this.processData();\n var lc = this.get('legendCanvas');\n\n if (!lc) {\n lc = new Canvas({\n container: this.get('container'),\n width: 200,\n height: 200\n });\n var rootGroup = lc.addGroup({\n name: 'root'\n });\n rootGroup.addGroup({\n name: 'node-group'\n });\n rootGroup.addGroup({\n name: 'edge-group'\n }); // nodeStateStyles: {\n // legendActive,\n // legendInactive\n // }\n\n this.set('legendCanvas', lc);\n }\n\n var group = lc.find(function (e) {\n return e.get('name') === 'root';\n });\n var nodeGroup = group.find(function (e) {\n return e.get('name') === 'node-group';\n });\n var edgeGroup = group.find(function (e) {\n return e.get('name') === 'edge-group';\n });\n var itemsData = this.get('itemsData');\n var itemTypes = ['nodes', 'edges'];\n var itemGroup = [nodeGroup, edgeGroup];\n itemTypes.forEach(function (itemType, i) {\n itemsData[itemType].forEach(function (data) {\n var _a;\n\n var subGroup = itemGroup[i].addGroup({\n id: data.id,\n name: 'node-container'\n });\n var attrs;\n var shapeType = data.type;\n\n var _b = _this.getShapeSize(data),\n width = _b.width,\n height = _b.height,\n r = _b.r;\n\n var style = _this.getStyle(itemType.substr(0, 4), data);\n\n switch (data.type) {\n case 'circle':\n attrs = {\n r: r,\n x: 0,\n y: 0\n };\n break;\n\n case 'rect':\n attrs = {\n width: width,\n height: height,\n x: -width / 2,\n y: -height / 2\n };\n break;\n\n case 'ellipse':\n attrs = {\n r1: width,\n r2: height,\n x: 0,\n y: 0\n };\n break;\n\n case 'line':\n attrs = {\n x1: -width / 2,\n y1: 0,\n x2: width / 2,\n y2: 0\n };\n shapeType = 'line';\n break;\n\n case 'quadratic':\n attrs = {\n path: [['M', -width / 2, 0], ['Q', 0, width / 2, width / 2, 0]]\n };\n shapeType = 'path';\n break;\n\n case 'cubic':\n attrs = {\n path: [['M', -width / 2, 0], ['C', -width / 6, width / 2, width / 6, -width / 2, width / 2, 0]]\n };\n shapeType = 'path';\n break;\n\n default:\n attrs = {\n r: r,\n x: 0,\n y: 0\n };\n break;\n }\n\n var keyShape = subGroup.addShape(shapeType, {\n attrs: __assign(__assign({}, attrs), style),\n name: data.type + \"-node-keyShape\",\n oriAttrs: __assign({\n opacity: 1\n }, style)\n });\n\n if (data.label) {\n var keyShapeBBox = keyShape.getBBox();\n var labelStyle = ((_a = data.labelCfg) === null || _a === void 0 ? void 0 : _a.style) || {};\n\n var attrs_1 = __assign({\n textAlign: 'begin',\n fontSize: 12,\n textBaseline: 'middle',\n fill: '#000',\n opacity: 1,\n fontWeight: 'normal'\n }, labelStyle);\n\n subGroup.addShape('text', {\n attrs: __assign({\n x: keyShapeBBox.maxX + 4,\n y: 0,\n text: data.label\n }, attrs_1),\n className: 'legend-label',\n name: data.type + \"-node-text\",\n oriAttrs: attrs_1\n });\n }\n });\n });\n var padding = this.get('padding');\n var titleShape;\n var titleGroup = group.find(function (e) {\n return e.get('name') === 'title-container';\n });\n var titleGroupBBox = {\n height: 0,\n maxY: 0,\n width: 0\n };\n\n if (this.get('title')) {\n if (!titleGroup) {\n titleGroup = group.addGroup({\n name: 'title-container'\n });\n }\n\n var defaultTitleStyle = {\n fontSize: 20,\n fontFamily: 'Arial',\n fontWeight: 300,\n textBaseline: 'top',\n textAlign: 'center',\n fill: \"#000\",\n x: 0,\n y: padding[0]\n };\n var titleConfig = this.get('titleConfig') || {};\n var style = Object.assign(defaultTitleStyle, titleConfig.style || {});\n titleShape = titleGroup.addShape('text', {\n attrs: __assign({\n text: this.get('title')\n }, style)\n });\n titleGroupBBox = titleGroup.getCanvasBBox();\n titleGroup.setMatrix([1, 0, 0, 0, 1, 0, titleConfig.offsetX, titleConfig.offsetY, 1]);\n }\n\n this.layoutItems();\n var lcBBox = group.getCanvasBBox();\n var nodeGroupBBox = nodeGroup.getCanvasBBox(); // 若有图形超过边界的情况,平移回来\n\n var nodeGroupBeginX = nodeGroupBBox.minX < 0 ? Math.abs(nodeGroupBBox.minX) + padding[3] : padding[3];\n var nodeGroupBeginY = titleGroupBBox.maxY < nodeGroupBBox.minY ? Math.abs(titleGroupBBox.maxY - nodeGroupBBox.minY) + padding[0] : titleGroupBBox.maxY + padding[0];\n var nodeGroupMatrix = [1, 0, 0, 0, 1, 0, nodeGroupBeginX, nodeGroupBeginY, 1];\n nodeGroup.setMatrix(nodeGroupMatrix);\n lcBBox = group.getCanvasBBox();\n var size = [lcBBox.minX + lcBBox.width + padding[1], lcBBox.minY + lcBBox.height + padding[2]]; // 根据 size 和 titleConfig 调整 title 位置,再调整 nodeGroup 位置\n\n if (titleShape) {\n var titleConfig = __assign({\n position: 'center',\n offsetX: 0,\n offsetY: 0\n }, this.get('titleConfig'));\n\n titleGroupBBox = titleGroup.getCanvasBBox();\n var titleGroupMatrix = titleGroup.getMatrix() || [1, 0, 0, 0, 1, 0, 0, 0, 1];\n\n if (titleConfig.position === 'center') {\n titleGroupMatrix[6] = size[0] / 2 + titleConfig.offsetX;\n } else if (titleConfig.position === 'right') {\n titleGroupMatrix[6] = size[0] - padding[3] + titleConfig.offsetX;\n titleShape.attr({\n textAlign: 'right'\n });\n } else {\n titleGroupMatrix[6] = padding[3] + titleConfig.offsetX;\n titleShape.attr({\n textAlign: 'left'\n });\n }\n\n titleGroup.setMatrix(titleGroupMatrix);\n titleGroupBBox = titleGroup.getCanvasBBox(); // 若有图形超过边界的情况,平移回来\n\n nodeGroupBeginX = nodeGroupBBox.minX < 0 ? Math.abs(nodeGroupBBox.minX) + padding[3] : padding[3];\n nodeGroupBeginY = nodeGroupBBox.minY < titleGroupBBox.maxY ? Math.abs(titleGroupBBox.maxY - nodeGroupBBox.minY) + padding[0] : titleGroupBBox.maxY + padding[0];\n nodeGroupMatrix = [1, 0, 0, 0, 1, 0, nodeGroupBeginX, nodeGroupBeginY, 1];\n nodeGroup.setMatrix(nodeGroupMatrix);\n var edgeGroupMatrix_1 = [1, 0, 0, 0, 1, 0, nodeGroupBeginX, nodeGroupBeginY, 1];\n if (this.get('layout') === 'vertical') edgeGroupMatrix_1[6] += nodeGroupBBox.maxX + this.get('horiSep');else edgeGroupMatrix_1[7] += nodeGroupBBox.maxY + this.get('vertiSep');\n edgeGroup.setMatrix(edgeGroupMatrix_1);\n } else {\n // 没有 title,也需要平移 edgeGroup\n nodeGroupBBox = nodeGroup.getCanvasBBox();\n var edgeGroupMatrix_2 = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n if (this.get('layout') === 'vertical') edgeGroupMatrix_2[6] += nodeGroupMatrix[6] + nodeGroupBBox.maxX + this.get('horiSep');else edgeGroupMatrix_2[7] += nodeGroupMatrix[7] + nodeGroupBBox.maxY + this.get('vertiSep');\n edgeGroup.setMatrix(edgeGroupMatrix_2);\n }\n\n lcBBox = group.getCanvasBBox();\n nodeGroupBBox = nodeGroup.getCanvasBBox();\n nodeGroupMatrix = nodeGroup.getMatrix() || [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var edgeGroupMatrix = edgeGroup.getMatrix() || [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var edgeGroupBBox = edgeGroup.getCanvasBBox();\n size = [Math.max(nodeGroupBBox.width + nodeGroupMatrix[6], edgeGroupBBox.width + edgeGroupMatrix[6]) + padding[1], Math.max(nodeGroupBBox.height + nodeGroupMatrix[7], edgeGroupBBox.height + edgeGroupMatrix[7]) + padding[2]];\n lc.changeSize(size[0], size[1]); // 更新容器背景样式\n\n var containerStyle = this.get('containerStyle');\n var viewportMatrix = group.getMatrix() || [1, 0, 0, 0, 1, 0, 0, 0, 1];\n var beginPos = Util.invertMatrix({\n x: 0,\n y: 0\n }, viewportMatrix);\n var backRect = group.addShape('rect', {\n attrs: __assign({\n x: beginPos.x + (containerStyle.lineWidth || 1),\n y: beginPos.y + (containerStyle.lineWidth || 1),\n width: size[0] - 2 * (containerStyle.lineWidth || 1),\n height: size[1] - 2 * (containerStyle.lineWidth || 1),\n fill: \"#f00\",\n stroke: '#000',\n lineWidth: 1,\n opacity: 0.5\n }, containerStyle),\n name: 'legend-back-rect',\n capture: false\n });\n backRect.toBack();\n return size;\n };\n\n Legend.prototype.layoutItems = function () {\n var lc = this.get('legendCanvas');\n var horiSep = this.get('horiSep');\n var vertiSep = this.get('vertiSep');\n var layout = this.get('layout');\n var align = this.get('align');\n var begin = [0, 0];\n var group = lc.find(function (e) {\n return e.get('name') === 'root';\n });\n var nodeGroup = group.find(function (e) {\n return e.get('name') === 'node-group';\n });\n var edgeGroup = group.find(function (e) {\n return e.get('name') === 'edge-group';\n });\n var nodeLegendSize = {\n min: 0,\n max: -Infinity\n };\n var rowMaxY = -Infinity;\n nodeGroup.get('children').forEach(function (cNodeGroup, i) {\n if (i === 0) nodeLegendSize.min = begin[0];\n var keyShape = cNodeGroup.get('children')[0];\n var bbox = cNodeGroup.getCanvasBBox();\n\n var _a = keyShape.getBBox(),\n keyShapeWidth = _a.width,\n keyShapeHeight = _a.height;\n\n var curHeight = 0,\n x = 0,\n y = 0;\n\n if (layout === 'vertical') {\n x = begin[1];\n y = begin[0] + keyShapeWidth / 2;\n begin[0] = y + bbox.height + vertiSep;\n curHeight = bbox.maxX + x + keyShapeWidth / 2;\n } else {\n x = begin[0] + keyShapeWidth / 2;\n y = begin[1];\n begin[0] = x + bbox.width + horiSep;\n curHeight = bbox.maxY + y + keyShapeHeight / 2;\n }\n\n if (begin[0] > nodeLegendSize.max) nodeLegendSize.max = begin[0];\n if (curHeight > rowMaxY) rowMaxY = curHeight;\n cNodeGroup.setMatrix([1, 0, 0, 0, 1, 0, x, y, 1]);\n });\n var nw = nodeLegendSize.max - nodeLegendSize.min;\n var edgeLegendSize = {\n min: 0,\n max: -Infinity\n };\n var nodeGroupBBox = nodeGroup.getCanvasBBox();\n begin[0] = 0;\n begin[1] = layout === 'vertical' ? nodeGroupBBox.maxX + horiSep : nodeGroupBBox.maxY + vertiSep;\n edgeGroup.get('children').forEach(function (subGroup, i) {\n if (i === 0) edgeLegendSize.min = begin[0];\n var keyShape = subGroup.get('children')[0];\n var bbox = subGroup.getCanvasBBox();\n\n var _a = keyShape.getBBox(),\n keyShapeWidth = _a.width,\n keyShapeHeight = _a.height;\n\n var x = 0,\n y = 0;\n\n if (layout === 'vertical') {\n x = begin[1];\n y = begin[0];\n begin[0] = y + bbox.height + vertiSep;\n subGroup.setMatrix([1, 0, 0, 0, 1, 0, 0, y + keyShapeHeight / 2, 1]);\n } else {\n x = begin[0];\n y = begin[1];\n begin[0] = x + bbox.width + horiSep;\n subGroup.setMatrix([1, 0, 0, 0, 1, 0, x + keyShapeWidth / 2, 0, 1]);\n }\n\n if (begin[0] > edgeLegendSize.max) edgeLegendSize.max = begin[0];\n });\n var ew = edgeLegendSize.max - edgeLegendSize.min;\n\n if (align && align !== '' && align !== 'left') {\n var widthDiff = nw - ew;\n var movement_1 = align === 'center' ? Math.abs(widthDiff) / 2 : Math.abs(widthDiff);\n var shouldAdjustGroup = widthDiff < 0 ? nodeGroup : edgeGroup;\n shouldAdjustGroup.get('children').forEach(function (subGroup) {\n var matrix = subGroup.getMatrix() || [1, 0, 0, 0, 1, 0, 0, 0, 1];\n if (layout === 'vertical') matrix[7] += movement_1;else matrix[6] += movement_1;\n subGroup.setMatrix(matrix);\n });\n }\n };\n\n Legend.prototype.processData = function () {\n var data = this.get('data');\n var itemsData = {\n nodes: [],\n edges: []\n };\n\n if (data.nodes) {\n data.nodes.sort(function (a, b) {\n return a.order - b.order;\n });\n data.nodes.forEach(function (node) {\n var _a, _b, _c, _d, _e;\n\n var size = node.size || [((_a = node.style) === null || _a === void 0 ? void 0 : _a.width) || ((_b = node.style) === null || _b === void 0 ? void 0 : _b.r) || 8, ((_c = node.style) === null || _c === void 0 ? void 0 : _c.height) || ((_d = node.style) === null || _d === void 0 ? void 0 : _d.r) || 8];\n var labelStyle = ((_e = node.labelCfg) === null || _e === void 0 ? void 0 : _e.style) || {};\n itemsData.nodes.push({\n id: node.id || uniqueId(),\n type: node.type || 'circle',\n style: __assign({}, node.style),\n order: node.order,\n label: node.label,\n itemType: 'node',\n size: size,\n labelCfg: {\n position: 'right',\n style: __assign({\n fontFamily: \"Arial\"\n }, labelStyle)\n }\n });\n });\n }\n\n if (data.edges) {\n data.edges.sort(function (a, b) {\n return a.order - b.order;\n });\n data.edges.forEach(function (edge) {\n var _a, _b;\n\n var type = edge.type || 'line';\n if (edge.type === 'cubic-horizontal') type = 'cubic';\n var labelStyle = ((_a = edge.labelCfg) === null || _a === void 0 ? void 0 : _a.style) || {};\n var size = edge.size || [((_b = edge.style) === null || _b === void 0 ? void 0 : _b.width) || 8, 1];\n itemsData.edges.push({\n id: edge.id || uniqueId(),\n type: type,\n size: size,\n style: __assign({\n lineWidth: isArray(size) ? size[1] : 1\n }, edge.style),\n order: edge.order,\n label: edge.label,\n itemType: 'edge',\n labelCfg: {\n position: 'right',\n style: __assign({\n fontFamily: \"Arial\"\n }, labelStyle)\n }\n });\n });\n }\n\n this.set('itemsData', itemsData);\n };\n\n Legend.prototype.getContainer = function () {\n return this.get('container');\n };\n\n Legend.prototype.formatArray = function (key) {\n var value = this.get(key);\n if (isNumber(value)) this.set(key, [value, value, value, value]);else if (isArray(value)) {\n switch (value.length) {\n case 0:\n this.set(key, [0, 0, 0, 0]);\n break;\n\n case 1:\n this.set(key, [value[0], value[0], value[0], value[0]]);\n break;\n\n case 2:\n this.set(key, [value[0], value[1], value[0], value[1]]);\n break;\n\n case 3:\n this.set(key, [value[0], value[1], value[2], value[1]]);\n break;\n\n default:\n break;\n }\n }\n return this.get(key);\n };\n\n Legend.prototype.getShapeSize = function (data) {\n var width, height, r;\n\n if (data.size) {\n if (isArray(data.size)) {\n width = data.size[0];\n height = data.size[1] || data.size[0];\n r = data.size[0] / 2;\n } else if (isNumber(data.size)) {\n width = data.size;\n height = data.size;\n r = data.size / 2;\n }\n }\n\n if (data.style) {\n if (data.style.width) width = data.style.width;\n if (data.style.height) height = data.style.height;\n if (data.style.r) r = data.style.r;\n }\n\n if (!r) r = 5;\n if (!width) width = r;\n if (!height) height = r;\n return {\n width: width,\n height: height,\n r: r\n };\n };\n\n Legend.prototype.getStyle = function (type, data) {\n var defaultStyle = type === 'node' ? {\n fill: '#ccc',\n lineWidth: 0\n } : {\n stroke: '#000',\n lineWidth: 1\n };\n return __assign(__assign({}, defaultStyle), data.style || {});\n };\n\n Legend.prototype.destroy = function () {\n var graph = this.get('graph');\n var graphContainer = graph.get('container');\n var container = this.get('container');\n graphContainer.removeChild(container);\n };\n\n return Legend;\n}(Base);\n\nexport default Legend;","import Plugin from '@antv/g6-plugin';\nexport default Plugin; // export default {};","import Grid from './grid';\nimport Menu from './menu';\nimport Minimap from './minimap';\nimport Bundling from './bundling';\nimport Fisheye from './fisheye';\nimport ToolBar from './toolBar';\nimport Tooltip from './tooltip';\nimport TimeBar from './timeBar';\nimport ImageMinimap from './imageMinimap';\nimport EdgeFilterLens from './edgeFilterLens';\nimport SnapLine from './snapline';\nimport PluginBase from './base';\nimport Legend from './legend';\nexport { PluginBase, Menu, Grid, Minimap, Bundling, ToolBar, Tooltip, Fisheye, TimeBar, ImageMinimap, EdgeFilterLens, SnapLine, Legend };\nvar Plugin = {\n PluginBase: PluginBase,\n Menu: Menu,\n Grid: Grid,\n Minimap: Minimap,\n Bundling: Bundling,\n ToolBar: ToolBar,\n Tooltip: Tooltip,\n Fisheye: Fisheye,\n TimeBar: TimeBar,\n ImageMinimap: ImageMinimap,\n EdgeFilterLens: EdgeFilterLens,\n SnapLine: SnapLine,\n Legend: Legend\n};\nexport default Plugin;","import { __assign, __rest } from \"tslib\";\nimport { registerNode, BaseGlobal as Global } from '@antv/g6-core';\nimport { deepMix } from '@antv/util'; // 带有图标的圆,可用于拓扑图中\n\nregisterNode('circle', {\n // 自定义节点时的配置\n options: {\n size: Global.defaultNode.size,\n style: {\n x: 0,\n y: 0,\n stroke: Global.defaultNode.style.stroke,\n fill: Global.defaultNode.style.fill,\n lineWidth: Global.defaultNode.style.lineWidth\n },\n labelCfg: {\n style: {\n fill: Global.nodeLabel.style.fill,\n fontSize: Global.nodeLabel.style.fontSize\n }\n },\n // 节点上左右上下四个方向上的链接circle配置\n linkPoints: {\n top: false,\n right: false,\n bottom: false,\n left: false,\n // circle的大小\n size: Global.defaultNode.linkPoints.size,\n lineWidth: Global.defaultNode.linkPoints.lineWidth,\n fill: Global.defaultNode.linkPoints.fill,\n stroke: Global.defaultNode.linkPoints.stroke\n },\n // 节点中icon配置\n icon: {\n // 是否显示icon,值为 false 则不渲染icon\n show: false,\n // icon的地址,字符串类型\n img: 'https://gw.alipayobjects.com/zos/bmw-prod/5d015065-8505-4e7a-baec-976f81e3c41d.svg',\n width: 20,\n height: 20\n },\n stateStyles: __assign({}, Global.nodeStateStyles)\n },\n shapeType: 'circle',\n // 文本位置\n labelPosition: 'center',\n drawShape: function drawShape(cfg, group) {\n var _a = this.getOptions(cfg).icon,\n defaultIcon = _a === void 0 ? {} : _a;\n var style = this.getShapeStyle(cfg);\n var icon = deepMix({}, defaultIcon, cfg.icon);\n var keyShape = group.addShape('circle', {\n attrs: style,\n className: this.type + \"-keyShape\",\n draggable: true\n });\n var width = icon.width,\n height = icon.height,\n show = icon.show,\n text = icon.text;\n\n if (show) {\n if (text) {\n group.addShape('text', {\n attrs: __assign({\n x: 0,\n y: 0,\n fontSize: 12,\n fill: '#000',\n stroke: '#000',\n textBaseline: 'middle',\n textAlign: 'center'\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n } else {\n group.addShape('image', {\n attrs: __assign({\n x: -width / 2,\n y: -height / 2\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n }\n }\n\n this.drawLinkPoints(cfg, group);\n return keyShape;\n },\n\n /**\n * 绘制节点上的LinkPoints\n * @param {Object} cfg data数据配置项\n * @param {Group} group Group实例\n */\n drawLinkPoints: function drawLinkPoints(cfg, group) {\n var _a = this.getOptions(cfg).linkPoints,\n linkPoints = _a === void 0 ? {} : _a;\n\n var top = linkPoints.top,\n left = linkPoints.left,\n right = linkPoints.right,\n bottom = linkPoints.bottom,\n markSize = linkPoints.size,\n markR = linkPoints.r,\n markStyle = __rest(linkPoints, [\"top\", \"left\", \"right\", \"bottom\", \"size\", \"r\"]);\n\n var size = this.getSize(cfg);\n var r = size[0] / 2;\n\n if (left) {\n // left circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: -r,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-left',\n name: 'link-point-left',\n isAnchorPoint: true\n });\n }\n\n if (right) {\n // right circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: r,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-right',\n name: 'link-point-right',\n isAnchorPoint: true\n });\n }\n\n if (top) {\n // top circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: -r,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-top',\n name: 'link-point-top',\n isAnchorPoint: true\n });\n }\n\n if (bottom) {\n // bottom circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: r,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-bottom',\n name: 'link-point-bottom',\n isAnchorPoint: true\n });\n }\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = deepMix({}, defaultStyle, strokeStyle);\n var size = this.getSize(cfg);\n var r = size[0] / 2;\n\n var styles = __assign({\n x: 0,\n y: 0,\n r: r\n }, style);\n\n return styles;\n },\n update: function update(cfg, item) {\n var group = item.getContainer();\n var size = this.getSize(cfg); // 下面这些属性需要覆盖默认样式与目前样式,但若在 cfg 中有指定则应该被 cfg 的相应配置覆盖。\n\n var strokeStyle = {\n stroke: cfg.color,\n r: size[0] / 2\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var keyShape = item.get('keyShape');\n var style = deepMix({}, keyShape.attr(), strokeStyle, cfg.style);\n this.updateShape(cfg, item, style, true);\n this.updateLinkPoints(cfg, group);\n }\n}, 'single-node');","import { __assign, __rest } from \"tslib\";\nimport { mix } from '@antv/util';\nimport { registerNode, BaseGlobal as Global } from '@antv/g6-core';\nregisterNode('rect', {\n // 自定义节点时的配置\n options: {\n size: [100, 30],\n style: {\n radius: 0,\n stroke: Global.defaultNode.style.stroke,\n fill: Global.defaultNode.style.fill,\n lineWidth: Global.defaultNode.style.lineWidth\n },\n // 文本样式配置\n labelCfg: {\n style: {\n fill: Global.nodeLabel.style.fill,\n fontSize: Global.nodeLabel.style.fontSize\n }\n },\n // 节点上左右上下四个方向上的链接circle配置\n linkPoints: {\n top: false,\n right: false,\n bottom: false,\n left: false,\n // circle的大小\n size: Global.defaultNode.linkPoints.size,\n lineWidth: Global.defaultNode.linkPoints.lineWidth,\n fill: Global.defaultNode.linkPoints.fill,\n stroke: Global.defaultNode.linkPoints.stroke\n },\n // 节点中icon配置\n icon: {\n // 是否显示icon,值为 false 则不渲染icon\n show: false,\n // icon的地址,字符串类型\n img: 'https://gw.alipayobjects.com/zos/bmw-prod/5d015065-8505-4e7a-baec-976f81e3c41d.svg',\n width: 20,\n height: 20\n },\n // 连接点,默认为左右\n // anchorPoints: [{ x: 0, y: 0.5 }, { x: 1, y: 0.5 }]\n anchorPoints: [[0, 0.5], [1, 0.5]],\n stateStyles: __assign({}, Global.nodeStateStyles)\n },\n shapeType: 'rect',\n labelPosition: 'center',\n drawShape: function drawShape(cfg, group) {\n var style = this.getShapeStyle(cfg);\n var keyShape = group.addShape('rect', {\n attrs: style,\n className: this.type + \"-keyShape\",\n name: this.type + \"-keyShape\",\n draggable: true\n });\n this.drawLinkPoints(cfg, group);\n return keyShape;\n },\n\n /**\n * 绘制节点上的LinkPoints\n * @param {Object} cfg data数据配置项\n * @param {Group} group Group实例\n */\n drawLinkPoints: function drawLinkPoints(cfg, group) {\n var _a = this.getOptions(cfg).linkPoints,\n linkPoints = _a === void 0 ? {} : _a;\n\n var top = linkPoints.top,\n left = linkPoints.left,\n right = linkPoints.right,\n bottom = linkPoints.bottom,\n markSize = linkPoints.size,\n markR = linkPoints.r,\n markStyle = __rest(linkPoints, [\"top\", \"left\", \"right\", \"bottom\", \"size\", \"r\"]);\n\n var size = this.getSize(cfg);\n var width = size[0];\n var height = size[1];\n\n if (left) {\n // left circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: -width / 2,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-left',\n name: 'link-point-left',\n isAnchorPoint: true\n });\n }\n\n if (right) {\n // right circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: width / 2,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-right',\n name: 'link-point-right',\n isAnchorPoint: true\n });\n }\n\n if (top) {\n // top circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: -height / 2,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-top',\n name: 'link-point-top',\n isAnchorPoint: true\n });\n }\n\n if (bottom) {\n // bottom circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: height / 2,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-bottom',\n name: 'link-point-bottom',\n isAnchorPoint: true\n });\n }\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = mix({}, defaultStyle, strokeStyle);\n var size = this.getSize(cfg);\n var width = style.width || size[0];\n var height = style.height || size[1];\n\n var styles = __assign({\n x: -width / 2,\n y: -height / 2,\n width: width,\n height: height\n }, style);\n\n return styles;\n },\n update: function update(cfg, item) {\n var group = item.getContainer(); // 这里不传 cfg 参数是因为 cfg.style 需要最后覆盖样式\n\n var defaultStyle = this.getOptions({}).style;\n var size = this.getSize(cfg);\n var keyShape = item.get('keyShape');\n\n if (!cfg.size) {\n size[0] = keyShape.attr('width') || defaultStyle.width;\n size[1] = keyShape.attr('height') || defaultStyle.height;\n } // 下面这些属性需要覆盖默认样式与目前样式,但若在 cfg 中有指定则应该被 cfg 的相应配置覆盖。\n\n\n var strokeStyle = {\n stroke: cfg.color,\n x: -size[0] / 2,\n y: -size[1] / 2,\n width: size[0],\n height: size[1]\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var style = mix({}, defaultStyle, keyShape.attr(), strokeStyle);\n style = mix(style, cfg.style);\n this.updateShape(cfg, item, style, false);\n this.updateLinkPoints(cfg, group);\n }\n}, 'single-node');","import { __assign, __rest } from \"tslib\";\nimport { registerNode, BaseGlobal as Global } from '@antv/g6-core';\nimport { mix } from '@antv/util';\n/**\n * 基本的椭圆,可以添加文本,默认文本居中\n */\n\nregisterNode('ellipse', {\n // 自定义节点时的配置\n options: {\n size: [80, 40],\n style: {\n x: 0,\n y: 0,\n stroke: Global.defaultNode.style.stroke,\n fill: Global.defaultNode.style.fill,\n lineWidth: Global.defaultNode.style.lineWidth\n },\n // 文本样式配置\n labelCfg: {\n style: {\n fill: Global.nodeLabel.style.fill,\n fontSize: Global.nodeLabel.style.fontSize\n }\n },\n // 节点上左右上下四个方向上的链接circle配置\n linkPoints: {\n top: false,\n right: false,\n bottom: false,\n left: false,\n // circle的大小\n size: Global.defaultNode.linkPoints.size,\n lineWidth: Global.defaultNode.linkPoints.lineWidth,\n fill: Global.defaultNode.linkPoints.fill,\n stroke: Global.defaultNode.linkPoints.stroke\n },\n // 节点中icon配置\n icon: {\n // 是否显示icon,值为 false 则不渲染icon\n show: false,\n // icon的地址,字符串类型\n img: 'https://gw.alipayobjects.com/zos/bmw-prod/5d015065-8505-4e7a-baec-976f81e3c41d.svg',\n width: 20,\n height: 20\n },\n stateStyles: __assign({}, Global.nodeStateStyles)\n },\n shapeType: 'ellipse',\n // 文本位置\n labelPosition: 'center',\n drawShape: function drawShape(cfg, group) {\n var _a = this.getOptions(cfg).icon,\n icon = _a === void 0 ? {} : _a;\n var style = this.getShapeStyle(cfg);\n var keyShape = group.addShape('ellipse', {\n attrs: style,\n className: 'ellipse-keyShape',\n name: 'ellipse-keyShape',\n draggable: true\n });\n var width = icon.width,\n height = icon.height,\n show = icon.show,\n text = icon.text;\n\n if (show) {\n if (text) {\n group.addShape('text', {\n attrs: __assign({\n x: 0,\n y: 0,\n fontSize: 12,\n fill: '#000',\n stroke: '#000',\n textBaseline: 'middle',\n textAlign: 'center'\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n } else {\n group.addShape('image', {\n attrs: __assign({\n x: -width / 2,\n y: -height / 2\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n }\n }\n\n this.drawLinkPoints(cfg, group);\n return keyShape;\n },\n\n /**\n * 绘制节点上的LinkPoints\n * @param {Object} cfg data数据配置项\n * @param {Group} group Group实例\n */\n drawLinkPoints: function drawLinkPoints(cfg, group) {\n var _a = this.getOptions(cfg).linkPoints,\n linkPoints = _a === void 0 ? {} : _a;\n\n var top = linkPoints.top,\n left = linkPoints.left,\n right = linkPoints.right,\n bottom = linkPoints.bottom,\n markSize = linkPoints.size,\n markR = linkPoints.r,\n markStyle = __rest(linkPoints, [\"top\", \"left\", \"right\", \"bottom\", \"size\", \"r\"]);\n\n var size = this.getSize(cfg);\n var rx = size[0] / 2;\n var ry = size[1] / 2;\n\n if (left) {\n // left circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: -rx,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-left',\n name: 'link-point-left',\n isAnchorPoint: true\n });\n }\n\n if (right) {\n // right circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: rx,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-right',\n name: 'link-point-right',\n isAnchorPoint: true\n });\n }\n\n if (top) {\n // top circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: -ry,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-top',\n name: 'link-point-top',\n isAnchorPoint: true\n });\n }\n\n if (bottom) {\n // bottom circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: ry,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-bottom',\n name: 'link-point-bottom',\n isAnchorPoint: true\n });\n }\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = mix({}, defaultStyle, strokeStyle);\n var size = this.getSize(cfg);\n var rx = size[0] / 2;\n var ry = size[1] / 2;\n\n var styles = __assign({\n x: 0,\n y: 0,\n rx: rx,\n ry: ry\n }, style);\n\n return styles;\n },\n update: function update(cfg, item) {\n var group = item.getContainer(); // 这里不传 cfg 参数是因为 cfg.style 需要最后覆盖样式\n\n var defaultStyle = this.getOptions({}).style;\n var size = this.getSize(cfg);\n var strokeStyle = {\n stroke: cfg.color,\n rx: size[0] / 2,\n ry: size[1] / 2\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var keyShape = item.get('keyShape');\n var style = mix({}, defaultStyle, keyShape.attr(), strokeStyle);\n style = mix(style, cfg.style);\n this.updateShape(cfg, item, style, true);\n this.updateLinkPoints(cfg, group);\n }\n}, 'single-node');","import { __assign, __rest } from \"tslib\";\nimport { registerNode, BaseGlobal as Global } from '@antv/g6-core';\nimport { mix } from '@antv/util'; // 菱形shape\n\nregisterNode('diamond', {\n // 自定义节点时的配置\n options: {\n size: [80, 80],\n style: {\n stroke: Global.defaultNode.style.stroke,\n fill: Global.defaultNode.style.fill,\n lineWidth: Global.defaultNode.style.lineWidth\n },\n // 文本样式配置\n labelCfg: {\n style: {\n fill: Global.nodeLabel.style.fill,\n fontSize: Global.nodeLabel.style.fontSize\n }\n },\n // 节点上左右上下四个方向上的链接circle配置\n linkPoints: {\n top: false,\n right: false,\n bottom: false,\n left: false,\n // circle的大小\n size: Global.defaultNode.linkPoints.size,\n lineWidth: Global.defaultNode.linkPoints.lineWidth,\n fill: Global.defaultNode.linkPoints.fill,\n stroke: Global.defaultNode.linkPoints.stroke\n },\n // 节点中icon配置\n icon: {\n // 是否显示icon,值为 false 则不渲染icon\n show: false,\n // icon的地址,字符串类型\n img: 'https://gw.alipayobjects.com/zos/bmw-prod/5d015065-8505-4e7a-baec-976f81e3c41d.svg',\n width: 20,\n height: 20\n },\n stateStyles: __assign({}, Global.nodeStateStyles)\n },\n shapeType: 'diamond',\n // 文本位置\n labelPosition: 'center',\n drawShape: function drawShape(cfg, group) {\n var _a = this.getOptions(cfg).icon,\n icon = _a === void 0 ? {} : _a;\n var style = this.getShapeStyle(cfg);\n var keyShape = group.addShape('path', {\n attrs: style,\n className: this.type + \"-keyShape\",\n name: this.type + \"-keyShape\",\n draggable: true\n });\n var w = icon.width,\n h = icon.height,\n show = icon.show,\n text = icon.text;\n\n if (show) {\n if (text) {\n group.addShape('text', {\n attrs: __assign({\n x: 0,\n y: 0,\n fontSize: 12,\n fill: '#000',\n stroke: '#000',\n textBaseline: 'middle',\n textAlign: 'center'\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n } else {\n group.addShape('image', {\n attrs: __assign({\n x: -w / 2,\n y: -h / 2\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n }\n }\n\n this.drawLinkPoints(cfg, group);\n return keyShape;\n },\n\n /**\n * 绘制节点上的LinkPoints\n * @param {Object} cfg data数据配置项\n * @param {Group} group Group实例\n */\n drawLinkPoints: function drawLinkPoints(cfg, group) {\n var _a = this.getOptions(cfg).linkPoints,\n linkPoints = _a === void 0 ? {} : _a;\n\n var top = linkPoints.top,\n left = linkPoints.left,\n right = linkPoints.right,\n bottom = linkPoints.bottom,\n markSize = linkPoints.size,\n markR = linkPoints.r,\n markStyle = __rest(linkPoints, [\"top\", \"left\", \"right\", \"bottom\", \"size\", \"r\"]);\n\n var size = this.getSize(cfg);\n var width = size[0];\n var height = size[1];\n\n if (left) {\n // left circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: -width / 2,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-left',\n name: 'link-point-left',\n isAnchorPoint: true\n });\n }\n\n if (right) {\n // right circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: width / 2,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-right',\n name: 'link-point-right',\n isAnchorPoint: true\n });\n }\n\n if (top) {\n // top circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: -height / 2,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-top',\n name: 'link-point-top',\n isAnchorPoint: true\n });\n }\n\n if (bottom) {\n // bottom circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: height / 2,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-bottom',\n name: 'link-point-bottom',\n isAnchorPoint: true\n });\n }\n },\n getPath: function getPath(cfg) {\n var size = this.getSize(cfg);\n var width = size[0];\n var height = size[1];\n var path = [['M', 0, -height / 2], ['L', width / 2, 0], ['L', 0, height / 2], ['L', -width / 2, 0], ['Z'] // 封闭\n ];\n return path;\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = mix({}, defaultStyle, strokeStyle);\n var path = this.getPath(cfg);\n\n var styles = __assign({\n path: path\n }, style);\n\n return styles;\n },\n update: function update(cfg, item) {\n var group = item.getContainer(); // 这里不传 cfg 参数是因为 cfg.style 需要最后覆盖样式\n\n var defaultStyle = this.getOptions({}).style;\n var path = this.getPath(cfg); // 下面这些属性需要覆盖默认样式与目前样式,但若在 cfg 中有指定则应该被 cfg 的相应配置覆盖。\n\n var strokeStyle = {\n stroke: cfg.color,\n path: path\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var keyShape = item.get('keyShape');\n var style = mix({}, defaultStyle, keyShape.attr(), strokeStyle);\n style = mix(style, cfg.style);\n this.updateShape(cfg, item, style, true);\n this.updateLinkPoints(cfg, group);\n }\n}, 'single-node');","import { __assign, __rest } from \"tslib\";\nimport { registerNode, BaseGlobal as Global } from '@antv/g6-core';\nimport { mix } from '@antv/util'; // 三角形\n\nregisterNode('triangle', {\n // 自定义节点时的配置\n options: {\n size: 40,\n direction: 'up',\n style: {\n stroke: Global.defaultNode.style.stroke,\n fill: Global.defaultNode.style.fill,\n lineWidth: Global.defaultNode.style.lineWidth\n },\n labelCfg: {\n style: {\n fill: Global.nodeLabel.style.fill,\n fontSize: Global.nodeLabel.style.fontSize\n },\n offset: 15\n },\n // 节点上左右上下四个方向上的链接circle配置\n linkPoints: {\n top: false,\n right: false,\n bottom: false,\n left: false,\n // circle的大小\n size: Global.defaultNode.linkPoints.size,\n lineWidth: Global.defaultNode.linkPoints.lineWidth,\n fill: Global.defaultNode.linkPoints.fill,\n stroke: Global.defaultNode.linkPoints.stroke\n },\n // 节点中icon配置\n icon: {\n // 是否显示icon,值为 false 则不渲染icon\n show: false,\n // icon的地址,字符串类型\n img: 'https://gw.alipayobjects.com/zos/bmw-prod/5d015065-8505-4e7a-baec-976f81e3c41d.svg',\n width: 20,\n height: 20,\n offset: 6\n },\n stateStyles: __assign({}, Global.nodeStateStyles)\n },\n shapeType: 'triangle',\n // 文本位置\n labelPosition: 'bottom',\n drawShape: function drawShape(cfg, group) {\n var _a = this.getOptions(cfg),\n _b = _a.icon,\n icon = _b === void 0 ? {} : _b,\n defaultDirection = _a.direction;\n\n var style = this.getShapeStyle(cfg);\n var direction = cfg.direction || defaultDirection;\n var keyShape = group.addShape('path', {\n attrs: style,\n className: this.type + \"-keyShape\",\n name: this.type + \"-keyShape\",\n draggable: true\n });\n var w = icon.width,\n h = icon.height,\n show = icon.show,\n offset = icon.offset,\n text = icon.text;\n\n if (show) {\n if (text) {\n group.addShape('text', {\n attrs: __assign({\n x: 0,\n y: 0,\n fontSize: 12,\n fill: '#000',\n stroke: '#000',\n textBaseline: 'middle',\n textAlign: 'center'\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n } else {\n var iconW = -w / 2;\n var iconH = -h / 2;\n\n if (direction === 'up' || direction === 'down') {\n iconH += offset;\n }\n\n if (direction === 'left' || direction === 'right') {\n iconW += offset;\n }\n\n group.addShape('image', {\n attrs: __assign({\n x: iconW,\n y: iconH\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n }\n }\n\n this.drawLinkPoints(cfg, group);\n return keyShape;\n },\n\n /**\n * 绘制节点上的LinkPoints\n * @param {Object} cfg data数据配置项\n * @param {Group} group Group实例\n */\n drawLinkPoints: function drawLinkPoints(cfg, group) {\n var _a = this.getOptions(cfg),\n _b = _a.linkPoints,\n linkPoints = _b === void 0 ? {} : _b,\n defaultDirection = _a.direction;\n\n var direction = cfg.direction || defaultDirection;\n\n var top = linkPoints.top,\n left = linkPoints.left,\n right = linkPoints.right,\n bottom = linkPoints.bottom,\n markSize = linkPoints.size,\n markR = linkPoints.r,\n markStyle = __rest(linkPoints, [\"top\", \"left\", \"right\", \"bottom\", \"size\", \"r\"]);\n\n var size = this.getSize(cfg);\n var len = size[0];\n\n if (left) {\n // up down left right 四个方向的坐标均不相同\n var leftPos = null;\n var diffY = len * Math.sin(1 / 3 * Math.PI);\n var r = len * Math.sin(1 / 3 * Math.PI);\n\n if (direction === 'up') {\n leftPos = [-r, diffY];\n } else if (direction === 'down') {\n leftPos = [-r, -diffY];\n } else if (direction === 'left') {\n leftPos = [-r, r - diffY];\n }\n\n if (leftPos) {\n // left circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: leftPos[0],\n y: leftPos[1],\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-left',\n name: 'link-point-left'\n });\n }\n }\n\n if (right) {\n // right circle\n // up down left right 四个方向的坐标均不相同\n var rightPos = null;\n var diffY = len * Math.sin(1 / 3 * Math.PI);\n var r = len * Math.sin(1 / 3 * Math.PI);\n\n if (direction === 'up') {\n rightPos = [r, diffY];\n } else if (direction === 'down') {\n rightPos = [r, -diffY];\n } else if (direction === 'right') {\n rightPos = [r, r - diffY];\n }\n\n if (rightPos) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: rightPos[0],\n y: rightPos[1],\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-right',\n name: 'link-point-right'\n });\n }\n }\n\n if (top) {\n // up down left right 四个方向的坐标均不相同\n var topPos = null;\n var diffY = len * Math.sin(1 / 3 * Math.PI);\n var r = len * Math.sin(1 / 3 * Math.PI);\n\n if (direction === 'up') {\n topPos = [r - diffY, -diffY];\n } else if (direction === 'left') {\n topPos = [r, -diffY];\n } else if (direction === 'right') {\n topPos = [-r, -diffY];\n }\n\n if (topPos) {\n // top circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: topPos[0],\n y: topPos[1],\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-top',\n name: 'link-point-top'\n });\n }\n }\n\n if (bottom) {\n // up down left right 四个方向的坐标均不相同\n var bottomPos = null;\n var diffY = len * Math.sin(1 / 3 * Math.PI);\n var r = len * Math.sin(1 / 3 * Math.PI);\n\n if (direction === 'down') {\n bottomPos = [-r + diffY, diffY];\n } else if (direction === 'left') {\n bottomPos = [r, diffY];\n } else if (direction === 'right') {\n bottomPos = [-r, diffY];\n }\n\n if (bottomPos) {\n // bottom circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: bottomPos[0],\n y: bottomPos[1],\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-bottom',\n name: 'link-point-bottom'\n });\n }\n }\n },\n getPath: function getPath(cfg) {\n var defaultDirection = this.getOptions(cfg).direction;\n var direction = cfg.direction || defaultDirection;\n var size = this.getSize(cfg);\n var len = size[0];\n var diffY = len * Math.sin(1 / 3 * Math.PI);\n var r = len * Math.sin(1 / 3 * Math.PI);\n var path = [['M', -r, diffY], ['L', 0, -diffY], ['L', r, diffY], ['Z'] // 封闭\n ];\n\n if (direction === 'down') {\n path = [['M', -r, -diffY], ['L', r, -diffY], ['L', 0, diffY], ['Z'] // 封闭\n ];\n } else if (direction === 'left') {\n path = [['M', -r, r - diffY], ['L', r, -r], ['L', r, r], ['Z'] // 封闭\n ];\n } else if (direction === 'right') {\n path = [['M', r, r - diffY], ['L', -r, r], ['L', -r, -r], ['Z'] // 封闭\n ];\n }\n\n return path;\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = mix({}, defaultStyle, strokeStyle);\n var path = this.getPath(cfg);\n\n var styles = __assign({\n path: path\n }, style);\n\n return styles;\n },\n update: function update(cfg, item) {\n var group = item.getContainer(); // 这里不传 cfg 参数是因为 cfg.style 需要最后覆盖样式\n\n var defaultStyle = this.getOptions({}).style;\n var path = this.getPath(cfg); // 下面这些属性需要覆盖默认样式与目前样式,但若在 cfg 中有指定则应该被 cfg 的相应配置覆盖。\n\n var strokeStyle = {\n stroke: cfg.color,\n path: path\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var keyShape = item.get('keyShape');\n var style = mix({}, defaultStyle, keyShape.attr(), strokeStyle);\n style = mix(style, cfg.style);\n this.updateShape(cfg, item, style, true);\n this.updateLinkPoints(cfg, group);\n },\n\n /**\n * 更新linkPoints\n * @param {Object} cfg 节点数据配置项\n * @param {Group} group Item所在的group\n */\n updateLinkPoints: function updateLinkPoints(cfg, group) {\n var _a = this.getOptions({}),\n defaultLinkPoints = _a.linkPoints,\n defaultDirection = _a.direction;\n\n var direction = cfg.direction || defaultDirection;\n var markLeft = group.find(function (element) {\n return element.get('className') === 'link-point-left';\n });\n var markRight = group.find(function (element) {\n return element.get('className') === 'link-point-right';\n });\n var markTop = group.find(function (element) {\n return element.get('className') === 'link-point-top';\n });\n var markBottom = group.find(function (element) {\n return element.get('className') === 'link-point-bottom';\n });\n var currentLinkPoints = defaultLinkPoints;\n var existLinkPoint = markLeft || markRight || markTop || markBottom;\n\n if (existLinkPoint) {\n currentLinkPoints = existLinkPoint.attr();\n }\n\n var linkPoints = mix({}, currentLinkPoints, cfg.linkPoints);\n var markFill = linkPoints.fill,\n markStroke = linkPoints.stroke,\n borderWidth = linkPoints.lineWidth;\n var markSize = linkPoints.size / 2;\n if (!markSize) markSize = linkPoints.r;\n\n var _b = cfg.linkPoints ? cfg.linkPoints : {\n left: undefined,\n right: undefined,\n top: undefined,\n bottom: undefined\n },\n left = _b.left,\n right = _b.right,\n top = _b.top,\n bottom = _b.bottom;\n\n var size = this.getSize(cfg);\n var len = size[0];\n var styles = {\n r: markSize,\n fill: markFill,\n stroke: markStroke,\n lineWidth: borderWidth\n };\n var leftPos = null;\n var diffY = len * Math.sin(1 / 3 * Math.PI);\n var r = len * Math.sin(1 / 3 * Math.PI);\n\n if (direction === 'up') {\n leftPos = [-r, diffY];\n } else if (direction === 'down') {\n leftPos = [-r, -diffY];\n } else if (direction === 'left') {\n leftPos = [-r, r - diffY];\n }\n\n if (leftPos) {\n if (markLeft) {\n if (!left && left !== undefined) {\n markLeft.remove();\n } else {\n markLeft.attr(__assign(__assign({}, styles), {\n x: leftPos[0],\n y: leftPos[1]\n }));\n }\n } else if (left) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: leftPos[0],\n y: leftPos[1]\n }),\n className: 'link-point-left',\n name: 'link-point-left',\n isAnchorPoint: true\n });\n }\n }\n\n var rightPos = null;\n\n if (direction === 'up') {\n rightPos = [r, diffY];\n } else if (direction === 'down') {\n rightPos = [r, -diffY];\n } else if (direction === 'right') {\n rightPos = [r, r - diffY];\n }\n\n if (rightPos) {\n if (markRight) {\n if (!right && right !== undefined) {\n markRight.remove();\n } else {\n markRight.attr(__assign(__assign({}, styles), {\n x: rightPos[0],\n y: rightPos[1]\n }));\n }\n } else if (right) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: rightPos[0],\n y: rightPos[1]\n }),\n className: 'link-point-right',\n name: 'link-point-right',\n isAnchorPoint: true\n });\n }\n }\n\n var topPos = null;\n\n if (direction === 'up') {\n topPos = [r - diffY, -diffY];\n } else if (direction === 'left') {\n topPos = [r, -diffY];\n } else if (direction === 'right') {\n topPos = [-r, -diffY];\n }\n\n if (topPos) {\n if (markTop) {\n if (!top && top !== undefined) {\n markTop.remove();\n } else {\n // top circle\n markTop.attr(__assign(__assign({}, styles), {\n x: topPos[0],\n y: topPos[1]\n }));\n }\n } else if (top) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: topPos[0],\n y: topPos[1]\n }),\n className: 'link-point-top',\n name: 'link-point-top',\n isAnchorPoint: true\n });\n }\n }\n\n var bottomPos = null;\n\n if (direction === 'down') {\n bottomPos = [-r + diffY, diffY];\n } else if (direction === 'left') {\n bottomPos = [r, diffY];\n } else if (direction === 'right') {\n bottomPos = [-r, diffY];\n }\n\n if (bottomPos) {\n if (markBottom) {\n if (!bottom && bottom !== undefined) {\n markBottom.remove();\n } else {\n markBottom.attr(__assign(__assign({}, styles), {\n x: bottomPos[0],\n y: bottomPos[1]\n }));\n }\n } else if (bottom) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: bottomPos[0],\n y: bottomPos[1]\n }),\n className: 'link-point-bottom',\n name: 'link-point-bottom',\n isAnchorPoint: true\n });\n }\n }\n }\n}, 'single-node');","import { __assign, __rest } from \"tslib\";\nimport { mix, isString } from '@antv/util';\nimport { registerNode, BaseGlobal as Global } from '@antv/g6-core';\nregisterNode('modelRect', {\n // 自定义节点时的配置\n options: {\n size: [185, 70],\n style: {\n radius: 5,\n stroke: '#69c0ff',\n fill: '#ffffff',\n lineWidth: Global.defaultNode.style.lineWidth,\n fillOpacity: 1\n },\n // 文本样式配置\n labelCfg: {\n style: {\n fill: '#595959',\n fontSize: 14\n },\n offset: 30 // 距离左侧的 offset,没有设置 y 轴上移动的配置\n\n },\n descriptionCfg: {\n style: {\n fontSize: 12,\n fill: '#bfbfbf'\n },\n paddingTop: 0\n },\n preRect: {\n show: true,\n width: 4,\n fill: '#40a9ff',\n radius: 2\n },\n // 节点上左右上下四个方向上的链接circle配置\n linkPoints: {\n top: false,\n right: false,\n bottom: false,\n left: false,\n // circle的大小\n size: 10,\n lineWidth: 1,\n fill: '#72CC4A',\n stroke: '#72CC4A'\n },\n // 节点中icon配置\n logoIcon: {\n // 是否显示icon,值为 false 则不渲染icon\n show: true,\n x: 0,\n y: 0,\n // icon的地址,字符串类型\n img: 'https://gw.alipayobjects.com/zos/basement_prod/4f81893c-1806-4de4-aff3-9a6b266bc8a2.svg',\n width: 16,\n height: 16,\n // 用于调整图标的左右位置\n offset: 0\n },\n // 节点中表示状态的icon配置\n stateIcon: {\n // 是否显示icon,值为 false 则不渲染icon\n show: true,\n x: 0,\n y: 0,\n // icon的地址,字符串类型\n img: 'https://gw.alipayobjects.com/zos/basement_prod/300a2523-67e0-4cbf-9d4a-67c077b40395.svg',\n width: 16,\n height: 16,\n // 用于调整图标的左右位置\n offset: -5\n },\n // 连接点,默认为左右\n // anchorPoints: [{ x: 0, y: 0.5 }, { x: 1, y: 0.5 }]\n anchorPoints: [[0, 0.5], [1, 0.5]]\n },\n shapeType: 'modelRect',\n drawShape: function drawShape(cfg, group) {\n var _a = this.getOptions(cfg).preRect,\n preRect = _a === void 0 ? {} : _a;\n var style = this.getShapeStyle(cfg);\n var size = this.getSize(cfg);\n var width = size[0];\n var height = size[1];\n var keyShape = group.addShape('rect', {\n attrs: style,\n className: this.type + \"-keyShape\",\n name: this.type + \"-keyShape\",\n draggable: true\n });\n\n var preRectShow = preRect.show,\n preRectStyle = __rest(preRect, [\"show\"]);\n\n if (preRectShow) {\n group.addShape('rect', {\n attrs: __assign({\n x: -width / 2,\n y: -height / 2,\n height: height\n }, preRectStyle),\n className: 'pre-rect',\n name: 'pre-rect',\n draggable: true\n });\n }\n\n this.drawLogoIcon(cfg, group);\n this.drawStateIcon(cfg, group);\n this.drawLinkPoints(cfg, group);\n return keyShape;\n },\n\n /**\n * 绘制模型矩形左边的logo图标\n * @param {Object} cfg 数据配置项\n * @param {Group} group Group实例\n */\n drawLogoIcon: function drawLogoIcon(cfg, group) {\n var _a = this.getOptions(cfg).logoIcon,\n logoIcon = _a === void 0 ? {} : _a;\n var size = this.getSize(cfg);\n var width = size[0];\n\n if (logoIcon.show) {\n var w = logoIcon.width,\n h = logoIcon.height,\n x = logoIcon.x,\n y = logoIcon.y,\n offset = logoIcon.offset,\n text = logoIcon.text,\n logoIconStyle = __rest(logoIcon, [\"width\", \"height\", \"x\", \"y\", \"offset\", \"text\"]);\n\n if (text) {\n group.addShape('text', {\n attrs: __assign({\n x: 0,\n y: 0,\n fontSize: 12,\n fill: '#000',\n stroke: '#000',\n textBaseline: 'middle',\n textAlign: 'center'\n }, logoIconStyle),\n className: 'rect-logo-icon',\n name: 'rect-logo-icon',\n draggable: true\n });\n } else {\n group.addShape('image', {\n attrs: __assign(__assign({}, logoIconStyle), {\n x: x || -width / 2 + w + offset,\n y: y || -h / 2,\n width: w,\n height: h\n }),\n className: 'rect-logo-icon',\n name: 'rect-logo-icon',\n draggable: true\n });\n }\n }\n },\n\n /**\n * 绘制模型矩形右边的状态图标\n * @param {Object} cfg 数据配置项\n * @param {Group} group Group实例\n */\n drawStateIcon: function drawStateIcon(cfg, group) {\n var _a = this.getOptions(cfg).stateIcon,\n stateIcon = _a === void 0 ? {} : _a;\n var size = this.getSize(cfg);\n var width = size[0];\n\n if (stateIcon.show) {\n var w = stateIcon.width,\n h = stateIcon.height,\n x = stateIcon.x,\n y = stateIcon.y,\n offset = stateIcon.offset,\n text = stateIcon.text,\n iconStyle = __rest(stateIcon, [\"width\", \"height\", \"x\", \"y\", \"offset\", \"text\"]);\n\n if (text) {\n group.addShape('text', {\n attrs: __assign({\n x: 0,\n y: 0,\n fontSize: 12,\n fill: '#000',\n stroke: '#000',\n textBaseline: 'middle',\n textAlign: 'center'\n }, iconStyle),\n className: 'rect-state-icon',\n name: 'rect-state-icon',\n draggable: true\n });\n } else {\n group.addShape('image', {\n attrs: __assign(__assign({}, iconStyle), {\n x: x || width / 2 - w + offset,\n y: y || -h / 2,\n width: w,\n height: h\n }),\n className: 'rect-state-icon',\n name: 'rect-state-icon',\n draggable: true\n });\n }\n }\n },\n\n /**\n * 绘制节点上的LinkPoints\n * @param {Object} cfg data数据配置项\n * @param {Group} group Group实例\n */\n drawLinkPoints: function drawLinkPoints(cfg, group) {\n var _a = this.getOptions(cfg).linkPoints,\n linkPoints = _a === void 0 ? {} : _a;\n\n var top = linkPoints.top,\n left = linkPoints.left,\n right = linkPoints.right,\n bottom = linkPoints.bottom,\n markSize = linkPoints.size,\n markR = linkPoints.r,\n markStyle = __rest(linkPoints, [\"top\", \"left\", \"right\", \"bottom\", \"size\", \"r\"]);\n\n var size = this.getSize(cfg);\n var width = size[0];\n var height = size[1];\n\n if (left) {\n // left circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: -width / 2,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-left',\n name: 'link-point-left',\n isAnchorPoint: true\n });\n }\n\n if (right) {\n // right circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: width / 2,\n y: 0,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-right',\n name: 'link-point-right',\n isAnchorPoint: true\n });\n }\n\n if (top) {\n // top circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: -height / 2,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-top',\n name: 'link-point-top',\n isAnchorPoint: true\n });\n }\n\n if (bottom) {\n // bottom circle\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: 0,\n y: height / 2,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-bottom',\n name: 'link-point-bottom',\n isAnchorPoint: true\n });\n }\n },\n drawLabel: function drawLabel(cfg, group) {\n var _a = this.getOptions(cfg),\n _b = _a.labelCfg,\n labelCfg = _b === void 0 ? {} : _b,\n _c = _a.logoIcon,\n logoIcon = _c === void 0 ? {} : _c,\n _d = _a.descriptionCfg,\n descriptionCfg = _d === void 0 ? {} : _d;\n\n var size = this.getSize(cfg);\n var width = size[0];\n var label = null;\n var show = logoIcon.show,\n w = logoIcon.width;\n var offsetX = -width / 2 + labelCfg.offset;\n\n if (show) {\n offsetX = -width / 2 + w + labelCfg.offset;\n }\n\n var fontStyle = labelCfg.style;\n var descriptionStyle = descriptionCfg.style,\n descriptionPaddingTop = descriptionCfg.paddingTop;\n\n if (isString(cfg.description)) {\n label = group.addShape('text', {\n attrs: __assign(__assign({}, fontStyle), {\n x: offsetX,\n y: -5,\n text: cfg.label\n }),\n className: 'text-shape',\n name: 'text-shape',\n draggable: true\n });\n group.addShape('text', {\n attrs: __assign(__assign({}, descriptionStyle), {\n x: offsetX,\n y: 17 + (descriptionPaddingTop || 0),\n text: cfg.description\n }),\n className: 'rect-description',\n name: 'rect-description',\n draggable: true\n });\n } else {\n label = group.addShape('text', {\n attrs: __assign(__assign({}, fontStyle), {\n x: offsetX,\n y: 7,\n text: cfg.label\n }),\n className: 'text-shape',\n name: 'text-shape',\n draggable: true\n });\n }\n\n return label;\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖默认的stroke属性\n\n var style = mix({}, defaultStyle, strokeStyle);\n var size = this.getSize(cfg);\n var width = style.width || size[0];\n var height = style.height || size[1];\n\n var styles = __assign({\n x: -width / 2,\n y: -height / 2,\n width: width,\n height: height\n }, style);\n\n return styles;\n },\n update: function update(cfg, item) {\n var _a = this.getOptions(cfg),\n _b = _a.style,\n style = _b === void 0 ? {} : _b,\n _c = _a.labelCfg,\n labelCfg = _c === void 0 ? {} : _c,\n _d = _a.descriptionCfg,\n descriptionCfg = _d === void 0 ? {} : _d;\n\n var size = this.getSize(cfg);\n var width = size[0];\n var height = size[1];\n var keyShape = item.get('keyShape');\n keyShape.attr(__assign(__assign({}, style), {\n x: -width / 2,\n y: -height / 2,\n width: width,\n height: height\n }));\n var group = item.getContainer();\n var logoIconShape = group.find(function (element) {\n return element.get('className') === 'rect-logo-icon';\n });\n var currentLogoIconAttr = logoIconShape ? logoIconShape.attr() : {};\n var logoIcon = mix({}, currentLogoIconAttr, cfg.logoIcon);\n var w = logoIcon.width;\n\n if (w === undefined) {\n w = this.options.logoIcon.width;\n }\n\n var show = cfg.logoIcon ? cfg.logoIcon.show : undefined;\n var offset = labelCfg.offset;\n var offsetX = -width / 2 + w + offset;\n\n if (!show && show !== undefined) {\n offsetX = -width / 2 + offset;\n }\n\n var label = group.find(function (element) {\n return element.get('className') === 'node-label';\n });\n var description = group.find(function (element) {\n return element.get('className') === 'rect-description';\n });\n\n if (cfg.label) {\n if (!label) {\n group.addShape('text', {\n attrs: __assign(__assign({}, labelCfg.style), {\n x: offsetX,\n y: cfg.description ? -5 : 7,\n text: cfg.label\n }),\n className: 'node-label',\n name: 'node-label',\n draggable: true\n });\n } else {\n var cfgStyle = cfg.labelCfg ? cfg.labelCfg.style : {};\n var labelStyle = mix({}, label.attr(), cfgStyle);\n if (cfg.label) labelStyle.text = cfg.label;\n labelStyle.x = offsetX;\n if (isString(cfg.description)) labelStyle.y = -5;\n\n if (description) {\n description.resetMatrix();\n description.attr({\n x: offsetX\n });\n }\n\n label.resetMatrix();\n label.attr(labelStyle);\n }\n }\n\n if (isString(cfg.description)) {\n var paddingTop = descriptionCfg.paddingTop;\n\n if (!description) {\n group.addShape('text', {\n attrs: __assign(__assign({}, descriptionCfg.style), {\n x: offsetX,\n y: 17 + (paddingTop || 0),\n text: cfg.description\n }),\n className: 'rect-description',\n name: 'rect-description',\n draggable: true\n });\n } else {\n var cfgStyle = cfg.descriptionCfg ? cfg.descriptionCfg.style : {};\n var descriptionStyle = mix({}, description.attr(), cfgStyle);\n if (isString(cfg.description)) descriptionStyle.text = cfg.description;\n descriptionStyle.x = offsetX;\n description.resetMatrix();\n description.attr(__assign(__assign({}, descriptionStyle), {\n y: 17 + (paddingTop || 0)\n }));\n }\n }\n\n var preRectShape = group.find(function (element) {\n return element.get('className') === 'pre-rect';\n });\n\n if (preRectShape) {\n var preRect = mix({}, preRectShape.attr(), cfg.preRect);\n preRectShape.attr(__assign(__assign({}, preRect), {\n x: -width / 2,\n y: -height / 2,\n height: height\n }));\n }\n\n if (logoIconShape) {\n if (!show && show !== undefined) {\n logoIconShape.remove();\n } else {\n var logoW = logoIcon.width,\n h = logoIcon.height,\n x = logoIcon.x,\n y = logoIcon.y,\n logoOffset = logoIcon.offset,\n logoIconStyle = __rest(logoIcon, [\"width\", \"height\", \"x\", \"y\", \"offset\"]);\n\n logoIconShape.attr(__assign(__assign({}, logoIconStyle), {\n x: x || -width / 2 + logoW + logoOffset,\n y: y || -h / 2,\n width: logoW,\n height: h\n }));\n }\n } else if (show) {\n this.drawLogoIcon(cfg, group);\n }\n\n var stateIconShape = group.find(function (element) {\n return element.get('className') === 'rect-state-icon';\n });\n var currentStateIconAttr = stateIconShape ? stateIconShape.attr() : {};\n var stateIcon = mix({}, currentStateIconAttr, cfg.stateIcon);\n\n if (stateIconShape) {\n if (!stateIcon.show && stateIcon.show !== undefined) {\n stateIconShape.remove();\n }\n\n var stateW = stateIcon.width,\n h = stateIcon.height,\n x = stateIcon.x,\n y = stateIcon.y,\n stateOffset = stateIcon.offset,\n stateIconStyle = __rest(stateIcon, [\"width\", \"height\", \"x\", \"y\", \"offset\"]);\n\n stateIconShape.attr(__assign(__assign({}, stateIconStyle), {\n x: x || width / 2 - stateW + stateOffset,\n y: y || -h / 2,\n width: stateW,\n height: h\n }));\n } else if (stateIcon.show) {\n this.drawStateIcon(cfg, group);\n }\n\n this.updateLinkPoints(cfg, group);\n }\n}, 'single-node');","import { __assign, __rest } from \"tslib\";\nimport { registerNode, BaseGlobal as Global } from '@antv/g6-core';\nimport { mix } from '@antv/util'; // 五角星shape\n\nregisterNode('star', {\n // 自定义节点时的配置\n options: {\n size: 60,\n style: {\n stroke: Global.defaultNode.style.stroke,\n fill: Global.defaultNode.style.fill,\n lineWidth: Global.defaultNode.style.lineWidth\n },\n labelCfg: {\n style: {\n fill: Global.nodeLabel.style.fill,\n fontSize: Global.nodeLabel.style.fontSize\n }\n },\n // 节点上左右上下四个方向上的链接circle配置\n linkPoints: {\n top: false,\n right: false,\n bottom: false,\n left: false,\n // circle的大小\n size: Global.defaultNode.linkPoints.size,\n lineWidth: Global.defaultNode.linkPoints.lineWidth,\n fill: Global.defaultNode.linkPoints.fill,\n stroke: Global.defaultNode.linkPoints.stroke\n },\n // 节点中icon配置\n icon: {\n // 是否显示icon,值为 false 则不渲染icon\n show: false,\n // icon的地址,字符串类型\n img: 'https://gw.alipayobjects.com/zos/bmw-prod/5d015065-8505-4e7a-baec-976f81e3c41d.svg',\n width: 20,\n height: 20\n },\n stateStyles: __assign({}, Global.nodeStateStyles)\n },\n shapeType: 'star',\n // 文本位置\n labelPosition: 'center',\n drawShape: function drawShape(cfg, group) {\n var _a = this.getOptions(cfg).icon,\n icon = _a === void 0 ? {} : _a;\n var style = this.getShapeStyle(cfg);\n var keyShape = group.addShape('path', {\n attrs: style,\n className: this.type + \"-keyShape\",\n name: this.type + \"-keyShape\",\n draggable: true\n });\n var w = icon.width,\n h = icon.height,\n show = icon.show,\n text = icon.text;\n\n if (show) {\n if (text) {\n group.addShape('text', {\n attrs: __assign({\n x: 0,\n y: 0,\n fontSize: 12,\n fill: '#000',\n stroke: '#000',\n textBaseline: 'middle',\n textAlign: 'center'\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n } else {\n group.addShape('image', {\n attrs: __assign({\n x: -w / 2,\n y: -h / 2\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n }\n }\n\n this.drawLinkPoints(cfg, group);\n return keyShape;\n },\n\n /**\n * 绘制节点上的LinkPoints\n * @param {Object} cfg data数据配置项\n * @param {Group} group Group实例\n */\n drawLinkPoints: function drawLinkPoints(cfg, group) {\n var _a = this.getOptions(cfg).linkPoints,\n linkPoints = _a === void 0 ? {} : _a;\n\n var top = linkPoints.top,\n left = linkPoints.left,\n right = linkPoints.right,\n leftBottom = linkPoints.leftBottom,\n rightBottom = linkPoints.rightBottom,\n markSize = linkPoints.size,\n markR = linkPoints.r,\n markStyle = __rest(linkPoints, [\"top\", \"left\", \"right\", \"leftBottom\", \"rightBottom\", \"size\", \"r\"]);\n\n var size = this.getSize(cfg);\n var outerR = size[0];\n\n if (right) {\n // right circle\n // up down left right 四个方向的坐标均不相同\n var x1 = Math.cos((18 + 72 * 0) / 180 * Math.PI) * outerR;\n var y1 = Math.sin((18 + 72 * 0) / 180 * Math.PI) * outerR;\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: x1,\n y: -y1,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-right',\n name: 'link-point-right'\n });\n }\n\n if (top) {\n // up down left right 四个方向的坐标均不相同\n var x1 = Math.cos((18 + 72 * 1) / 180 * Math.PI) * outerR;\n var y1 = Math.sin((18 + 72 * 1) / 180 * Math.PI) * outerR; // top circle\n\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: x1,\n y: -y1,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-top',\n name: 'link-point-top'\n });\n }\n\n if (left) {\n // up down left right 四个方向的坐标均不相同\n var x1 = Math.cos((18 + 72 * 2) / 180 * Math.PI) * outerR;\n var y1 = Math.sin((18 + 72 * 2) / 180 * Math.PI) * outerR; // left circle\n\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: x1,\n y: -y1,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-left',\n name: 'link-point-left'\n });\n }\n\n if (leftBottom) {\n // up down left right 四个方向的坐标均不相同\n var x1 = Math.cos((18 + 72 * 3) / 180 * Math.PI) * outerR;\n var y1 = Math.sin((18 + 72 * 3) / 180 * Math.PI) * outerR; // left bottom circle\n\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: x1,\n y: -y1,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-left-bottom',\n name: 'link-point-left-bottom'\n });\n }\n\n if (rightBottom) {\n // up down left right 四个方向的坐标均不相同\n var x1 = Math.cos((18 + 72 * 4) / 180 * Math.PI) * outerR;\n var y1 = Math.sin((18 + 72 * 4) / 180 * Math.PI) * outerR; // left bottom circle\n\n group.addShape('circle', {\n attrs: __assign(__assign({}, markStyle), {\n x: x1,\n y: -y1,\n r: markSize / 2 || markR || 5\n }),\n className: 'link-point-right-bottom',\n name: 'link-point-right-bottom'\n });\n }\n },\n getPath: function getPath(cfg) {\n var size = this.getSize(cfg);\n var outerR = size[0];\n var defaultInnerR = outerR * 3 / 8;\n var innerR = cfg.innerR || defaultInnerR;\n var path = [];\n\n for (var i = 0; i < 5; i++) {\n var x1 = Math.cos((18 + 72 * i) / 180 * Math.PI) * outerR;\n var y1 = Math.sin((18 + 72 * i) / 180 * Math.PI) * outerR;\n var x2 = Math.cos((54 + 72 * i) / 180 * Math.PI) * innerR;\n var y2 = Math.sin((54 + 72 * i) / 180 * Math.PI) * innerR;\n\n if (i === 0) {\n path.push(['M', x1, -y1]);\n } else {\n path.push(['L', x1, -y1]);\n }\n\n path.push(['L', x2, -y2]);\n }\n\n path.push(['Z']);\n return path;\n },\n\n /**\n * 获取节点的样式,供基于该节点自定义时使用\n * @param {Object} cfg 节点数据模型\n * @return {Object} 节点的样式\n */\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.getOptions(cfg).style;\n var strokeStyle = {\n stroke: cfg.color\n }; // 如果设置了color,则覆盖原来默认的 stroke 属性。但 cfg 中但 stroke 属性优先级更高\n\n var style = mix({}, defaultStyle, strokeStyle);\n var path = this.getPath(cfg);\n\n var styles = __assign({\n path: path\n }, style);\n\n return styles;\n },\n update: function update(cfg, item) {\n var group = item.getContainer(); // 这里不传 cfg 参数是因为 cfg.style 需要最后覆盖样式\n\n var defaultStyle = this.getOptions({}).style;\n var path = this.getPath(cfg); // 下面这些属性需要覆盖默认样式与目前样式,但若在 cfg 中有指定则应该被 cfg 的相应配置覆盖。\n\n var strokeStyle = {\n stroke: cfg.color,\n path: path\n }; // 与 getShapeStyle 不同在于,update 时需要获取到当前的 style 进行融合。即新传入的配置项中没有涉及的属性,保留当前的配置。\n\n var keyShape = item.get('keyShape');\n var style = mix({}, defaultStyle, keyShape.attr(), strokeStyle);\n style = mix(style, cfg.style);\n this.updateShape(cfg, item, style, true);\n this.updateLinkPoints(cfg, group);\n },\n\n /**\n * 更新linkPoints\n * @param {Object} cfg 节点数据配置项\n * @param {Group} group Item所在的group\n */\n updateLinkPoints: function updateLinkPoints(cfg, group) {\n var defaultLinkPoints = this.getOptions({}).linkPoints;\n var markLeft = group.find(function (element) {\n return element.get('className') === 'link-point-left';\n });\n var markRight = group.find(function (element) {\n return element.get('className') === 'link-point-right';\n });\n var markTop = group.find(function (element) {\n return element.get('className') === 'link-point-top';\n });\n var markLeftBottom = group.find(function (element) {\n return element.get('className') === 'link-point-left-bottom';\n });\n var markRightBottom = group.find(function (element) {\n return element.get('className') === 'link-point-right-bottom';\n });\n var currentLinkPoints = defaultLinkPoints;\n var existLinkPoint = markLeft || markRight || markTop || markLeftBottom || markRightBottom;\n\n if (existLinkPoint) {\n currentLinkPoints = existLinkPoint.attr();\n }\n\n var linkPoints = mix({}, currentLinkPoints, cfg.linkPoints);\n var markFill = linkPoints.fill,\n markStroke = linkPoints.stroke,\n borderWidth = linkPoints.lineWidth;\n var markSize = linkPoints.size / 2;\n if (!markSize) markSize = linkPoints.r;\n\n var _a = cfg.linkPoints ? cfg.linkPoints : {\n left: undefined,\n right: undefined,\n top: undefined,\n leftBottom: undefined,\n rightBottom: undefined\n },\n left = _a.left,\n right = _a.right,\n top = _a.top,\n leftBottom = _a.leftBottom,\n rightBottom = _a.rightBottom;\n\n var size = this.getSize(cfg);\n var outerR = size[0];\n var styles = {\n r: markSize,\n fill: markFill,\n stroke: markStroke,\n lineWidth: borderWidth\n };\n var x = Math.cos((18 + 72 * 0) / 180 * Math.PI) * outerR;\n var y = Math.sin((18 + 72 * 0) / 180 * Math.PI) * outerR;\n\n if (markRight) {\n if (!right && right !== undefined) {\n markRight.remove();\n } else {\n markRight.attr(__assign(__assign({}, styles), {\n x: x,\n y: -y\n }));\n }\n } else if (right) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: x,\n y: -y\n }),\n className: 'link-point-right',\n name: 'link-point-right',\n isAnchorPoint: true\n });\n }\n\n x = Math.cos((18 + 72 * 1) / 180 * Math.PI) * outerR;\n y = Math.sin((18 + 72 * 1) / 180 * Math.PI) * outerR;\n\n if (markTop) {\n if (!top && top !== undefined) {\n markTop.remove();\n } else {\n markTop.attr(__assign(__assign({}, styles), {\n x: x,\n y: -y\n }));\n }\n } else if (top) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: x,\n y: -y\n }),\n className: 'link-point-top',\n name: 'link-point-top',\n isAnchorPoint: true\n });\n }\n\n x = Math.cos((18 + 72 * 2) / 180 * Math.PI) * outerR;\n y = Math.sin((18 + 72 * 2) / 180 * Math.PI) * outerR;\n\n if (markLeft) {\n if (!left && left !== undefined) {\n markLeft.remove();\n } else {\n markLeft.attr(__assign(__assign({}, styles), {\n x: x,\n y: -y\n }));\n }\n } else if (left) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: x,\n y: -y\n }),\n className: 'link-point-left',\n name: 'link-point-left',\n isAnchorPoint: true\n });\n }\n\n x = Math.cos((18 + 72 * 3) / 180 * Math.PI) * outerR;\n y = Math.sin((18 + 72 * 3) / 180 * Math.PI) * outerR;\n\n if (markLeftBottom) {\n if (!leftBottom && leftBottom !== undefined) {\n markLeftBottom.remove();\n } else {\n markLeftBottom.attr(__assign(__assign({}, styles), {\n x: x,\n y: -y\n }));\n }\n } else if (leftBottom) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: x,\n y: -y\n }),\n className: 'link-point-left-bottom',\n name: 'link-point-left-bottom',\n isAnchorPoint: true\n });\n }\n\n x = Math.cos((18 + 72 * 4) / 180 * Math.PI) * outerR;\n y = Math.sin((18 + 72 * 4) / 180 * Math.PI) * outerR;\n\n if (markRightBottom) {\n if (!rightBottom && rightBottom !== undefined) {\n markLeftBottom.remove();\n } else {\n markRightBottom.attr(__assign(__assign({}, styles), {\n x: x,\n y: -y\n }));\n }\n } else if (rightBottom) {\n group.addShape('circle', {\n attrs: __assign(__assign({}, styles), {\n x: x,\n y: -y\n }),\n className: 'link-point-right-bottom',\n name: 'link-point-right-bottom',\n isAnchorPoint: true\n });\n }\n }\n}, 'single-node');","import { __assign } from \"tslib\";\nimport { registerNode, BaseGlobal as Global, Util } from '@antv/g6-core';\nimport { deepMix, isNumber } from '@antv/util';\nvar defaultSubjectColors = Util.defaultSubjectColors; // 饼图节点\n\nregisterNode('donut', {\n // 自定义节点时的配置\n options: {\n size: Global.defaultNode.size,\n style: {\n x: 0,\n y: 0,\n stroke: Global.defaultNode.style.stroke,\n fill: Global.defaultNode.style.fill,\n lineWidth: Global.defaultNode.style.lineWidth\n },\n labelCfg: {\n style: {\n fill: Global.nodeLabel.style.fill,\n fontSize: Global.nodeLabel.style.fontSize\n }\n },\n // 节点上左右上下四个方向上的链接circle配置\n linkPoints: {\n top: false,\n right: false,\n bottom: false,\n left: false,\n // circle的大小\n size: Global.defaultNode.linkPoints.size,\n lineWidth: Global.defaultNode.linkPoints.lineWidth,\n fill: Global.defaultNode.linkPoints.fill,\n stroke: Global.defaultNode.linkPoints.stroke\n },\n // 节点中icon配置\n icon: {\n // 是否显示icon,值为 false 则不渲染icon\n show: false,\n // icon的地址,字符串类型\n img: 'https://gw.alipayobjects.com/zos/bmw-prod/5d015065-8505-4e7a-baec-976f81e3c41d.svg',\n width: 20,\n height: 20\n },\n stateStyles: __assign({}, Global.nodeStateStyles)\n },\n shapeType: 'circle',\n // 文本位置\n labelPosition: 'center',\n drawShape: function drawShape(cfg, group) {\n var _a = this.getOptions(cfg).icon,\n defaultIcon = _a === void 0 ? {} : _a;\n var style = this.getShapeStyle(cfg);\n var icon = deepMix({}, defaultIcon, cfg.icon);\n var keyShape = group.addShape('circle', {\n attrs: style,\n className: this.type + \"-keyShape\",\n draggable: true,\n name: this.type + \"-keyShape\"\n });\n var width = icon.width,\n height = icon.height,\n show = icon.show,\n text = icon.text;\n\n if (show) {\n if (text) {\n group.addShape('text', {\n attrs: __assign({\n x: 0,\n y: 0,\n fontSize: 12,\n fill: '#000',\n stroke: '#000',\n textBaseline: 'middle',\n textAlign: 'center'\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n } else {\n group.addShape('image', {\n attrs: __assign({\n x: -width / 2,\n y: -height / 2\n }, icon),\n className: this.type + \"-icon\",\n name: this.type + \"-icon\",\n draggable: true\n });\n }\n }\n\n var donutR = keyShape.attr('r');\n var innerR = 0.6 * donutR; // 甜甜圈的内环半径\n\n var arcR = (donutR + innerR) / 2; // 内环半径与外环半径的平均值\n\n var _b = cfg,\n _c = _b.donutAttrs,\n donutAttrs = _c === void 0 ? {} : _c,\n _d = _b.donutColorMap,\n donutColorMap = _d === void 0 ? {} : _d;\n var attrNum = Object.keys(donutAttrs).length;\n\n if (donutAttrs && attrNum > 1) {\n var attrs_1 = [];\n var totalValue_1 = 0;\n Object.keys(donutAttrs).forEach(function (name) {\n var value = donutAttrs[name] || 0;\n if (!isNumber(value)) return;\n attrs_1.push({\n key: name,\n value: value,\n color: donutColorMap[name]\n });\n totalValue_1 += value;\n });\n\n if (totalValue_1) {\n var lineWidth_1 = donutR - innerR;\n\n if (attrNum === 1) {\n group.addShape('circle', {\n attrs: {\n r: arcR,\n x: 0,\n y: 0,\n stroke: attrs_1[0].color || defaultSubjectColors[0],\n lineWidth: lineWidth_1\n },\n name: \"fan-shape-0\"\n });\n return;\n }\n\n var arcBegin_1 = [arcR, 0];\n var beginAngle_1 = 0;\n attrs_1.forEach(function (attr, i) {\n var percent = attr.value / totalValue_1;\n if (percent < 0.001) return;\n if (percent > 0.999) percent = 1;\n\n if (percent === 1) {\n group.addShape('circle', {\n attrs: {\n r: arcR,\n x: 0,\n y: 0,\n stroke: attr.color || defaultSubjectColors[i % defaultSubjectColors.length],\n lineWidth: lineWidth_1\n },\n name: \"fan-shape-\" + i\n });\n return;\n }\n\n attr.percent = percent;\n attr.angle = percent * Math.PI * 2;\n attr.beginAgnle = beginAngle_1;\n beginAngle_1 += attr.angle;\n attr.endAngle = beginAngle_1;\n attr.arcBegin = arcBegin_1;\n attr.arcEnd = [arcR * Math.cos(attr.endAngle), -arcR * Math.sin(attr.endAngle)];\n var isBig = attr.angle > Math.PI ? 1 : 0;\n var path = [['M', attr.arcBegin[0], attr.arcBegin[1]], ['A', arcR, arcR, 0, isBig, 0, attr.arcEnd[0], attr.arcEnd[1]], ['L', attr.arcEnd[0], attr.arcEnd[1]]];\n group.addShape('path', {\n attrs: {\n path: path,\n lineWidth: lineWidth_1,\n stroke: attr.color || defaultSubjectColors[i % defaultSubjectColors.length]\n },\n name: \"fan-shape-\" + i\n });\n arcBegin_1 = attr.arcEnd;\n });\n }\n }\n\n this.drawLinkPoints(cfg, group);\n return keyShape;\n },\n update: undefined\n}, 'circle');","export var getBBoxFromPoint = function getBBoxFromPoint(point) {\n var x = point.x,\n y = point.y;\n return {\n x: x,\n y: y,\n centerX: x,\n centerY: y,\n minX: x,\n minY: y,\n maxX: x,\n maxY: y,\n height: 0,\n width: 0\n };\n};\nexport var getBBoxFromPoints = function getBBoxFromPoints(points) {\n if (points === void 0) {\n points = [];\n }\n\n var xs = [];\n var ys = [];\n points.forEach(function (p) {\n xs.push(p.x);\n ys.push(p.y);\n });\n var minX = Math.min.apply(Math, xs);\n var maxX = Math.max.apply(Math, xs);\n var minY = Math.min.apply(Math, ys);\n var maxY = Math.max.apply(Math, ys);\n return {\n centerX: (minX + maxX) / 2,\n centerY: (minY + maxY) / 2,\n maxX: maxX,\n maxY: maxY,\n minX: minX,\n minY: minY,\n height: maxY - minY,\n width: maxX - minX\n };\n};\nexport var isBBoxesOverlapping = function isBBoxesOverlapping(b1, b2) {\n return Math.abs(b1.centerX - b2.centerX) * 2 < b1.width + b2.width && Math.abs(b1.centerY - b2.centerY) * 2 < b1.height + b2.height;\n};\nexport var filterConnectPoints = function filterConnectPoints(points) {\n // pre-process: remove duplicated points\n var result = [];\n var pointsMap = {};\n var pointsLength = points.length;\n\n for (var i = pointsLength - 1; i >= 0; i--) {\n var p = points[i];\n p.id = p.x + \"|||\" + p.y;\n pointsMap[p.id] = p;\n result.push(p);\n }\n\n return result;\n};\nexport var simplifyPolyline = function simplifyPolyline(points) {\n return filterConnectPoints(points);\n};\nexport var getSimplePolyline = function getSimplePolyline(sPoint, tPoint) {\n return [sPoint, {\n x: sPoint.x,\n y: tPoint.y\n }, tPoint];\n};\nexport var getExpandedBBox = function getExpandedBBox(bbox, offset) {\n if (bbox.width || bbox.height) {\n return {\n centerX: bbox.centerX,\n centerY: bbox.centerY,\n minX: bbox.minX - offset,\n minY: bbox.minY - offset,\n maxX: bbox.maxX + offset,\n maxY: bbox.maxY + offset,\n height: bbox.height + 2 * offset,\n width: bbox.width + 2 * offset\n };\n } // when it is a point\n\n\n return bbox;\n};\nexport var isHorizontalPort = function isHorizontalPort(port, bbox) {\n var dx = Math.abs(port.x - bbox.centerX);\n var dy = Math.abs(port.y - bbox.centerY);\n if (dx === 0 && dy === 0) return 0;\n return dx / bbox.width > dy / bbox.height;\n};\nexport var getExpandedBBoxPoint = function getExpandedBBoxPoint(bbox, // 将原来节点 bbox 扩展了 offset 后的 bbox,且被 gridSize 格式化\npoint, // 被 gridSize 格式化后的位置(anchorPoint)\nanotherPoint) {\n var isHorizontal = isHorizontalPort(point, bbox);\n\n if (isHorizontal === 0) {\n // 说明锚点是节点中心,linkCenter: true。需要根据两个节点的相对关系决定方向\n var x = bbox.centerX;\n var y = bbox.centerY;\n\n if (anotherPoint.y < point.y) {\n // 另一端在左上/右上方时,总是从上方走\n y = bbox.minY;\n } else if (anotherPoint.x > point.x) {\n // 另一端在右下方,往右边走\n x = bbox.maxX;\n } else if (anotherPoint.x < point.x) {\n // 另一端在左下方,往左边走\n x = bbox.minX;\n } else if (anotherPoint.x === point.x) {\n // 另一段在正下方,往下走\n y = bbox.maxY;\n }\n\n return {\n x: x,\n y: y\n };\n }\n\n if (isHorizontal) {\n return {\n x: point.x > bbox.centerX ? bbox.maxX : bbox.minX,\n y: point.y\n };\n }\n\n return {\n x: point.x,\n y: point.y > bbox.centerY ? bbox.maxY : bbox.minY\n };\n};\n/**\n *\n * @param b1\n * @param b2\n */\n\nexport var mergeBBox = function mergeBBox(b1, b2) {\n var minX = Math.min(b1.minX, b2.minX);\n var minY = Math.min(b1.minY, b2.minY);\n var maxX = Math.max(b1.maxX, b2.maxX);\n var maxY = Math.max(b1.maxY, b2.maxY);\n return {\n centerX: (minX + maxX) / 2,\n centerY: (minY + maxY) / 2,\n minX: minX,\n minY: minY,\n maxX: maxX,\n maxY: maxY,\n height: maxY - minY,\n width: maxX - minX\n };\n};\nexport var getPointsFromBBox = function getPointsFromBBox(bbox) {\n // anticlockwise\n // const { minX, minY, maxX, maxY } = bbox;\n return [{\n x: bbox.minX,\n y: bbox.minY\n }, {\n x: bbox.maxX,\n y: bbox.minY\n }, {\n x: bbox.maxX,\n y: bbox.maxY\n }, {\n x: bbox.minX,\n y: bbox.maxY\n }];\n};\nexport var isPointOutsideBBox = function isPointOutsideBBox(point, bbox) {\n var x = point.x,\n y = point.y;\n return x < bbox.minX || x > bbox.maxX || y < bbox.minY || y > bbox.maxY;\n};\nexport var getBBoxXCrossPoints = function getBBoxXCrossPoints(bbox, x) {\n if (x < bbox.minX || x > bbox.maxX) {\n return [];\n }\n\n return [{\n x: x,\n y: bbox.minY\n }, {\n x: x,\n y: bbox.maxY\n }];\n};\nexport var getBBoxYCrossPoints = function getBBoxYCrossPoints(bbox, y) {\n if (y < bbox.minY || y > bbox.maxY) {\n return [];\n }\n\n return [{\n x: bbox.minX,\n y: y\n }, {\n x: bbox.maxX,\n y: y\n }];\n};\nexport var getBBoxCrossPointsByPoint = function getBBoxCrossPointsByPoint(bbox, point) {\n return getBBoxXCrossPoints(bbox, point.x).concat(getBBoxYCrossPoints(bbox, point.y));\n};\n/**\n * 曼哈顿距离\n */\n\nexport var distance = function distance(p1, p2) {\n return Math.abs(p1.x - p2.x) + Math.abs(p1.y - p2.y);\n};\n/**\n * 如果 points 中的一个节点 x 与 p 相等,则消耗 -2。y 同\n * 即优先选择和 points 在同一水平线 / 垂直线上的点\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\n\nexport var _costByPoints = function _costByPoints(p, points) {\n var offset = -2;\n var result = 0;\n points.forEach(function (point) {\n if (point) {\n if (p.x === point.x) {\n result += offset;\n }\n\n if (p.y === point.y) {\n result += offset;\n }\n }\n });\n return result;\n};\n/**\n * ps 经过 p 到 pt 的距离,减去其他路过节点造成的消耗\n */\n\nexport var heuristicCostEstimate = function heuristicCostEstimate(p, ps, pt, source, target) {\n return distance(p, ps) + distance(p, pt) + _costByPoints(p, [ps, pt, source, target]);\n};\nexport var reconstructPath = function reconstructPath(pathPoints, pointById, cameFrom, currentId, iterator) {\n if (iterator === void 0) {\n iterator = 0;\n }\n\n pathPoints.unshift(pointById[currentId]);\n\n if (cameFrom[currentId] && cameFrom[currentId] !== currentId && iterator <= 100) {\n reconstructPath(pathPoints, pointById, cameFrom, cameFrom[currentId], iterator + 1);\n }\n};\n/**\n * 从 arr 中删去 item\n */\n\nexport var removeFrom = function removeFrom(arr, item) {\n var index = arr.indexOf(item);\n\n if (index > -1) {\n arr.splice(index, 1);\n }\n};\nexport var isSegmentsIntersected = function isSegmentsIntersected(p0, p1, p2, p3) {\n var v1x = p2.x - p0.x;\n var v1y = p2.y - p0.y;\n var v2x = p3.x - p0.x;\n var v2y = p3.y - p0.y;\n var v3x = p2.x - p1.x;\n var v3y = p2.y - p1.y;\n var v4x = p3.x - p1.x;\n var v4y = p3.y - p1.y;\n var pd1 = v1x * v2y - v1y * v2x;\n var pd2 = v3x * v4y - v3y * v4x;\n var pd3 = v1x * v3y - v1y * v3x;\n var pd4 = v2x * v4y - v2y * v4x;\n return pd1 * pd2 <= 0 && pd3 * pd4 <= 0;\n};\nexport var isSegmentCrossingBBox = function isSegmentCrossingBBox(p1, p2, bbox) {\n if (bbox.width || bbox.height) {\n var _a = getPointsFromBBox(bbox),\n pa = _a[0],\n pb = _a[1],\n pc = _a[2],\n pd = _a[3];\n\n return isSegmentsIntersected(p1, p2, pa, pb) || isSegmentsIntersected(p1, p2, pa, pd) || isSegmentsIntersected(p1, p2, pb, pc) || isSegmentsIntersected(p1, p2, pc, pd);\n }\n\n return false;\n};\n/**\n * 在 points 中找到满足 x 或 y 和 point 的 x 或 y 相等,且与 point 连线不经过 bbox1 与 bbox2 的点\n */\n\nexport var getNeighborPoints = function getNeighborPoints(points, point, bbox1, bbox2) {\n var neighbors = [];\n points.forEach(function (p) {\n if (p === point) return;\n\n if (p.x === point.x || p.y === point.y) {\n if (isSegmentCrossingBBox(p, point, bbox1) || isSegmentCrossingBBox(p, point, bbox2)) return;\n neighbors.push(p);\n }\n });\n return filterConnectPoints(neighbors);\n};\nexport var pathFinder = function pathFinder(points, start, goal, sBBox, tBBox, os, ot) {\n // A-Star Algorithm\n var closedSet = [];\n var openSet = [start];\n var cameFrom = {};\n var gScore = {}; // all default values are Infinity\n\n var fScore = {}; // all default values are Infinity\n\n gScore[start.id] = 0;\n fScore[start.id] = heuristicCostEstimate(start, goal, start);\n var pointById = {};\n points.forEach(function (p) {\n pointById[p.id] = p;\n });\n var current, lowestFScore;\n\n while (openSet.length) {\n current = undefined;\n lowestFScore = Infinity; // 找到 openSet 中 fScore 最小的点\n\n openSet.forEach(function (p) {\n if (fScore[p.id] <= lowestFScore) {\n lowestFScore = fScore[p.id];\n current = p;\n }\n }); // 若 openSet 中 fScore 最小的点就是终点\n\n if (current === goal) {\n // ending condition\n var pathPoints = [];\n reconstructPath(pathPoints, pointById, cameFrom, goal.id);\n return pathPoints;\n }\n\n removeFrom(openSet, current);\n closedSet.push(current);\n getNeighborPoints(points, current, sBBox, tBBox).forEach(function (neighbor) {\n if (closedSet.indexOf(neighbor) !== -1) {\n return;\n }\n\n if (openSet.indexOf(neighbor) === -1) {\n openSet.push(neighbor);\n }\n\n var tentativeGScore = fScore[current.id] + distance(current, neighbor); // + distance(neighbor, goal);\n\n if (gScore[neighbor.id] && tentativeGScore >= gScore[neighbor.id]) {\n return;\n }\n\n cameFrom[neighbor.id] = current.id;\n gScore[neighbor.id] = tentativeGScore;\n fScore[neighbor.id] = gScore[neighbor.id] + heuristicCostEstimate(neighbor, goal, start, os, ot);\n });\n } // throw new Error('Cannot find path');\n\n\n return [start, goal];\n};\nexport var isBending = function isBending(p0, p1, p2) {\n return !(p0.x === p1.x && p1.x === p2.x || p0.y === p1.y && p1.y === p2.y);\n};\nexport var getBorderRadiusPoints = function getBorderRadiusPoints(p0, p1, p2, r) {\n var d0 = distance(p0, p1);\n var d1 = distance(p2, p1);\n\n if (d0 < r) {\n r = d0;\n }\n\n if (d1 < r) {\n r = d1;\n }\n\n var ps = {\n x: p1.x - r / d0 * (p1.x - p0.x),\n y: p1.y - r / d0 * (p1.y - p0.y)\n };\n var pt = {\n x: p1.x - r / d1 * (p1.x - p2.x),\n y: p1.y - r / d1 * (p1.y - p2.y)\n };\n return [ps, pt];\n};\nexport var getPathWithBorderRadiusByPolyline = function getPathWithBorderRadiusByPolyline(points, borderRadius) {\n var pathSegments = [];\n var startPoint = points[0];\n pathSegments.push(\"M\" + startPoint.x + \" \" + startPoint.y);\n points.forEach(function (p, i) {\n var p1 = points[i + 1];\n var p2 = points[i + 2];\n\n if (p1 && p2) {\n if (isBending(p, p1, p2)) {\n var _a = getBorderRadiusPoints(p, p1, p2, borderRadius),\n ps = _a[0],\n pt = _a[1];\n\n pathSegments.push(\"L\" + ps.x + \" \" + ps.y);\n pathSegments.push(\"Q\" + p1.x + \" \" + p1.y + \" \" + pt.x + \" \" + pt.y);\n pathSegments.push(\"L\" + pt.x + \" \" + pt.y);\n } else {\n pathSegments.push(\"L\" + p1.x + \" \" + p1.y);\n }\n } else if (p1) {\n pathSegments.push(\"L\" + p1.x + \" \" + p1.y);\n }\n });\n return pathSegments.join('');\n};\nexport var getPolylinePoints = function getPolylinePoints(start, end, sNode, tNode, offset) {\n var sBBox, tBBox;\n\n if (!sNode || !sNode.getType()) {\n sBBox = getBBoxFromPoint(start);\n } else if (sNode.getType() === 'combo') {\n var sNodeKeyShape = sNode.getKeyShape();\n sBBox = sNodeKeyShape.getCanvasBBox() || getBBoxFromPoint(start);\n sBBox.centerX = (sBBox.minX + sBBox.maxX) / 2;\n sBBox.centerY = (sBBox.minY + sBBox.maxY) / 2;\n } else {\n sBBox = sNode.getBBox();\n }\n\n if (!tNode || !tNode.getType()) {\n tBBox = getBBoxFromPoint(end);\n } else if (tNode.getType() === 'combo') {\n var tKeyShapeBBox = tNode.getKeyShape().getBBox();\n\n if (tKeyShapeBBox) {\n var _a = tNode.getModel(),\n tx = _a.x,\n ty = _a.y;\n\n tBBox = {\n x: tx,\n y: ty,\n width: tKeyShapeBBox.width,\n height: tKeyShapeBBox.height,\n minX: tKeyShapeBBox.minX + tx,\n maxX: tKeyShapeBBox.maxX + tx,\n minY: tKeyShapeBBox.minY + ty,\n maxY: tKeyShapeBBox.maxY + ty\n };\n tBBox.centerX = (tBBox.minX + tBBox.maxX) / 2;\n tBBox.centerY = (tBBox.minY + tBBox.maxY) / 2;\n } else {\n tBBox = getBBoxFromPoint(end);\n }\n } else {\n tBBox = tNode && tNode.getBBox();\n } // if (isBBoxesOverlapping(sBBox, tBBox)) {\n // // source and target nodes are overlapping\n // return simplifyPolyline(getSimplePolyline(start, end));\n // }\n\n\n var sxBBox = getExpandedBBox(sBBox, offset);\n var txBBox = getExpandedBBox(tBBox, offset); // if (isBBoxesOverlapping(sxBBox, txBBox)) {\n // // the expanded bounding boxes of source and target nodes are overlapping\n // return simplifyPolyline(getSimplePolyline(start, end));\n // }\n\n var sPoint = getExpandedBBoxPoint(sxBBox, start, end);\n var tPoint = getExpandedBBoxPoint(txBBox, end, start);\n var lineBBox = getBBoxFromPoints([sPoint, tPoint]);\n var sMixBBox = mergeBBox(sxBBox, lineBBox);\n var tMixBBox = mergeBBox(txBBox, lineBBox);\n var connectPoints = [];\n connectPoints = connectPoints.concat(getPointsFromBBox(sMixBBox)).concat(getPointsFromBBox(tMixBBox));\n var centerPoint = {\n x: (start.x + end.x) / 2,\n y: (start.y + end.y) / 2\n };\n [lineBBox, sMixBBox, tMixBBox].forEach(function (bbox) {\n connectPoints = connectPoints.concat(getBBoxCrossPointsByPoint(bbox, centerPoint).filter(function (p) {\n return isPointOutsideBBox(p, sxBBox) && isPointOutsideBBox(p, txBBox);\n }));\n });\n [{\n x: sPoint.x,\n y: tPoint.y\n }, {\n x: tPoint.x,\n y: sPoint.y\n }].forEach(function (p) {\n // impossible!!\n if (isPointOutsideBBox(p, sxBBox) && isPointOutsideBBox(p, txBBox) // &&\n // isPointInsideBBox(p, sMixBBox) && isPointInsideBBox(p, tMixBBox)\n ) {\n connectPoints.push(p);\n }\n });\n connectPoints.unshift(sPoint);\n connectPoints.push(tPoint); // filter out dulplicated points in connectPoints\n\n connectPoints = filterConnectPoints(connectPoints); // , sxBBox, txBBox, outerBBox\n\n var pathPoints = pathFinder(connectPoints, sPoint, tPoint, sBBox, tBBox, start, end);\n pathPoints.unshift(start);\n pathPoints.push(end);\n return simplifyPolyline(pathPoints);\n};","/**\n * 通过配置不同的 costFunc, distFunc, constraints 可以得到不同效果的 router\n * generalRouter: 不限制搜索时的移动方向,避开障碍即可\n * orthogonal: 线必须沿着竖直或水平方向(4个方向)\n * octolinearRouter: 线沿着竖直、水平、对角线方向(8个方向)\n */\nimport { Util } from '@antv/g6-core';\nimport { deepMix } from '@antv/util';\nimport { getExpandedBBox, getExpandedBBoxPoint, getPolylinePoints, simplifyPolyline, isSegmentCrossingBBox } from './polyline-util';\n\nvar manhattanDist = function manhattanDist(p1, p2) {\n return Math.abs(p1.x - p2.x) + Math.abs(p1.y - p2.y);\n};\n\nvar eucliDist = function eucliDist(p1, p2) {\n return Math.sqrt(Math.pow(p1.x - p2.x, 2) + Math.pow(p1.y - p2.y, 2));\n};\n\nvar straightPath = function straightPath(start, end) {\n // console.warn('fallbackRoute: straight path');\n return [start, end];\n};\n\nvar simplePolyline = function simplePolyline(start, end, startNode, endNode, cfg) {\n return simplifyPolyline(getPolylinePoints(start, end, startNode, endNode, cfg.offset));\n}; // getPolylinePoints\n\n\nvar defaultCfg = {\n offset: 20,\n maxAllowedDirectionChange: Math.PI / 2,\n maximumLoops: 2000,\n gridSize: 10,\n directions: [{\n stepX: 1,\n stepY: 0\n }, {\n stepX: -1,\n stepY: 0\n }, {\n stepX: 0,\n stepY: 1\n }, {\n stepX: 0,\n stepY: -1\n } // top\n ],\n\n get penalties() {\n return {\n 0: 0,\n 45: this.gridSize / 2,\n 90: this.gridSize / 2\n };\n },\n\n distFunc: manhattanDist,\n fallbackRoute: simplePolyline\n};\nexport var octolinearCfg = {\n maxAllowedDirectionChange: Math.PI / 4,\n // 8 个方向: 上下左右 + 45度斜线方向\n directions: [{\n stepX: 1,\n stepY: 0\n }, {\n stepX: 1,\n stepY: 1\n }, {\n stepX: 0,\n stepY: 1\n }, {\n stepX: -1,\n stepY: 1\n }, {\n stepX: -1,\n stepY: 0\n }, {\n stepX: -1,\n stepY: -1\n }, {\n stepX: 0,\n stepY: -1\n }, {\n stepX: 1,\n stepY: -1\n }],\n distFunc: eucliDist,\n fallbackRoute: straightPath\n};\n\nvar pos2GridIx = function pos2GridIx(pos, gridSize) {\n var gridIx = Math.round(Math.abs(pos / gridSize));\n var sign = pos < 0 ? -1 : 1;\n return gridIx < 0 ? 0 : sign * gridIx;\n};\n\nvar getObstacleMap = function getObstacleMap(items, gridSize, offset) {\n var map = {};\n items.forEach(function (item) {\n // create-edge 时,当边类型为 polyline 时 endNode 为 null\n if (!item) return;\n var bbox = getExpandedBBox(item.getBBox(), offset);\n\n for (var x = pos2GridIx(bbox.minX, gridSize); x <= pos2GridIx(bbox.maxX, gridSize); x += 1) {\n for (var y = pos2GridIx(bbox.minY, gridSize); y <= pos2GridIx(bbox.maxY, gridSize); y += 1) {\n map[x + \"|||\" + y] = true;\n }\n }\n });\n return map;\n};\n/**\n * 方向角:计算从 p1 到 p2 的射线与水平线形成的夹角度数(顺时针从右侧0°转到该射线的角度)\n * @param p1 PolyPoint\n * @param p2 PolyPoint\n */\n\n\nvar getDirectionAngle = function getDirectionAngle(p1, p2) {\n var deltaX = p2.x - p1.x;\n var deltaY = p2.y - p1.y;\n\n if (deltaX || deltaY) {\n return Math.atan2(deltaY, deltaX);\n }\n\n return 0;\n};\n/**\n * 方向角的改变,取小于180度角\n * @param angle1\n * @param angle2\n */\n\n\nvar getAngleDiff = function getAngleDiff(angle1, angle2) {\n var directionChange = Math.abs(angle1 - angle2);\n return directionChange > Math.PI ? 2 * Math.PI - directionChange : directionChange; // return directionChange > 180 ? 360 - directionChange : directionChange;\n}; // Path finder //\n\n\nvar estimateCost = function estimateCost(from, endPoints, distFunc) {\n var min = Infinity;\n\n for (var i = 0, len = endPoints.length; i < len; i++) {\n var cost = distFunc(from, endPoints[i]);\n\n if (cost < min) {\n min = cost;\n }\n }\n\n return min;\n}; // 计算考虑 offset 后的 BBox 上的连接点\n\n\nvar getBoxPoints = function getBoxPoints(point, // 被 gridSize 格式化后的位置(anchorPoint)\noriPoint, // 未被 gridSize 格式化的位置(anchorPoint)\nnode, // 原始节点,用于获取 bbox\nanotherPoint, // 另一端被 gridSize 格式化后的位置\ncfg) {\n var points = []; // create-edge 生成边的过程中,endNode 为 null\n\n if (!node) {\n return [point];\n }\n\n var directions = cfg.directions,\n offset = cfg.offset;\n var bbox = node.getBBox();\n var isInside = oriPoint.x > bbox.minX && oriPoint.x < bbox.maxX && oriPoint.y > bbox.minY && oriPoint.y < bbox.maxY;\n var expandBBox = getExpandedBBox(bbox, offset);\n\n for (var i in expandBBox) {\n expandBBox[i] = pos2GridIx(expandBBox[i], cfg.gridSize);\n }\n\n if (isInside) {\n // 如果 anchorPoint 在节点内部,允许第一段线穿过节点\n for (var _i = 0, directions_1 = directions; _i < directions_1.length; _i++) {\n var dir = directions_1[_i];\n var bounds = [[{\n x: expandBBox.minX,\n y: expandBBox.minY\n }, {\n x: expandBBox.maxX,\n y: expandBBox.minY\n }], [{\n x: expandBBox.minX,\n y: expandBBox.minY\n }, {\n x: expandBBox.minX,\n y: expandBBox.maxY\n }], [{\n x: expandBBox.maxX,\n y: expandBBox.minY\n }, {\n x: expandBBox.maxX,\n y: expandBBox.maxY\n }], [{\n x: expandBBox.minX,\n y: expandBBox.maxY\n }, {\n x: expandBBox.maxX,\n y: expandBBox.maxY\n }]];\n\n for (var i = 0; i < 4; i++) {\n var boundLine = bounds[i];\n var insterctP_1 = Util.getLineIntersect(point, {\n x: point.x + dir.stepX * expandBBox.width,\n y: point.y + dir.stepY * expandBBox.height\n }, boundLine[0], boundLine[1]);\n\n if (insterctP_1 && !isSegmentCrossingBBox(point, insterctP_1, bbox)) {\n insterctP_1.id = insterctP_1.x + \"|||\" + insterctP_1.y;\n points.push(insterctP_1);\n }\n }\n }\n\n return points;\n } // 如果 anchorPoint 在节点上,只有一个可选方向\n\n\n var insterctP = getExpandedBBoxPoint(expandBBox, point, anotherPoint);\n insterctP.id = insterctP.x + \"|||\" + insterctP.y;\n return [insterctP];\n};\n\nvar getDirectionChange = function getDirectionChange(current, neighbor, cameFrom, scaleStartPoint) {\n var directionAngle = getDirectionAngle(current, neighbor);\n\n if (!cameFrom[current.id]) {\n var startAngle = getDirectionAngle(scaleStartPoint, current);\n return getAngleDiff(startAngle, directionAngle);\n }\n\n var prevDirectionAngle = getDirectionAngle({\n x: cameFrom[current.id].x,\n y: cameFrom[current.id].y\n }, current);\n return getAngleDiff(prevDirectionAngle, directionAngle);\n};\n\nvar getControlPoints = function getControlPoints(current, cameFrom, scaleStartPoint, endPoint, startPoint, scaleEndPoint, gridSize) {\n var controlPoints = [endPoint];\n var currentId = current.id;\n var currentX = current.x;\n var currentY = current.y;\n var lastPoint = {\n x: currentX,\n y: currentY,\n id: currentId\n };\n\n if (getDirectionChange(lastPoint, scaleEndPoint, cameFrom, scaleStartPoint)) {\n // if (scaleEndPoint.x === endPoint.x && scaleEndPoint.y === endPoint.y)\n // controlPoints.unshift({\n // x: endPoint.x,\n // y: endPoint.y\n // })\n // else\n // controlPoints.unshift({\n // x: lastPoint.x * gridSize,\n // y: lastPoint.y * gridSize,\n // });\n controlPoints.unshift({\n x: scaleEndPoint.x === endPoint.x ? endPoint.x : lastPoint.x * gridSize,\n y: scaleEndPoint.y === endPoint.y ? endPoint.y : lastPoint.y * gridSize\n });\n }\n\n while (cameFrom[currentId] && cameFrom[currentId].id !== currentId) {\n var point = {\n x: currentX,\n y: currentY,\n id: currentId\n };\n var preId = cameFrom[currentId].id;\n var preX = cameFrom[currentId].x;\n var preY = cameFrom[currentId].y;\n var prePoint = {\n x: preX,\n y: preY,\n id: preId\n };\n var directionChange = getDirectionChange(prePoint, point, cameFrom, scaleStartPoint);\n\n if (directionChange) {\n // if (prePoint.x === point.x && prePoint.y === point.y)\n // controlPoints.unshift({\n // x: controlPoints[0].x,\n // y: controlPoints[0].y\n // })\n // else\n // controlPoints.unshift({\n // x: prePoint.x * gridSize,\n // y: prePoint.y * gridSize,\n // });\n controlPoints.unshift({\n x: prePoint.x === point.x ? controlPoints[0].x : prePoint.x * gridSize,\n y: prePoint.y === point.y ? controlPoints[0].y : prePoint.y * gridSize\n });\n }\n\n currentId = preId;\n currentX = preX;\n currentY = preY;\n } // 和startNode对齐\n\n\n var firstPoint = {\n x: currentX,\n y: currentY,\n id: currentId\n }; // if (firstPoint.x === scaleStartPoint.x && firstPoint.y === scaleStartPoint.y) {\n // controlPoints[0].x = startPoint.x;\n // controlPoints[0].y = startPoint.y;\n // }\n\n controlPoints[0].x = firstPoint.x === scaleStartPoint.x ? startPoint.x : controlPoints[0].x;\n controlPoints[0].y = firstPoint.y === scaleStartPoint.y ? startPoint.y : controlPoints[0].y;\n controlPoints.unshift(startPoint);\n return controlPoints;\n};\n\nexport var pathFinder = function pathFinder(startPoint, endPoint, startNode, endNode, routerCfg) {\n if (isNaN(startPoint.x) || isNaN(endPoint.x)) return [];\n var cfg = deepMix(defaultCfg, routerCfg);\n cfg.obstacles = cfg.obstacles || [];\n var gridSize = cfg.gridSize;\n var map = getObstacleMap(cfg.obstacles.concat([startNode, endNode]), gridSize, cfg.offset);\n var scaleStartPoint = {\n x: pos2GridIx(startPoint.x, gridSize),\n y: pos2GridIx(startPoint.y, gridSize)\n };\n var scaleEndPoint = {\n x: pos2GridIx(endPoint.x, gridSize),\n y: pos2GridIx(endPoint.y, gridSize)\n };\n startPoint.id = scaleStartPoint.x + \"|||\" + scaleStartPoint.y;\n endPoint.id = scaleEndPoint.x + \"|||\" + scaleEndPoint.y;\n var startPoints = getBoxPoints(scaleStartPoint, startPoint, startNode, scaleEndPoint, cfg);\n var endPoints = getBoxPoints(scaleEndPoint, endPoint, endNode, scaleStartPoint, cfg);\n startPoints.forEach(function (point) {\n delete map[point.id];\n });\n endPoints.forEach(function (point) {\n delete map[point.id];\n });\n var openSet = {};\n var closedSet = {};\n var cameFrom = {}; // 从起点到当前点已产生的 cost, default: Infinity\n\n var gScore = {}; // 起点经过当前点到达终点预估的 cost, default: Infinity\n\n var fScore = {}; // initialize\n\n for (var i = 0; i < startPoints.length; i++) {\n var firstStep = startPoints[i];\n openSet[firstStep.id] = firstStep; // cameFrom[firstStep.id] = startPoint.id;\n\n gScore[firstStep.id] = 0;\n fScore[firstStep.id] = estimateCost(firstStep, endPoints, cfg.distFunc);\n }\n\n var remainLoops = cfg.maximumLoops;\n var penalties = cfg.penalties;\n var current, curCost, direction, neighbor, neighborCost, costFromStart, directionChange;\n\n while (Object.keys(openSet).length > 0 && remainLoops > 0) {\n current = undefined;\n curCost = Infinity; // 找到 openSet 中 fScore 最小的点\n\n Object.keys(openSet).forEach(function (key) {\n var id = openSet[key].id;\n\n if (fScore[id] <= curCost) {\n curCost = fScore[id];\n current = openSet[id];\n }\n });\n if (!current) break; // 如果 fScore 最小的点就是终点\n\n if (endPoints.findIndex(function (point) {\n return point.x === current.x && point.y === current.y;\n }) > -1) {\n return getControlPoints(current, cameFrom, scaleStartPoint, endPoint, startPoint, scaleEndPoint, gridSize);\n }\n\n delete openSet[current.id];\n closedSet[current.id] = true; // 获取符合条件的下一步的候选连接点\n // 沿候选方向走一步\n\n for (var i = 0; i < cfg.directions.length; i++) {\n direction = cfg.directions[i];\n neighbor = {\n x: current.x + direction.stepX,\n y: current.y + direction.stepY,\n id: Math.round(current.x) + direction.stepX + \"|||\" + (Math.round(current.y) + direction.stepY)\n };\n if (closedSet[neighbor.id]) continue;\n directionChange = getDirectionChange(current, neighbor, cameFrom, scaleStartPoint);\n if (directionChange > cfg.maxAllowedDirectionChange) continue;\n if (map[neighbor.id]) continue; // 如果交叉则跳过\n // 将候选点加入 openSet, 并计算每个候选点的 cost\n\n if (!openSet[neighbor.id]) {\n openSet[neighbor.id] = neighbor;\n }\n\n neighborCost = cfg.distFunc(current, neighbor) + (isNaN(penalties[directionChange]) ? gridSize : penalties[directionChange]);\n costFromStart = gScore[current.id] + neighborCost;\n\n if (gScore[neighbor.id] && costFromStart >= gScore[neighbor.id]) {\n continue;\n }\n\n cameFrom[neighbor.id] = current;\n gScore[neighbor.id] = costFromStart;\n fScore[neighbor.id] = costFromStart + estimateCost(neighbor, endPoints, cfg.distFunc);\n }\n\n remainLoops -= 1;\n }\n\n return cfg.fallbackRoute(startPoint, endPoint, startNode, endNode, cfg);\n};","import { __assign } from \"tslib\";\nimport { mix, each, isArray, isString } from '@antv/util';\nimport { registerEdge, Util, BaseGlobal as Global } from '@antv/g6-core';\nimport { getPathWithBorderRadiusByPolyline, getPolylinePoints } from './polyline-util';\nimport { pathFinder } from './router'; // 折线\n\nregisterEdge('polyline', {\n options: {\n color: Global.defaultEdge.color,\n size: Global.defaultEdge.size,\n style: {\n radius: 0,\n offset: 15,\n x: 0,\n y: 0,\n stroke: Global.defaultEdge.style.stroke,\n lineAppendWidth: Global.defaultEdge.style.lineAppendWidth\n },\n // 文本样式配置\n labelCfg: {\n style: {\n fill: Global.edgeLabel.style.fill,\n fontSize: Global.edgeLabel.style.fontSize\n }\n },\n routeCfg: {\n obstacles: [],\n maxAllowedDirectionChange: Math.PI,\n maximumLoops: 500,\n gridSize: 10 // 指定精度\n\n },\n stateStyles: __assign({}, Global.edgeStateStyles)\n },\n shapeType: 'polyline',\n // 文本位置\n labelPosition: 'center',\n drawShape: function drawShape(cfg, group) {\n var shapeStyle = this.getShapeStyle(cfg);\n if (shapeStyle.radius === 0) delete shapeStyle.radius;\n var keyShape = group.addShape('path', {\n className: 'edge-shape',\n name: 'edge-shape',\n attrs: shapeStyle\n });\n return keyShape;\n },\n getShapeStyle: function getShapeStyle(cfg) {\n var defaultStyle = this.options.style;\n var strokeStyle = {\n stroke: cfg.color\n };\n var style = mix({}, defaultStyle, strokeStyle, cfg.style);\n cfg = this.getPathPoints(cfg);\n this.radius = style.radius;\n this.offset = style.offset;\n var startPoint = cfg.startPoint,\n endPoint = cfg.endPoint;\n var controlPoints = this.getControlPoints(cfg);\n var points = [startPoint]; // 添加起始点\n // 添加控制点\n\n if (controlPoints) {\n points = points.concat(controlPoints);\n } // 添加结束点\n\n\n points.push(endPoint);\n var source = cfg.sourceNode;\n var target = cfg.targetNode;\n var radius = style.radius;\n var defaultRouteCfg = this.options.routeCfg;\n var routeCfg = mix({}, defaultRouteCfg, cfg.routeCfg);\n routeCfg.offset = style.offset;\n var path = this.getPath(points, source, target, radius, routeCfg);\n\n if (isArray(path) && path.length <= 1 || isString(path) && path.indexOf('L') === -1) {\n path = 'M0 0, L0 0';\n }\n\n if (isNaN(startPoint.x) || isNaN(startPoint.y) || isNaN(endPoint.x) || isNaN(endPoint.y)) {\n path = 'M0 0, L0 0';\n }\n\n var attrs = mix({}, Global.defaultEdge.style, style, {\n lineWidth: cfg.size,\n path: path\n });\n return attrs;\n },\n updateShapeStyle: function updateShapeStyle(cfg, item) {\n var group = item.getContainer();\n if (!item.isVisible()) return;\n var strokeStyle = {\n stroke: cfg.color\n };\n var shape = group.find(function (element) {\n return element.get('className') === 'edge-shape';\n }) || item.getKeyShape();\n var size = cfg.size;\n cfg = this.getPathPoints(cfg);\n var startPoint = cfg.startPoint,\n endPoint = cfg.endPoint;\n var controlPoints = this.getControlPoints(cfg); // || cfg.controlPoints;\n\n var points = [startPoint]; // 添加起始点\n // 添加控制点\n\n if (controlPoints) {\n points = points.concat(controlPoints);\n } // 添加结束点\n\n\n points.push(endPoint);\n var currentAttr = shape.attr();\n var previousStyle = mix({}, strokeStyle, currentAttr, cfg.style);\n var source = cfg.sourceNode;\n var target = cfg.targetNode;\n var radius = previousStyle.radius;\n var defaultRouteCfg = this.options.routeCfg;\n var routeCfg = mix({}, defaultRouteCfg, cfg.routeCfg);\n routeCfg.offset = previousStyle.offset;\n var path = this.getPath(points, source, target, radius, routeCfg);\n\n if (isArray(path) && path.length <= 1 || isString(path) && path.indexOf('L') === -1) {\n path = 'M0 0, L0 0';\n }\n\n if (isNaN(startPoint.x) || isNaN(startPoint.y) || isNaN(endPoint.x) || isNaN(endPoint.y)) {\n path = 'M0 0, L0 0';\n }\n\n if (currentAttr.endArrow && previousStyle.endArrow === false) {\n cfg.style.endArrow = {\n path: ''\n };\n }\n\n if (currentAttr.startArrow && previousStyle.startArrow === false) {\n cfg.style.startArrow = {\n path: ''\n };\n }\n\n var style = mix(strokeStyle, shape.attr(), {\n lineWidth: size,\n path: path\n }, cfg.style);\n\n if (shape) {\n shape.attr(style);\n }\n },\n getPath: function getPath(points, source, target, radius, routeCfg) {\n var offset = routeCfg.offset,\n simple = routeCfg.simple; // 指定了控制点\n\n if (!offset || points.length > 2) {\n if (radius) {\n return getPathWithBorderRadiusByPolyline(points, radius);\n }\n\n var pathArray_1 = [];\n each(points, function (point, index) {\n if (index === 0) {\n pathArray_1.push(['M', point.x, point.y]);\n } else {\n pathArray_1.push(['L', point.x, point.y]);\n }\n });\n return pathArray_1;\n } // 未指定控制点\n\n\n var polylinePoints = simple ? getPolylinePoints(points[points.length - 1], points[0], target, source, offset) : pathFinder(points[0], points[points.length - 1], source, target, routeCfg);\n if (!polylinePoints || !polylinePoints.length) return 'M0 0, L0 0';\n\n if (radius) {\n var res_1 = getPathWithBorderRadiusByPolyline(polylinePoints, radius);\n return res_1;\n }\n\n var res = Util.pointsToPolygon(polylinePoints);\n return res;\n }\n}, 'single-edge');","import { G6Event } from '@antv/g6-core';\nimport Util from '../util';\nvar cloneEvent = Util.cloneEvent,\n isNaN = Util.isNaN;\nvar abs = Math.abs;\nvar DRAG_OFFSET = 10;\nvar ALLOW_EVENTS = ['shift', 'ctrl', 'alt', 'control'];\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n direction: 'both',\n enableOptimize: false,\n // drag-canvas 可拖动的扩展范围,默认为 0,即最多可以拖动一屏的位置\n // 当设置的值大于 0 时,即拖动可以超过一屏\n // 当设置的值小于 0 时,相当于缩小了可拖动范围\n // 具体实例可参考:https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*IFfoS67_HssAAAAAAAAAAAAAARQnAQ\n scalableRange: 0,\n allowDragOnItem: false\n };\n },\n getEvents: function getEvents() {\n return {\n dragstart: 'onMouseDown',\n drag: 'onMouseMove',\n dragend: 'onMouseUp',\n 'canvas:click': 'onMouseUp',\n keyup: 'onKeyUp',\n focus: 'onKeyUp',\n keydown: 'onKeyDown',\n touchstart: 'onTouchStart',\n touchmove: 'onTouchMove',\n touchend: 'onMouseUp'\n };\n },\n updateViewport: function updateViewport(e) {\n var origin = this.origin;\n var clientX = +e.clientX;\n var clientY = +e.clientY;\n\n if (isNaN(clientX) || isNaN(clientY)) {\n return;\n }\n\n var dx = clientX - origin.x;\n var dy = clientY - origin.y;\n\n if (this.get('direction') === 'x') {\n dy = 0;\n } else if (this.get('direction') === 'y') {\n dx = 0;\n }\n\n this.origin = {\n x: clientX,\n y: clientY\n };\n var width = this.graph.get('width');\n var height = this.graph.get('height');\n var graphCanvasBBox = this.graph.get('canvas').getCanvasBBox();\n var expandWidth = this.scalableRange;\n var expandHeight = this.scalableRange; // 若 scalableRange 是 0~1 的小数,则作为比例考虑\n\n if (expandWidth < 1 && expandWidth > -1) {\n expandWidth = width * expandWidth;\n expandHeight = height * expandHeight;\n }\n\n if (graphCanvasBBox.minX <= width + expandWidth && graphCanvasBBox.minX + dx > width + expandWidth || graphCanvasBBox.maxX + expandWidth >= 0 && graphCanvasBBox.maxX + expandWidth + dx < 0) {\n dx = 0;\n }\n\n if (graphCanvasBBox.minY <= height + expandHeight && graphCanvasBBox.minY + dy > height + expandHeight || graphCanvasBBox.maxY + expandHeight >= 0 && graphCanvasBBox.maxY + expandHeight + dy < 0) {\n dy = 0;\n }\n\n this.graph.translate(dx, dy);\n },\n onTouchStart: function onTouchStart(e) {\n var self = this;\n var touches = e.originalEvent.touches;\n var event1 = touches[0];\n var event2 = touches[1]; // 如果是双指操作,不允许拖拽画布\n\n if (event1 && event2) {\n return;\n }\n\n e.preventDefault();\n self.onMouseDown(e);\n },\n onMouseDown: function onMouseDown(e) {\n var self = this;\n var event = e.originalEvent;\n\n if (event && e.name !== G6Event.TOUCHSTART && event.button !== 0) {\n return;\n }\n\n if (e.name !== G6Event.TOUCHSTART && typeof window !== 'undefined' && window.event && !window.event.buttons && !window.event.button) {\n return;\n }\n\n if (!this.shouldBegin.call(this, e)) {\n return;\n }\n\n if (self.keydown) return;\n var target = e.target;\n var targetIsCanvas = target && target.isCanvas && target.isCanvas();\n if (!this.allowDragOnItem && !targetIsCanvas) return;\n self.origin = {\n x: e.clientX,\n y: e.clientY\n };\n self.dragging = false;\n\n if (this.enableOptimize) {\n // 拖动 canvas 过程中隐藏所有的边及label\n var graph = this.graph;\n var edges = graph.getEdges();\n\n for (var i = 0, len = edges.length; i < len; i++) {\n var shapes = edges[i].get('group').get('children');\n if (!shapes) continue;\n shapes.forEach(function (shape) {\n shape.set('ori-visibility', shape.get('ori-visibility') || shape.get('visible'));\n shape.hide();\n });\n }\n\n var nodes = graph.getNodes();\n\n for (var j = 0, nodeLen = nodes.length; j < nodeLen; j++) {\n var container = nodes[j].getContainer();\n var children = container.get('children');\n\n for (var _i = 0, children_1 = children; _i < children_1.length; _i++) {\n var child = children_1[_i];\n var isKeyShape = child.get('isKeyShape');\n\n if (!isKeyShape) {\n child.set('ori-visibility', child.get('ori-visibility') || child.get('visible'));\n child.hide();\n }\n }\n }\n }\n },\n onTouchMove: function onTouchMove(e) {\n var self = this;\n var touches = e.originalEvent.touches;\n var event1 = touches[0];\n var event2 = touches[1]; // 如果是双指操作,不允许拖拽画布,结束拖拽\n\n if (event1 && event2) {\n this.onMouseUp(e);\n return;\n }\n\n e.preventDefault();\n self.onMouseMove(e);\n },\n onMouseMove: function onMouseMove(e) {\n var graph = this.graph;\n if (this.keydown) return;\n var target = e.target;\n var targetIsCanvas = target && target.isCanvas && target.isCanvas();\n if (!this.allowDragOnItem && !targetIsCanvas) return;\n e = cloneEvent(e);\n\n if (!this.origin) {\n return;\n }\n\n if (!this.dragging) {\n if (abs(this.origin.x - e.clientX) + abs(this.origin.y - e.clientY) < DRAG_OFFSET) {\n return;\n }\n\n if (this.shouldBegin.call(this, e)) {\n e.type = 'dragstart';\n graph.emit('canvas:dragstart', e);\n this.dragging = true;\n }\n } else {\n e.type = 'drag';\n graph.emit('canvas:drag', e);\n }\n\n if (this.shouldUpdate.call(this, e)) {\n this.updateViewport(e);\n }\n },\n onMouseUp: function onMouseUp(e) {\n var _a, _b;\n\n var graph = this.graph;\n if (this.keydown) return;\n var currentZoom = graph.getZoom();\n var modeController = graph.get('modeController');\n var zoomCanvas = (_b = (_a = modeController === null || modeController === void 0 ? void 0 : modeController.modes[modeController.mode]) === null || _a === void 0 ? void 0 : _a.filter(function (behavior) {\n return behavior.type === 'zoom-canvas';\n })) === null || _b === void 0 ? void 0 : _b[0];\n var optimizeZoom = zoomCanvas ? zoomCanvas.optimizeZoom || 0.1 : 0;\n\n if (this.enableOptimize) {\n // 拖动结束后显示所有的边\n var edges = graph.getEdges();\n\n for (var i = 0, len = edges.length; i < len; i++) {\n var shapes = edges[i].get('group').get('children');\n if (!shapes) continue;\n shapes.forEach(function (shape) {\n var oriVis = shape.get('ori-visibility');\n if (oriVis) shape.show();\n });\n }\n\n if (currentZoom > optimizeZoom) {\n var nodes = graph.getNodes();\n\n for (var j = 0, nodeLen = nodes.length; j < nodeLen; j++) {\n var container = nodes[j].getContainer();\n var children = container.get('children');\n\n for (var _i = 0, children_2 = children; _i < children_2.length; _i++) {\n var child = children_2[_i];\n var isKeyShape = child.get('isKeyShape');\n\n if (!isKeyShape) {\n var oriVis = child.get('ori-visibility');\n if (oriVis) child.show();\n }\n }\n }\n }\n }\n\n if (!this.dragging) {\n this.origin = null;\n return;\n }\n\n e = cloneEvent(e);\n\n if (this.shouldEnd.call(this, e)) {\n this.updateViewport(e);\n }\n\n e.type = 'dragend';\n graph.emit('canvas:dragend', e);\n this.endDrag();\n },\n endDrag: function endDrag() {\n this.origin = null;\n this.dragging = false;\n this.dragbegin = false;\n },\n onKeyDown: function onKeyDown(e) {\n var self = this;\n var code = e.key;\n\n if (!code) {\n return;\n }\n\n if (ALLOW_EVENTS.indexOf(code.toLowerCase()) > -1) {\n self.keydown = true;\n } else {\n self.keydown = false;\n }\n },\n onKeyUp: function onKeyUp() {\n this.keydown = false;\n this.origin = null;\n this.dragging = false;\n this.dragbegin = false;\n }\n};","import { __assign } from \"tslib\";\nimport { deepMix, clone, debounce } from '@antv/util';\nimport Global from '../global';\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n updateEdge: true,\n delegateStyle: {},\n // 是否开启delegate\n enableDelegate: false,\n // 拖动节点过程中是否只改变 Combo 的大小,而不改变其结构\n onlyChangeComboSize: false,\n // 拖动过程中目标 combo 状态样式\n comboActiveState: '',\n selectedState: 'selected',\n enableOptimize: false,\n enableDebounce: false,\n enableStack: true\n };\n },\n getEvents: function getEvents() {\n return {\n 'node:dragstart': 'onDragStart',\n 'node:drag': 'onDrag',\n 'node:dragend': 'onDragEnd',\n 'combo:dragenter': 'onDragEnter',\n 'combo:dragleave': 'onDragLeave',\n 'combo:drop': 'onDropCombo',\n 'node:drop': 'onDropNode',\n 'canvas:drop': 'onDropCanvas',\n 'touchstart': 'onTouchStart',\n 'touchmove': 'onTouchMove',\n 'touchend': 'onDragEnd'\n };\n },\n validationCombo: function validationCombo(item) {\n if (!this.origin || !item || item.destroyed) {\n return false;\n }\n\n var type = item.getType();\n\n if (type !== 'combo') {\n return false;\n }\n\n return true;\n },\n onTouchStart: function onTouchStart(e) {\n if (!e.item) return;\n var self = this;\n\n try {\n var touches = e.originalEvent.touches;\n var event1 = touches[0];\n var event2 = touches[1];\n\n if (event1 && event2) {\n return;\n }\n\n e.preventDefault();\n } catch (e) {\n console.warn('Touch original event not exist!');\n }\n\n self.onDragStart(e);\n },\n onTouchMove: function onTouchMove(e) {\n var self = this;\n\n try {\n var touches = e.originalEvent.touches;\n var event1 = touches[0];\n var event2 = touches[1];\n\n if (event1 && event2) {\n self.onDragEnd(e);\n return;\n }\n\n e.preventDefault();\n } catch (e) {\n console.warn('Touch original event not exist!');\n }\n\n self.onDrag(e);\n },\n\n /**\n * 开始拖动节点\n * @param evt\n */\n onDragStart: function onDragStart(evt) {\n var _this = this;\n\n this.currentShouldEnd = true;\n\n if (!this.shouldBegin.call(this, evt)) {\n return;\n }\n\n var item = evt.item;\n\n if (!item || item.destroyed || item.hasLocked()) {\n return;\n } // 拖动时,设置拖动元素的 capture 为false,则不拾取拖动的元素\n\n\n var group = item.getContainer();\n group.set('capture', false);\n if (!this.cachedCaptureItems) this.cachedCaptureItems = [];\n this.cachedCaptureItems.push(item); // 如果拖动的target 是linkPoints / anchorPoints 则不允许拖动\n\n var target = evt.target;\n\n if (target) {\n var isAnchorPoint = target.get('isAnchorPoint');\n\n if (isAnchorPoint) {\n return;\n }\n }\n\n var graph = this.graph;\n this.targets = []; // 将节点拖入到指定的 Combo\n\n this.targetCombo = null; // 获取所有选中的元素\n\n var nodes = graph.findAllByState('node', this.selectedState);\n var currentNodeId = item.get('id'); // 当前拖动的节点是否是选中的节点\n\n var dragNodes = nodes.filter(function (node) {\n var nodeId = node.get('id');\n return currentNodeId === nodeId;\n }); // 只拖动当前节点\n\n if (dragNodes.length === 0) {\n this.targets.push(item);\n } else if (nodes.length > 1) {\n // 拖动多个节点\n nodes.forEach(function (node) {\n var locked = node.hasLocked();\n\n if (!locked) {\n _this.targets.push(node);\n }\n });\n } else {\n this.targets.push(item);\n }\n\n var beforeDragNodes = [];\n this.targets.forEach(function (t) {\n beforeDragNodes.push(clone(t.getModel()));\n });\n this.set('beforeDragNodes', beforeDragNodes);\n this.hidenEdge = {};\n\n if (this.get('updateEdge') && this.enableOptimize && !this.enableDelegate) {\n this.targets.forEach(function (node) {\n var edges = node.getEdges();\n edges.forEach(function (edge) {\n if (!edge.isVisible()) return;\n _this.hidenEdge[edge.getID()] = true;\n edge.hide();\n });\n });\n }\n\n this.origin = {\n x: evt.x,\n y: evt.y\n };\n this.point = {};\n this.originPoint = {};\n },\n\n /**\n * 持续拖动节点\n * @param evt\n */\n onDrag: function onDrag(evt) {\n var _this = this;\n\n if (!this.origin) {\n return;\n }\n\n if (!this.shouldUpdate(this, evt)) {\n return;\n }\n\n if (this.get('enableDelegate')) {\n this.updateDelegate(evt);\n } else {\n if (this.enableDebounce) this.debounceUpdate({\n targets: this.targets,\n graph: this.graph,\n point: this.point,\n origin: this.origin,\n evt: evt,\n updateEdge: this.get('updateEdge')\n });else this.targets.map(function (target) {\n _this.update(target, evt);\n });\n }\n },\n\n /**\n * 拖动结束,设置拖动元素capture为true,更新元素位置,如果是拖动涉及到 combo,则更新 combo 结构\n * @param evt\n */\n onDragEnd: function onDragEnd(evt) {\n var _this = this;\n\n var _a;\n\n if (!this.origin) {\n return;\n } // 拖动结束后,设置拖动元素 group 的 capture 为 true,允许拾取拖动元素\n\n\n (_a = this.cachedCaptureItems) === null || _a === void 0 ? void 0 : _a.forEach(function (item) {\n var group = item.getContainer();\n group.set('capture', true);\n });\n this.cachedCaptureItems = [];\n\n if (this.delegateRect) {\n this.delegateRect.remove();\n this.delegateRect = null;\n }\n\n if (this.get('updateEdge') && this.enableOptimize && !this.enableDelegate) {\n this.targets.forEach(function (node) {\n var edges = node.getEdges();\n edges.forEach(function (edge) {\n if (_this.hidenEdge[edge.getID()]) edge.show();\n edge.refresh();\n });\n });\n }\n\n this.hidenEdge = {};\n var graph = this.graph; // 拖动结束后,入栈\n\n if (graph.get('enabledStack') && this.enableStack) {\n var stackData_1 = {\n before: {\n nodes: [],\n edges: [],\n combos: []\n },\n after: {\n nodes: [],\n edges: [],\n combos: []\n }\n };\n this.get('beforeDragNodes').forEach(function (model) {\n stackData_1.before.nodes.push({\n id: model.id,\n x: model.x,\n y: model.y\n });\n });\n this.targets.forEach(function (target) {\n var targetModel = target.getModel();\n stackData_1.after.nodes.push({\n id: targetModel.id,\n x: targetModel.x,\n y: targetModel.y\n });\n });\n graph.pushStack('update', clone(stackData_1));\n } // 拖动结束后emit事件,将当前操作的节点抛出去,目标节点为null\n\n\n graph.emit('dragnodeend', {\n items: this.targets,\n targetItem: null\n });\n this.point = {};\n this.origin = null;\n this.originPoint = {};\n this.targets.length = 0;\n this.targetCombo = null;\n },\n\n /**\n * 拖动过程中将节点放置到 combo 上\n * @param evt\n */\n onDropCombo: function onDropCombo(evt) {\n var item = evt.item;\n this.currentShouldEnd = this.shouldEnd.call(this, evt, item); // 若不允许结束,则将节点位置设置回初识位置。后面的逻辑仍需要执行\n\n this.updatePositions(evt, !this.currentShouldEnd);\n if (!this.currentShouldEnd || !this.validationCombo(item)) return;\n var graph = this.graph;\n\n if (this.comboActiveState) {\n graph.setItemState(item, this.comboActiveState, false);\n }\n\n this.targetCombo = item; // 拖动结束后是动态改变 Combo 大小还是将节点从 Combo 中删除\n\n if (this.onlyChangeComboSize) {\n // 拖动节点结束后,动态改变 Combo 的大小\n graph.updateCombos();\n } else {\n var targetComboModel_1 = item.getModel();\n this.targets.map(function (node) {\n var nodeModel = node.getModel();\n\n if (nodeModel.comboId !== targetComboModel_1.id) {\n graph.updateComboTree(node, targetComboModel_1.id);\n }\n });\n graph.updateCombo(item);\n } // 将节点拖动到 combo 上面,emit事件抛出当前操作的节点及目标 combo\n\n\n graph.emit('dragnodeend', {\n items: this.targets,\n targetItem: this.targetCombo\n });\n },\n onDropCanvas: function onDropCanvas(evt) {\n var graph = this.graph;\n this.currentShouldEnd = this.shouldEnd.call(this, evt, undefined); // 若不允许结束,则将节点位置设置回初识位置。后面的逻辑仍需要执行\n\n this.updatePositions(evt, !this.currentShouldEnd);\n if (!this.targets || this.targets.length === 0 || !this.currentShouldEnd) return;\n\n if (this.onlyChangeComboSize) {\n // 拖动节点结束后,动态改变 Combo 的大小\n graph.updateCombos();\n } else {\n this.targets.map(function (node) {\n // 拖动的节点有 comboId,即是从其他 combo 中拖出时才处理\n var model = node.getModel();\n\n if (model.comboId) {\n graph.updateComboTree(node);\n }\n });\n }\n },\n\n /**\n * 拖动放置到某个 combo 中的子 node 上\n * @param evt\n */\n onDropNode: function onDropNode(evt) {\n if (!this.targets || this.targets.length === 0) return;\n var self = this;\n var item = evt.item;\n var graph = self.graph;\n var comboId = item.getModel().comboId;\n var newParentCombo = comboId ? graph.findById(comboId) : undefined;\n this.currentShouldEnd = this.shouldEnd.call(this, evt, newParentCombo); // 若不允许结束,则将节点位置设置回初识位置。后面的逻辑仍需要执行\n\n this.updatePositions(evt, !this.currentShouldEnd);\n if (!this.currentShouldEnd) return;\n\n if (this.onlyChangeComboSize) {\n graph.updateCombos();\n } else if (comboId) {\n var combo = graph.findById(comboId);\n\n if (self.comboActiveState) {\n graph.setItemState(combo, self.comboActiveState, false);\n }\n\n this.targets.map(function (node) {\n var nodeModel = node.getModel();\n\n if (comboId !== nodeModel.comboId) {\n graph.updateComboTree(node, comboId);\n }\n });\n graph.updateCombo(combo);\n } else {\n this.targets.map(function (node) {\n var model = node.getModel();\n\n if (model.comboId) {\n graph.updateComboTree(node);\n }\n });\n } // 将节点拖动到另外个节点上面,emit 事件抛出当前操作的节点及目标节点\n\n\n graph.emit('dragnodeend', {\n items: this.targets,\n targetItem: item\n });\n },\n\n /**\n * 将节点拖入到 Combo 中\n * @param evt\n */\n onDragEnter: function onDragEnter(evt) {\n var item = evt.item;\n if (!this.validationCombo(item)) return;\n var graph = this.graph;\n\n if (this.comboActiveState) {\n graph.setItemState(item, this.comboActiveState, true);\n }\n },\n\n /**\n * 将节点从 Combo 中拖出\n * @param evt\n */\n onDragLeave: function onDragLeave(evt) {\n var item = evt.item;\n if (!this.validationCombo(item)) return;\n var graph = this.graph;\n\n if (this.comboActiveState) {\n graph.setItemState(item, this.comboActiveState, false);\n }\n },\n updatePositions: function updatePositions(evt, restore) {\n var _this = this;\n\n if (!this.targets || this.targets.length === 0) return; // 当开启 delegate 时,拖动结束后需要更新所有已选中节点的位置\n\n if (this.get('enableDelegate')) {\n if (this.enableDebounce) this.debounceUpdate({\n targets: this.targets,\n graph: this.graph,\n point: this.point,\n origin: this.origin,\n evt: evt,\n updateEdge: this.get('updateEdge'),\n updateFunc: this.update\n });else if (!restore) this.targets.map(function (node) {\n return _this.update(node, evt);\n });\n } else this.targets.map(function (node) {\n return _this.update(node, evt, restore);\n });\n },\n\n /**\n * 更新节点\n * @param item 拖动的节点实例\n * @param evt\n */\n update: function update(item, evt, restore) {\n var origin = this.origin;\n var model = item.get('model');\n var nodeId = item.get('id');\n\n if (!this.point[nodeId]) {\n this.point[nodeId] = {\n x: model.x || 0,\n y: model.y || 0\n };\n }\n\n var x = evt.x - origin.x + this.point[nodeId].x;\n var y = evt.y - origin.y + this.point[nodeId].y;\n\n if (restore) {\n x += origin.x - evt.x;\n y += origin.y - evt.y;\n }\n\n var pos = {\n x: x,\n y: y\n };\n\n if (this.get('updateEdge')) {\n this.graph.updateItem(item, pos, false);\n } else {\n item.updatePosition(pos);\n }\n },\n\n /**\n * 限流更新节点\n * @param item 拖动的节点实例\n * @param evt\n */\n debounceUpdate: debounce(function (event) {\n var targets = event.targets,\n graph = event.graph,\n point = event.point,\n origin = event.origin,\n evt = event.evt,\n updateEdge = event.updateEdge,\n updateFunc = event.updateFunc;\n targets.map(function (item) {\n var model = item.get('model');\n var nodeId = item.get('id');\n\n if (!point[nodeId]) {\n point[nodeId] = {\n x: model.x || 0,\n y: model.y || 0\n };\n }\n\n var x = evt.x - origin.x + point[nodeId].x;\n var y = evt.y - origin.y + point[nodeId].y;\n var pos = {\n x: x,\n y: y\n };\n\n if (updateEdge) {\n graph.updateItem(item, pos, false);\n } else {\n item.updatePosition(pos);\n }\n });\n }, 50, true),\n\n /**\n * 更新拖动元素时的delegate\n * @param {Event} e 事件句柄\n * @param {number} x 拖动单个元素时候的x坐标\n * @param {number} y 拖动单个元素时候的y坐标\n */\n updateDelegate: function updateDelegate(e) {\n var graph = this.graph;\n\n if (!this.delegateRect) {\n // 拖动多个\n var parent_1 = graph.get('group');\n var attrs = deepMix({}, Global.delegateStyle, this.delegateStyle);\n\n var _a = this.calculationGroupPosition(e),\n cx = _a.x,\n cy = _a.y,\n width = _a.width,\n height = _a.height,\n minX = _a.minX,\n minY = _a.minY;\n\n this.originPoint = {\n x: cx,\n y: cy,\n width: width,\n height: height,\n minX: minX,\n minY: minY\n }; // model上的x, y是相对于图形中心的,delegateShape是g实例,x,y是绝对坐标\n\n this.delegateRect = parent_1.addShape('rect', {\n attrs: __assign({\n width: width,\n height: height,\n x: cx,\n y: cy\n }, attrs),\n name: 'rect-delegate-shape'\n });\n this.delegate = this.delegateRect;\n this.delegateRect.set('capture', false);\n } else {\n var clientX = e.x - this.origin.x + this.originPoint.minX;\n var clientY = e.y - this.origin.y + this.originPoint.minY;\n this.delegateRect.attr({\n x: clientX,\n y: clientY\n });\n }\n },\n\n /**\n * 计算delegate位置,包括左上角左边及宽度和高度\n * @memberof ItemGroup\n * @return {object} 计算出来的delegate坐标信息及宽高\n */\n calculationGroupPosition: function calculationGroupPosition(evt) {\n var nodes = this.targets;\n\n if (nodes.length === 0) {\n nodes.push(evt.item);\n }\n\n var minx = Infinity;\n var maxx = -Infinity;\n var miny = Infinity;\n var maxy = -Infinity; // 获取已节点的所有最大最小x y值\n\n for (var i = 0; i < nodes.length; i++) {\n var element = nodes[i];\n var bbox = element.getBBox();\n var minX = bbox.minX,\n minY = bbox.minY,\n maxX = bbox.maxX,\n maxY = bbox.maxY;\n\n if (minX < minx) {\n minx = minX;\n }\n\n if (minY < miny) {\n miny = minY;\n }\n\n if (maxX > maxx) {\n maxx = maxX;\n }\n\n if (maxY > maxy) {\n maxy = maxY;\n }\n }\n\n var x = Math.floor(minx);\n var y = Math.floor(miny);\n var width = Math.ceil(maxx) - Math.floor(minx);\n var height = Math.ceil(maxy) - Math.floor(miny);\n return {\n x: x,\n y: y,\n width: width,\n height: height,\n minX: minx,\n minY: miny\n };\n }\n};","export default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n // 可选 mouseenter || click\n // 选择 click 会监听 touch,mouseenter 不会监听\n trigger: 'mouseenter',\n activeState: 'active',\n inactiveState: 'inactive',\n resetSelected: false,\n shouldUpdate: function shouldUpdate() {\n return true;\n }\n };\n },\n getEvents: function getEvents() {\n if (this.get('trigger') === 'mouseenter') {\n return {\n 'node:mouseenter': 'setAllItemStates',\n 'combo:mouseenter': 'setAllItemStates',\n 'node:mouseleave': 'clearActiveState',\n 'combo:mouseleave': 'clearActiveState'\n };\n }\n\n return {\n 'node:click': 'setAllItemStates',\n 'combo:click': 'setAllItemStates',\n 'canvas:click': 'clearActiveState',\n 'node:touchstart': 'setOnTouchStart',\n 'combo:touchstart': 'setOnTouchStart',\n 'canvas:touchstart': 'clearOnTouchStart'\n };\n },\n setOnTouchStart: function setOnTouchStart(e) {\n var self = this;\n\n try {\n var touches = e.originalEvent.touches;\n var event1 = touches[0];\n var event2 = touches[1];\n\n if (event1 && event2) {\n return;\n }\n\n e.preventDefault();\n } catch (e) {\n console.warn('Touch original event not exist!');\n }\n\n self.setAllItemStates(e);\n },\n clearOnTouchStart: function clearOnTouchStart(e) {\n var self = this;\n\n try {\n var touches = e.originalEvent.touches;\n var event1 = touches[0];\n var event2 = touches[1];\n\n if (event1 && event2) {\n return;\n }\n\n e.preventDefault();\n } catch (e) {\n console.warn('Touch original event not exist!');\n }\n\n self.clearActiveState(e);\n },\n setAllItemStates: function setAllItemStates(e) {\n var item = e.item;\n var graph = this.graph;\n this.item = item;\n\n if (!this.shouldUpdate(e.item, {\n event: e,\n action: 'activate'\n })) {\n return;\n }\n\n var self = this;\n var activeState = this.activeState;\n var inactiveState = this.inactiveState;\n var nodes = graph.getNodes();\n var combos = graph.getCombos();\n var edges = graph.getEdges();\n var vEdges = graph.get('vedges');\n var nodeLength = nodes.length;\n var comboLength = combos.length;\n var edgeLength = edges.length;\n var vEdgeLength = vEdges.length;\n\n for (var i = 0; i < nodeLength; i++) {\n var node = nodes[i];\n var hasSelected = node.hasState('selected');\n\n if (self.resetSelected) {\n if (hasSelected) {\n graph.setItemState(node, 'selected', false);\n }\n }\n\n graph.setItemState(node, activeState, false);\n\n if (inactiveState) {\n graph.setItemState(node, inactiveState, true);\n }\n }\n\n for (var i = 0; i < comboLength; i++) {\n var combo = combos[i];\n var hasSelected = combo.hasState('selected');\n\n if (self.resetSelected) {\n if (hasSelected) {\n graph.setItemState(combo, 'selected', false);\n }\n }\n\n graph.setItemState(combo, activeState, false);\n\n if (inactiveState) {\n graph.setItemState(combo, inactiveState, true);\n }\n }\n\n for (var i = 0; i < edgeLength; i++) {\n var edge = edges[i];\n graph.setItemState(edge, activeState, false);\n\n if (inactiveState) {\n graph.setItemState(edge, inactiveState, true);\n }\n }\n\n for (var i = 0; i < vEdgeLength; i++) {\n var vEdge = vEdges[i];\n graph.setItemState(vEdge, activeState, false);\n\n if (inactiveState) {\n graph.setItemState(vEdge, inactiveState, true);\n }\n }\n\n if (inactiveState) {\n graph.setItemState(item, inactiveState, false);\n }\n\n graph.setItemState(item, activeState, true);\n var rEdges = item.getEdges();\n var rEdgeLegnth = rEdges.length;\n\n for (var i = 0; i < rEdgeLegnth; i++) {\n var edge = rEdges[i];\n var otherEnd = void 0;\n\n if (edge.getSource() === item) {\n otherEnd = edge.getTarget();\n } else {\n otherEnd = edge.getSource();\n }\n\n if (inactiveState) {\n graph.setItemState(otherEnd, inactiveState, false);\n }\n\n graph.setItemState(otherEnd, activeState, true);\n graph.setItemState(edge, inactiveState, false);\n graph.setItemState(edge, activeState, true);\n edge.toFront();\n }\n\n graph.emit('afteractivaterelations', {\n item: e.item,\n action: 'activate'\n });\n },\n clearActiveState: function clearActiveState(e) {\n var self = this;\n var graph = self.get('graph');\n\n if (!self.shouldUpdate(e.item, {\n event: e,\n action: 'deactivate'\n })) {\n return;\n }\n\n var activeState = this.activeState;\n var inactiveState = this.inactiveState;\n var autoPaint = graph.get('autoPaint');\n graph.setAutoPaint(false);\n var nodes = graph.getNodes() || [];\n var combos = graph.getCombos() || [];\n var edges = graph.getEdges() || [];\n var vEdges = graph.get('vedges') || [];\n var nodeLength = nodes.length;\n var comboLength = combos.length;\n var edgeLength = edges.length;\n var vEdgeLength = vEdges.length;\n\n for (var i = 0; i < nodeLength; i++) {\n var node = nodes[i];\n graph.clearItemStates(node, [activeState, inactiveState]);\n }\n\n for (var i = 0; i < comboLength; i++) {\n var combo = combos[i];\n graph.clearItemStates(combo, [activeState, inactiveState]);\n }\n\n for (var i = 0; i < edgeLength; i++) {\n var edge = edges[i];\n graph.clearItemStates(edge, [activeState, inactiveState, 'deactivate']);\n }\n\n for (var i = 0; i < vEdgeLength; i++) {\n var vEdge = vEdges[i];\n graph.clearItemStates(vEdge, [activeState, inactiveState, 'deactivate']);\n }\n\n graph.paint();\n graph.setAutoPaint(autoPaint);\n graph.emit('afteractivaterelations', {\n item: e.item || self.get('item'),\n action: 'deactivate'\n });\n }\n};","var min = Math.min,\n max = Math.max,\n abs = Math.abs;\nvar DEFAULT_TRIGGER = 'shift';\nvar ALLOW_EVENTS = ['drag', 'shift', 'ctrl', 'alt', 'control'];\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n brushStyle: {\n fill: '#EEF6FF',\n fillOpacity: 0.4,\n stroke: '#DDEEFE',\n lineWidth: 1\n },\n onSelect: function onSelect() {},\n onDeselect: function onDeselect() {},\n selectedState: 'selected',\n trigger: DEFAULT_TRIGGER,\n includeEdges: true,\n selectedEdges: [],\n selectedNodes: []\n };\n },\n getEvents: function getEvents() {\n // 检测输入是否合法\n if (!(ALLOW_EVENTS.indexOf(this.trigger.toLowerCase()) > -1)) {\n this.trigger = DEFAULT_TRIGGER;\n console.warn(\"Behavior brush-select 的 trigger 参数不合法,请输入 'drag'、'shift'、'ctrl' 或 'alt'\");\n }\n\n if (this.trigger === 'drag') {\n return {\n dragstart: 'onMouseDown',\n drag: 'onMouseMove',\n dragend: 'onMouseUp',\n 'canvas:click': 'clearStates'\n };\n }\n\n return {\n dragstart: 'onMouseDown',\n drag: 'onMouseMove',\n dragend: 'onMouseUp',\n 'canvas:click': 'clearStates',\n keyup: 'onKeyUp',\n keydown: 'onKeyDown'\n };\n },\n onMouseDown: function onMouseDown(e) {\n // 按在node上面拖动时候不应该是框选\n var item = e.item;\n var brush = this.brush;\n\n if (item) {\n return;\n }\n\n if (this.trigger !== 'drag' && !this.keydown) {\n return;\n }\n\n if (this.selectedNodes && this.selectedNodes.length !== 0) {\n this.clearStates();\n }\n\n if (!brush) {\n brush = this.createBrush();\n }\n\n this.originPoint = {\n x: e.canvasX,\n y: e.canvasY\n };\n brush.attr({\n width: 0,\n height: 0\n });\n brush.show();\n this.dragging = true;\n },\n onMouseMove: function onMouseMove(e) {\n if (!this.dragging) {\n return;\n }\n\n if (this.trigger !== 'drag' && !this.keydown) {\n return;\n }\n\n this.updateBrush(e);\n },\n onMouseUp: function onMouseUp(e) {\n var graph = this.graph; // TODO: 触发了 canvas:click 导致 clearStates\n\n if (!this.brush && !this.dragging) {\n return;\n }\n\n if (this.trigger !== 'drag' && !this.keydown) {\n return;\n }\n\n this.brush.remove(true); // remove and destroy\n\n this.brush = null;\n this.getSelectedNodes(e);\n this.dragging = false;\n },\n clearStates: function clearStates() {\n var _a = this,\n graph = _a.graph,\n selectedState = _a.selectedState;\n\n var nodes = graph.findAllByState('node', selectedState);\n var edges = graph.findAllByState('edge', selectedState);\n nodes.forEach(function (node) {\n return graph.setItemState(node, selectedState, false);\n });\n edges.forEach(function (edge) {\n return graph.setItemState(edge, selectedState, false);\n });\n this.selectedNodes = [];\n this.selectedEdges = [];\n\n if (this.onDeselect) {\n this.onDeselect(this.selectedNodes, this.selectedEdges);\n }\n\n graph.emit('nodeselectchange', {\n selectedItems: {\n nodes: [],\n edges: []\n },\n select: false\n });\n },\n getSelectedNodes: function getSelectedNodes(e) {\n var _this = this;\n\n var _a = this,\n graph = _a.graph,\n originPoint = _a.originPoint,\n shouldUpdate = _a.shouldUpdate;\n\n var state = this.selectedState;\n var p1 = {\n x: e.x,\n y: e.y\n };\n var p2 = graph.getPointByCanvas(originPoint.x, originPoint.y);\n var left = min(p1.x, p2.x);\n var right = max(p1.x, p2.x);\n var top = min(p1.y, p2.y);\n var bottom = max(p1.y, p2.y);\n var selectedNodes = [];\n var selectedIds = [];\n graph.getNodes().forEach(function (node) {\n if (!node.isVisible()) return; // 隐藏节点不能被选中\n\n var bbox = node.getBBox();\n\n if (bbox.centerX >= left && bbox.centerX <= right && bbox.centerY >= top && bbox.centerY <= bottom) {\n if (shouldUpdate(node, 'select')) {\n selectedNodes.push(node);\n var model = node.getModel();\n selectedIds.push(model.id);\n graph.setItemState(node, state, true);\n }\n }\n });\n var selectedEdges = [];\n\n if (this.includeEdges) {\n // 选中边,边的source和target都在选中的节点中时才选中\n selectedNodes.forEach(function (node) {\n var edges = node.getOutEdges();\n edges.forEach(function (edge) {\n if (!edge.isVisible()) return; // 隐藏边不能够被选中\n\n var model = edge.getModel();\n var source = model.source,\n target = model.target;\n\n if (selectedIds.includes(source) && selectedIds.includes(target) && shouldUpdate(edge, 'select')) {\n selectedEdges.push(edge);\n graph.setItemState(edge, _this.selectedState, true);\n }\n });\n });\n }\n\n this.selectedEdges = selectedEdges;\n this.selectedNodes = selectedNodes;\n\n if (this.onSelect) {\n this.onSelect(selectedNodes, selectedEdges);\n }\n\n graph.emit('nodeselectchange', {\n selectedItems: {\n nodes: selectedNodes,\n edges: selectedEdges\n },\n select: true\n });\n },\n createBrush: function createBrush() {\n var self = this;\n var brush = self.graph.get('canvas').addShape('rect', {\n attrs: self.brushStyle,\n capture: false,\n name: 'brush-shape'\n });\n this.brush = brush;\n this.delegate = brush;\n return brush;\n },\n updateBrush: function updateBrush(e) {\n var originPoint = this.originPoint;\n this.brush.attr({\n width: abs(e.canvasX - originPoint.x),\n height: abs(e.canvasY - originPoint.y),\n x: min(e.canvasX, originPoint.x),\n y: min(e.canvasY, originPoint.y)\n });\n },\n onKeyDown: function onKeyDown(e) {\n var code = e.key;\n\n if (!code) {\n return;\n }\n\n var triggerLowerCase = this.trigger.toLowerCase();\n var codeLowerCase = code.toLowerCase(); // 按住 control 键时,允许用户设置 trigger 为 ctrl\n\n if (codeLowerCase === triggerLowerCase || codeLowerCase === 'control' && triggerLowerCase === 'ctrl' || codeLowerCase === 'ctrl' && triggerLowerCase === 'control') {\n this.keydown = true;\n } else {\n this.keydown = false;\n }\n },\n onKeyUp: function onKeyUp() {\n if (this.brush) {\n // 清除所有选中状态后,设置拖得动状态为false,并清除框选的brush\n this.brush.remove(true);\n this.brush = null;\n this.dragging = false;\n }\n\n this.keydown = false;\n }\n};","import { each } from '@antv/util';\nvar DEFAULT_TRIGGER = 'shift';\nvar ALLOW_EVENTS = ['shift', 'ctrl', 'alt', 'control'];\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n multiple: true,\n trigger: DEFAULT_TRIGGER,\n selectedState: 'selected'\n };\n },\n getEvents: function getEvents() {\n var self = this; // 检测输入是否合法\n\n if (!(ALLOW_EVENTS.indexOf(self.trigger.toLowerCase()) > -1)) {\n self.trigger = DEFAULT_TRIGGER; // eslint-disable-next-line no-console\n\n console.warn(\"Behavior brush-select 的 trigger 参数不合法,请输入 'drag'、'shift'、'ctrl' 或 'alt'\");\n }\n\n if (!self.multiple) {\n return {\n 'node:click': 'onClick',\n 'combo:click': 'onClick',\n 'canvas:click': 'onCanvasClick'\n };\n }\n\n return {\n 'node:click': 'onClick',\n 'combo:click': 'onClick',\n 'canvas:click': 'onCanvasClick',\n keyup: 'onKeyUp',\n keydown: 'onKeyDown'\n };\n },\n onClick: function onClick(evt) {\n var self = this;\n var item = evt.item;\n\n if (!item || item.destroyed) {\n return;\n }\n\n var type = item.getType();\n var graph = self.graph,\n keydown = self.keydown,\n multiple = self.multiple,\n shouldUpdate = self.shouldUpdate,\n shouldBegin = self.shouldBegin;\n\n if (!shouldBegin.call(self, evt)) {\n return;\n } // allow to select multiple nodes but did not press a key || do not allow the select multiple nodes\n\n\n if (!keydown || !multiple) {\n var selected = graph.findAllByState('node', self.selectedState).concat(graph.findAllByState('combo', self.selectedState));\n each(selected, function (combo) {\n if (combo !== item) {\n graph.setItemState(combo, self.selectedState, false);\n }\n });\n }\n\n if (item.hasState(self.selectedState)) {\n if (shouldUpdate.call(self, evt)) {\n graph.setItemState(item, self.selectedState, false);\n }\n\n var selectedNodes = graph.findAllByState('node', self.selectedState);\n var selectedCombos = graph.findAllByState('combo', self.selectedState);\n graph.emit('nodeselectchange', {\n target: item,\n selectedItems: {\n nodes: selectedNodes,\n combos: selectedCombos\n },\n select: false\n });\n } else {\n if (shouldUpdate.call(self, evt)) {\n graph.setItemState(item, self.selectedState, true);\n }\n\n var selectedNodes = graph.findAllByState('node', self.selectedState);\n var selectedCombos = graph.findAllByState('combo', self.selectedState);\n graph.emit('nodeselectchange', {\n target: item,\n selectedItems: {\n nodes: selectedNodes,\n combos: selectedCombos\n },\n select: true\n });\n }\n },\n onCanvasClick: function onCanvasClick() {\n var _this = this;\n\n var graph = this.graph;\n var selected = graph.findAllByState('node', this.selectedState);\n each(selected, function (node) {\n graph.setItemState(node, _this.selectedState, false);\n });\n var selectedCombos = graph.findAllByState('combo', this.selectedState);\n each(selectedCombos, function (combo) {\n graph.setItemState(combo, _this.selectedState, false);\n });\n graph.emit('nodeselectchange', {\n selectedItems: {\n nodes: [],\n edges: [],\n combos: []\n },\n select: false\n });\n },\n onKeyDown: function onKeyDown(e) {\n var self = this;\n var code = e.key;\n\n if (!code) {\n return;\n }\n\n if (code.toLowerCase() === this.trigger.toLowerCase() || code.toLowerCase() === 'control') {\n self.keydown = true;\n } else {\n self.keydown = false;\n }\n },\n onKeyUp: function onKeyUp() {\n var self = this;\n self.keydown = false;\n }\n};","import { ext } from '@antv/matrix-util';\nimport { clone } from '@antv/util';\nvar transform = ext.transform;\nvar DELTA = 0.05;\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n sensitivity: 2,\n minZoom: undefined,\n maxZoom: undefined,\n enableOptimize: false,\n optimizeZoom: 0.1,\n fixSelectedItems: {\n fixAll: false,\n fixLineWidth: false,\n fixLabel: false,\n fixState: 'selected'\n }\n };\n },\n getEvents: function getEvents() {\n var fixSelectedItems = this.fixSelectedItems;\n if (!fixSelectedItems.fixState) fixSelectedItems.fixState = 'selected';\n\n if (fixSelectedItems.fixAll) {\n fixSelectedItems.fixLineWidth = true;\n fixSelectedItems.fixLabel = true;\n }\n\n return {\n wheel: 'onWheel',\n touchstart: 'onTouchStart',\n touchmove: 'onTouchMove',\n touchend: 'onTouchEnd'\n };\n },\n onTouchStart: function onTouchStart(evt) {\n var touches = evt.originalEvent.touches;\n var event1 = touches[0];\n var event2 = touches[1];\n evt.preventDefault(); // 如果不是缩放事件则禁止继续执行\n\n if (!event2) {\n return;\n }\n\n if (this.shouldBegin && !this.shouldBegin.call(this, evt)) {\n return;\n } // 第一个触摸点位置\n\n\n this.startPoint = {\n pageX: event1.pageX,\n pageY: event1.pageY\n };\n this.moveable = true;\n\n if (event2) {\n this.endPoint = {\n pageX: event2.pageX,\n pageY: event2.pageY\n };\n }\n\n this.originScale = this.graph.getZoom() || this.currentScale || 1;\n },\n onTouchMove: function onTouchMove(evt) {\n if (!this.moveable) {\n return;\n }\n\n evt.preventDefault();\n var touches = evt.originalEvent.touches;\n var event1 = touches[0];\n var event2 = touches[1];\n\n if (!event2) {\n return;\n }\n\n if (!this.endPoint) {\n this.endPoint = {\n pageX: event2.pageX,\n pageY: event2.pageY\n };\n } // 获取坐标之间的距离\n\n\n var getDistance = function getDistance(start, end) {\n return Math.hypot(end.x - start.x, end.y - start.y);\n }; // 双指缩放比例\n\n\n var scale = getDistance({\n x: event1.pageX,\n y: event1.pageY\n }, {\n x: event2.pageX,\n y: event2.pageY\n }) / getDistance({\n x: this.startPoint.pageX,\n y: this.startPoint.pageY\n }, {\n x: this.endPoint.pageX,\n y: this.endPoint.pageY\n }); // 应用到画布上的缩放比例\n\n var zoom = this.originScale * scale; // 缓存当前的缩放比例\n\n this.currentScale = zoom;\n var minZoom = this.get('minZoom') || this.graph.get('minZoom');\n var maxZoom = this.get('maxZoom') || this.graph.get('maxZoom');\n\n if (zoom > maxZoom || zoom < minZoom) {\n return;\n }\n\n var canvas = this.graph.get('canvas');\n var point = canvas.getPointByClient(evt.clientX, evt.clientY);\n this.graph.zoomTo(zoom, {\n x: point.x,\n y: point.y\n });\n this.graph.emit('wheelzoom', evt);\n },\n onTouchEnd: function onTouchEnd() {\n this.moveable = false;\n this.endPoint = null;\n },\n onWheel: function onWheel(e) {\n var _this = this;\n\n var _a = this,\n graph = _a.graph,\n fixSelectedItems = _a.fixSelectedItems;\n\n if (this.shouldBegin && !this.shouldBegin.call(this, e)) {\n return;\n }\n\n if (!this.shouldUpdate.call(this, e)) {\n return;\n }\n\n e.preventDefault();\n var canvas = graph.get('canvas');\n var point = canvas.getPointByClient(e.clientX, e.clientY);\n var sensitivity = this.get('sensitivity');\n var graphZoom = graph.getZoom();\n var ratio = graphZoom;\n var zoom = graphZoom; // 兼容IE、Firefox及Chrome\n\n if (e.wheelDelta < 0) {\n ratio = 1 - DELTA * sensitivity;\n } else {\n ratio = 1 / (1 - DELTA * sensitivity);\n }\n\n zoom = graphZoom * ratio; // const zoom = ratio * graphZoom;\n\n var minZoom = this.get('minZoom') || graph.get('minZoom');\n var maxZoom = this.get('maxZoom') || graph.get('maxZoom');\n\n if (zoom > maxZoom || zoom < minZoom) {\n return;\n } // hide the shapes when the zoom ratio is smaller than optimizeZoom\n // hide the shapes when zoomming\n\n\n var enableOptimize = this.get('enableOptimize');\n\n if (enableOptimize) {\n var optimizeZoom_1 = this.get('optimizeZoom');\n var optimized = this.get('optimized');\n var nodes_1 = graph.getNodes();\n var edges_1 = graph.getEdges();\n var nodesLength_1 = nodes_1.length;\n var edgesLength_1 = edges_1.length; // hiding\n\n if (!optimized) {\n for (var n = 0; n < nodesLength_1; n++) {\n var node = nodes_1[n];\n\n if (!node.destroyed) {\n var children = node.get('group').get('children');\n var childrenLength = children.length;\n\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n\n if (!shape.destoryed && !shape.get('isKeyShape')) {\n shape.set('ori-visibility', shape.get('ori-visibility') || shape.get('visible'));\n shape.hide();\n }\n }\n }\n }\n\n for (var edgeIndex = 0; edgeIndex < edgesLength_1; edgeIndex++) {\n var edge = edges_1[edgeIndex];\n var children = edge.get('group').get('children');\n var childrenLength = children.length;\n\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n shape.set('ori-visibility', shape.get('ori-visibility') || shape.get('visible'));\n shape.hide();\n }\n }\n\n this.set('optimized', true);\n } // showing after 100ms\n\n\n clearTimeout(this.get('timeout'));\n var timeout = setTimeout(function () {\n var currentZoom = graph.getZoom();\n\n var curOptimized = _this.get('optimized');\n\n if (curOptimized) {\n _this.set('optimized', false);\n\n for (var n = 0; n < nodesLength_1; n++) {\n var node = nodes_1[n];\n var children = node.get('group').get('children');\n var childrenLength = children.length;\n\n if (currentZoom < optimizeZoom_1) {\n var keyShape = node.getKeyShape();\n var oriVis = keyShape.get('ori-visibility');\n if (oriVis) keyShape.show();\n } else {\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n var oriVis = shape.get('ori-visibility');\n\n if (!shape.get('visible') && oriVis) {\n if (oriVis) shape.show();\n }\n }\n }\n }\n\n for (var edgeIndex = 0; edgeIndex < edgesLength_1; edgeIndex++) {\n var edge = edges_1[edgeIndex];\n var children = edge.get('group').get('children');\n var childrenLength = children.length;\n\n if (currentZoom < optimizeZoom_1) {\n var keyShape = edge.getKeyShape();\n var oriVis = keyShape.get('ori-visibility');\n if (oriVis) keyShape.show();\n } else {\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n\n if (!shape.get('visible')) {\n var oriVis = shape.get('ori-visibility');\n if (oriVis) shape.show();\n }\n }\n }\n }\n }\n }, 100);\n this.set('timeout', timeout);\n } // fix the items when zooming\n\n\n if (graphZoom <= 1) {\n var fixNodes = void 0,\n fixEdges = void 0;\n\n if (fixSelectedItems.fixAll || fixSelectedItems.fixLineWidth || fixSelectedItems.fixLabel) {\n fixNodes = graph.findAllByState('node', fixSelectedItems.fixState);\n fixEdges = graph.findAllByState('edge', fixSelectedItems.fixState);\n var scale = graphZoom / zoom;\n var fixNodesLength = fixNodes.length;\n\n for (var fn = 0; fn < fixNodesLength; fn++) {\n var node = fixNodes[fn];\n var group = node.getContainer();\n var nodeModel = node.getModel();\n var originStyle = node.getOriginStyle();\n var itemStateStyle = node.getStateStyle(fixSelectedItems.fixState);\n var shapeStateStyle = node.get('shapeFactory').getShape(nodeModel.type).getStateStyle(fixSelectedItems.fixState, node)[fixSelectedItems.fixState];\n\n if (fixSelectedItems.fixAll) {\n if (zoom <= 1) {\n var groupMatrix = clone(group.getMatrix());\n if (!groupMatrix) groupMatrix = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n\n var _b = node.getModel(),\n x = _b.x,\n y = _b.y;\n\n groupMatrix = transform(groupMatrix, [['t', -x, -y], ['s', scale, scale], ['t', x, y]]);\n group.setMatrix(groupMatrix);\n }\n } else {\n var children = group.get('children');\n var childrenLength = children.length;\n\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n var fontSize = void 0,\n lineWidth = void 0;\n\n if (fixSelectedItems.fixLabel) {\n var shapeType = shape.get('type');\n\n if (shapeType === 'text') {\n fontSize = shape.attr('fontSize') || 12;\n var itemStyle = itemStateStyle[shape.get('name')];\n var shapeStyle = shapeStateStyle[shape.get('name')];\n var itemFontSize = itemStyle ? itemStyle.fontSize : 12;\n var shapeFontSize = shapeStyle ? shapeStyle.fontSize : 12;\n var oriFontSize = itemFontSize || shapeFontSize || 12;\n if (zoom <= 1) shape.attr('fontSize', oriFontSize / zoom); // * graphZoom / zoom\n\n if (lineWidth) break;\n }\n }\n\n if (fixSelectedItems.fixLineWidth) {\n if (shape.get('isKeyShape')) {\n lineWidth = shape.attr('lineWidth') || 0;\n var oriLineWidth = itemStateStyle.lineWidth || shapeStateStyle.lineWidth || originStyle.lineWidth || 0;\n if (zoom <= 1) shape.attr('lineWidth', oriLineWidth / zoom); // * graphZoom / zoom\n\n if (fontSize) break;\n }\n }\n }\n }\n }\n\n var fixEdgesLength = fixEdges.length;\n\n for (var fe = 0; fe < fixEdgesLength; fe++) {\n var edge = fixEdges[fe];\n var group = edge.getContainer();\n var children = group.get('children');\n var nodeModel = edge.getModel();\n var itemStateStyle = edge.getStateStyle(fixSelectedItems.fixState);\n var shapeStateStyle = edge.get('shapeFactory').getShape(nodeModel.type).getStateStyle(fixSelectedItems.fixState, edge)[fixSelectedItems.fixState];\n var childrenLength = children.length;\n\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n var fontSize = void 0,\n lineWidth = void 0;\n\n if (fixSelectedItems.fixLabel || fixSelectedItems.fixAll) {\n var shapeType = shape.get('type');\n\n if (shapeType === 'text') {\n fontSize = shape.attr('fontSize') || 12;\n var itemStyle = itemStateStyle[shape.get('name')];\n var shapeStyle = shapeStateStyle[shape.get('name')];\n var itemFontSize = itemStyle ? itemStyle.fontSize : 12;\n var shapeFontSize = shapeStyle ? shapeStyle.fontSize : 12;\n var oriFontSize = itemFontSize || shapeFontSize || 12;\n if (zoom <= 1) shape.attr('fontSize', oriFontSize / zoom);\n if (lineWidth) break;\n }\n }\n\n if (fixSelectedItems.fixLineWidth || fixSelectedItems.fixAll) {\n if (shape.get('isKeyShape')) {\n lineWidth = shape.attr('lineWidth') || 0;\n var oriLineWidth = itemStateStyle.lineWidth || shapeStateStyle.lineWidth || 1;\n if (zoom <= 1) shape.attr('lineWidth', oriLineWidth / zoom);\n if (fontSize) break;\n }\n }\n }\n }\n }\n }\n\n graph.zoomTo(zoom, {\n x: point.x,\n y: point.y\n });\n graph.emit('wheelzoom', e);\n }\n};","import { modifyCSS, createDom } from '@antv/dom-util';\nexport default {\n onMouseEnter: function onMouseEnter(e) {\n var item = e.item;\n this.currentTarget = item;\n this.showTooltip(e);\n this.graph.emit('tooltipchange', {\n item: e.item,\n action: 'show'\n });\n },\n onMouseMove: function onMouseMove(e) {\n if (!this.shouldUpdate(e)) {\n this.hideTooltip();\n return;\n }\n\n if (!this.currentTarget || e.item !== this.currentTarget) {\n return;\n }\n\n this.updatePosition(e);\n },\n onMouseLeave: function onMouseLeave(e) {\n if (!this.shouldEnd(e)) {\n return;\n }\n\n this.hideTooltip();\n this.graph.emit('tooltipchange', {\n item: this.currentTarget,\n action: 'hide'\n });\n this.currentTarget = null;\n },\n showTooltip: function showTooltip(e) {\n var container = this.container;\n\n if (!e.item || e.item.destroyed) {\n return;\n }\n\n if (!container) {\n container = this.createTooltip(this.graph.get('canvas'));\n this.container = container;\n }\n\n var text = this.formatText(e.item.get('model'), e);\n container.innerHTML = text;\n modifyCSS(this.container, {\n visibility: 'visible'\n });\n this.updatePosition(e);\n },\n hideTooltip: function hideTooltip() {\n modifyCSS(this.container, {\n visibility: 'hidden'\n });\n },\n updatePosition: function updatePosition(e) {\n var shouldBegin = this.get('shouldBegin');\n\n var _a = this,\n width = _a.width,\n height = _a.height,\n container = _a.container,\n graph = _a.graph;\n\n if (!shouldBegin(e)) {\n modifyCSS(container, {\n visibility: 'hidden'\n });\n return;\n }\n\n var point = graph.getPointByClient(e.clientX, e.clientY);\n\n var _b = graph.getCanvasByPoint(point.x, point.y),\n x = _b.x,\n y = _b.y;\n\n var bbox = container.getBoundingClientRect();\n\n if (x > width / 2) {\n x -= bbox.width;\n } else {\n x += this.offset;\n }\n\n if (y > height / 2) {\n y -= bbox.height;\n } else {\n y += this.offset;\n }\n\n var left = x + \"px\";\n var top = y + \"px\";\n modifyCSS(this.container, {\n left: left,\n top: top,\n visibility: 'visible'\n });\n },\n createTooltip: function createTooltip(canvas) {\n var el = canvas.get('el');\n el.style.position = 'relative';\n var container = createDom(\"<div class=\\\"g6-tooltip g6-\" + this.item + \"-tooltip\\\"></div>\");\n el.parentNode.appendChild(container);\n modifyCSS(container, {\n position: 'absolute',\n visibility: 'visible'\n });\n this.width = canvas.get('width');\n this.height = canvas.get('height');\n this.container = container;\n this.graph.get('tooltips').push(container);\n return container;\n }\n};","import { __assign } from \"tslib\";\nimport base from './tooltip-base';\nexport default __assign({\n getDefaultCfg: function getDefaultCfg() {\n return {\n item: 'node',\n offset: 12,\n formatText: function formatText(model) {\n return model.label;\n }\n };\n },\n getEvents: function getEvents() {\n return {\n 'node:mouseenter': 'onMouseEnter',\n 'node:mouseleave': 'onMouseLeave',\n 'node:mousemove': 'onMouseMove',\n afterremoveitem: 'onMouseLeave'\n };\n }\n}, base);","import { __assign } from \"tslib\";\nimport base from './tooltip-base';\nexport default __assign({\n getDefaultCfg: function getDefaultCfg() {\n return {\n item: 'edge',\n offset: 12,\n formatText: function formatText(model) {\n return \"source: \" + model.source + \" target: \" + model.target;\n }\n };\n },\n getEvents: function getEvents() {\n return {\n 'edge:mouseenter': 'onMouseEnter',\n 'edge:mouseleave': 'onMouseLeave',\n 'edge:mousemove': 'onMouseMove',\n afterremoveitem: 'onMouseLeave'\n };\n }\n}, base);","var DEFAULT_TRIGGER = 'click';\nvar ALLOW_EVENTS = ['click', 'dblclick'];\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n /**\n * 发生收缩/扩展变化时的回调\n */\n trigger: DEFAULT_TRIGGER,\n onChange: function onChange() {}\n };\n },\n getEvents: function getEvents() {\n var _a;\n\n var trigger; // 检测输入是否合法\n\n if (ALLOW_EVENTS.includes(this.trigger)) {\n trigger = this.trigger;\n } else {\n trigger = DEFAULT_TRIGGER; // eslint-disable-next-line no-console\n\n console.warn(\"Behavior collapse-expand 的 trigger 参数不合法,请输入 'click' 或 'dblclick'\");\n }\n\n return _a = {}, _a[\"node:\" + trigger] = 'onNodeClick', // 支持移动端事件\n _a.touchstart = 'onNodeClick', _a;\n },\n onNodeClick: function onNodeClick(e) {\n var item = e.item;\n if (!item) return; // 如果节点进行过更新,model 会进行 merge,直接改 model 就不能改布局,所以需要去改源数据\n\n var sourceData = this.graph.findDataById(item.get('id'));\n\n if (!sourceData) {\n return;\n }\n\n var children = sourceData.children; // 叶子节点的收缩和展开没有意义\n\n if (!children || children.length === 0) {\n return;\n }\n\n var collapsed = !sourceData.collapsed;\n\n if (!this.shouldBegin(e, collapsed)) {\n return;\n }\n\n sourceData.collapsed = collapsed;\n item.getModel().collapsed = collapsed;\n this.graph.emit('itemcollapsed', {\n item: e.item,\n collapsed: collapsed\n });\n\n if (!this.shouldUpdate(e, collapsed)) {\n return;\n }\n\n this.onChange(item, collapsed);\n this.graph.layout();\n }\n};","import { __assign } from \"tslib\";\n/*\n * @Author: moyee\n * @LastEditors: moyee\n * @Description: 拖动 Combo\n */\n\nimport { each } from '@antv/util';\nimport Util from '../util';\nimport Global from '../global';\nvar calculationItemsBBox = Util.calculationItemsBBox;\n/**\n * 遍历拖动的 Combo 下的所有 Combo\n * @param data 拖动的 Combo\n * @param fn\n */\n\nvar traverseCombo = function traverseCombo(data, fn) {\n if (fn(data) === false) {\n return;\n }\n\n if (data) {\n var combos = data.get('combos');\n\n if (combos.length === 0) {\n return false;\n }\n\n each(combos, function (child) {\n traverseCombo(child, fn);\n });\n }\n};\n\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n enableDelegate: false,\n delegateStyle: {},\n // 拖动节点过程中是否只改变 Combo 的大小,而不改变其结构\n onlyChangeComboSize: false,\n // 拖动过程中目标 combo 状态样式\n activeState: '',\n selectedState: 'selected'\n };\n },\n getEvents: function getEvents() {\n return {\n 'combo:dragstart': 'onDragStart',\n 'combo:drag': 'onDrag',\n 'combo:dragend': 'onDragEnd',\n 'combo:drop': 'onDrop',\n 'node:drop': 'onNodeDrop',\n 'combo:dragenter': 'onDragEnter',\n 'combo:dragleave': 'onDragLeave'\n };\n },\n validationCombo: function validationCombo(evt) {\n var item = evt.item;\n\n if (!item || item.destroyed) {\n return false;\n }\n\n if (!this.shouldUpdate(this, evt)) {\n return false;\n }\n\n var type = item.getType();\n\n if (type !== 'combo') {\n return false;\n }\n\n return true;\n },\n onDragStart: function onDragStart(evt) {\n var _this = this;\n\n var graph = this.graph;\n var item = evt.item;\n this.currentShouldEnd = true;\n if (!this.validationCombo(evt)) return;\n this.targets = []; // 获取所有选中的 Combo\n\n var combos = graph.findAllByState('combo', this.selectedState);\n var currentCombo = item.get('id');\n var dragCombos = combos.filter(function (combo) {\n var comboId = combo.get('id');\n return currentCombo === comboId;\n });\n\n if (dragCombos.length === 0) {\n this.targets.push(item);\n } else {\n this.targets = combos;\n }\n\n if (this.activeState) {\n this.targets.map(function (combo) {\n var model = combo.getModel();\n\n if (model.parentId) {\n var parentCombo = graph.findById(model.parentId);\n\n if (parentCombo) {\n graph.setItemState(parentCombo, _this.activeState, true);\n }\n }\n });\n }\n\n this.point = {};\n this.originPoint = {};\n this.origin = {\n x: evt.x,\n y: evt.y\n };\n this.currentItemChildCombos = [];\n traverseCombo(item, function (param) {\n if (param.destroyed) {\n return false;\n }\n\n var model = param.getModel();\n\n _this.currentItemChildCombos.push(model.id);\n\n return true;\n });\n },\n onDrag: function onDrag(evt) {\n var _this = this;\n\n if (!this.origin) {\n return;\n }\n\n if (!this.validationCombo(evt)) return;\n\n if (this.enableDelegate) {\n this.updateDelegate(evt);\n } else {\n if (this.activeState) {\n var graph_1 = this.graph;\n var item = evt.item;\n var model_1 = item.getModel(); // 拖动过程中实时计算距离\n\n var combos = graph_1.getCombos();\n var sourceBBox = item.getBBox();\n var centerX_1 = sourceBBox.centerX,\n centerY_1 = sourceBBox.centerY,\n width_1 = sourceBBox.width; // 参与计算的 Combo,需要排除掉:\n // 1、拖动 combo 自己\n // 2、拖动 combo 的 parent\n // 3、拖动 Combo 的 children\n\n var calcCombos = combos.filter(function (combo) {\n var cmodel = combo.getModel(); // 被拖动的是最外层的 Combo,无 parent,排除自身和子元素\n\n if (!model_1.parentId) {\n return cmodel.id !== model_1.id && !_this.currentItemChildCombos.includes(cmodel.id);\n }\n\n return cmodel.id !== model_1.id && !_this.currentItemChildCombos.includes(cmodel.id);\n });\n calcCombos.map(function (combo) {\n var _a = combo.getBBox(),\n cx = _a.centerX,\n cy = _a.centerY,\n w = _a.width; // 拖动的 combo 和要进入的 combo 之间的距离\n\n\n var disX = centerX_1 - cx;\n var disY = centerY_1 - cy; // 圆心距离\n\n var distance = 2 * Math.sqrt(disX * disX + disY * disY);\n\n if (width_1 + w - distance > 0.8 * width_1) {\n graph_1.setItemState(combo, _this.activeState, true);\n } else {\n graph_1.setItemState(combo, _this.activeState, false);\n }\n });\n }\n\n each(this.targets, function (item) {\n _this.updateCombo(item, evt);\n });\n }\n },\n updatePositions: function updatePositions(evt, restore) {\n var _this = this; // 当启用 delegate 时,拖动结束时需要更新 combo\n\n\n if (this.enableDelegate || restore) {\n each(this.targets, function (item) {\n _this.updateCombo(item, evt, restore);\n });\n }\n },\n onDrop: function onDrop(evt) {\n var _this = this; // 被放下的目标 combo\n\n\n var item = evt.item;\n this.currentShouldEnd = this.shouldEnd.call(this, evt, item);\n this.updatePositions(evt, !this.currentShouldEnd);\n if (!this.currentShouldEnd || !item || !this.targets || item.destroyed) return;\n var graph = this.graph;\n var targetModel = item.getModel();\n this.targets.map(function (combo) {\n var model = combo.getModel();\n\n if (model.parentId !== targetModel.id) {\n if (_this.activeState) {\n graph.setItemState(item, _this.activeState, false);\n } // 将 Combo 放置到某个 Combo 上面时,只有当 onlyChangeComboSize 为 false 时候才更新 Combo 结构\n\n\n if (!_this.onlyChangeComboSize) {\n graph.updateComboTree(combo, targetModel.id);\n } else {\n graph.updateCombo(combo);\n }\n } else {\n graph.updateCombo(item);\n }\n });\n this.end(item, evt); // 如果已经拖放下了,则不需要再通过距离判断了\n\n this.endComparison = true;\n },\n onNodeDrop: function onNodeDrop(evt) {\n var _this = this;\n\n if (!this.targets || this.targets.length === 0) return;\n var graph = this.graph;\n var item = evt.item;\n var comboId = item.getModel().comboId;\n var newParentCombo = comboId ? graph.findById(comboId) : undefined;\n this.currentShouldEnd = this.shouldEnd.call(this, evt, newParentCombo);\n this.updatePositions(evt, !this.currentShouldEnd);\n if (!this.currentShouldEnd) return;\n var droppedCombo; // 如果被放置的的节点有 comboId,且这个 comboId 与正在被拖拽的 combo 的父 id 不相同,则更新父亲为 comboId\n\n if (comboId) {\n if (this.activeState) {\n var combo = graph.findById(comboId);\n graph.setItemState(combo, this.activeState, false);\n }\n\n this.targets.map(function (combo) {\n if (!_this.onlyChangeComboSize) {\n if (comboId !== combo.getID()) {\n droppedCombo = graph.findById(comboId);\n if (comboId !== combo.getModel().parentId) graph.updateComboTree(combo, comboId);\n }\n } else {\n graph.updateCombo(combo);\n }\n });\n } else {\n // 如果被放置的节点没有 comboId,且正在被拖拽的 combo 有父 id,则更新父亲为 undefined\n this.targets.map(function (combo) {\n if (!_this.onlyChangeComboSize) {\n var model = combo.getModel();\n\n if (model.comboId) {\n graph.updateComboTree(combo);\n }\n } else {\n graph.updateCombo(combo);\n }\n });\n } // 如果已经拖放下了,则不需要再通过距离判断了\n\n\n this.endComparison = true;\n this.end(droppedCombo, evt);\n },\n onDragEnter: function onDragEnter(evt) {\n if (!this.origin) {\n return;\n }\n\n if (!this.validationCombo(evt)) return;\n var item = evt.item;\n var graph = this.graph;\n\n if (this.activeState) {\n graph.setItemState(item, this.activeState, true);\n }\n },\n onDragLeave: function onDragLeave(evt) {\n if (!this.origin) {\n return;\n }\n\n if (!this.validationCombo(evt)) return;\n var item = evt.item;\n var graph = this.graph;\n\n if (this.activeState) {\n graph.setItemState(item, this.activeState, false);\n }\n },\n onDragEnd: function onDragEnd(evt) {\n if (!this.targets || this.targets.length === 0) return;\n var item = evt.item;\n\n if (this.currentShouldEnd) {\n this.updatePositions(evt);\n }\n\n var parentCombo = this.getParentCombo(item.getModel().parentId);\n var graph = this.graph;\n\n if (parentCombo && this.activeState) {\n graph.setItemState(parentCombo, this.activeState, false);\n }\n\n this.end(undefined, evt);\n },\n end: function end(comboDropedOn, evt) {\n var _this = this;\n\n if (!this.origin) return;\n var graph = this.graph; // 删除delegate shape\n\n if (this.delegateShape) {\n var delegateGroup = graph.get('delegateGroup');\n delegateGroup.clear();\n this.delegateShape = null;\n }\n\n if (comboDropedOn && this.activeState) {\n graph.setItemState(comboDropedOn, this.activeState, false);\n } // 若没有被放置的 combo,则是被放置在画布上\n\n\n if (!comboDropedOn) {\n this.targets.map(function (combo) {\n // 将 Combo 放置到某个 Combo 上面时,只有当 onlyChangeComboSize 为 false 时候才更新 Combo 结构\n if (!_this.onlyChangeComboSize) {\n graph.updateComboTree(combo);\n } else {\n graph.updateCombo(combo);\n }\n });\n }\n\n this.point = [];\n this.origin = null;\n this.originPoint = null;\n this.targets.length = 0;\n },\n\n /**\n * 遍历 comboTree,分别更新 node 和 combo\n * @param data\n * @param fn\n */\n traverse: function traverse(data, fn) {\n var _this = this;\n\n if (fn(data) === false) {\n return;\n }\n\n if (data) {\n var combos = data.get('combos');\n each(combos, function (child) {\n _this.traverse(child, fn);\n });\n var nodes = data.get('nodes');\n each(nodes, function (child) {\n _this.traverse(child, fn);\n });\n }\n },\n updateCombo: function updateCombo(item, evt, restore) {\n var _this = this;\n\n this.traverse(item, function (param) {\n if (param.destroyed) {\n return false;\n }\n\n _this.updateSignleItem(param, evt, restore);\n\n return true;\n });\n },\n\n /**\n *\n * @param item 当前正在拖动的元素\n * @param evt\n */\n updateSignleItem: function updateSignleItem(item, evt, restore) {\n var origin = this.origin;\n var graph = this.graph;\n var model = item.getModel();\n var itemId = item.get('id');\n\n if (!this.point[itemId]) {\n this.point[itemId] = {\n x: model.x,\n y: model.y\n };\n }\n\n var x = evt.x - origin.x + this.point[itemId].x;\n var y = evt.y - origin.y + this.point[itemId].y;\n\n if (restore) {\n x += origin.x - evt.x;\n y += origin.y - evt.y;\n }\n\n graph.updateItem(item, {\n x: x,\n y: y\n });\n },\n\n /**\n * 根据 ID 获取父 Combo\n * @param parentId 父 Combo ID\n */\n getParentCombo: function getParentCombo(parentId) {\n var graph = this.graph;\n\n if (!parentId) {\n return undefined;\n }\n\n var parentCombo = graph.findById(parentId);\n\n if (!parentCombo) {\n return undefined;\n }\n\n return parentCombo;\n },\n updateDelegate: function updateDelegate(evt) {\n var graph = this.graph; // 当没有 delegate shape 时创建\n\n if (!this.delegateShape) {\n var delegateGroup = graph.get('delegateGroup');\n var bbox = null;\n\n if (this.targets.length > 1) {\n bbox = calculationItemsBBox(this.targets);\n } else {\n bbox = this.targets[0].getBBox();\n }\n\n var x = bbox.x,\n y = bbox.y,\n width = bbox.width,\n height = bbox.height,\n minX = bbox.minX,\n minY = bbox.minY;\n this.originPoint = {\n x: x,\n y: y,\n width: width,\n height: height,\n minX: minX,\n minY: minY\n };\n\n var attrs = __assign(__assign({}, Global.delegateStyle), this.delegateStyle);\n\n this.delegateShape = delegateGroup.addShape('rect', {\n attrs: __assign({\n width: bbox.width,\n height: bbox.height,\n x: bbox.x,\n y: bbox.y\n }, attrs),\n name: 'combo-delegate-shape'\n });\n this.delegateShape.set('capture', false);\n this.delegate = this.delegateShape;\n } else {\n var clientX = evt.x - this.origin.x + this.originPoint.minX;\n var clientY = evt.y - this.origin.y + this.originPoint.minY;\n this.delegateShape.attr({\n x: clientX,\n y: clientY\n });\n }\n }\n};","/*\n * @Author: Shiwu\n * @Description: 收起和展开 Combo\n */\nvar DEFAULT_TRIGGER = 'dblclick';\nvar ALLOW_EVENTS = ['click', 'dblclick'];\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n trigger: DEFAULT_TRIGGER,\n relayout: true\n };\n },\n getEvents: function getEvents() {\n var _a;\n\n var trigger; // 检测输入是否合法\n\n if (ALLOW_EVENTS.includes(this.trigger)) {\n trigger = this.trigger;\n } else {\n trigger = DEFAULT_TRIGGER; // eslint-disable-next-line no-console\n\n console.warn(\"Behavior collapse-expand-group 的 trigger 参数不合法,请输入 'click' 或 'dblclick'\");\n }\n\n return _a = {}, _a[\"combo:\" + trigger] = 'onComboClick', _a;\n },\n onComboClick: function onComboClick(evt) {\n var item = evt.item;\n\n var _a = this,\n graph = _a.graph,\n relayout = _a.relayout;\n\n if (!item || item.destroyed || item.getType() !== 'combo') return;\n var model = item.getModel();\n var comboId = model.id;\n\n if (!comboId) {\n return;\n }\n\n graph.collapseExpandCombo(comboId);\n if (relayout && graph.get('layout')) graph.layout();else graph.refreshPositions();\n }\n};","import { __assign } from \"tslib\";\nimport Util from '../util';\nvar isPolygonsIntersect = Util.isPolygonsIntersect,\n pathToPoints = Util.pathToPoints;\nvar DEFAULT_TRIGGER = 'shift';\nvar ALLOW_EVENTS = ['drag', 'shift', 'ctrl', 'alt', 'control'];\n\nvar isItemIntersecPolygon = function isItemIntersecPolygon(item, polyPoints) {\n var shapePoints;\n var shape = item.getKeyShape();\n\n if (item.get('type') === 'path') {\n shapePoints = pathToPoints(shape.attr('path'));\n } else {\n var shapeBBox = shape.getCanvasBBox();\n shapePoints = [[shapeBBox.minX, shapeBBox.minY], [shapeBBox.maxX, shapeBBox.minY], [shapeBBox.maxX, shapeBBox.maxY], [shapeBBox.minX, shapeBBox.maxY]];\n }\n\n return isPolygonsIntersect(polyPoints, shapePoints);\n};\n\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n delegateStyle: {\n fill: '#EEF6FF',\n fillOpacity: 0.4,\n stroke: '#DDEEFE',\n lineWidth: 1\n },\n onSelect: function onSelect() {},\n onDeselect: function onDeselect() {},\n selectedState: 'selected',\n trigger: DEFAULT_TRIGGER,\n includeEdges: true,\n selectedEdges: [],\n selectedNodes: [] // multiple: false,\n\n };\n },\n getEvents: function getEvents() {\n // 检测输入是否合法\n if (!(ALLOW_EVENTS.indexOf(this.trigger.toLowerCase()) > -1)) {\n this.trigger = DEFAULT_TRIGGER;\n console.warn(\"Behavior lasso-select 的 trigger 参数不合法,请输入 'drag'、'shift'、'ctrl' 或 'alt'\");\n }\n\n if (this.trigger === 'drag') {\n return {\n dragstart: 'onDragStart',\n drag: 'onDragMove',\n dragend: 'onDragEnd',\n 'canvas:click': 'clearStates'\n };\n }\n\n return {\n dragstart: 'onDragStart',\n drag: 'onDragMove',\n dragend: 'onDragEnd',\n keyup: 'onKeyUp',\n keydown: 'onKeyDown',\n 'canvas:click': 'clearStates'\n };\n },\n onDragStart: function onDragStart(e) {\n var lasso = this.lasso;\n var item = e.item; // 排除在节点上拖动\n\n if (item) {\n return;\n }\n\n if (this.trigger !== 'drag' && !this.keydown) {\n return;\n }\n\n if (this.selectedNodes && this.selectedNodes.length !== 0) {\n this.clearStates();\n }\n\n if (!lasso) {\n lasso = this.createLasso();\n }\n\n this.dragging = true;\n this.originPoint = {\n x: e.x,\n y: e.y\n };\n this.points.push(this.originPoint);\n lasso.show();\n },\n onDragMove: function onDragMove(e) {\n if (!this.dragging) {\n return;\n }\n\n if (this.trigger !== 'drag' && !this.keydown) {\n return;\n }\n\n this.points.push({\n x: e.x,\n y: e.y\n });\n this.updateLasso(e);\n },\n onDragEnd: function onDragEnd(e) {\n if (!this.lasso && !this.dragging) {\n return;\n }\n\n if (this.trigger !== 'drag' && !this.keydown) {\n return;\n }\n\n this.points.push(this.originPoint);\n this.getSelectedItems();\n this.lasso.remove(true);\n this.lasso = null;\n this.points = [];\n this.dragging = false;\n },\n getLassoPath: function getLassoPath() {\n var points = this.points;\n var path = [];\n\n if (points.length) {\n points.forEach(function (point, index) {\n if (index === 0) {\n path.push(['M', point.x, point.y]);\n } else {\n path.push(['L', point.x, point.y]);\n }\n });\n path.push(['L', points[0].x, points[0].y]);\n }\n\n return path;\n },\n clearStates: function clearStates() {\n var _a = this,\n graph = _a.graph,\n selectedState = _a.selectedState;\n\n var nodes = graph.findAllByState('node', selectedState);\n var edges = graph.findAllByState('edge', selectedState);\n nodes.forEach(function (node) {\n return graph.setItemState(node, selectedState, false);\n });\n edges.forEach(function (edge) {\n return graph.setItemState(edge, selectedState, false);\n });\n\n if (this.onDeselect) {\n this.onDeselect(this.selectedNodes, this.selectedEdges);\n }\n\n this.selectedNodes = [];\n this.selectedEdges = [];\n graph.emit('nodeselectchange', {\n selectedItems: {\n nodes: [],\n edges: []\n },\n select: false\n });\n },\n getSelectedItems: function getSelectedItems() {\n var _this = this;\n\n var _a = this,\n graph = _a.graph,\n shouldUpdate = _a.shouldUpdate;\n\n var lassoContour = this.points.map(function (point) {\n return [graph.getCanvasByPoint(point.x, point.y).x, graph.getCanvasByPoint(point.x, point.y).y];\n });\n var state = this.selectedState;\n var selectedNodes = [];\n var selectedIds = [];\n graph.getNodes().forEach(function (node) {\n if (!node.isVisible()) return; // 隐藏节点不能被选中\n\n if (isItemIntersecPolygon(node, lassoContour)) {\n if (shouldUpdate(node, 'select')) {\n selectedNodes.push(node);\n var model = node.getModel();\n selectedIds.push(model.id);\n graph.setItemState(node, state, true);\n }\n }\n });\n var selectedEdges = [];\n\n if (this.includeEdges) {\n // 选中边,边的source和target都在选中的节点中时才选中\n selectedNodes.forEach(function (node) {\n var edges = node.getOutEdges();\n edges.forEach(function (edge) {\n if (!edge.isVisible()) return; // 隐藏边不能够被选中\n\n var model = edge.getModel();\n var source = model.source,\n target = model.target;\n\n if (selectedIds.includes(source) && selectedIds.includes(target) && shouldUpdate(edge, 'select')) {\n selectedEdges.push(edge);\n graph.setItemState(edge, _this.selectedState, true);\n }\n });\n });\n }\n\n this.selectedEdges = selectedEdges;\n this.selectedNodes = selectedNodes;\n\n if (this.onSelect) {\n this.onSelect(selectedNodes, selectedEdges);\n }\n\n graph.emit('nodeselectchange', {\n selectedItems: {\n nodes: selectedNodes,\n edges: selectedEdges\n },\n select: true\n });\n },\n createLasso: function createLasso() {\n var self = this;\n var lasso = self.graph.get('delegateGroup').addShape('path', {\n attrs: __assign({\n path: []\n }, self.delegateStyle),\n capture: false,\n name: 'lasso-shape'\n });\n this.lasso = lasso;\n this.delegate = lasso;\n this.points = [];\n return lasso;\n },\n updateLasso: function updateLasso(e) {\n var self = this;\n this.lasso.attr({\n path: self.getLassoPath()\n });\n },\n onKeyDown: function onKeyDown(e) {\n var code = e.key;\n\n if (!code) {\n return;\n } // if (this.selectedNodes && this.selectedNodes.length !== 0) {\n // this.clearStates();\n // }\n\n\n if (code.toLowerCase() === this.trigger.toLowerCase()) {\n this.keydown = true;\n } else {\n this.keydown = false;\n }\n },\n onKeyUp: function onKeyUp() {\n if (this.lasso) {\n // 清除所有选中状态后,设置拖得动状态为false,并清除框选的lasso\n this.lasso.remove(true);\n this.lasso = null;\n this.points = [];\n this.dragging = false;\n }\n\n this.keydown = false;\n }\n};","import { __assign } from \"tslib\";\nimport { isFunction } from '@antv/util';\nvar DEFAULT_TRIGGER = 'click';\nvar ALLOW_EVENTS = ['click', 'drag'];\nvar DEFAULT_KEY = undefined;\nvar ALLOW_KEYS = ['shift', 'ctrl', 'control', 'alt', 'meta', undefined];\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n trigger: DEFAULT_TRIGGER,\n key: DEFAULT_KEY,\n edgeConfig: {},\n getEdgeConfig: undefined\n };\n },\n getEvents: function getEvents() {\n var self = this; // 检测输入是否合法\n\n if (!(ALLOW_EVENTS.indexOf(self.trigger.toLowerCase()) > -1)) {\n self.trigger = DEFAULT_TRIGGER; // eslint-disable-next-line no-console\n\n console.warn(\"Behavior create-edge 的 trigger 参数不合法,请输入 'click','drag'\");\n }\n\n if (self.key && ALLOW_KEYS.indexOf(self.key.toLowerCase()) === -1) {\n self.trigger = DEFAULT_KEY; // eslint-disable-next-line no-console\n\n console.warn(\"Behavior create-edge 的 key 参数不合法,请输入 'shift','ctrl','alt','control',或 undefined\");\n }\n\n var events;\n\n if (self.trigger === 'drag') {\n events = {\n 'node:dragstart': 'onClick',\n 'combo:dragstart': 'onClick',\n drag: 'updateEndPoint',\n 'node:drop': 'onClick',\n 'combo:drop': 'onClick',\n dragend: 'onDragEnd'\n };\n } else if (self.trigger === 'click') {\n events = {\n 'node:click': 'onClick',\n mousemove: 'updateEndPoint',\n 'edge:click': 'cancelCreating',\n 'canvas:click': 'cancelCreating',\n 'combo:click': 'onClick'\n };\n }\n\n if (self.key) {\n events.keydown = 'onKeyDown';\n events.keyup = 'onKeyUp';\n }\n\n return events;\n },\n onDragEnd: function onDragEnd(ev) {\n var self = this;\n if (self.key && !self.keydown) return;\n var item = ev.item;\n if (!item || item.getID() === self.source || item.getType() !== 'node') self.cancelCreating({\n item: self.edge,\n x: ev.x,\n y: ev.y\n });\n },\n // 如果边的起点没有指定,则根据起点创建新边;如果起点已经指定而终点未指定,则指定终点\n onClick: function onClick(ev) {\n var self = this;\n if (self.key && !self.keydown) return;\n var node = ev.item;\n var graph = self.graph;\n var model = node.getModel();\n var getEdgeConfig = self.getEdgeConfig; // 如果起点已经指定而终点未指定,则指定终点\n\n if (self.addingEdge && self.edge) {\n if (!self.shouldEnd.call(self, ev)) return;\n var edgeConfig = void 0;\n\n if (getEdgeConfig && isFunction(getEdgeConfig)) {\n edgeConfig = getEdgeConfig({\n source: self.source,\n target: model.id\n });\n } else {\n edgeConfig = self.edgeConfig;\n }\n\n var updateCfg = __assign({\n target: model.id\n }, edgeConfig);\n\n if (self.source === model.id) {\n updateCfg.type = 'loop';\n }\n\n graph.emit('beforecreateedge', {});\n graph.updateItem(self.edge, updateCfg, false);\n\n if (graph.get('enabledStack')) {\n var addedModel = __assign(__assign({}, self.edge.getModel()), {\n itemType: 'edge'\n });\n\n var after = {};\n after.edges = [addedModel];\n graph.pushStack('add', {\n before: {},\n after: after\n });\n }\n\n graph.emit('aftercreateedge', {\n edge: self.edge\n }); // 暂时将该边的 capture 恢复为 true\n\n self.edge.getKeyShape().set('capture', true);\n self.edge = null;\n self.addingEdge = false;\n } else {\n // 如果边的起点没有指定,则根据起点创建新边\n if (!self.shouldBegin.call(self, ev)) return; // 获取自定义 edge 配置\n\n var edgeConfig = void 0;\n\n if (getEdgeConfig && isFunction(getEdgeConfig)) {\n edgeConfig = getEdgeConfig({\n source: model.id,\n target: model.id\n });\n } else {\n edgeConfig = self.edgeConfig;\n }\n\n self.edge = graph.addItem('edge', __assign({\n source: model.id,\n target: model.id\n }, edgeConfig), false);\n self.source = model.id;\n self.addingEdge = true; // 暂时将该边的 capture 设置为 false,这样可以拾取到后面的元素\n\n self.edge.getKeyShape().set('capture', false);\n }\n },\n // 边的起点已经确定,边的末端跟随鼠标移动\n updateEndPoint: function updateEndPoint(ev) {\n var self = this;\n if (self.key && !self.keydown) return;\n var point = {\n x: ev.x,\n y: ev.y\n }; // 若此时 source 节点已经被移除,结束添加边\n\n if (!self.graph.findById(self.source)) {\n self.addingEdge = false;\n return;\n }\n\n if (self.addingEdge && self.edge) {\n // 更新边的终点为鼠标位置\n self.graph.updateItem(self.edge, {\n target: point\n }, false);\n }\n },\n // 取消增加边,删除该边;或指定终点\n cancelCreating: function cancelCreating(ev) {\n var self = this;\n if (self.key && !self.keydown) return;\n var graph = self.graph;\n var currentEdge = ev.item;\n\n if (self.addingEdge && ev.target && ev.target.isCanvas && ev.target.isCanvas()) {\n graph.removeItem(self.edge, false);\n self.edge = null;\n self.addingEdge = false;\n return;\n }\n\n if (self.addingEdge && self.edge === currentEdge) {\n graph.removeItem(self.edge, false);\n self.edge = null;\n self.addingEdge = false;\n }\n },\n onKeyDown: function onKeyDown(e) {\n var self = this;\n var code = e.key;\n\n if (!code) {\n return;\n }\n\n if (code.toLowerCase() === self.key.toLowerCase()) {\n self.keydown = true;\n } else {\n self.keydown = false;\n }\n },\n onKeyUp: function onKeyUp() {\n var self = this;\n\n if (self.addingEdge && self.edge) {\n // 清除正在增加的边\n self.graph.removeItem(self.edge, false);\n self.addingEdge = false;\n self.edge = null;\n }\n\n this.keydown = false;\n }\n};","var DEFAULT_TRIGGER = 'ctrl';\nvar ALLOW_EVENTS = ['shift', 'ctrl', 'alt', 'control'];\nvar DEFAULT_COMBINED_KEY = '1';\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n trigger: DEFAULT_TRIGGER,\n combinedKey: DEFAULT_COMBINED_KEY,\n functionName: 'fitView',\n functionParams: []\n };\n },\n getEvents: function getEvents() {\n // 检测输入是否合法\n if (!(ALLOW_EVENTS.indexOf(this.trigger.toLowerCase()) > -1)) {\n this.trigger = DEFAULT_TRIGGER;\n console.warn(\"Behavior shortcuts-fit-view \\u7684 trigger \\u53C2\\u6570 '\" + this.trigger + \"' \\u4E0D\\u5408\\u6CD5\\uFF0C\\u8BF7\\u8F93\\u5165 'drag'\\u3001'shift'\\u3001'ctrl' \\u6216 'alt'\");\n }\n\n if (this.combinedKey === this.trigger) {\n this.combinedKey = undefined;\n }\n\n return {\n keyup: 'onKeyUp',\n keydown: 'onKeyDown'\n };\n },\n onKeyDown: function onKeyDown(e) {\n var code = e.key;\n\n if (!code) {\n return;\n }\n\n var triggerLowerCase = this.trigger.toLowerCase();\n var codeLowerCase = code.toLowerCase(); // 按住 control 键时,允许用户设置 trigger 为 ctrl\n\n if (!this.triggerKeydown) {\n if (codeLowerCase === triggerLowerCase || codeLowerCase === 'control' && triggerLowerCase === 'ctrl' || codeLowerCase === 'ctrl' && triggerLowerCase === 'control') {\n this.triggerKeydown = true;\n } else {\n this.triggerKeydown = false;\n }\n }\n\n var graph = this.graph;\n\n if (!graph[this.functionName]) {\n console.warn(\"Behavior shortcuts-fit-view \\u7684 functionName \\u53C2\\u6570 '\" + this.functionName + \"' \\u4E0D\\u5408\\u6CD5\\uFF0C\\u5B83\\u4E0D\\u662F Graph \\u7684\\u4E00\\u4E2A\\u51FD\\u6570\\u540D\");\n return {};\n } // 未配置 combinedKey,直接 fitView\n\n\n if (this.triggerKeydown && !this.combinedKey) {\n if (this.functionParams && this.functionParams.length) graph[this.functionName].apply(graph, this.functionParams);else graph[this.functionName]();\n return;\n }\n\n var combinedKeyLowerCase = this.combinedKey.toLowerCase();\n\n if (this.triggerKeydown) {\n if (codeLowerCase === combinedKeyLowerCase || codeLowerCase === 'control' && combinedKeyLowerCase === 'ctrl' || codeLowerCase === 'ctrl' && combinedKeyLowerCase === 'control') {\n if (this.functionParams && this.functionParams.length) graph[this.functionName].apply(graph, this.functionParams);else graph[this.functionName]();\n }\n }\n },\n onKeyUp: function onKeyUp() {\n if (this.brush) {\n // 清除所有选中状态后,设置拖得动状态为false,并清除框选的brush\n this.brush.remove(true);\n this.brush = null;\n this.dragging = false;\n }\n\n this.triggerKeydown = false;\n }\n};","var ALLOW_EVENTS = ['shift', 'ctrl', 'alt', 'control'];\nexport default {\n getDefaultCfg: function getDefaultCfg() {\n return {\n direction: 'both',\n enableOptimize: false,\n zoomKey: 'ctrl',\n // scroll-canvas 可滚动的扩展范围,默认为 0,即最多可以滚动一屏的位置\n // 当设置的值大于 0 时,即滚动可以超过一屏\n // 当设置的值小于 0 时,相当于缩小了可滚动范围\n // 具体实例可参考:https://gw.alipayobjects.com/mdn/rms_f8c6a0/afts/img/A*IFfoS67_HssAAAAAAAAAAAAAARQnAQ\n scalableRange: 0\n };\n },\n getEvents: function getEvents() {\n if (!this.zoomKey || ALLOW_EVENTS.indexOf(this.zoomKey) === -1) this.zoomKey = 'ctrl';\n return {\n wheel: 'onWheel'\n };\n },\n onWheel: function onWheel(ev) {\n var _this = this;\n\n var graph = this.graph;\n var keyDown = ev[this.zoomKey + \"Key\"];\n if (this.zoomKey === 'control') keyDown = ev.ctrlKey;\n\n if (keyDown) {\n var canvas = graph.get('canvas');\n var point = canvas.getPointByClient(ev.clientX, ev.clientY);\n var ratio = graph.getZoom();\n\n if (ev.wheelDelta > 0) {\n ratio = ratio + ratio * 0.05;\n } else {\n ratio = ratio - ratio * 0.05;\n }\n\n graph.zoomTo(ratio, {\n x: point.x,\n y: point.y\n });\n } else {\n var dx = ev.deltaX || ev.movementX;\n var dy = ev.deltaY || ev.movementY;\n if (!dy && navigator.userAgent.indexOf('Firefox') > -1) dy = -ev.wheelDelta * 125 / 3;\n var width = this.graph.get('width');\n var height = this.graph.get('height');\n var graphCanvasBBox = this.graph.get('canvas').getCanvasBBox();\n var expandWidth = this.scalableRange;\n var expandHeight = this.scalableRange; // 若 scalableRange 是 0~1 的小数,则作为比例考虑\n\n if (expandWidth < 1 && expandWidth > -1) {\n expandWidth = width * expandWidth;\n expandHeight = height * expandHeight;\n }\n\n var minX = graphCanvasBBox.minX,\n maxX = graphCanvasBBox.maxX,\n minY = graphCanvasBBox.minY,\n maxY = graphCanvasBBox.maxY;\n\n if (dx > 0) {\n if (maxX < -expandWidth) {\n dx = 0;\n } else if (maxX - dx < -expandWidth) {\n dx = maxX + expandWidth;\n }\n } else if (dx < 0) {\n if (minX > width + expandWidth) {\n dx = 0;\n } else if (minX - dx > width + expandWidth) {\n dx = minX - (width + expandWidth);\n }\n }\n\n if (dy > 0) {\n if (maxY < -expandHeight) {\n dy = 0;\n } else if (maxY - dy < -expandHeight) {\n dy = maxY + expandHeight;\n }\n } else if (dy < 0) {\n if (minY > height + expandHeight) {\n dy = 0;\n } else if (minY - dy > height + expandHeight) {\n dy = minY - (height + expandHeight);\n }\n }\n\n if (this.get('direction') === 'x') {\n dy = 0;\n } else if (this.get('direction') === 'y') {\n dx = 0;\n }\n\n graph.translate(-dx, -dy);\n }\n\n ev.preventDefault(); // hide the shapes when the zoom ratio is smaller than optimizeZoom\n // hide the shapes when zoomming\n\n var enableOptimize = this.get('enableOptimize');\n\n if (enableOptimize) {\n var optimizeZoom_1 = this.get('optimizeZoom');\n var optimized = this.get('optimized');\n var nodes_1 = graph.getNodes();\n var edges_1 = graph.getEdges();\n var nodesLength_1 = nodes_1.length;\n var edgesLength_1 = edges_1.length; // hiding\n\n if (!optimized) {\n for (var n = 0; n < nodesLength_1; n++) {\n var node = nodes_1[n];\n\n if (!node.destroyed) {\n var children = node.get('group').get('children');\n var childrenLength = children.length;\n\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n\n if (!shape.destoryed && !shape.get('isKeyShape')) {\n shape.set('ori-visibility', shape.get('ori-visibility') || shape.get('visible'));\n shape.hide();\n }\n }\n }\n }\n\n for (var edgeIndex = 0; edgeIndex < edgesLength_1; edgeIndex++) {\n var edge = edges_1[edgeIndex];\n var children = edge.get('group').get('children');\n var childrenLength = children.length;\n\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n shape.set('ori-visibility', shape.get('ori-visibility') || shape.get('visible'));\n shape.hide();\n }\n }\n\n this.set('optimized', true);\n } // showing after 100ms\n\n\n clearTimeout(this.get('timeout'));\n var timeout = setTimeout(function () {\n var currentZoom = graph.getZoom();\n\n var curOptimized = _this.get('optimized');\n\n if (curOptimized) {\n _this.set('optimized', false);\n\n for (var n = 0; n < nodesLength_1; n++) {\n var node = nodes_1[n];\n var children = node.get('group').get('children');\n var childrenLength = children.length;\n\n if (currentZoom < optimizeZoom_1) {\n var keyShape = node.getKeyShape();\n var oriVis = keyShape.get('ori-visibility');\n if (oriVis) keyShape.show();\n } else {\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n var oriVis = shape.get('ori-visibility');\n\n if (!shape.get('visible') && oriVis) {\n if (oriVis) shape.show();\n }\n }\n }\n }\n\n for (var edgeIndex = 0; edgeIndex < edgesLength_1; edgeIndex++) {\n var edge = edges_1[edgeIndex];\n var children = edge.get('group').get('children');\n var childrenLength = children.length;\n\n if (currentZoom < optimizeZoom_1) {\n var keyShape = edge.getKeyShape();\n var oriVis = keyShape.get('ori-visibility');\n if (oriVis) keyShape.show();\n } else {\n for (var c = 0; c < childrenLength; c++) {\n var shape = children[c];\n\n if (!shape.get('visible')) {\n var oriVis = shape.get('ori-visibility');\n if (oriVis) shape.show();\n }\n }\n }\n }\n }\n }, 100);\n this.set('timeout', timeout);\n }\n }\n};","import { each } from '@antv/util';\nimport { registerBehavior } from '@antv/g6-core'; // import Behavior from './behavior';\n\nimport DragCanvas from './drag-canvas';\nimport DragNode from './drag-node';\nimport ActivateRelations from './activate-relations';\nimport BrushSelect from './brush-select';\nimport ClickSelect from './click-select';\nimport ZoomCanvas from './zoom-canvas';\nimport Tooltip from './tooltip';\nimport EdgeTooltip from './edge-tooltip';\nimport CollapseExpand from './collapse-expand';\nimport DragCombo from './drag-combo';\nimport CollapseExpandCombo from './collapse-expand-combo';\nimport LassoSelect from './lasso-select';\nimport CreateEdge from './create-edge';\nimport ShortcutsCall from './shortcuts-call';\nimport ScrollCanvas from './scroll-canvas';\nvar behaviors = {\n 'drag-canvas': DragCanvas,\n 'zoom-canvas': ZoomCanvas,\n 'drag-node': DragNode,\n 'activate-relations': ActivateRelations,\n 'brush-select': BrushSelect,\n 'click-select': ClickSelect,\n 'lasso-select': LassoSelect,\n tooltip: Tooltip,\n 'edge-tooltip': EdgeTooltip,\n 'collapse-expand': CollapseExpand,\n 'drag-combo': DragCombo,\n 'collapse-expand-combo': CollapseExpandCombo,\n 'create-edge': CreateEdge,\n 'shortcuts-call': ShortcutsCall,\n 'scroll-canvas': ScrollCanvas\n};\neach(behaviors, function (behavior, type) {\n registerBehavior(type, behavior);\n}); // export default Behavior;","import { __assign } from \"tslib\";\nimport { registerBehavior, registerCombo, registerEdge, registerNode, Arrow, Marker, Shape } from '@antv/g6-core';\nimport * as AlgorithmSync from '@antv/algorithm';\nimport * as AlgorithmAsync from '@antv/algorithm/lib/asyncIndex';\nimport Graph from './graph/graph';\nimport TreeGraph from './graph/tree-graph';\nimport { TreeLayout, Layout, registerLayout } from './layout';\nimport Global from './global';\nimport Util from './util';\nimport Plugin from './plugin';\nimport './element';\nimport './behavior';\n\nvar Algorithm = __assign(__assign({}, AlgorithmSync), AlgorithmAsync);\n\nvar Grid = Plugin.Grid;\nvar Minimap = Plugin.Minimap;\nvar Bundling = Plugin.Bundling;\nvar Menu = Plugin.Menu;\nvar Fisheye = Plugin.Fisheye;\nvar ToolBar = Plugin.ToolBar;\nvar Tooltip = Plugin.Tooltip;\nvar TimeBar = Plugin.TimeBar;\nvar ImageMinimap = Plugin.ImageMinimap;\nvar EdgeFilterLens = Plugin.EdgeFilterLens;\nvar SnapLine = Plugin.SnapLine;\nvar Legend = Plugin.Legend;\nexport * from '@antv/g6-core';\nexport * from './types';\nexport * from './interface/graph';\nexport { Graph, TreeGraph, Util, Layout, TreeLayout, registerLayout, Global, Minimap, Grid, Bundling, Menu, Fisheye, Algorithm, ToolBar, Tooltip, TimeBar, ImageMinimap, EdgeFilterLens, SnapLine, Legend, Arrow, Marker, Shape };\nexport default {\n version: Global.version,\n Graph: Graph,\n TreeGraph: TreeGraph,\n Util: Util,\n Layout: Layout,\n TreeLayout: TreeLayout,\n registerLayout: registerLayout,\n Global: Global,\n registerBehavior: registerBehavior,\n registerCombo: registerCombo,\n registerEdge: registerEdge,\n registerNode: registerNode,\n Minimap: Plugin.Minimap,\n Grid: Plugin.Grid,\n Bundling: Plugin.Bundling,\n Menu: Plugin.Menu,\n ToolBar: Plugin.ToolBar,\n Tooltip: Plugin.Tooltip,\n Legend: Plugin.Legend,\n TimeBar: TimeBar,\n SnapLine: SnapLine,\n Fisheye: Fisheye,\n ImageMinimap: ImageMinimap,\n EdgeFilterLens: EdgeFilterLens,\n Algorithm: Algorithm,\n Arrow: Arrow,\n Marker: Marker,\n Shape: Shape\n};","import G6 from '@antv/g6-pc';\n\nG6.version = '4.3.11';\n\nexport * from '@antv/g6-pc';\nexport default G6;\nexport const version = '4.3.11';\n"],"sourceRoot":""}
\No newline at end of file