@visactor/vrender-core 1.0.47-alpha.0 → 1.1.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/application.d.ts +14 -5
- package/cjs/application.js +1 -8
- package/cjs/application.js.map +1 -1
- package/cjs/canvas/empty-context.js +4 -14
- package/cjs/canvas/empty-context.js.map +1 -1
- package/cjs/canvas/util.d.ts +2 -3
- package/cjs/canvas/util.js +17 -3
- package/cjs/canvas/util.js.map +1 -1
- package/cjs/color-string/index.js +2 -1
- package/cjs/common/contribution-provider.d.ts +16 -9
- package/cjs/common/contribution-provider.js +9 -4
- package/cjs/common/contribution-provider.js.map +1 -1
- package/cjs/common/diff.js +1 -2
- package/cjs/common/enums.d.ts +2 -0
- package/cjs/common/enums.js +1 -0
- package/cjs/common/enums.js.map +1 -1
- package/cjs/common/event-transformer.js +43 -6
- package/cjs/common/event-transformer.js.map +1 -1
- package/cjs/common/explicit-binding.d.ts +5 -0
- package/cjs/common/explicit-binding.js +16 -0
- package/cjs/common/explicit-binding.js.map +1 -0
- package/cjs/common/performance-raf.d.ts +1 -0
- package/cjs/common/performance-raf.js +5 -0
- package/cjs/common/performance-raf.js.map +1 -1
- package/cjs/common/render-area.js +1 -1
- package/cjs/common/render-command-list.js +1 -1
- package/cjs/common/render-curve.js +1 -1
- package/cjs/common/render-utils.js +1 -1
- package/cjs/common/seg-context.js +1 -2
- package/cjs/common/simplify.js +1 -1
- package/cjs/common/sort.js +1 -1
- package/cjs/common/split-path.js +1 -1
- package/cjs/common/store.js +1 -1
- package/cjs/common/text.js +1 -1
- package/cjs/common/utils.js +1 -1
- package/cjs/core/application.js +1 -1
- package/cjs/core/camera.js +1 -1
- package/cjs/core/constants.js +1 -1
- package/cjs/core/contributions/env/base-contribution.js +4 -9
- package/cjs/core/contributions/env/base-contribution.js.map +1 -1
- package/cjs/core/contributions/env/modules.d.ts +4 -3
- package/cjs/core/contributions/env/modules.js +6 -4
- package/cjs/core/contributions/env/modules.js.map +1 -1
- package/cjs/core/contributions/layerHandler/canvas2d-contribution.js +3 -12
- package/cjs/core/contributions/layerHandler/canvas2d-contribution.js.map +1 -1
- package/cjs/core/contributions/layerHandler/empty-contribution.js +3 -12
- package/cjs/core/contributions/layerHandler/empty-contribution.js.map +1 -1
- package/cjs/core/contributions/layerHandler/modules.d.ts +4 -3
- package/cjs/core/contributions/layerHandler/modules.js +6 -4
- package/cjs/core/contributions/layerHandler/modules.js.map +1 -1
- package/cjs/core/contributions/layerHandler/offscreen2d-contribution.js +3 -12
- package/cjs/core/contributions/layerHandler/offscreen2d-contribution.js.map +1 -1
- package/cjs/core/contributions/modules.d.ts +2 -2
- package/cjs/core/contributions/modules.js +7 -1
- package/cjs/core/contributions/modules.js.map +1 -1
- package/cjs/core/contributions/textMeasure/AtextMeasure.js +3 -10
- package/cjs/core/contributions/textMeasure/AtextMeasure.js.map +1 -1
- package/cjs/core/contributions/textMeasure/modules.d.ts +4 -3
- package/cjs/core/contributions/textMeasure/modules.js +6 -4
- package/cjs/core/contributions/textMeasure/modules.js.map +1 -1
- package/cjs/core/contributions/textMeasure/textMeasure-contribution.js +3 -10
- package/cjs/core/contributions/textMeasure/textMeasure-contribution.js.map +1 -1
- package/cjs/core/contributions/window/base-contribution.js +3 -12
- package/cjs/core/contributions/window/base-contribution.js.map +1 -1
- package/cjs/core/core-modules.d.ts +4 -3
- package/cjs/core/core-modules.js +11 -7
- package/cjs/core/core-modules.js.map +1 -1
- package/cjs/core/global-module.js +2 -0
- package/cjs/core/global-module.js.map +1 -1
- package/cjs/core/global.d.ts +2 -0
- package/cjs/core/global.js +9 -18
- package/cjs/core/global.js.map +1 -1
- package/cjs/core/graphic-utils.d.ts +1 -2
- package/cjs/core/graphic-utils.js +8 -23
- package/cjs/core/graphic-utils.js.map +1 -1
- package/cjs/core/index.js +1 -1
- package/cjs/core/layer-service.d.ts +7 -2
- package/cjs/core/layer-service.js +29 -27
- package/cjs/core/layer-service.js.map +1 -1
- package/cjs/core/layer.js +1 -1
- package/cjs/core/layer.js.map +1 -1
- package/cjs/core/light.js +1 -1
- package/cjs/core/stage.d.ts +19 -7
- package/cjs/core/stage.js +50 -39
- package/cjs/core/stage.js.map +1 -1
- package/cjs/core/window.d.ts +7 -5
- package/cjs/core/window.js +14 -18
- package/cjs/core/window.js.map +1 -1
- package/cjs/create.d.ts +1 -2
- package/cjs/create.js +2 -2
- package/cjs/create.js.map +1 -1
- package/cjs/entries/app-context.d.ts +30 -0
- package/cjs/entries/app-context.js +84 -0
- package/cjs/entries/app-context.js.map +1 -0
- package/cjs/entries/browser.d.ts +25 -0
- package/cjs/entries/browser.js +44 -0
- package/cjs/entries/browser.js.map +1 -0
- package/cjs/entries/index.d.ts +7 -0
- package/cjs/entries/index.js +32 -0
- package/cjs/entries/index.js.map +1 -0
- package/cjs/entries/miniapp.d.ts +6 -0
- package/cjs/entries/miniapp.js +20 -0
- package/cjs/entries/miniapp.js.map +1 -0
- package/cjs/entries/node.d.ts +6 -0
- package/cjs/entries/node.js +20 -0
- package/cjs/entries/node.js.map +1 -0
- package/cjs/entries/runtime-installer.d.ts +11 -0
- package/cjs/entries/runtime-installer.js +111 -0
- package/cjs/entries/runtime-installer.js.map +1 -0
- package/cjs/entries/types.d.ts +29 -0
- package/cjs/{common/inversify-lite/interfaces/interfaces.js → entries/types.js} +1 -1
- package/cjs/entries/types.js.map +1 -0
- package/cjs/event/util.d.ts +1 -1
- package/cjs/factory/graphic-factory.d.ts +7 -0
- package/cjs/factory/graphic-factory.js +23 -0
- package/cjs/factory/graphic-factory.js.map +1 -0
- package/cjs/factory/index.d.ts +4 -0
- package/cjs/{common/inversify-lite → factory}/index.js +2 -1
- package/cjs/factory/index.js.map +1 -0
- package/cjs/factory/layer-factory.d.ts +7 -0
- package/cjs/factory/layer-factory.js +19 -0
- package/cjs/factory/layer-factory.js.map +1 -0
- package/cjs/factory/stage-factory.d.ts +8 -0
- package/cjs/factory/stage-factory.js +20 -0
- package/cjs/factory/stage-factory.js.map +1 -0
- package/cjs/factory/types.d.ts +34 -0
- package/cjs/{common/inversify/interfaces.js → factory/types.js} +1 -1
- package/cjs/factory/types.js.map +1 -0
- package/cjs/factory.d.ts +1 -0
- package/cjs/factory.js +16 -1
- package/cjs/factory.js.map +1 -1
- package/cjs/global.d.ts +2 -0
- package/cjs/global.js +11 -0
- package/cjs/global.js.map +1 -0
- package/cjs/graphic/area.js +1 -1
- package/cjs/graphic/area.js.map +1 -1
- package/cjs/graphic/bounds.js +3 -3
- package/cjs/graphic/bounds.js.map +1 -1
- package/cjs/graphic/config.js +0 -1
- package/cjs/graphic/config.js.map +1 -1
- package/cjs/graphic/glyph.js +9 -3
- package/cjs/graphic/glyph.js.map +1 -1
- package/cjs/graphic/graphic-creator.d.ts +9 -4
- package/cjs/graphic/graphic-creator.js +35 -7
- package/cjs/graphic/graphic-creator.js.map +1 -1
- package/cjs/graphic/graphic-service/graphic-module.d.ts +4 -3
- package/cjs/graphic/graphic-service/graphic-module.js +6 -4
- package/cjs/graphic/graphic-service/graphic-module.js.map +1 -1
- package/cjs/graphic/graphic-service/graphic-service.d.ts +2 -3
- package/cjs/graphic/graphic-service/graphic-service.js +5 -20
- package/cjs/graphic/graphic-service/graphic-service.js.map +1 -1
- package/cjs/graphic/graphic.d.ts +80 -11
- package/cjs/graphic/graphic.js +474 -152
- package/cjs/graphic/graphic.js.map +1 -1
- package/cjs/graphic/group.d.ts +11 -1
- package/cjs/graphic/group.js +46 -11
- package/cjs/graphic/group.js.map +1 -1
- package/cjs/graphic/index.d.ts +3 -0
- package/cjs/graphic/index.js +34 -15
- package/cjs/graphic/index.js.map +1 -1
- package/cjs/graphic/line.js +1 -1
- package/cjs/graphic/line.js.map +1 -1
- package/cjs/graphic/state/attribute-update-classifier.d.ts +13 -0
- package/cjs/graphic/state/attribute-update-classifier.js +67 -0
- package/cjs/graphic/state/attribute-update-classifier.js.map +1 -0
- package/cjs/graphic/state/shared-state-refresh.d.ts +6 -0
- package/cjs/graphic/state/shared-state-refresh.js +55 -0
- package/cjs/graphic/state/shared-state-refresh.js.map +1 -0
- package/cjs/graphic/state/shared-state-scope.d.ts +25 -0
- package/cjs/graphic/state/shared-state-scope.js +98 -0
- package/cjs/graphic/state/shared-state-scope.js.map +1 -0
- package/cjs/graphic/state/state-batch-scheduler.d.ts +42 -0
- package/cjs/graphic/state/state-batch-scheduler.js +285 -0
- package/cjs/graphic/state/state-batch-scheduler.js.map +1 -0
- package/cjs/graphic/state/state-definition-compiler.d.ts +6 -0
- package/cjs/graphic/state/state-definition-compiler.js +91 -0
- package/cjs/graphic/state/state-definition-compiler.js.map +1 -0
- package/cjs/graphic/state/state-definition.d.ts +44 -0
- package/cjs/graphic/state/state-definition.js +6 -0
- package/cjs/graphic/state/state-definition.js.map +1 -0
- package/cjs/graphic/state/state-engine.d.ts +38 -0
- package/cjs/graphic/state/state-engine.js +220 -0
- package/cjs/graphic/state/state-engine.js.map +1 -0
- package/cjs/graphic/state/state-model.d.ts +43 -0
- package/cjs/graphic/state/state-model.js +143 -0
- package/cjs/graphic/state/state-model.js.map +1 -0
- package/cjs/graphic/state/state-perf-monitor.d.ts +119 -0
- package/cjs/graphic/state/state-perf-monitor.js +217 -0
- package/cjs/graphic/state/state-perf-monitor.js.map +1 -0
- package/cjs/graphic/state/state-style-resolver.d.ts +22 -0
- package/cjs/graphic/state/state-style-resolver.js +73 -0
- package/cjs/graphic/state/state-style-resolver.js.map +1 -0
- package/cjs/graphic/state/state-transition-orchestrator.d.ts +41 -0
- package/cjs/graphic/state/state-transition-orchestrator.js +74 -0
- package/cjs/graphic/state/state-transition-orchestrator.js.map +1 -0
- package/cjs/graphic/text.d.ts +3 -2
- package/cjs/graphic/text.js +22 -14
- package/cjs/graphic/text.js.map +1 -1
- package/cjs/graphic/theme.d.ts +5 -0
- package/cjs/graphic/theme.js +7 -0
- package/cjs/graphic/theme.js.map +1 -1
- package/cjs/graphic/wrap-text.d.ts +1 -1
- package/cjs/graphic/wrap-text.js +17 -14
- package/cjs/graphic/wrap-text.js.map +1 -1
- package/cjs/index.d.ts +7 -4
- package/cjs/index.js +95 -25
- package/cjs/index.js.map +1 -1
- package/cjs/interface/global.d.ts +2 -0
- package/cjs/interface/global.js.map +1 -1
- package/cjs/interface/graphic/group.d.ts +6 -0
- package/cjs/interface/graphic/group.js.map +1 -1
- package/cjs/interface/graphic/theme.d.ts +3 -0
- package/cjs/interface/graphic/theme.js.map +1 -1
- package/cjs/interface/graphic.d.ts +24 -26
- package/cjs/interface/graphic.js.map +1 -1
- package/cjs/interface/plugin.d.ts +2 -0
- package/cjs/interface/plugin.js.map +1 -1
- package/cjs/interface/stage.d.ts +11 -3
- package/cjs/interface/stage.js.map +1 -1
- package/cjs/interface/theme-service.js.map +1 -1
- package/cjs/legacy/binding-context.d.ts +24 -0
- package/cjs/legacy/binding-context.js +98 -0
- package/cjs/legacy/binding-context.js.map +1 -0
- package/cjs/legacy/bootstrap.d.ts +10 -0
- package/cjs/legacy/bootstrap.js +72 -0
- package/cjs/legacy/bootstrap.js.map +1 -0
- package/cjs/legacy/module-types.d.ts +2 -0
- package/cjs/legacy/module-types.js +6 -0
- package/cjs/legacy/module-types.js.map +1 -0
- package/cjs/modules.d.ts +5 -6
- package/cjs/modules.js +54 -20
- package/cjs/modules.js.map +1 -1
- package/cjs/picker/global-picker-service.js +3 -12
- package/cjs/picker/global-picker-service.js.map +1 -1
- package/cjs/picker/pick-interceptor.js +9 -19
- package/cjs/picker/pick-interceptor.js.map +1 -1
- package/cjs/picker/pick-modules.d.ts +5 -3
- package/cjs/picker/pick-modules.js +6 -4
- package/cjs/picker/pick-modules.js.map +1 -1
- package/cjs/picker/picker-service.d.ts +13 -4
- package/cjs/picker/picker-service.js +16 -22
- package/cjs/picker/picker-service.js.map +1 -1
- package/cjs/plugins/base-plugin.d.ts +8 -0
- package/cjs/plugins/base-plugin.js +15 -0
- package/cjs/plugins/base-plugin.js.map +1 -0
- package/cjs/plugins/browser-env-plugin.d.ts +8 -0
- package/cjs/plugins/browser-env-plugin.js +24 -0
- package/cjs/plugins/browser-env-plugin.js.map +1 -0
- package/cjs/plugins/builtin-plugin/dirty-bounds-plugin.d.ts +4 -1
- package/cjs/plugins/builtin-plugin/dirty-bounds-plugin.js +25 -4
- package/cjs/plugins/builtin-plugin/dirty-bounds-plugin.js.map +1 -1
- package/cjs/plugins/builtin-plugin/richtext-edit-plugin.js +3 -1
- package/cjs/plugins/builtin-plugin/richtext-edit-plugin.js.map +1 -1
- package/cjs/plugins/index.d.ts +5 -0
- package/cjs/plugins/index.js +23 -0
- package/cjs/plugins/index.js.map +1 -0
- package/cjs/plugins/picker-plugin.d.ts +7 -0
- package/cjs/plugins/picker-plugin.js +19 -0
- package/cjs/plugins/picker-plugin.js.map +1 -0
- package/cjs/plugins/plugin-modules.d.ts +4 -3
- package/cjs/plugins/plugin-modules.js +6 -4
- package/cjs/plugins/plugin-modules.js.map +1 -1
- package/cjs/plugins/plugin-service.d.ts +16 -2
- package/cjs/plugins/plugin-service.js +24 -26
- package/cjs/plugins/plugin-service.js.map +1 -1
- package/cjs/plugins/renderer-plugin.d.ts +7 -0
- package/cjs/plugins/renderer-plugin.js +19 -0
- package/cjs/plugins/renderer-plugin.js.map +1 -0
- package/cjs/plugins/types.d.ts +28 -0
- package/cjs/plugins/types.js +6 -0
- package/cjs/plugins/types.js.map +1 -0
- package/cjs/register/register-arc.js +1 -1
- package/cjs/register/register-arc.js.map +1 -1
- package/cjs/register/register-arc3d.js +1 -1
- package/cjs/register/register-arc3d.js.map +1 -1
- package/cjs/register/register-area.js +1 -1
- package/cjs/register/register-area.js.map +1 -1
- package/cjs/register/register-circle.js +1 -1
- package/cjs/register/register-circle.js.map +1 -1
- package/cjs/register/register-glyph.js +1 -1
- package/cjs/register/register-glyph.js.map +1 -1
- package/cjs/register/register-group.js +1 -1
- package/cjs/register/register-group.js.map +1 -1
- package/cjs/register/register-image.js +1 -1
- package/cjs/register/register-image.js.map +1 -1
- package/cjs/register/register-line.js +1 -1
- package/cjs/register/register-line.js.map +1 -1
- package/cjs/register/register-path.js +1 -1
- package/cjs/register/register-path.js.map +1 -1
- package/cjs/register/register-polygon.js +1 -1
- package/cjs/register/register-polygon.js.map +1 -1
- package/cjs/register/register-pyramid3d.js +1 -1
- package/cjs/register/register-pyramid3d.js.map +1 -1
- package/cjs/register/register-rect.js +1 -1
- package/cjs/register/register-rect.js.map +1 -1
- package/cjs/register/register-rect3d.js +1 -1
- package/cjs/register/register-rect3d.js.map +1 -1
- package/cjs/register/register-richtext.js +1 -1
- package/cjs/register/register-richtext.js.map +1 -1
- package/cjs/register/register-shadowRoot.js +1 -1
- package/cjs/register/register-shadowRoot.js.map +1 -1
- package/cjs/register/register-star.js +1 -1
- package/cjs/register/register-star.js.map +1 -1
- package/cjs/register/register-symbol.js +1 -1
- package/cjs/register/register-symbol.js.map +1 -1
- package/cjs/register/register-text.js +1 -1
- package/cjs/register/register-text.js.map +1 -1
- package/cjs/register/register-wraptext.js +1 -1
- package/cjs/register/register-wraptext.js.map +1 -1
- package/cjs/registry/contribution-registry.d.ts +9 -0
- package/cjs/registry/contribution-registry.js +33 -0
- package/cjs/registry/contribution-registry.js.map +1 -0
- package/cjs/registry/index.d.ts +5 -0
- package/cjs/registry/index.js +23 -0
- package/cjs/registry/index.js.map +1 -0
- package/cjs/registry/picker-registry.d.ts +10 -0
- package/cjs/registry/picker-registry.js +29 -0
- package/cjs/registry/picker-registry.js.map +1 -0
- package/cjs/registry/plugin-registry.d.ts +10 -0
- package/cjs/registry/plugin-registry.js +29 -0
- package/cjs/registry/plugin-registry.js.map +1 -0
- package/cjs/registry/renderer-registry.d.ts +11 -0
- package/cjs/registry/renderer-registry.js +37 -0
- package/cjs/registry/renderer-registry.js.map +1 -0
- package/cjs/registry/types.d.ts +34 -0
- package/cjs/registry/types.js +6 -0
- package/cjs/registry/types.js.map +1 -0
- package/cjs/render/contributions/modules.d.ts +2 -2
- package/cjs/render/contributions/modules.js +3 -1
- package/cjs/render/contributions/modules.js.map +1 -1
- package/cjs/render/contributions/render/arc-module.d.ts +4 -2
- package/cjs/render/contributions/render/arc-module.js +6 -4
- package/cjs/render/contributions/render/arc-module.js.map +1 -1
- package/cjs/render/contributions/render/arc-render.js +4 -19
- package/cjs/render/contributions/render/arc-render.js.map +1 -1
- package/cjs/render/contributions/render/arc3d-module.d.ts +4 -2
- package/cjs/render/contributions/render/arc3d-module.js +6 -4
- package/cjs/render/contributions/render/arc3d-module.js.map +1 -1
- package/cjs/render/contributions/render/arc3d-render.js +3 -10
- package/cjs/render/contributions/render/arc3d-render.js.map +1 -1
- package/cjs/render/contributions/render/area-module.d.ts +4 -2
- package/cjs/render/contributions/render/area-module.js +6 -4
- package/cjs/render/contributions/render/area-module.js.map +1 -1
- package/cjs/render/contributions/render/area-render.js +4 -19
- package/cjs/render/contributions/render/area-render.js.map +1 -1
- package/cjs/render/contributions/render/base-render.js +9 -5
- package/cjs/render/contributions/render/base-render.js.map +1 -1
- package/cjs/render/contributions/render/circle-module.d.ts +4 -2
- package/cjs/render/contributions/render/circle-module.js +6 -4
- package/cjs/render/contributions/render/circle-module.js.map +1 -1
- package/cjs/render/contributions/render/circle-render.js +3 -18
- package/cjs/render/contributions/render/circle-render.js.map +1 -1
- package/cjs/render/contributions/render/contributions/base-contribution-render.js +3 -18
- package/cjs/render/contributions/render/contributions/base-contribution-render.js.map +1 -1
- package/cjs/render/contributions/render/contributions/rect-contribution-render.js +5 -13
- package/cjs/render/contributions/render/contributions/rect-contribution-render.js.map +1 -1
- package/cjs/render/contributions/render/contributions/text-contribution-render.js.map +1 -1
- package/cjs/render/contributions/render/draw-contribution.d.ts +13 -4
- package/cjs/render/contributions/render/draw-contribution.js +22 -22
- package/cjs/render/contributions/render/draw-contribution.js.map +1 -1
- package/cjs/render/contributions/render/draw-interceptor.js +5 -15
- package/cjs/render/contributions/render/draw-interceptor.js.map +1 -1
- package/cjs/render/contributions/render/glyph-module.d.ts +4 -2
- package/cjs/render/contributions/render/glyph-module.js +6 -4
- package/cjs/render/contributions/render/glyph-module.js.map +1 -1
- package/cjs/render/contributions/render/glyph-render.js +3 -10
- package/cjs/render/contributions/render/glyph-render.js.map +1 -1
- package/cjs/render/contributions/render/graphic-render.js +1 -10
- package/cjs/render/contributions/render/graphic-render.js.map +1 -1
- package/cjs/render/contributions/render/group-render.js +4 -19
- package/cjs/render/contributions/render/group-render.js.map +1 -1
- package/cjs/render/contributions/render/image-module.d.ts +4 -2
- package/cjs/render/contributions/render/image-module.js +6 -4
- package/cjs/render/contributions/render/image-module.js.map +1 -1
- package/cjs/render/contributions/render/image-render.d.ts +2 -2
- package/cjs/render/contributions/render/image-render.js +14 -30
- package/cjs/render/contributions/render/image-render.js.map +1 -1
- package/cjs/render/contributions/render/incremental-area-render.js +3 -10
- package/cjs/render/contributions/render/incremental-area-render.js.map +1 -1
- package/cjs/render/contributions/render/incremental-draw-contribution.d.ts +2 -2
- package/cjs/render/contributions/render/incremental-draw-contribution.js +4 -19
- package/cjs/render/contributions/render/incremental-draw-contribution.js.map +1 -1
- package/cjs/render/contributions/render/incremental-line-render.js +3 -10
- package/cjs/render/contributions/render/incremental-line-render.js.map +1 -1
- package/cjs/render/contributions/render/line-module.d.ts +4 -2
- package/cjs/render/contributions/render/line-module.js +6 -4
- package/cjs/render/contributions/render/line-module.js.map +1 -1
- package/cjs/render/contributions/render/line-render.js +3 -10
- package/cjs/render/contributions/render/line-render.js.map +1 -1
- package/cjs/render/contributions/render/module.d.ts +4 -3
- package/cjs/render/contributions/render/module.js +10 -6
- package/cjs/render/contributions/render/module.js.map +1 -1
- package/cjs/render/contributions/render/path-module.d.ts +4 -2
- package/cjs/render/contributions/render/path-module.js +6 -4
- package/cjs/render/contributions/render/path-module.js.map +1 -1
- package/cjs/render/contributions/render/path-render.js +3 -18
- package/cjs/render/contributions/render/path-render.js.map +1 -1
- package/cjs/render/contributions/render/polygon-module.d.ts +4 -2
- package/cjs/render/contributions/render/polygon-module.js +6 -4
- package/cjs/render/contributions/render/polygon-module.js.map +1 -1
- package/cjs/render/contributions/render/polygon-render.js +3 -18
- package/cjs/render/contributions/render/polygon-render.js.map +1 -1
- package/cjs/render/contributions/render/pyramid3d-module.d.ts +4 -2
- package/cjs/render/contributions/render/pyramid3d-module.js +6 -4
- package/cjs/render/contributions/render/pyramid3d-module.js.map +1 -1
- package/cjs/render/contributions/render/pyramid3d-render.js +3 -10
- package/cjs/render/contributions/render/pyramid3d-render.js.map +1 -1
- package/cjs/render/contributions/render/rect-module.d.ts +4 -2
- package/cjs/render/contributions/render/rect-module.js +11 -8
- package/cjs/render/contributions/render/rect-module.js.map +1 -1
- package/cjs/render/contributions/render/rect-render.js +3 -18
- package/cjs/render/contributions/render/rect-render.js.map +1 -1
- package/cjs/render/contributions/render/rect3d-module.d.ts +4 -2
- package/cjs/render/contributions/render/rect3d-module.js +6 -4
- package/cjs/render/contributions/render/rect3d-module.js.map +1 -1
- package/cjs/render/contributions/render/rect3d-render.js +3 -10
- package/cjs/render/contributions/render/rect3d-render.js.map +1 -1
- package/cjs/render/contributions/render/render-slector.js.map +1 -1
- package/cjs/render/contributions/render/richtext-module.d.ts +4 -2
- package/cjs/render/contributions/render/richtext-module.js +6 -4
- package/cjs/render/contributions/render/richtext-module.js.map +1 -1
- package/cjs/render/contributions/render/richtext-render.js +3 -12
- package/cjs/render/contributions/render/richtext-render.js.map +1 -1
- package/cjs/render/contributions/render/star-module.d.ts +4 -2
- package/cjs/render/contributions/render/star-module.js +9 -6
- package/cjs/render/contributions/render/star-module.js.map +1 -1
- package/cjs/render/contributions/render/star-render.js +3 -18
- package/cjs/render/contributions/render/star-render.js.map +1 -1
- package/cjs/render/contributions/render/symbol-module.d.ts +4 -2
- package/cjs/render/contributions/render/symbol-module.js +6 -4
- package/cjs/render/contributions/render/symbol-module.js.map +1 -1
- package/cjs/render/contributions/render/symbol-render.js +3 -18
- package/cjs/render/contributions/render/symbol-render.js.map +1 -1
- package/cjs/render/contributions/render/text-module.d.ts +4 -2
- package/cjs/render/contributions/render/text-module.js +6 -4
- package/cjs/render/contributions/render/text-module.js.map +1 -1
- package/cjs/render/contributions/render/text-render.js +3 -18
- package/cjs/render/contributions/render/text-render.js.map +1 -1
- package/cjs/render/render-modules.d.ts +4 -3
- package/cjs/render/render-modules.js +6 -4
- package/cjs/render/render-modules.js.map +1 -1
- package/cjs/render/render-service.d.ts +1 -1
- package/cjs/render/render-service.js +4 -18
- package/cjs/render/render-service.js.map +1 -1
- package/dist/index.es.js +22505 -20114
- package/es/application.d.ts +14 -5
- package/es/application.js +1 -10
- package/es/application.js.map +1 -1
- package/es/canvas/empty-context.js +2 -17
- package/es/canvas/empty-context.js.map +1 -1
- package/es/canvas/util.d.ts +2 -3
- package/es/canvas/util.js +15 -5
- package/es/canvas/util.js.map +1 -1
- package/es/color-string/index.js +2 -1
- package/es/common/contribution-provider.d.ts +16 -9
- package/es/common/contribution-provider.js +6 -2
- package/es/common/contribution-provider.js.map +1 -1
- package/es/common/diff.js +1 -2
- package/es/common/enums.d.ts +2 -0
- package/es/common/enums.js +1 -0
- package/es/common/enums.js.map +1 -1
- package/es/common/event-transformer.js +43 -6
- package/es/common/event-transformer.js.map +1 -1
- package/es/common/explicit-binding.d.ts +5 -0
- package/es/common/explicit-binding.js +10 -0
- package/es/common/explicit-binding.js.map +1 -0
- package/es/common/performance-raf.d.ts +1 -0
- package/es/common/performance-raf.js +5 -0
- package/es/common/performance-raf.js.map +1 -1
- package/es/common/render-area.js +1 -1
- package/es/common/render-command-list.js +1 -1
- package/es/common/render-curve.js +1 -1
- package/es/common/render-utils.js +1 -1
- package/es/common/seg-context.js +1 -2
- package/es/common/simplify.js +1 -1
- package/es/common/sort.js +1 -1
- package/es/common/split-path.js +1 -1
- package/es/common/store.js +1 -1
- package/es/common/text.js +1 -1
- package/es/common/utils.js +1 -1
- package/es/core/application.js +1 -1
- package/es/core/camera.js +1 -1
- package/es/core/constants.js +1 -1
- package/es/core/contributions/env/base-contribution.js +3 -13
- package/es/core/contributions/env/base-contribution.js.map +1 -1
- package/es/core/contributions/env/modules.d.ts +4 -3
- package/es/core/contributions/env/modules.js +4 -4
- package/es/core/contributions/env/modules.js.map +1 -1
- package/es/core/contributions/layerHandler/canvas2d-contribution.js +2 -16
- package/es/core/contributions/layerHandler/canvas2d-contribution.js.map +1 -1
- package/es/core/contributions/layerHandler/empty-contribution.js +2 -16
- package/es/core/contributions/layerHandler/empty-contribution.js.map +1 -1
- package/es/core/contributions/layerHandler/modules.d.ts +4 -3
- package/es/core/contributions/layerHandler/modules.js +4 -4
- package/es/core/contributions/layerHandler/modules.js.map +1 -1
- package/es/core/contributions/layerHandler/offscreen2d-contribution.js +2 -16
- package/es/core/contributions/layerHandler/offscreen2d-contribution.js.map +1 -1
- package/es/core/contributions/modules.d.ts +2 -2
- package/es/core/contributions/modules.js +7 -1
- package/es/core/contributions/modules.js.map +1 -1
- package/es/core/contributions/textMeasure/AtextMeasure.js +2 -14
- package/es/core/contributions/textMeasure/AtextMeasure.js.map +1 -1
- package/es/core/contributions/textMeasure/modules.d.ts +4 -3
- package/es/core/contributions/textMeasure/modules.js +4 -4
- package/es/core/contributions/textMeasure/modules.js.map +1 -1
- package/es/core/contributions/textMeasure/textMeasure-contribution.js +2 -14
- package/es/core/contributions/textMeasure/textMeasure-contribution.js.map +1 -1
- package/es/core/contributions/window/base-contribution.js +2 -16
- package/es/core/contributions/window/base-contribution.js.map +1 -1
- package/es/core/core-modules.d.ts +4 -3
- package/es/core/core-modules.js +13 -9
- package/es/core/core-modules.js.map +1 -1
- package/es/core/global-module.js +2 -0
- package/es/core/global-module.js.map +1 -1
- package/es/core/global.d.ts +2 -0
- package/es/core/global.js +8 -24
- package/es/core/global.js.map +1 -1
- package/es/core/graphic-utils.d.ts +1 -2
- package/es/core/graphic-utils.js +8 -35
- package/es/core/graphic-utils.js.map +1 -1
- package/es/core/index.js +1 -1
- package/es/core/layer-service.d.ts +7 -2
- package/es/core/layer-service.js +28 -34
- package/es/core/layer-service.js.map +1 -1
- package/es/core/layer.js +1 -1
- package/es/core/layer.js.map +1 -1
- package/es/core/light.js +1 -1
- package/es/core/stage.d.ts +19 -7
- package/es/core/stage.js +64 -48
- package/es/core/stage.js.map +1 -1
- package/es/core/window.d.ts +7 -5
- package/es/core/window.js +13 -25
- package/es/core/window.js.map +1 -1
- package/es/create.d.ts +1 -2
- package/es/create.js +4 -2
- package/es/create.js.map +1 -1
- package/es/entries/app-context.d.ts +30 -0
- package/es/entries/app-context.js +86 -0
- package/es/entries/app-context.js.map +1 -0
- package/es/entries/browser.d.ts +25 -0
- package/es/entries/browser.js +36 -0
- package/es/entries/browser.js.map +1 -0
- package/es/entries/index.d.ts +7 -0
- package/es/entries/index.js +14 -0
- package/es/entries/index.js.map +1 -0
- package/es/entries/miniapp.d.ts +6 -0
- package/es/entries/miniapp.js +12 -0
- package/es/entries/miniapp.js.map +1 -0
- package/es/entries/node.d.ts +6 -0
- package/es/entries/node.js +12 -0
- package/es/entries/node.js.map +1 -0
- package/es/entries/runtime-installer.d.ts +11 -0
- package/es/entries/runtime-installer.js +130 -0
- package/es/entries/runtime-installer.js.map +1 -0
- package/es/entries/types.d.ts +29 -0
- package/es/entries/types.js +2 -0
- package/es/entries/types.js.map +1 -0
- package/es/event/util.d.ts +1 -1
- package/es/factory/graphic-factory.d.ts +7 -0
- package/es/factory/graphic-factory.js +15 -0
- package/es/factory/graphic-factory.js.map +1 -0
- package/es/factory/index.d.ts +4 -0
- package/es/factory/index.js +8 -0
- package/es/factory/index.js.map +1 -0
- package/es/factory/layer-factory.d.ts +7 -0
- package/es/factory/layer-factory.js +11 -0
- package/es/factory/layer-factory.js.map +1 -0
- package/es/factory/stage-factory.d.ts +8 -0
- package/es/factory/stage-factory.js +12 -0
- package/es/factory/stage-factory.js.map +1 -0
- package/es/factory/types.d.ts +34 -0
- package/es/factory/types.js +2 -0
- package/es/factory/types.js.map +1 -0
- package/es/factory.d.ts +1 -0
- package/es/factory.js +2 -0
- package/es/factory.js.map +1 -1
- package/es/global.d.ts +2 -0
- package/es/global.js +10 -0
- package/es/global.js.map +1 -0
- package/es/graphic/area.js +1 -1
- package/es/graphic/area.js.map +1 -1
- package/es/graphic/bounds.js +3 -3
- package/es/graphic/bounds.js.map +1 -1
- package/es/graphic/config.js +0 -1
- package/es/graphic/config.js.map +1 -1
- package/es/graphic/glyph.js +9 -3
- package/es/graphic/glyph.js.map +1 -1
- package/es/graphic/graphic-creator.d.ts +9 -4
- package/es/graphic/graphic-creator.js +32 -5
- package/es/graphic/graphic-creator.js.map +1 -1
- package/es/graphic/graphic-service/graphic-module.d.ts +4 -3
- package/es/graphic/graphic-service/graphic-module.js +4 -4
- package/es/graphic/graphic-service/graphic-module.js.map +1 -1
- package/es/graphic/graphic-service/graphic-service.d.ts +2 -3
- package/es/graphic/graphic-service/graphic-service.js +6 -25
- package/es/graphic/graphic-service/graphic-service.js.map +1 -1
- package/es/graphic/graphic.d.ts +80 -11
- package/es/graphic/graphic.js +473 -139
- package/es/graphic/graphic.js.map +1 -1
- package/es/graphic/group.d.ts +11 -1
- package/es/graphic/group.js +46 -10
- package/es/graphic/group.js.map +1 -1
- package/es/graphic/index.d.ts +3 -0
- package/es/graphic/index.js +4 -0
- package/es/graphic/index.js.map +1 -1
- package/es/graphic/line.js +1 -1
- package/es/graphic/line.js.map +1 -1
- package/es/graphic/state/attribute-update-classifier.d.ts +13 -0
- package/es/graphic/state/attribute-update-classifier.js +61 -0
- package/es/graphic/state/attribute-update-classifier.js.map +1 -0
- package/es/graphic/state/shared-state-refresh.d.ts +6 -0
- package/es/graphic/state/shared-state-refresh.js +46 -0
- package/es/graphic/state/shared-state-refresh.js.map +1 -0
- package/es/graphic/state/shared-state-scope.d.ts +25 -0
- package/es/graphic/state/shared-state-scope.js +90 -0
- package/es/graphic/state/shared-state-scope.js.map +1 -0
- package/es/graphic/state/state-batch-scheduler.d.ts +42 -0
- package/es/graphic/state/state-batch-scheduler.js +278 -0
- package/es/graphic/state/state-batch-scheduler.js.map +1 -0
- package/es/graphic/state/state-definition-compiler.d.ts +6 -0
- package/es/graphic/state/state-definition-compiler.js +83 -0
- package/es/graphic/state/state-definition-compiler.js.map +1 -0
- package/es/graphic/state/state-definition.d.ts +44 -0
- package/es/graphic/state/state-definition.js +2 -0
- package/es/graphic/state/state-definition.js.map +1 -0
- package/es/graphic/state/state-engine.d.ts +38 -0
- package/es/graphic/state/state-engine.js +212 -0
- package/es/graphic/state/state-engine.js.map +1 -0
- package/es/graphic/state/state-model.d.ts +43 -0
- package/es/graphic/state/state-model.js +135 -0
- package/es/graphic/state/state-model.js.map +1 -0
- package/es/graphic/state/state-perf-monitor.d.ts +119 -0
- package/es/graphic/state/state-perf-monitor.js +207 -0
- package/es/graphic/state/state-perf-monitor.js.map +1 -0
- package/es/graphic/state/state-style-resolver.d.ts +22 -0
- package/es/graphic/state/state-style-resolver.js +65 -0
- package/es/graphic/state/state-style-resolver.js.map +1 -0
- package/es/graphic/state/state-transition-orchestrator.d.ts +41 -0
- package/es/graphic/state/state-transition-orchestrator.js +68 -0
- package/es/graphic/state/state-transition-orchestrator.js.map +1 -0
- package/es/graphic/text.d.ts +3 -2
- package/es/graphic/text.js +22 -13
- package/es/graphic/text.js.map +1 -1
- package/es/graphic/theme.d.ts +5 -0
- package/es/graphic/theme.js +7 -0
- package/es/graphic/theme.js.map +1 -1
- package/es/graphic/wrap-text.d.ts +1 -1
- package/es/graphic/wrap-text.js +18 -13
- package/es/graphic/wrap-text.js.map +1 -1
- package/es/index.d.ts +7 -4
- package/es/index.js +12 -6
- package/es/index.js.map +1 -1
- package/es/interface/global.d.ts +2 -0
- package/es/interface/global.js.map +1 -1
- package/es/interface/graphic/group.d.ts +6 -0
- package/es/interface/graphic/group.js.map +1 -1
- package/es/interface/graphic/theme.d.ts +3 -0
- package/es/interface/graphic/theme.js.map +1 -1
- package/es/interface/graphic.d.ts +24 -26
- package/es/interface/graphic.js.map +1 -1
- package/es/interface/plugin.d.ts +2 -0
- package/es/interface/plugin.js.map +1 -1
- package/es/interface/stage.d.ts +11 -3
- package/es/interface/stage.js.map +1 -1
- package/es/interface/theme-service.js.map +1 -1
- package/es/legacy/binding-context.d.ts +24 -0
- package/es/legacy/binding-context.js +90 -0
- package/es/legacy/binding-context.js.map +1 -0
- package/es/legacy/bootstrap.d.ts +10 -0
- package/es/legacy/bootstrap.js +73 -0
- package/es/legacy/bootstrap.js.map +1 -0
- package/es/legacy/module-types.d.ts +2 -0
- package/es/legacy/module-types.js +2 -0
- package/es/legacy/module-types.js.map +1 -0
- package/es/modules.d.ts +5 -6
- package/es/modules.js +37 -33
- package/es/modules.js.map +1 -1
- package/es/picker/global-picker-service.js +2 -16
- package/es/picker/global-picker-service.js.map +1 -1
- package/es/picker/pick-interceptor.js +8 -32
- package/es/picker/pick-interceptor.js.map +1 -1
- package/es/picker/pick-modules.d.ts +5 -3
- package/es/picker/pick-modules.js +4 -4
- package/es/picker/pick-modules.js.map +1 -1
- package/es/picker/picker-service.d.ts +13 -4
- package/es/picker/picker-service.js +16 -26
- package/es/picker/picker-service.js.map +1 -1
- package/es/plugins/base-plugin.d.ts +8 -0
- package/es/plugins/base-plugin.js +7 -0
- package/es/plugins/base-plugin.js.map +1 -0
- package/es/plugins/browser-env-plugin.d.ts +8 -0
- package/es/plugins/browser-env-plugin.js +16 -0
- package/es/plugins/browser-env-plugin.js.map +1 -0
- package/es/plugins/builtin-plugin/dirty-bounds-plugin.d.ts +4 -1
- package/es/plugins/builtin-plugin/dirty-bounds-plugin.js +26 -3
- package/es/plugins/builtin-plugin/dirty-bounds-plugin.js.map +1 -1
- package/es/plugins/builtin-plugin/richtext-edit-plugin.js +3 -1
- package/es/plugins/builtin-plugin/richtext-edit-plugin.js.map +1 -1
- package/es/plugins/index.d.ts +5 -0
- package/es/plugins/index.js +10 -0
- package/es/plugins/index.js.map +1 -0
- package/es/plugins/picker-plugin.d.ts +7 -0
- package/es/plugins/picker-plugin.js +11 -0
- package/es/plugins/picker-plugin.js.map +1 -0
- package/es/plugins/plugin-modules.d.ts +4 -3
- package/es/plugins/plugin-modules.js +4 -4
- package/es/plugins/plugin-modules.js.map +1 -1
- package/es/plugins/plugin-service.d.ts +16 -2
- package/es/plugins/plugin-service.js +25 -32
- package/es/plugins/plugin-service.js.map +1 -1
- package/es/plugins/renderer-plugin.d.ts +7 -0
- package/es/plugins/renderer-plugin.js +11 -0
- package/es/plugins/renderer-plugin.js.map +1 -0
- package/es/plugins/types.d.ts +28 -0
- package/es/plugins/types.js +2 -0
- package/es/plugins/types.js.map +1 -0
- package/es/register/register-arc.js +2 -2
- package/es/register/register-arc.js.map +1 -1
- package/es/register/register-arc3d.js +2 -2
- package/es/register/register-arc3d.js.map +1 -1
- package/es/register/register-area.js +2 -2
- package/es/register/register-area.js.map +1 -1
- package/es/register/register-circle.js +2 -2
- package/es/register/register-circle.js.map +1 -1
- package/es/register/register-glyph.js +2 -2
- package/es/register/register-glyph.js.map +1 -1
- package/es/register/register-group.js +2 -2
- package/es/register/register-group.js.map +1 -1
- package/es/register/register-image.js +2 -2
- package/es/register/register-image.js.map +1 -1
- package/es/register/register-line.js +2 -2
- package/es/register/register-line.js.map +1 -1
- package/es/register/register-path.js +2 -2
- package/es/register/register-path.js.map +1 -1
- package/es/register/register-polygon.js +2 -2
- package/es/register/register-polygon.js.map +1 -1
- package/es/register/register-pyramid3d.js +2 -2
- package/es/register/register-pyramid3d.js.map +1 -1
- package/es/register/register-rect.js +2 -2
- package/es/register/register-rect.js.map +1 -1
- package/es/register/register-rect3d.js +2 -2
- package/es/register/register-rect3d.js.map +1 -1
- package/es/register/register-richtext.js +2 -2
- package/es/register/register-richtext.js.map +1 -1
- package/es/register/register-shadowRoot.js +2 -2
- package/es/register/register-shadowRoot.js.map +1 -1
- package/es/register/register-star.js +2 -2
- package/es/register/register-star.js.map +1 -1
- package/es/register/register-symbol.js +2 -2
- package/es/register/register-symbol.js.map +1 -1
- package/es/register/register-text.js +2 -2
- package/es/register/register-text.js.map +1 -1
- package/es/register/register-wraptext.js +2 -2
- package/es/register/register-wraptext.js.map +1 -1
- package/es/registry/contribution-registry.d.ts +9 -0
- package/es/registry/contribution-registry.js +25 -0
- package/es/registry/contribution-registry.js.map +1 -0
- package/es/registry/index.d.ts +5 -0
- package/es/registry/index.js +10 -0
- package/es/registry/index.js.map +1 -0
- package/es/registry/picker-registry.d.ts +10 -0
- package/es/registry/picker-registry.js +21 -0
- package/es/registry/picker-registry.js.map +1 -0
- package/es/registry/plugin-registry.d.ts +10 -0
- package/es/registry/plugin-registry.js +21 -0
- package/es/registry/plugin-registry.js.map +1 -0
- package/es/registry/renderer-registry.d.ts +11 -0
- package/es/registry/renderer-registry.js +29 -0
- package/es/registry/renderer-registry.js.map +1 -0
- package/es/registry/types.d.ts +34 -0
- package/es/registry/types.js +2 -0
- package/es/registry/types.js.map +1 -0
- package/es/render/contributions/modules.d.ts +2 -2
- package/es/render/contributions/modules.js +3 -1
- package/es/render/contributions/modules.js.map +1 -1
- package/es/render/contributions/render/arc-module.d.ts +4 -2
- package/es/render/contributions/render/arc-module.js +4 -4
- package/es/render/contributions/render/arc-module.js.map +1 -1
- package/es/render/contributions/render/arc-render.js +2 -24
- package/es/render/contributions/render/arc-render.js.map +1 -1
- package/es/render/contributions/render/arc3d-module.d.ts +4 -2
- package/es/render/contributions/render/arc3d-module.js +4 -4
- package/es/render/contributions/render/arc3d-module.js.map +1 -1
- package/es/render/contributions/render/arc3d-render.js +2 -14
- package/es/render/contributions/render/arc3d-render.js.map +1 -1
- package/es/render/contributions/render/area-module.d.ts +4 -2
- package/es/render/contributions/render/area-module.js +4 -4
- package/es/render/contributions/render/area-module.js.map +1 -1
- package/es/render/contributions/render/area-render.js +2 -24
- package/es/render/contributions/render/area-render.js.map +1 -1
- package/es/render/contributions/render/base-render.js +8 -5
- package/es/render/contributions/render/base-render.js.map +1 -1
- package/es/render/contributions/render/circle-module.d.ts +4 -2
- package/es/render/contributions/render/circle-module.js +4 -4
- package/es/render/contributions/render/circle-module.js.map +1 -1
- package/es/render/contributions/render/circle-render.js +2 -24
- package/es/render/contributions/render/circle-render.js.map +1 -1
- package/es/render/contributions/render/contributions/base-contribution-render.js +2 -24
- package/es/render/contributions/render/contributions/base-contribution-render.js.map +1 -1
- package/es/render/contributions/render/contributions/rect-contribution-render.js +4 -20
- package/es/render/contributions/render/contributions/rect-contribution-render.js.map +1 -1
- package/es/render/contributions/render/contributions/text-contribution-render.js.map +1 -1
- package/es/render/contributions/render/draw-contribution.d.ts +13 -4
- package/es/render/contributions/render/draw-contribution.js +24 -34
- package/es/render/contributions/render/draw-contribution.js.map +1 -1
- package/es/render/contributions/render/draw-interceptor.js +4 -19
- package/es/render/contributions/render/draw-interceptor.js.map +1 -1
- package/es/render/contributions/render/glyph-module.d.ts +4 -2
- package/es/render/contributions/render/glyph-module.js +4 -4
- package/es/render/contributions/render/glyph-module.js.map +1 -1
- package/es/render/contributions/render/glyph-render.js +2 -14
- package/es/render/contributions/render/glyph-render.js.map +1 -1
- package/es/render/contributions/render/graphic-render.js +1 -13
- package/es/render/contributions/render/graphic-render.js.map +1 -1
- package/es/render/contributions/render/group-render.js +2 -24
- package/es/render/contributions/render/group-render.js.map +1 -1
- package/es/render/contributions/render/image-module.d.ts +4 -2
- package/es/render/contributions/render/image-module.js +4 -4
- package/es/render/contributions/render/image-module.js.map +1 -1
- package/es/render/contributions/render/image-render.d.ts +2 -2
- package/es/render/contributions/render/image-render.js +9 -31
- package/es/render/contributions/render/image-render.js.map +1 -1
- package/es/render/contributions/render/incremental-area-render.js +2 -14
- package/es/render/contributions/render/incremental-area-render.js.map +1 -1
- package/es/render/contributions/render/incremental-draw-contribution.d.ts +2 -2
- package/es/render/contributions/render/incremental-draw-contribution.js +3 -29
- package/es/render/contributions/render/incremental-draw-contribution.js.map +1 -1
- package/es/render/contributions/render/incremental-line-render.js +2 -14
- package/es/render/contributions/render/incremental-line-render.js.map +1 -1
- package/es/render/contributions/render/line-module.d.ts +4 -2
- package/es/render/contributions/render/line-module.js +4 -4
- package/es/render/contributions/render/line-module.js.map +1 -1
- package/es/render/contributions/render/line-render.js +2 -14
- package/es/render/contributions/render/line-render.js.map +1 -1
- package/es/render/contributions/render/module.d.ts +4 -3
- package/es/render/contributions/render/module.js +10 -10
- package/es/render/contributions/render/module.js.map +1 -1
- package/es/render/contributions/render/path-module.d.ts +4 -2
- package/es/render/contributions/render/path-module.js +4 -4
- package/es/render/contributions/render/path-module.js.map +1 -1
- package/es/render/contributions/render/path-render.js +2 -24
- package/es/render/contributions/render/path-render.js.map +1 -1
- package/es/render/contributions/render/polygon-module.d.ts +4 -2
- package/es/render/contributions/render/polygon-module.js +4 -4
- package/es/render/contributions/render/polygon-module.js.map +1 -1
- package/es/render/contributions/render/polygon-render.js +2 -24
- package/es/render/contributions/render/polygon-render.js.map +1 -1
- package/es/render/contributions/render/pyramid3d-module.d.ts +4 -2
- package/es/render/contributions/render/pyramid3d-module.js +4 -4
- package/es/render/contributions/render/pyramid3d-module.js.map +1 -1
- package/es/render/contributions/render/pyramid3d-render.js +2 -14
- package/es/render/contributions/render/pyramid3d-render.js.map +1 -1
- package/es/render/contributions/render/rect-module.d.ts +4 -2
- package/es/render/contributions/render/rect-module.js +7 -7
- package/es/render/contributions/render/rect-module.js.map +1 -1
- package/es/render/contributions/render/rect-render.js +2 -24
- package/es/render/contributions/render/rect-render.js.map +1 -1
- package/es/render/contributions/render/rect3d-module.d.ts +4 -2
- package/es/render/contributions/render/rect3d-module.js +4 -4
- package/es/render/contributions/render/rect3d-module.js.map +1 -1
- package/es/render/contributions/render/rect3d-render.js +2 -14
- package/es/render/contributions/render/rect3d-render.js.map +1 -1
- package/es/render/contributions/render/render-slector.js.map +1 -1
- package/es/render/contributions/render/richtext-module.d.ts +4 -2
- package/es/render/contributions/render/richtext-module.js +4 -4
- package/es/render/contributions/render/richtext-module.js.map +1 -1
- package/es/render/contributions/render/richtext-render.js +2 -16
- package/es/render/contributions/render/richtext-render.js.map +1 -1
- package/es/render/contributions/render/star-module.d.ts +4 -2
- package/es/render/contributions/render/star-module.js +9 -5
- package/es/render/contributions/render/star-module.js.map +1 -1
- package/es/render/contributions/render/star-render.js +2 -24
- package/es/render/contributions/render/star-render.js.map +1 -1
- package/es/render/contributions/render/symbol-module.d.ts +4 -2
- package/es/render/contributions/render/symbol-module.js +4 -4
- package/es/render/contributions/render/symbol-module.js.map +1 -1
- package/es/render/contributions/render/symbol-render.js +2 -24
- package/es/render/contributions/render/symbol-render.js.map +1 -1
- package/es/render/contributions/render/text-module.d.ts +4 -2
- package/es/render/contributions/render/text-module.js +4 -4
- package/es/render/contributions/render/text-module.js.map +1 -1
- package/es/render/contributions/render/text-render.js +2 -24
- package/es/render/contributions/render/text-render.js.map +1 -1
- package/es/render/render-modules.d.ts +4 -3
- package/es/render/render-modules.js +4 -4
- package/es/render/render-modules.js.map +1 -1
- package/es/render/render-service.d.ts +1 -1
- package/es/render/render-service.js +4 -22
- package/es/render/render-service.js.map +1 -1
- package/package.json +8 -7
- package/cjs/common/inversify/annotation/inject.d.ts +0 -1
- package/cjs/common/inversify/annotation/inject.js +0 -10
- package/cjs/common/inversify/annotation/inject.js.map +0 -1
- package/cjs/common/inversify/annotation/inject_base.d.ts +0 -14
- package/cjs/common/inversify/annotation/inject_base.js +0 -39
- package/cjs/common/inversify/annotation/inject_base.js.map +0 -1
- package/cjs/common/inversify/annotation/injectable.d.ts +0 -1
- package/cjs/common/inversify/annotation/injectable.js +0 -46
- package/cjs/common/inversify/annotation/injectable.js.map +0 -1
- package/cjs/common/inversify/annotation/multi_inject.d.ts +0 -1
- package/cjs/common/inversify/annotation/multi_inject.js +0 -10
- package/cjs/common/inversify/annotation/multi_inject.js.map +0 -1
- package/cjs/common/inversify/annotation/named.d.ts +0 -1
- package/cjs/common/inversify/annotation/named.js +0 -14
- package/cjs/common/inversify/annotation/named.js.map +0 -1
- package/cjs/common/inversify/annotation/optional.d.ts +0 -2
- package/cjs/common/inversify/annotation/optional.js +0 -14
- package/cjs/common/inversify/annotation/optional.js.map +0 -1
- package/cjs/common/inversify/binding.d.ts +0 -18
- package/cjs/common/inversify/binding.js +0 -26
- package/cjs/common/inversify/binding.js.map +0 -1
- package/cjs/common/inversify/container.d.ts +0 -28
- package/cjs/common/inversify/container.js +0 -158
- package/cjs/common/inversify/container.js.map +0 -1
- package/cjs/common/inversify/cotainer-module.d.ts +0 -6
- package/cjs/common/inversify/cotainer-module.js +0 -16
- package/cjs/common/inversify/cotainer-module.js.map +0 -1
- package/cjs/common/inversify/index.d.ts +0 -7
- package/cjs/common/inversify/index.js +0 -75
- package/cjs/common/inversify/index.js.map +0 -1
- package/cjs/common/inversify/interfaces.d.ts +0 -218
- package/cjs/common/inversify/interfaces.js.map +0 -1
- package/cjs/common/inversify/literal_types.d.ts +0 -5
- package/cjs/common/inversify/literal_types.js +0 -34
- package/cjs/common/inversify/literal_types.js.map +0 -1
- package/cjs/common/inversify/meta-data.d.ts +0 -6
- package/cjs/common/inversify/meta-data.js +0 -19
- package/cjs/common/inversify/meta-data.js.map +0 -1
- package/cjs/common/inversify/metadata_keys.d.ts +0 -12
- package/cjs/common/inversify/metadata_keys.js +0 -15
- package/cjs/common/inversify/metadata_keys.js.map +0 -1
- package/cjs/common/inversify/metadata_reader.d.ts +0 -6
- package/cjs/common/inversify/metadata_reader.js +0 -28
- package/cjs/common/inversify/metadata_reader.js.map +0 -1
- package/cjs/common/inversify/syntax/binding_in_syntax.d.ts +0 -10
- package/cjs/common/inversify/syntax/binding_in_syntax.js +0 -29
- package/cjs/common/inversify/syntax/binding_in_syntax.js.map +0 -1
- package/cjs/common/inversify/syntax/binding_to_syntax.d.ts +0 -12
- package/cjs/common/inversify/syntax/binding_to_syntax.js +0 -40
- package/cjs/common/inversify/syntax/binding_to_syntax.js.map +0 -1
- package/cjs/common/inversify/syntax/constraint_helpers.d.ts +0 -2
- package/cjs/common/inversify/syntax/constraint_helpers.js +0 -20
- package/cjs/common/inversify/syntax/constraint_helpers.js.map +0 -1
- package/cjs/common/inversify-lite/annotation/decorator_utils.d.ts +0 -16
- package/cjs/common/inversify-lite/annotation/decorator_utils.js +0 -97
- package/cjs/common/inversify-lite/annotation/decorator_utils.js.map +0 -1
- package/cjs/common/inversify-lite/annotation/inject.d.ts +0 -2
- package/cjs/common/inversify-lite/annotation/inject.js +0 -36
- package/cjs/common/inversify-lite/annotation/inject.js.map +0 -1
- package/cjs/common/inversify-lite/annotation/inject_base.d.ts +0 -3
- package/cjs/common/inversify-lite/annotation/inject_base.js +0 -20
- package/cjs/common/inversify-lite/annotation/inject_base.js.map +0 -1
- package/cjs/common/inversify-lite/annotation/injectable.d.ts +0 -2
- package/cjs/common/inversify-lite/annotation/injectable.js +0 -48
- package/cjs/common/inversify-lite/annotation/injectable.js.map +0 -1
- package/cjs/common/inversify-lite/annotation/lazy_service_identifier.d.ts +0 -7
- package/cjs/common/inversify-lite/annotation/lazy_service_identifier.js +0 -17
- package/cjs/common/inversify-lite/annotation/lazy_service_identifier.js.map +0 -1
- package/cjs/common/inversify-lite/annotation/multi_inject.d.ts +0 -2
- package/cjs/common/inversify-lite/annotation/multi_inject.js +0 -36
- package/cjs/common/inversify-lite/annotation/multi_inject.js.map +0 -1
- package/cjs/common/inversify-lite/annotation/named.d.ts +0 -2
- package/cjs/common/inversify-lite/annotation/named.js +0 -39
- package/cjs/common/inversify-lite/annotation/named.js.map +0 -1
- package/cjs/common/inversify-lite/annotation/property_event_decorator.d.ts +0 -4
- package/cjs/common/inversify-lite/annotation/property_event_decorator.js +0 -24
- package/cjs/common/inversify-lite/annotation/property_event_decorator.js.map +0 -1
- package/cjs/common/inversify-lite/bindings/binding.d.ts +0 -20
- package/cjs/common/inversify-lite/bindings/binding.js +0 -27
- package/cjs/common/inversify-lite/bindings/binding.js.map +0 -1
- package/cjs/common/inversify-lite/bindings/binding_count.d.ts +0 -5
- package/cjs/common/inversify-lite/bindings/binding_count.js +0 -10
- package/cjs/common/inversify-lite/bindings/binding_count.js.map +0 -1
- package/cjs/common/inversify-lite/constants/error_msgs.d.ts +0 -32
- package/cjs/common/inversify-lite/constants/error_msgs.js +0 -50
- package/cjs/common/inversify-lite/constants/error_msgs.js.map +0 -1
- package/cjs/common/inversify-lite/constants/literal_types.d.ts +0 -5
- package/cjs/common/inversify-lite/constants/literal_types.js +0 -35
- package/cjs/common/inversify-lite/constants/literal_types.js.map +0 -1
- package/cjs/common/inversify-lite/constants/metadata_keys.d.ts +0 -13
- package/cjs/common/inversify-lite/constants/metadata_keys.js +0 -16
- package/cjs/common/inversify-lite/constants/metadata_keys.js.map +0 -1
- package/cjs/common/inversify-lite/container/container.d.ts +0 -46
- package/cjs/common/inversify-lite/container/container.js +0 -290
- package/cjs/common/inversify-lite/container/container.js.map +0 -1
- package/cjs/common/inversify-lite/container/container_module.d.ts +0 -11
- package/cjs/common/inversify-lite/container/container_module.js +0 -24
- package/cjs/common/inversify-lite/container/container_module.js.map +0 -1
- package/cjs/common/inversify-lite/container/lookup.d.ts +0 -16
- package/cjs/common/inversify-lite/container/lookup.js +0 -97
- package/cjs/common/inversify-lite/container/lookup.js.map +0 -1
- package/cjs/common/inversify-lite/index.d.ts +0 -1
- package/cjs/common/inversify-lite/index.js.map +0 -1
- package/cjs/common/inversify-lite/interfaces/interfaces.d.ts +0 -237
- package/cjs/common/inversify-lite/interfaces/interfaces.js.map +0 -1
- package/cjs/common/inversify-lite/planning/context.d.ts +0 -11
- package/cjs/common/inversify-lite/planning/context.js +0 -22
- package/cjs/common/inversify-lite/planning/context.js.map +0 -1
- package/cjs/common/inversify-lite/planning/metadata.d.ts +0 -8
- package/cjs/common/inversify-lite/planning/metadata.js +0 -44
- package/cjs/common/inversify-lite/planning/metadata.js.map +0 -1
- package/cjs/common/inversify-lite/planning/metadata_reader.d.ts +0 -6
- package/cjs/common/inversify-lite/planning/metadata_reader.js +0 -51
- package/cjs/common/inversify-lite/planning/metadata_reader.js.map +0 -1
- package/cjs/common/inversify-lite/planning/plan.d.ts +0 -7
- package/cjs/common/inversify-lite/planning/plan.js +0 -14
- package/cjs/common/inversify-lite/planning/plan.js.map +0 -1
- package/cjs/common/inversify-lite/planning/planner.d.ts +0 -5
- package/cjs/common/inversify-lite/planning/planner.js +0 -132
- package/cjs/common/inversify-lite/planning/planner.js.map +0 -1
- package/cjs/common/inversify-lite/planning/queryable_string.d.ts +0 -9
- package/cjs/common/inversify-lite/planning/queryable_string.js +0 -23
- package/cjs/common/inversify-lite/planning/queryable_string.js.map +0 -1
- package/cjs/common/inversify-lite/planning/reflection_utils.d.ts +0 -5
- package/cjs/common/inversify-lite/planning/reflection_utils.js +0 -129
- package/cjs/common/inversify-lite/planning/reflection_utils.js.map +0 -1
- package/cjs/common/inversify-lite/planning/request.d.ts +0 -14
- package/cjs/common/inversify-lite/planning/request.js +0 -22
- package/cjs/common/inversify-lite/planning/request.js.map +0 -1
- package/cjs/common/inversify-lite/planning/target.d.ts +0 -23
- package/cjs/common/inversify-lite/planning/target.js +0 -81
- package/cjs/common/inversify-lite/planning/target.js.map +0 -1
- package/cjs/common/inversify-lite/resolution/instantiation.d.ts +0 -3
- package/cjs/common/inversify-lite/resolution/instantiation.js +0 -143
- package/cjs/common/inversify-lite/resolution/instantiation.js.map +0 -1
- package/cjs/common/inversify-lite/resolution/resolver.d.ts +0 -3
- package/cjs/common/inversify-lite/resolution/resolver.js +0 -74
- package/cjs/common/inversify-lite/resolution/resolver.js.map +0 -1
- package/cjs/common/inversify-lite/scope/scope.d.ts +0 -3
- package/cjs/common/inversify-lite/scope/scope.js +0 -56
- package/cjs/common/inversify-lite/scope/scope.js.map +0 -1
- package/cjs/common/inversify-lite/syntax/binding_in_syntax.d.ts +0 -9
- package/cjs/common/inversify-lite/syntax/binding_in_syntax.js +0 -25
- package/cjs/common/inversify-lite/syntax/binding_in_syntax.js.map +0 -1
- package/cjs/common/inversify-lite/syntax/binding_in_when_on_syntax.d.ts +0 -12
- package/cjs/common/inversify-lite/syntax/binding_in_when_on_syntax.js +0 -29
- package/cjs/common/inversify-lite/syntax/binding_in_when_on_syntax.js.map +0 -1
- package/cjs/common/inversify-lite/syntax/binding_on_syntax.d.ts +0 -6
- package/cjs/common/inversify-lite/syntax/binding_on_syntax.js +0 -14
- package/cjs/common/inversify-lite/syntax/binding_on_syntax.js.map +0 -1
- package/cjs/common/inversify-lite/syntax/binding_to_syntax.d.ts +0 -18
- package/cjs/common/inversify-lite/syntax/binding_to_syntax.js +0 -88
- package/cjs/common/inversify-lite/syntax/binding_to_syntax.js.map +0 -1
- package/cjs/common/inversify-lite/syntax/binding_when_on_syntax.d.ts +0 -8
- package/cjs/common/inversify-lite/syntax/binding_when_on_syntax.js +0 -19
- package/cjs/common/inversify-lite/syntax/binding_when_on_syntax.js.map +0 -1
- package/cjs/common/inversify-lite/syntax/binding_when_syntax.d.ts +0 -7
- package/cjs/common/inversify-lite/syntax/binding_when_syntax.js +0 -20
- package/cjs/common/inversify-lite/syntax/binding_when_syntax.js.map +0 -1
- package/cjs/common/inversify-lite/syntax/constraint_helpers.d.ts +0 -3
- package/cjs/common/inversify-lite/syntax/constraint_helpers.js +0 -38
- package/cjs/common/inversify-lite/syntax/constraint_helpers.js.map +0 -1
- package/cjs/common/inversify-lite/utils/async.d.ts +0 -3
- package/cjs/common/inversify-lite/utils/async.js +0 -15
- package/cjs/common/inversify-lite/utils/async.js.map +0 -1
- package/cjs/common/inversify-lite/utils/binding_utils.d.ts +0 -4
- package/cjs/common/inversify-lite/utils/binding_utils.js +0 -94
- package/cjs/common/inversify-lite/utils/binding_utils.js.map +0 -1
- package/cjs/common/inversify-lite/utils/clonable.d.ts +0 -3
- package/cjs/common/inversify-lite/utils/clonable.js +0 -10
- package/cjs/common/inversify-lite/utils/clonable.js.map +0 -1
- package/cjs/common/inversify-lite/utils/exceptions.d.ts +0 -2
- package/cjs/common/inversify-lite/utils/exceptions.js +0 -43
- package/cjs/common/inversify-lite/utils/exceptions.js.map +0 -1
- package/cjs/common/inversify-lite/utils/factory_type.d.ts +0 -5
- package/cjs/common/inversify-lite/utils/factory_type.js +0 -11
- package/cjs/common/inversify-lite/utils/factory_type.js.map +0 -1
- package/cjs/common/inversify-lite/utils/id.d.ts +0 -2
- package/cjs/common/inversify-lite/utils/id.js +0 -14
- package/cjs/common/inversify-lite/utils/id.js.map +0 -1
- package/cjs/common/inversify-lite/utils/js.d.ts +0 -1
- package/cjs/common/inversify-lite/utils/js.js +0 -14
- package/cjs/common/inversify-lite/utils/js.js.map +0 -1
- package/cjs/common/inversify-lite/utils/serialization.d.ts +0 -10
- package/cjs/common/inversify-lite/utils/serialization.js +0 -99
- package/cjs/common/inversify-lite/utils/serialization.js.map +0 -1
- package/cjs/container.d.ts +0 -2
- package/cjs/container.js +0 -10
- package/cjs/container.js.map +0 -1
- package/es/common/inversify/annotation/inject.d.ts +0 -1
- package/es/common/inversify/annotation/inject.js +0 -6
- package/es/common/inversify/annotation/inject.js.map +0 -1
- package/es/common/inversify/annotation/inject_base.d.ts +0 -14
- package/es/common/inversify/annotation/inject_base.js +0 -29
- package/es/common/inversify/annotation/inject_base.js.map +0 -1
- package/es/common/inversify/annotation/injectable.d.ts +0 -1
- package/es/common/inversify/annotation/injectable.js +0 -10
- package/es/common/inversify/annotation/injectable.js.map +0 -1
- package/es/common/inversify/annotation/multi_inject.d.ts +0 -1
- package/es/common/inversify/annotation/multi_inject.js +0 -6
- package/es/common/inversify/annotation/multi_inject.js.map +0 -1
- package/es/common/inversify/annotation/named.d.ts +0 -1
- package/es/common/inversify/annotation/named.js +0 -10
- package/es/common/inversify/annotation/named.js.map +0 -1
- package/es/common/inversify/annotation/optional.d.ts +0 -2
- package/es/common/inversify/annotation/optional.js +0 -12
- package/es/common/inversify/annotation/optional.js.map +0 -1
- package/es/common/inversify/binding.d.ts +0 -18
- package/es/common/inversify/binding.js +0 -22
- package/es/common/inversify/binding.js.map +0 -1
- package/es/common/inversify/container.d.ts +0 -28
- package/es/common/inversify/container.js +0 -158
- package/es/common/inversify/container.js.map +0 -1
- package/es/common/inversify/cotainer-module.d.ts +0 -6
- package/es/common/inversify/cotainer-module.js +0 -8
- package/es/common/inversify/cotainer-module.js.map +0 -1
- package/es/common/inversify/index.d.ts +0 -7
- package/es/common/inversify/index.js +0 -14
- package/es/common/inversify/index.js.map +0 -1
- package/es/common/inversify/interfaces.d.ts +0 -218
- package/es/common/inversify/interfaces.js +0 -2
- package/es/common/inversify/interfaces.js.map +0 -1
- package/es/common/inversify/literal_types.d.ts +0 -5
- package/es/common/inversify/literal_types.js +0 -20
- package/es/common/inversify/literal_types.js.map +0 -1
- package/es/common/inversify/meta-data.d.ts +0 -6
- package/es/common/inversify/meta-data.js +0 -11
- package/es/common/inversify/meta-data.js.map +0 -1
- package/es/common/inversify/metadata_keys.d.ts +0 -12
- package/es/common/inversify/metadata_keys.js +0 -28
- package/es/common/inversify/metadata_keys.js.map +0 -1
- package/es/common/inversify/metadata_reader.d.ts +0 -6
- package/es/common/inversify/metadata_reader.js +0 -18
- package/es/common/inversify/metadata_reader.js.map +0 -1
- package/es/common/inversify/syntax/binding_in_syntax.d.ts +0 -10
- package/es/common/inversify/syntax/binding_in_syntax.js +0 -24
- package/es/common/inversify/syntax/binding_in_syntax.js.map +0 -1
- package/es/common/inversify/syntax/binding_to_syntax.d.ts +0 -12
- package/es/common/inversify/syntax/binding_to_syntax.js +0 -36
- package/es/common/inversify/syntax/binding_to_syntax.js.map +0 -1
- package/es/common/inversify/syntax/constraint_helpers.d.ts +0 -2
- package/es/common/inversify/syntax/constraint_helpers.js +0 -18
- package/es/common/inversify/syntax/constraint_helpers.js.map +0 -1
- package/es/common/inversify-lite/annotation/decorator_utils.d.ts +0 -16
- package/es/common/inversify-lite/annotation/decorator_utils.js +0 -67
- package/es/common/inversify-lite/annotation/decorator_utils.js.map +0 -1
- package/es/common/inversify-lite/annotation/inject.d.ts +0 -2
- package/es/common/inversify-lite/annotation/inject.js +0 -8
- package/es/common/inversify-lite/annotation/inject.js.map +0 -1
- package/es/common/inversify-lite/annotation/inject_base.d.ts +0 -3
- package/es/common/inversify-lite/annotation/inject_base.js +0 -16
- package/es/common/inversify-lite/annotation/inject_base.js.map +0 -1
- package/es/common/inversify-lite/annotation/injectable.d.ts +0 -2
- package/es/common/inversify-lite/annotation/injectable.js +0 -16
- package/es/common/inversify-lite/annotation/injectable.js.map +0 -1
- package/es/common/inversify-lite/annotation/lazy_service_identifier.d.ts +0 -7
- package/es/common/inversify-lite/annotation/lazy_service_identifier.js +0 -9
- package/es/common/inversify-lite/annotation/lazy_service_identifier.js.map +0 -1
- package/es/common/inversify-lite/annotation/multi_inject.d.ts +0 -2
- package/es/common/inversify-lite/annotation/multi_inject.js +0 -8
- package/es/common/inversify-lite/annotation/multi_inject.js.map +0 -1
- package/es/common/inversify-lite/annotation/named.d.ts +0 -2
- package/es/common/inversify-lite/annotation/named.js +0 -12
- package/es/common/inversify-lite/annotation/named.js.map +0 -1
- package/es/common/inversify-lite/annotation/property_event_decorator.d.ts +0 -4
- package/es/common/inversify-lite/annotation/property_event_decorator.js +0 -14
- package/es/common/inversify-lite/annotation/property_event_decorator.js.map +0 -1
- package/es/common/inversify-lite/bindings/binding.d.ts +0 -20
- package/es/common/inversify-lite/bindings/binding.js +0 -23
- package/es/common/inversify-lite/bindings/binding.js.map +0 -1
- package/es/common/inversify-lite/bindings/binding_count.d.ts +0 -5
- package/es/common/inversify-lite/bindings/binding_count.js +0 -6
- package/es/common/inversify-lite/bindings/binding_count.js.map +0 -1
- package/es/common/inversify-lite/constants/error_msgs.d.ts +0 -32
- package/es/common/inversify-lite/constants/error_msgs.js +0 -64
- package/es/common/inversify-lite/constants/error_msgs.js.map +0 -1
- package/es/common/inversify-lite/constants/literal_types.d.ts +0 -5
- package/es/common/inversify-lite/constants/literal_types.js +0 -21
- package/es/common/inversify-lite/constants/literal_types.js.map +0 -1
- package/es/common/inversify-lite/constants/metadata_keys.d.ts +0 -13
- package/es/common/inversify-lite/constants/metadata_keys.js +0 -30
- package/es/common/inversify-lite/constants/metadata_keys.js.map +0 -1
- package/es/common/inversify-lite/container/container.d.ts +0 -46
- package/es/common/inversify-lite/container/container.js +0 -279
- package/es/common/inversify-lite/container/container.js.map +0 -1
- package/es/common/inversify-lite/container/container_module.d.ts +0 -11
- package/es/common/inversify-lite/container/container_module.js +0 -14
- package/es/common/inversify-lite/container/container_module.js.map +0 -1
- package/es/common/inversify-lite/container/lookup.d.ts +0 -16
- package/es/common/inversify-lite/container/lookup.js +0 -68
- package/es/common/inversify-lite/container/lookup.js.map +0 -1
- package/es/common/inversify-lite/index.d.ts +0 -1
- package/es/common/inversify-lite/index.js +0 -2
- package/es/common/inversify-lite/index.js.map +0 -1
- package/es/common/inversify-lite/interfaces/interfaces.d.ts +0 -237
- package/es/common/inversify-lite/interfaces/interfaces.js +0 -2
- package/es/common/inversify-lite/interfaces/interfaces.js.map +0 -1
- package/es/common/inversify-lite/planning/context.d.ts +0 -11
- package/es/common/inversify-lite/planning/context.js +0 -16
- package/es/common/inversify-lite/planning/context.js.map +0 -1
- package/es/common/inversify-lite/planning/metadata.d.ts +0 -8
- package/es/common/inversify-lite/planning/metadata.js +0 -13
- package/es/common/inversify-lite/planning/metadata.js.map +0 -1
- package/es/common/inversify-lite/planning/metadata_reader.d.ts +0 -6
- package/es/common/inversify-lite/planning/metadata_reader.js +0 -18
- package/es/common/inversify-lite/planning/metadata_reader.js.map +0 -1
- package/es/common/inversify-lite/planning/plan.d.ts +0 -7
- package/es/common/inversify-lite/planning/plan.js +0 -8
- package/es/common/inversify-lite/planning/plan.js.map +0 -1
- package/es/common/inversify-lite/planning/planner.d.ts +0 -5
- package/es/common/inversify-lite/planning/planner.js +0 -120
- package/es/common/inversify-lite/planning/planner.js.map +0 -1
- package/es/common/inversify-lite/planning/queryable_string.d.ts +0 -9
- package/es/common/inversify-lite/planning/queryable_string.js +0 -17
- package/es/common/inversify-lite/planning/queryable_string.js.map +0 -1
- package/es/common/inversify-lite/planning/reflection_utils.d.ts +0 -5
- package/es/common/inversify-lite/planning/reflection_utils.js +0 -99
- package/es/common/inversify-lite/planning/reflection_utils.js.map +0 -1
- package/es/common/inversify-lite/planning/request.d.ts +0 -14
- package/es/common/inversify-lite/planning/request.js +0 -16
- package/es/common/inversify-lite/planning/request.js.map +0 -1
- package/es/common/inversify-lite/planning/target.d.ts +0 -23
- package/es/common/inversify-lite/planning/target.js +0 -58
- package/es/common/inversify-lite/planning/target.js.map +0 -1
- package/es/common/inversify-lite/resolution/instantiation.d.ts +0 -3
- package/es/common/inversify-lite/resolution/instantiation.js +0 -117
- package/es/common/inversify-lite/resolution/instantiation.js.map +0 -1
- package/es/common/inversify-lite/resolution/resolver.d.ts +0 -3
- package/es/common/inversify-lite/resolution/resolver.js +0 -55
- package/es/common/inversify-lite/resolution/resolver.js.map +0 -1
- package/es/common/inversify-lite/scope/scope.d.ts +0 -3
- package/es/common/inversify-lite/scope/scope.js +0 -50
- package/es/common/inversify-lite/scope/scope.js.map +0 -1
- package/es/common/inversify-lite/syntax/binding_in_syntax.d.ts +0 -9
- package/es/common/inversify-lite/syntax/binding_in_syntax.js +0 -21
- package/es/common/inversify-lite/syntax/binding_in_syntax.js.map +0 -1
- package/es/common/inversify-lite/syntax/binding_in_when_on_syntax.d.ts +0 -12
- package/es/common/inversify-lite/syntax/binding_in_when_on_syntax.js +0 -25
- package/es/common/inversify-lite/syntax/binding_in_when_on_syntax.js.map +0 -1
- package/es/common/inversify-lite/syntax/binding_on_syntax.d.ts +0 -6
- package/es/common/inversify-lite/syntax/binding_on_syntax.js +0 -8
- package/es/common/inversify-lite/syntax/binding_on_syntax.js.map +0 -1
- package/es/common/inversify-lite/syntax/binding_to_syntax.d.ts +0 -18
- package/es/common/inversify-lite/syntax/binding_to_syntax.js +0 -63
- package/es/common/inversify-lite/syntax/binding_to_syntax.js.map +0 -1
- package/es/common/inversify-lite/syntax/binding_when_on_syntax.d.ts +0 -8
- package/es/common/inversify-lite/syntax/binding_when_on_syntax.js +0 -13
- package/es/common/inversify-lite/syntax/binding_when_on_syntax.js.map +0 -1
- package/es/common/inversify-lite/syntax/binding_when_syntax.d.ts +0 -7
- package/es/common/inversify-lite/syntax/binding_when_syntax.js +0 -15
- package/es/common/inversify-lite/syntax/binding_when_syntax.js.map +0 -1
- package/es/common/inversify-lite/syntax/constraint_helpers.d.ts +0 -3
- package/es/common/inversify-lite/syntax/constraint_helpers.js +0 -11
- package/es/common/inversify-lite/syntax/constraint_helpers.js.map +0 -1
- package/es/common/inversify-lite/utils/async.d.ts +0 -3
- package/es/common/inversify-lite/utils/async.js +0 -10
- package/es/common/inversify-lite/utils/async.js.map +0 -1
- package/es/common/inversify-lite/utils/binding_utils.d.ts +0 -4
- package/es/common/inversify-lite/utils/binding_utils.js +0 -65
- package/es/common/inversify-lite/utils/binding_utils.js.map +0 -1
- package/es/common/inversify-lite/utils/clonable.d.ts +0 -3
- package/es/common/inversify-lite/utils/clonable.js +0 -6
- package/es/common/inversify-lite/utils/clonable.js.map +0 -1
- package/es/common/inversify-lite/utils/exceptions.d.ts +0 -2
- package/es/common/inversify-lite/utils/exceptions.js +0 -8
- package/es/common/inversify-lite/utils/exceptions.js.map +0 -1
- package/es/common/inversify-lite/utils/factory_type.d.ts +0 -5
- package/es/common/inversify-lite/utils/factory_type.js +0 -7
- package/es/common/inversify-lite/utils/factory_type.js.map +0 -1
- package/es/common/inversify-lite/utils/id.d.ts +0 -2
- package/es/common/inversify-lite/utils/id.js +0 -8
- package/es/common/inversify-lite/utils/id.js.map +0 -1
- package/es/common/inversify-lite/utils/js.d.ts +0 -1
- package/es/common/inversify-lite/utils/js.js +0 -8
- package/es/common/inversify-lite/utils/js.js.map +0 -1
- package/es/common/inversify-lite/utils/serialization.d.ts +0 -10
- package/es/common/inversify-lite/utils/serialization.js +0 -66
- package/es/common/inversify-lite/utils/serialization.js.map +0 -1
- package/es/container.d.ts +0 -2
- package/es/container.js +0 -4
- package/es/container.js.map +0 -1
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
}), exports.collectSharedStateScopeChain = exports.ensureSharedStateScopeFresh = exports.rebuildSharedStateScope = exports.setRootSharedStateScopeThemeDefinitions = exports.setSharedStateScopeLocalDefinitions = exports.setSharedStateScopeParent = exports.createGroupSharedStateScope = exports.createRootSharedStateScope = void 0;
|
|
6
|
+
|
|
7
|
+
const state_definition_compiler_1 = require("./state-definition-compiler"), state_perf_monitor_1 = require("./state-perf-monitor"), compiler = new state_definition_compiler_1.StateDefinitionCompiler;
|
|
8
|
+
|
|
9
|
+
function copyDefinitions(definitions) {
|
|
10
|
+
return definitions ? Object.assign({}, definitions) : {};
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
function buildEffectiveSourceDefinitions(parentScope, localStateDefinitions, themeStateDefinitions) {
|
|
14
|
+
const merged = copyDefinitions(parentScope ? parentScope.effectiveSourceDefinitions : themeStateDefinitions);
|
|
15
|
+
return localStateDefinitions && Object.keys(localStateDefinitions).forEach((stateName => {
|
|
16
|
+
merged[stateName] = localStateDefinitions[stateName];
|
|
17
|
+
})), merged;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
function initializeScope(scope, revision = 0) {
|
|
21
|
+
var _a;
|
|
22
|
+
const effectiveSourceDefinitions = buildEffectiveSourceDefinitions(scope.parentScope, scope.localStateDefinitions, scope.themeStateDefinitions);
|
|
23
|
+
return scope.effectiveSourceDefinitions = effectiveSourceDefinitions, scope.effectiveCompiledDefinitions = compiler.compile(effectiveSourceDefinitions),
|
|
24
|
+
scope.parentRevisionAtBuild = null === (_a = scope.parentScope) || void 0 === _a ? void 0 : _a.revision,
|
|
25
|
+
scope.revision = revision, scope.dirty = !1, scope;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
function createRootSharedStateScope(stage, themeStateDefinitions) {
|
|
29
|
+
return initializeScope({
|
|
30
|
+
ownerKind: "root",
|
|
31
|
+
ownerStage: stage,
|
|
32
|
+
themeStateDefinitions: themeStateDefinitions,
|
|
33
|
+
effectiveSourceDefinitions: {},
|
|
34
|
+
effectiveCompiledDefinitions: new Map,
|
|
35
|
+
revision: 0,
|
|
36
|
+
dirty: !1,
|
|
37
|
+
subtreeActiveDescendants: new Set
|
|
38
|
+
}, 0);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function createGroupSharedStateScope(group, parentScope, localStateDefinitions) {
|
|
42
|
+
return initializeScope({
|
|
43
|
+
ownerKind: "group",
|
|
44
|
+
ownerGroup: group,
|
|
45
|
+
ownerStage: group.stage,
|
|
46
|
+
parentScope: parentScope,
|
|
47
|
+
localStateDefinitions: localStateDefinitions,
|
|
48
|
+
effectiveSourceDefinitions: {},
|
|
49
|
+
effectiveCompiledDefinitions: new Map,
|
|
50
|
+
revision: 0,
|
|
51
|
+
dirty: !1,
|
|
52
|
+
subtreeActiveDescendants: new Set
|
|
53
|
+
}, 0);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
function setSharedStateScopeParent(scope, parentScope) {
|
|
57
|
+
return scope.parentScope !== parentScope && (scope.parentScope = parentScope, scope.dirty = !0,
|
|
58
|
+
!0);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
function setSharedStateScopeLocalDefinitions(scope, localStateDefinitions) {
|
|
62
|
+
return scope.localStateDefinitions !== localStateDefinitions && (scope.localStateDefinitions = localStateDefinitions,
|
|
63
|
+
rebuildSharedStateScope(scope), !0);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
function setRootSharedStateScopeThemeDefinitions(scope, themeStateDefinitions) {
|
|
67
|
+
return scope.themeStateDefinitions !== themeStateDefinitions && (scope.themeStateDefinitions = themeStateDefinitions,
|
|
68
|
+
rebuildSharedStateScope(scope), !0);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
function rebuildSharedStateScope(scope) {
|
|
72
|
+
var _a;
|
|
73
|
+
const effectiveSourceDefinitions = buildEffectiveSourceDefinitions(scope.parentScope, scope.localStateDefinitions, scope.themeStateDefinitions);
|
|
74
|
+
return scope.effectiveSourceDefinitions = effectiveSourceDefinitions, scope.effectiveCompiledDefinitions = compiler.compile(effectiveSourceDefinitions),
|
|
75
|
+
scope.parentRevisionAtBuild = null === (_a = scope.parentScope) || void 0 === _a ? void 0 : _a.revision,
|
|
76
|
+
scope.revision += 1, scope.dirty = !1, scope;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
function ensureSharedStateScopeFresh(scope) {
|
|
80
|
+
var _a;
|
|
81
|
+
if (scope) return null === (_a = (0, state_perf_monitor_1.getStageStatePerfMonitor)(scope.ownerStage)) || void 0 === _a || _a.recordRefresh("ensureFreshCalls"),
|
|
82
|
+
scope.parentScope && ensureSharedStateScopeFresh(scope.parentScope), (scope.dirty || scope.parentScope && scope.parentRevisionAtBuild !== scope.parentScope.revision) && rebuildSharedStateScope(scope),
|
|
83
|
+
scope;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
function collectSharedStateScopeChain(scope) {
|
|
87
|
+
const chain = [];
|
|
88
|
+
let current = scope;
|
|
89
|
+
for (;current; ) chain.push(current), current = current.parentScope;
|
|
90
|
+
return chain;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
exports.createRootSharedStateScope = createRootSharedStateScope, exports.createGroupSharedStateScope = createGroupSharedStateScope,
|
|
94
|
+
exports.setSharedStateScopeParent = setSharedStateScopeParent, exports.setSharedStateScopeLocalDefinitions = setSharedStateScopeLocalDefinitions,
|
|
95
|
+
exports.setRootSharedStateScopeThemeDefinitions = setRootSharedStateScopeThemeDefinitions,
|
|
96
|
+
exports.rebuildSharedStateScope = rebuildSharedStateScope, exports.ensureSharedStateScopeFresh = ensureSharedStateScopeFresh,
|
|
97
|
+
exports.collectSharedStateScopeChain = collectSharedStateScopeChain;
|
|
98
|
+
//# sourceMappingURL=shared-state-scope.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/graphic/state/shared-state-scope.ts"],"names":[],"mappings":"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","file":"shared-state-scope.js","sourcesContent":["import type { IGraphic, IStage } from '../../interface';\nimport type { IGroup } from '../../interface/graphic/group';\nimport { StateDefinitionCompiler } from './state-definition-compiler';\nimport type { CompiledStateDefinition, StateDefinitionsInput } from './state-definition';\nimport { getStageStatePerfMonitor } from './state-perf-monitor';\n\nexport interface SharedStateScope<T extends Record<string, any> = Record<string, any>> {\n ownerKind: 'group' | 'root';\n ownerGroup?: IGroup;\n ownerStage?: IStage;\n parentScope?: SharedStateScope<T>;\n themeStateDefinitions?: StateDefinitionsInput<T>;\n localStateDefinitions?: StateDefinitionsInput<T>;\n effectiveSourceDefinitions: StateDefinitionsInput<T>;\n effectiveCompiledDefinitions: Map<string, CompiledStateDefinition<T>>;\n revision: number;\n parentRevisionAtBuild?: number;\n dirty: boolean;\n subtreeActiveDescendants: Set<IGraphic>;\n}\n\nconst compiler = new StateDefinitionCompiler<any>();\n\nfunction copyDefinitions<T extends Record<string, any>>(\n definitions?: StateDefinitionsInput<T>\n): StateDefinitionsInput<T> {\n return definitions ? ({ ...definitions } as StateDefinitionsInput<T>) : ({} as StateDefinitionsInput<T>);\n}\n\nfunction buildEffectiveSourceDefinitions<T extends Record<string, any>>(\n parentScope?: SharedStateScope<T>,\n localStateDefinitions?: StateDefinitionsInput<T>,\n themeStateDefinitions?: StateDefinitionsInput<T>\n): StateDefinitionsInput<T> {\n const merged = parentScope\n ? copyDefinitions(parentScope.effectiveSourceDefinitions)\n : copyDefinitions(themeStateDefinitions);\n\n if (localStateDefinitions) {\n Object.keys(localStateDefinitions).forEach(stateName => {\n merged[stateName] = localStateDefinitions[stateName];\n });\n }\n\n return merged;\n}\n\nfunction initializeScope<T extends Record<string, any>>(\n scope: SharedStateScope<T>,\n revision: number = 0\n): SharedStateScope<T> {\n const effectiveSourceDefinitions = buildEffectiveSourceDefinitions(\n scope.parentScope,\n scope.localStateDefinitions,\n scope.themeStateDefinitions\n );\n\n scope.effectiveSourceDefinitions = effectiveSourceDefinitions;\n scope.effectiveCompiledDefinitions = compiler.compile(effectiveSourceDefinitions);\n scope.parentRevisionAtBuild = scope.parentScope?.revision;\n scope.revision = revision;\n scope.dirty = false;\n\n return scope;\n}\n\nexport function createRootSharedStateScope<T extends Record<string, any> = Record<string, any>>(\n stage: IStage,\n themeStateDefinitions?: StateDefinitionsInput<T>\n): SharedStateScope<T> {\n return initializeScope(\n {\n ownerKind: 'root',\n ownerStage: stage,\n themeStateDefinitions,\n effectiveSourceDefinitions: {} as StateDefinitionsInput<T>,\n effectiveCompiledDefinitions: new Map(),\n revision: 0,\n dirty: false,\n subtreeActiveDescendants: new Set()\n },\n 0\n );\n}\n\nexport function createGroupSharedStateScope<T extends Record<string, any> = Record<string, any>>(\n group: IGroup,\n parentScope?: SharedStateScope<T>,\n localStateDefinitions?: StateDefinitionsInput<T>\n): SharedStateScope<T> {\n return initializeScope(\n {\n ownerKind: 'group',\n ownerGroup: group,\n ownerStage: group.stage,\n parentScope,\n localStateDefinitions,\n effectiveSourceDefinitions: {} as StateDefinitionsInput<T>,\n effectiveCompiledDefinitions: new Map(),\n revision: 0,\n dirty: false,\n subtreeActiveDescendants: new Set()\n },\n 0\n );\n}\n\nexport function setSharedStateScopeParent<T extends Record<string, any> = Record<string, any>>(\n scope: SharedStateScope<T>,\n parentScope?: SharedStateScope<T>\n): boolean {\n if (scope.parentScope === parentScope) {\n return false;\n }\n\n scope.parentScope = parentScope;\n scope.dirty = true;\n return true;\n}\n\nexport function setSharedStateScopeLocalDefinitions<T extends Record<string, any> = Record<string, any>>(\n scope: SharedStateScope<T>,\n localStateDefinitions?: StateDefinitionsInput<T>\n): boolean {\n if (scope.localStateDefinitions === localStateDefinitions) {\n return false;\n }\n\n scope.localStateDefinitions = localStateDefinitions;\n rebuildSharedStateScope(scope);\n return true;\n}\n\nexport function setRootSharedStateScopeThemeDefinitions<T extends Record<string, any> = Record<string, any>>(\n scope: SharedStateScope<T>,\n themeStateDefinitions?: StateDefinitionsInput<T>\n): boolean {\n if (scope.themeStateDefinitions === themeStateDefinitions) {\n return false;\n }\n\n scope.themeStateDefinitions = themeStateDefinitions;\n rebuildSharedStateScope(scope);\n return true;\n}\n\nexport function rebuildSharedStateScope<T extends Record<string, any> = Record<string, any>>(\n scope: SharedStateScope<T>\n): SharedStateScope<T> {\n const effectiveSourceDefinitions = buildEffectiveSourceDefinitions(\n scope.parentScope,\n scope.localStateDefinitions,\n scope.themeStateDefinitions\n );\n\n scope.effectiveSourceDefinitions = effectiveSourceDefinitions;\n scope.effectiveCompiledDefinitions = compiler.compile(effectiveSourceDefinitions);\n scope.parentRevisionAtBuild = scope.parentScope?.revision;\n scope.revision += 1;\n scope.dirty = false;\n\n return scope;\n}\n\nexport function ensureSharedStateScopeFresh<T extends Record<string, any> = Record<string, any>>(\n scope?: SharedStateScope<T>\n): SharedStateScope<T> | undefined {\n if (!scope) {\n return undefined;\n }\n\n getStageStatePerfMonitor(scope.ownerStage)?.recordRefresh('ensureFreshCalls');\n\n if (scope.parentScope) {\n ensureSharedStateScopeFresh(scope.parentScope);\n }\n\n if (scope.dirty || (scope.parentScope && scope.parentRevisionAtBuild !== scope.parentScope.revision)) {\n rebuildSharedStateScope(scope);\n }\n\n return scope;\n}\n\nexport function collectSharedStateScopeChain<T extends Record<string, any> = Record<string, any>>(\n scope?: SharedStateScope<T>\n): SharedStateScope<T>[] {\n const chain: SharedStateScope<T>[] = [];\n let current = scope;\n\n while (current) {\n chain.push(current);\n current = current.parentScope;\n }\n\n return chain;\n}\n"]}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import type { IGraphic, IGroup, ILayer, IStage } from '../../interface';
|
|
2
|
+
import { type IDeferredStateConfig, type StatePerfMonitor } from './state-perf-monitor';
|
|
3
|
+
type StateBatchJobKind = 'apply_states';
|
|
4
|
+
type StateBatchIntentKey = string;
|
|
5
|
+
export interface IStateBatchJob {
|
|
6
|
+
id: number;
|
|
7
|
+
kind: StateBatchJobKind;
|
|
8
|
+
intentKey: StateBatchIntentKey;
|
|
9
|
+
status: 'pending' | 'running' | 'completed' | 'cancelled';
|
|
10
|
+
targetStates: string[];
|
|
11
|
+
targetStatesKey: string;
|
|
12
|
+
pendingGraphics: Set<IGraphic>;
|
|
13
|
+
orderedGraphics: IGraphic[];
|
|
14
|
+
config: Required<IDeferredStateConfig>;
|
|
15
|
+
contextOwner: IStage | ILayer | IGroup;
|
|
16
|
+
contextOwnerId: number;
|
|
17
|
+
configFingerprint: string;
|
|
18
|
+
createdAt: number;
|
|
19
|
+
processedCount: number;
|
|
20
|
+
}
|
|
21
|
+
export declare class StateBatchScheduler {
|
|
22
|
+
private readonly stage;
|
|
23
|
+
private readonly perfMonitor?;
|
|
24
|
+
readonly jobsByIntentKey: Map<string, IStateBatchJob>;
|
|
25
|
+
readonly pendingIntentByGraphic: Map<IGraphic<Partial<import("../../interface").IGraphicAttribute>>, string>;
|
|
26
|
+
private nextJobId;
|
|
27
|
+
private readonly runningJobs;
|
|
28
|
+
constructor(stage: IStage, perfMonitor?: StatePerfMonitor);
|
|
29
|
+
schedule(graphics: IGraphic[], targetStates: string[]): void;
|
|
30
|
+
release(): void;
|
|
31
|
+
private resolveEligibility;
|
|
32
|
+
private resolveDeferredContext;
|
|
33
|
+
private classifyGraphicTargetStates;
|
|
34
|
+
private enqueueDeferredIntent;
|
|
35
|
+
private removeGraphicFromPending;
|
|
36
|
+
private removeGraphicFromIntentJob;
|
|
37
|
+
private ensureJobRunning;
|
|
38
|
+
private runJob;
|
|
39
|
+
private waitForNextFrame;
|
|
40
|
+
private commitSynchronously;
|
|
41
|
+
}
|
|
42
|
+
export {};
|
|
@@ -0,0 +1,285 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var __awaiter = this && this.__awaiter || function(thisArg, _arguments, P, generator) {
|
|
4
|
+
return new (P || (P = Promise))((function(resolve, reject) {
|
|
5
|
+
function fulfilled(value) {
|
|
6
|
+
try {
|
|
7
|
+
step(generator.next(value));
|
|
8
|
+
} catch (e) {
|
|
9
|
+
reject(e);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
function rejected(value) {
|
|
13
|
+
try {
|
|
14
|
+
step(generator.throw(value));
|
|
15
|
+
} catch (e) {
|
|
16
|
+
reject(e);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
function step(result) {
|
|
20
|
+
var value;
|
|
21
|
+
result.done ? resolve(result.value) : (value = result.value, value instanceof P ? value : new P((function(resolve) {
|
|
22
|
+
resolve(value);
|
|
23
|
+
}))).then(fulfilled, rejected);
|
|
24
|
+
}
|
|
25
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
26
|
+
}));
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
Object.defineProperty(exports, "__esModule", {
|
|
30
|
+
value: !0
|
|
31
|
+
}), exports.StateBatchScheduler = void 0;
|
|
32
|
+
|
|
33
|
+
const attribute_update_classifier_1 = require("./attribute-update-classifier"), state_perf_monitor_1 = require("./state-perf-monitor");
|
|
34
|
+
|
|
35
|
+
function isRenderableGraphic(graphic) {
|
|
36
|
+
return !!graphic.stage && "released" !== graphic.releaseStatus;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
function createTargetStatesKey(targetStates) {
|
|
40
|
+
return targetStates.length ? targetStates.join("|") : "__clear__";
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function createIntentKey(contextOwnerId, configFingerprint, targetStatesKey) {
|
|
44
|
+
return `${contextOwnerId}:${configFingerprint}:${targetStatesKey}`;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function hasMeaningfulDeferredConfig(config) {
|
|
48
|
+
const normalized = (0, state_perf_monitor_1.normalizeDeferredStateOwnerConfig)(config);
|
|
49
|
+
return !!normalized && (null != normalized.localEnabled || null != normalized.deferred);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
function getGraphicCompiledDefinitions(graphic) {
|
|
53
|
+
const graphicAny = graphic;
|
|
54
|
+
if ("function" == typeof graphicAny.resolveEffectiveCompiledDefinitions) {
|
|
55
|
+
const result = graphicAny.resolveEffectiveCompiledDefinitions();
|
|
56
|
+
return {
|
|
57
|
+
compiledDefinitions: result.compiledDefinitions,
|
|
58
|
+
stateProxyEligibility: result.stateProxyEligibility
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
return {};
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
function getCurrentStateNames(graphic) {
|
|
65
|
+
var _a, _b;
|
|
66
|
+
return null !== (_b = null === (_a = graphic.currentStates) || void 0 === _a ? void 0 : _a.slice()) && void 0 !== _b ? _b : [];
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
class StateBatchScheduler {
|
|
70
|
+
constructor(stage, perfMonitor) {
|
|
71
|
+
this.stage = stage, this.perfMonitor = perfMonitor, this.jobsByIntentKey = new Map,
|
|
72
|
+
this.pendingIntentByGraphic = new Map, this.nextJobId = 1, this.runningJobs = new Map;
|
|
73
|
+
}
|
|
74
|
+
schedule(graphics, targetStates) {
|
|
75
|
+
const batchOperation = graphics.length > 1;
|
|
76
|
+
graphics.forEach((graphic => {
|
|
77
|
+
const eligibility = this.resolveEligibility(graphic, targetStates, batchOperation, !0);
|
|
78
|
+
if ("reason" in eligibility) return this.removeGraphicFromPending(graphic), void ("graphic_unavailable" !== eligibility.reason && this.commitSynchronously(graphic, targetStates));
|
|
79
|
+
this.enqueueDeferredIntent(graphic, targetStates, eligibility.context, eligibility.targetStatesKey);
|
|
80
|
+
}));
|
|
81
|
+
}
|
|
82
|
+
release() {
|
|
83
|
+
var _a;
|
|
84
|
+
this.jobsByIntentKey.forEach((job => {
|
|
85
|
+
job.status = "cancelled";
|
|
86
|
+
})), this.jobsByIntentKey.clear(), this.pendingIntentByGraphic.clear(), this.runningJobs.clear(),
|
|
87
|
+
null === (_a = this.perfMonitor) || void 0 === _a || _a.updateBatchPending(0);
|
|
88
|
+
}
|
|
89
|
+
resolveEligibility(graphic, targetStates, batchOperation, recordObservability) {
|
|
90
|
+
var _a, _b, _c, _d, _e, _f;
|
|
91
|
+
if (!isRenderableGraphic(graphic)) return recordObservability && (null === (_a = this.perfMonitor) || void 0 === _a || _a.recordDeferredIneligible("graphic_unavailable")),
|
|
92
|
+
{
|
|
93
|
+
eligible: !1,
|
|
94
|
+
reason: "graphic_unavailable"
|
|
95
|
+
};
|
|
96
|
+
if (!batchOperation) return recordObservability && (null === (_b = this.perfMonitor) || void 0 === _b || _b.recordDeferredIneligible("non_batch_operation")),
|
|
97
|
+
{
|
|
98
|
+
eligible: !1,
|
|
99
|
+
reason: "non_batch_operation"
|
|
100
|
+
};
|
|
101
|
+
const context = this.resolveDeferredContext(graphic);
|
|
102
|
+
if (!context) return recordObservability && (null === (_c = this.perfMonitor) || void 0 === _c || _c.recordDeferredIneligible("graphic_unavailable")),
|
|
103
|
+
{
|
|
104
|
+
eligible: !1,
|
|
105
|
+
reason: "graphic_unavailable"
|
|
106
|
+
};
|
|
107
|
+
if (!context.config.enabled) {
|
|
108
|
+
const normalizedOwnerConfig = (0, state_perf_monitor_1.normalizeDeferredStateOwnerConfig)(context.contextOwner.deferredStateConfig), reason = !1 === (null == normalizedOwnerConfig ? void 0 : normalizedOwnerConfig.localEnabled) ? "context_disabled" : "config_disabled";
|
|
109
|
+
return recordObservability && (null === (_d = this.perfMonitor) || void 0 === _d || _d.recordDeferredIneligible(reason)),
|
|
110
|
+
{
|
|
111
|
+
eligible: !1,
|
|
112
|
+
reason: reason
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
const classification = this.classifyGraphicTargetStates(graphic, targetStates);
|
|
116
|
+
return classification.reason ? (recordObservability && (null === (_e = this.perfMonitor) || void 0 === _e || _e.recordDeferredIneligible(classification.reason)),
|
|
117
|
+
{
|
|
118
|
+
eligible: !1,
|
|
119
|
+
reason: classification.reason
|
|
120
|
+
}) : classification.category !== attribute_update_classifier_1.UpdateCategory.PAINT ? (recordObservability && (null === (_f = this.perfMonitor) || void 0 === _f || _f.recordDeferredIneligible("mixed_update_category")),
|
|
121
|
+
{
|
|
122
|
+
eligible: !1,
|
|
123
|
+
reason: "mixed_update_category"
|
|
124
|
+
}) : {
|
|
125
|
+
eligible: !0,
|
|
126
|
+
context: context,
|
|
127
|
+
targetStatesKey: createTargetStatesKey(targetStates)
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
resolveDeferredContext(graphic) {
|
|
131
|
+
var _a;
|
|
132
|
+
const stage = graphic.stage;
|
|
133
|
+
if (!stage) return;
|
|
134
|
+
let owner = stage, config = (0, state_perf_monitor_1.normalizeDeferredStateConfig)(void 0);
|
|
135
|
+
const ownerConfigs = [ stage ], parents = [];
|
|
136
|
+
let parent = graphic.parent;
|
|
137
|
+
for (;parent && parent !== stage; ) parents.push(parent), parent = parent.parent;
|
|
138
|
+
parents.reverse().forEach((current => ownerConfigs.push(current))), ownerConfigs.forEach((current => {
|
|
139
|
+
const deferredStateConfig = (0, state_perf_monitor_1.normalizeDeferredStateOwnerConfig)(current.deferredStateConfig);
|
|
140
|
+
deferredStateConfig && (deferredStateConfig.deferred && (config = Object.assign(Object.assign({}, config), deferredStateConfig.deferred)),
|
|
141
|
+
null != deferredStateConfig.localEnabled && (config.enabled = deferredStateConfig.localEnabled),
|
|
142
|
+
hasMeaningfulDeferredConfig(current.deferredStateConfig) && (owner = current));
|
|
143
|
+
}));
|
|
144
|
+
const normalized = (0, state_perf_monitor_1.normalizeDeferredStateConfig)(config);
|
|
145
|
+
return {
|
|
146
|
+
contextOwner: owner,
|
|
147
|
+
contextOwnerId: null !== (_a = owner._uid) && void 0 !== _a ? _a : 0,
|
|
148
|
+
config: normalized,
|
|
149
|
+
configFingerprint: (0, state_perf_monitor_1.fingerprintDeferredStateConfig)(normalized)
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
classifyGraphicTargetStates(graphic, targetStates) {
|
|
153
|
+
const {compiledDefinitions: compiledDefinitions, stateProxyEligibility: stateProxyEligibility} = getGraphicCompiledDefinitions(graphic), candidateStates = Array.from(new Set([ ...getCurrentStateNames(graphic), ...targetStates ]));
|
|
154
|
+
let category = attribute_update_classifier_1.UpdateCategory.NONE;
|
|
155
|
+
return candidateStates.forEach((stateName => {
|
|
156
|
+
if (null == stateProxyEligibility ? void 0 : stateProxyEligibility(stateName)) return void (category = attribute_update_classifier_1.UpdateCategory.NONE);
|
|
157
|
+
const definition = null == compiledDefinitions ? void 0 : compiledDefinitions.get(stateName);
|
|
158
|
+
definition && (definition.hasResolver && 0 === definition.affectedKeys.size ? category = attribute_update_classifier_1.UpdateCategory.NONE : category |= (0,
|
|
159
|
+
attribute_update_classifier_1.classifyAffectedKeys)(definition.affectedKeys));
|
|
160
|
+
})), candidateStates.some((stateName => null == stateProxyEligibility ? void 0 : stateProxyEligibility(stateName))) || candidateStates.some((stateName => {
|
|
161
|
+
const definition = null == compiledDefinitions ? void 0 : compiledDefinitions.get(stateName);
|
|
162
|
+
return !!(null == definition ? void 0 : definition.hasResolver) && 0 === definition.affectedKeys.size;
|
|
163
|
+
})) ? {
|
|
164
|
+
category: attribute_update_classifier_1.UpdateCategory.NONE,
|
|
165
|
+
reason: "resolver_unstable_keys"
|
|
166
|
+
} : {
|
|
167
|
+
category: category === attribute_update_classifier_1.UpdateCategory.NONE ? attribute_update_classifier_1.UpdateCategory.PAINT : category
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
enqueueDeferredIntent(graphic, targetStates, context, targetStatesKey) {
|
|
171
|
+
var _a, _b, _c, _d, _e, _f;
|
|
172
|
+
const nextIntentKey = createIntentKey(context.contextOwnerId, context.configFingerprint, targetStatesKey), prevIntentKey = this.pendingIntentByGraphic.get(graphic);
|
|
173
|
+
if (prevIntentKey === nextIntentKey) return void (null === (_a = this.perfMonitor) || void 0 === _a || _a.incrementCounter("deferredJobsCoalesced"));
|
|
174
|
+
prevIntentKey && this.removeGraphicFromIntentJob(graphic, prevIntentKey);
|
|
175
|
+
let job = this.jobsByIntentKey.get(nextIntentKey);
|
|
176
|
+
job ? null === (_d = this.perfMonitor) || void 0 === _d || _d.incrementCounter("deferredJobsCoalesced") : (job = {
|
|
177
|
+
id: this.nextJobId++,
|
|
178
|
+
kind: "apply_states",
|
|
179
|
+
intentKey: nextIntentKey,
|
|
180
|
+
status: "pending",
|
|
181
|
+
targetStates: [ ...targetStates ],
|
|
182
|
+
targetStatesKey: targetStatesKey,
|
|
183
|
+
pendingGraphics: new Set,
|
|
184
|
+
orderedGraphics: [],
|
|
185
|
+
config: context.config,
|
|
186
|
+
contextOwner: context.contextOwner,
|
|
187
|
+
contextOwnerId: context.contextOwnerId,
|
|
188
|
+
configFingerprint: context.configFingerprint,
|
|
189
|
+
createdAt: Date.now(),
|
|
190
|
+
processedCount: 0
|
|
191
|
+
}, this.jobsByIntentKey.set(nextIntentKey, job), null === (_b = this.perfMonitor) || void 0 === _b || _b.incrementCounter("deferredJobsCreated"),
|
|
192
|
+
null === (_c = this.perfMonitor) || void 0 === _c || _c.updateBatchPending(this.jobsByIntentKey.size)),
|
|
193
|
+
job.pendingGraphics.has(graphic) || (job.pendingGraphics.add(graphic), job.orderedGraphics.push(graphic),
|
|
194
|
+
this.pendingIntentByGraphic.set(graphic, nextIntentKey), null === (_e = this.perfMonitor) || void 0 === _e || _e.recordAllocation("batchEntriesCreated"),
|
|
195
|
+
null === (_f = this.perfMonitor) || void 0 === _f || _f.updateMaxGraphicsInJob(job.pendingGraphics.size)),
|
|
196
|
+
this.ensureJobRunning(job);
|
|
197
|
+
}
|
|
198
|
+
removeGraphicFromPending(graphic) {
|
|
199
|
+
const prevIntentKey = this.pendingIntentByGraphic.get(graphic);
|
|
200
|
+
prevIntentKey && this.removeGraphicFromIntentJob(graphic, prevIntentKey);
|
|
201
|
+
}
|
|
202
|
+
removeGraphicFromIntentJob(graphic, intentKey) {
|
|
203
|
+
var _a, _b, _c;
|
|
204
|
+
const job = this.jobsByIntentKey.get(intentKey);
|
|
205
|
+
job ? (job.pendingGraphics.delete(graphic), this.pendingIntentByGraphic.get(graphic) === intentKey && this.pendingIntentByGraphic.delete(graphic),
|
|
206
|
+
0 === job.pendingGraphics.size && "completed" !== job.status && (job.status = "cancelled",
|
|
207
|
+
this.jobsByIntentKey.delete(intentKey), null === (_a = this.perfMonitor) || void 0 === _a || _a.incrementCounter("deferredJobsCancelled"),
|
|
208
|
+
null === (_b = this.perfMonitor) || void 0 === _b || _b.recordEvent("deferred-job-cancel", {
|
|
209
|
+
intentKey: intentKey,
|
|
210
|
+
jobId: job.id
|
|
211
|
+
}), null === (_c = this.perfMonitor) || void 0 === _c || _c.updateBatchPending(this.jobsByIntentKey.size))) : this.pendingIntentByGraphic.delete(graphic);
|
|
212
|
+
}
|
|
213
|
+
ensureJobRunning(job) {
|
|
214
|
+
if (this.runningJobs.has(job.intentKey)) return;
|
|
215
|
+
const runner = this.runJob(job).then((() => {
|
|
216
|
+
this.runningJobs.delete(job.intentKey);
|
|
217
|
+
}), (() => {
|
|
218
|
+
this.runningJobs.delete(job.intentKey);
|
|
219
|
+
}));
|
|
220
|
+
this.runningJobs.set(job.intentKey, runner);
|
|
221
|
+
}
|
|
222
|
+
runJob(job) {
|
|
223
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
|
224
|
+
return __awaiter(this, void 0, void 0, (function*() {
|
|
225
|
+
if ("cancelled" === job.status) return;
|
|
226
|
+
if (yield this.waitForNextFrame(), "cancelled" === job.status) return;
|
|
227
|
+
job.status = "running", null === (_a = this.perfMonitor) || void 0 === _a || _a.recordEvent("deferred-job-start", {
|
|
228
|
+
intentKey: job.intentKey,
|
|
229
|
+
jobId: job.id
|
|
230
|
+
});
|
|
231
|
+
let index = 0, frameStart = performance.now(), processedInFrame = 0, committedInSlice = 0;
|
|
232
|
+
for (;index < job.orderedGraphics.length; ) {
|
|
233
|
+
if ("cancelled" === job.status) return;
|
|
234
|
+
processedInFrame > 0 && (processedInFrame >= job.config.maxGraphicsPerFrame || performance.now() - frameStart >= job.config.frameBudget) && (null === (_b = this.perfMonitor) || void 0 === _b || _b.incrementCounter("deferredBudgetYields"),
|
|
235
|
+
null === (_c = this.perfMonitor) || void 0 === _c || _c.recordCost("batchSlice", performance.now() - frameStart),
|
|
236
|
+
null === (_d = this.perfMonitor) || void 0 === _d || _d.recordEvent("deferred-job-yield", {
|
|
237
|
+
intentKey: job.intentKey,
|
|
238
|
+
jobId: job.id,
|
|
239
|
+
processedInFrame: processedInFrame
|
|
240
|
+
}), committedInSlice > 0 && this.stage.renderNextFrame(), yield this.waitForNextFrame(),
|
|
241
|
+
frameStart = performance.now(), processedInFrame = 0, committedInSlice = 0);
|
|
242
|
+
const graphic = job.orderedGraphics[index++];
|
|
243
|
+
if (!job.pendingGraphics.has(graphic)) continue;
|
|
244
|
+
if (!isRenderableGraphic(graphic)) {
|
|
245
|
+
job.pendingGraphics.delete(graphic), this.pendingIntentByGraphic.get(graphic) === job.intentKey && this.pendingIntentByGraphic.delete(graphic);
|
|
246
|
+
continue;
|
|
247
|
+
}
|
|
248
|
+
if (this.pendingIntentByGraphic.get(graphic) !== job.intentKey) {
|
|
249
|
+
job.pendingGraphics.delete(graphic);
|
|
250
|
+
continue;
|
|
251
|
+
}
|
|
252
|
+
const nextEligibility = this.resolveEligibility(graphic, job.targetStates, !0, !1);
|
|
253
|
+
if (!nextEligibility.eligible) {
|
|
254
|
+
job.pendingGraphics.delete(graphic), this.pendingIntentByGraphic.delete(graphic),
|
|
255
|
+
this.commitSynchronously(graphic, job.targetStates);
|
|
256
|
+
continue;
|
|
257
|
+
}
|
|
258
|
+
createIntentKey(nextEligibility.context.contextOwnerId, nextEligibility.context.configFingerprint, nextEligibility.targetStatesKey) === job.intentKey ? (this.commitSynchronously(graphic, job.targetStates),
|
|
259
|
+
job.pendingGraphics.delete(graphic), this.pendingIntentByGraphic.delete(graphic),
|
|
260
|
+
job.processedCount += 1, processedInFrame += 1, committedInSlice += 1, null === (_e = this.perfMonitor) || void 0 === _e || _e.incrementCounter("deferredGraphicsCommitted")) : (job.pendingGraphics.delete(graphic),
|
|
261
|
+
this.pendingIntentByGraphic.delete(graphic), this.enqueueDeferredIntent(graphic, job.targetStates, nextEligibility.context, nextEligibility.targetStatesKey));
|
|
262
|
+
}
|
|
263
|
+
processedInFrame > 0 && (null === (_f = this.perfMonitor) || void 0 === _f || _f.recordCost("batchSlice", performance.now() - frameStart),
|
|
264
|
+
this.stage.renderNextFrame()), 0 === job.pendingGraphics.size && this.jobsByIntentKey.get(job.intentKey) === job && (job.status = "completed",
|
|
265
|
+
this.jobsByIntentKey.delete(job.intentKey), null === (_g = this.perfMonitor) || void 0 === _g || _g.incrementCounter("deferredJobsCompleted"),
|
|
266
|
+
null === (_h = this.perfMonitor) || void 0 === _h || _h.recordEvent("deferred-job-complete", {
|
|
267
|
+
intentKey: job.intentKey,
|
|
268
|
+
jobId: job.id,
|
|
269
|
+
processedCount: job.processedCount
|
|
270
|
+
}), null === (_j = this.perfMonitor) || void 0 === _j || _j.updateBatchPending(this.jobsByIntentKey.size));
|
|
271
|
+
}));
|
|
272
|
+
}
|
|
273
|
+
waitForNextFrame() {
|
|
274
|
+
const stageGlobal = this.stage.global;
|
|
275
|
+
return (null == stageGlobal ? void 0 : stageGlobal.getSpecifiedPerformanceRAF) ? stageGlobal.getSpecifiedPerformanceRAF(this.stage.rafId).wait() : new Promise((resolve => {
|
|
276
|
+
null == stageGlobal || stageGlobal.getSpecifiedRequestAnimationFrame(this.stage.rafId)((() => resolve()));
|
|
277
|
+
}));
|
|
278
|
+
}
|
|
279
|
+
commitSynchronously(graphic, targetStates) {
|
|
280
|
+
isRenderableGraphic(graphic) && (targetStates.length ? graphic.useStates(targetStates, !1) : graphic.clearStates(!1));
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
exports.StateBatchScheduler = StateBatchScheduler;
|
|
285
|
+
//# sourceMappingURL=state-batch-scheduler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/graphic/state/state-batch-scheduler.ts"],"names":[],"mappings":"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","file":"state-batch-scheduler.js","sourcesContent":["import type { IGraphic, IGroup, ILayer, IStage } from '../../interface';\nimport type { CompiledStateDefinition } from './state-definition';\nimport { UpdateCategory, classifyAffectedKeys } from './attribute-update-classifier';\nimport {\n type DeferredIneligibleReason,\n type IDeferredStateConfig,\n type IDeferredStateOwnerConfig,\n type IResolvedDeferredContext,\n type StatePerfMonitor,\n fingerprintDeferredStateConfig,\n normalizeDeferredStateConfig,\n normalizeDeferredStateOwnerConfig\n} from './state-perf-monitor';\n\ntype StateBatchJobKind = 'apply_states';\ntype StateBatchIntentKey = string;\n\nexport interface IStateBatchJob {\n id: number;\n kind: StateBatchJobKind;\n intentKey: StateBatchIntentKey;\n status: 'pending' | 'running' | 'completed' | 'cancelled';\n targetStates: string[];\n targetStatesKey: string;\n pendingGraphics: Set<IGraphic>;\n orderedGraphics: IGraphic[];\n config: Required<IDeferredStateConfig>;\n contextOwner: IStage | ILayer | IGroup;\n contextOwnerId: number;\n configFingerprint: string;\n createdAt: number;\n processedCount: number;\n}\n\ntype DeferredEligibilityResult =\n | {\n eligible: true;\n context: IResolvedDeferredContext;\n targetStatesKey: string;\n }\n | {\n eligible: false;\n reason: DeferredIneligibleReason;\n };\n\nfunction isRenderableGraphic(graphic: IGraphic): boolean {\n return !!graphic.stage && (graphic as any).releaseStatus !== 'released';\n}\n\nfunction createTargetStatesKey(targetStates: string[]): string {\n return targetStates.length ? targetStates.join('|') : '__clear__';\n}\n\nfunction createIntentKey(\n contextOwnerId: number,\n configFingerprint: string,\n targetStatesKey: string\n): StateBatchIntentKey {\n return `${contextOwnerId}:${configFingerprint}:${targetStatesKey}`;\n}\n\nfunction hasMeaningfulDeferredConfig(config?: IDeferredStateOwnerConfig): boolean {\n const normalized = normalizeDeferredStateOwnerConfig(config);\n return !!normalized && (normalized.localEnabled != null || normalized.deferred != null);\n}\n\nfunction getGraphicCompiledDefinitions(graphic: IGraphic): {\n compiledDefinitions?: Map<string, CompiledStateDefinition<any>>;\n stateProxyEligibility?: (stateName: string) => boolean;\n} {\n const graphicAny = graphic as any;\n if (typeof graphicAny.resolveEffectiveCompiledDefinitions === 'function') {\n const result = graphicAny.resolveEffectiveCompiledDefinitions();\n return {\n compiledDefinitions: result.compiledDefinitions,\n stateProxyEligibility: result.stateProxyEligibility\n };\n }\n\n return {};\n}\n\nfunction getCurrentStateNames(graphic: IGraphic): string[] {\n return ((graphic as any).currentStates as string[] | undefined)?.slice() ?? [];\n}\n\nexport class StateBatchScheduler {\n readonly jobsByIntentKey = new Map<StateBatchIntentKey, IStateBatchJob>();\n readonly pendingIntentByGraphic = new Map<IGraphic, StateBatchIntentKey>();\n\n private nextJobId = 1;\n private readonly runningJobs = new Map<StateBatchIntentKey, Promise<void>>();\n\n constructor(private readonly stage: IStage, private readonly perfMonitor?: StatePerfMonitor) {}\n\n schedule(graphics: IGraphic[], targetStates: string[]): void {\n const batchOperation = graphics.length > 1;\n\n graphics.forEach(graphic => {\n const eligibility = this.resolveEligibility(graphic, targetStates, batchOperation, true);\n if ('reason' in eligibility) {\n this.removeGraphicFromPending(graphic);\n if (eligibility.reason !== 'graphic_unavailable') {\n this.commitSynchronously(graphic, targetStates);\n }\n return;\n }\n\n this.enqueueDeferredIntent(graphic, targetStates, eligibility.context, eligibility.targetStatesKey);\n });\n }\n\n release(): void {\n this.jobsByIntentKey.forEach(job => {\n job.status = 'cancelled';\n });\n this.jobsByIntentKey.clear();\n this.pendingIntentByGraphic.clear();\n this.runningJobs.clear();\n this.perfMonitor?.updateBatchPending(0);\n }\n\n private resolveEligibility(\n graphic: IGraphic,\n targetStates: string[],\n batchOperation: boolean,\n recordObservability: boolean\n ): DeferredEligibilityResult {\n if (!isRenderableGraphic(graphic)) {\n if (recordObservability) {\n this.perfMonitor?.recordDeferredIneligible('graphic_unavailable');\n }\n return { eligible: false, reason: 'graphic_unavailable' };\n }\n\n if (!batchOperation) {\n if (recordObservability) {\n this.perfMonitor?.recordDeferredIneligible('non_batch_operation');\n }\n return { eligible: false, reason: 'non_batch_operation' };\n }\n\n const context = this.resolveDeferredContext(graphic);\n if (!context) {\n if (recordObservability) {\n this.perfMonitor?.recordDeferredIneligible('graphic_unavailable');\n }\n return { eligible: false, reason: 'graphic_unavailable' };\n }\n\n if (!context.config.enabled) {\n const normalizedOwnerConfig = normalizeDeferredStateOwnerConfig(\n (context.contextOwner as any).deferredStateConfig as IDeferredStateOwnerConfig | undefined\n );\n const reason = normalizedOwnerConfig?.localEnabled === false ? 'context_disabled' : 'config_disabled';\n if (recordObservability) {\n this.perfMonitor?.recordDeferredIneligible(reason);\n }\n return { eligible: false, reason };\n }\n\n const classification = this.classifyGraphicTargetStates(graphic, targetStates);\n if (classification.reason) {\n if (recordObservability) {\n this.perfMonitor?.recordDeferredIneligible(classification.reason);\n }\n return { eligible: false, reason: classification.reason };\n }\n\n if (classification.category !== UpdateCategory.PAINT) {\n if (recordObservability) {\n this.perfMonitor?.recordDeferredIneligible('mixed_update_category');\n }\n return { eligible: false, reason: 'mixed_update_category' };\n }\n\n return {\n eligible: true,\n context,\n targetStatesKey: createTargetStatesKey(targetStates)\n };\n }\n\n private resolveDeferredContext(graphic: IGraphic): IResolvedDeferredContext | undefined {\n const stage = graphic.stage;\n if (!stage) {\n return undefined;\n }\n\n let owner: IStage | ILayer | IGroup = stage;\n let config = normalizeDeferredStateConfig(undefined);\n\n const ownerConfigs: Array<IStage | ILayer | IGroup> = [stage];\n const parents: Array<IGroup | ILayer> = [];\n let parent = graphic.parent as any;\n\n while (parent && parent !== stage) {\n parents.push(parent);\n parent = parent.parent as any;\n }\n\n parents.reverse().forEach(current => ownerConfigs.push(current));\n\n ownerConfigs.forEach(current => {\n const deferredStateConfig = normalizeDeferredStateOwnerConfig(\n (current as any).deferredStateConfig as IDeferredStateOwnerConfig | undefined\n );\n if (!deferredStateConfig) {\n return;\n }\n\n if (deferredStateConfig.deferred) {\n config = {\n ...config,\n ...deferredStateConfig.deferred\n };\n }\n\n if (deferredStateConfig.localEnabled != null) {\n config.enabled = deferredStateConfig.localEnabled;\n }\n\n if (hasMeaningfulDeferredConfig((current as any).deferredStateConfig)) {\n owner = current;\n }\n });\n\n const normalized = normalizeDeferredStateConfig(config);\n return {\n contextOwner: owner,\n contextOwnerId: (owner as any)._uid ?? 0,\n config: normalized,\n configFingerprint: fingerprintDeferredStateConfig(normalized)\n };\n }\n\n private classifyGraphicTargetStates(\n graphic: IGraphic,\n targetStates: string[]\n ): { category: UpdateCategory; reason?: DeferredIneligibleReason } {\n const { compiledDefinitions, stateProxyEligibility } = getGraphicCompiledDefinitions(graphic);\n const candidateStates = Array.from(new Set([...getCurrentStateNames(graphic), ...targetStates]));\n let category = UpdateCategory.NONE;\n\n candidateStates.forEach(stateName => {\n if (stateProxyEligibility?.(stateName)) {\n category = UpdateCategory.NONE;\n return;\n }\n\n const definition = compiledDefinitions?.get(stateName);\n if (!definition) {\n return;\n }\n\n if (definition.hasResolver && definition.affectedKeys.size === 0) {\n category = UpdateCategory.NONE;\n return;\n }\n\n category |= classifyAffectedKeys(definition.affectedKeys);\n });\n\n if (\n candidateStates.some(stateName => stateProxyEligibility?.(stateName)) ||\n candidateStates.some(stateName => {\n const definition = compiledDefinitions?.get(stateName);\n return !!definition?.hasResolver && definition.affectedKeys.size === 0;\n })\n ) {\n return {\n category: UpdateCategory.NONE,\n reason: 'resolver_unstable_keys'\n };\n }\n\n return {\n category: category === UpdateCategory.NONE ? UpdateCategory.PAINT : category\n };\n }\n\n private enqueueDeferredIntent(\n graphic: IGraphic,\n targetStates: string[],\n context: IResolvedDeferredContext,\n targetStatesKey: string\n ): void {\n const nextIntentKey = createIntentKey(context.contextOwnerId, context.configFingerprint, targetStatesKey);\n const prevIntentKey = this.pendingIntentByGraphic.get(graphic);\n\n if (prevIntentKey === nextIntentKey) {\n this.perfMonitor?.incrementCounter('deferredJobsCoalesced');\n return;\n }\n\n if (prevIntentKey) {\n this.removeGraphicFromIntentJob(graphic, prevIntentKey);\n }\n\n let job = this.jobsByIntentKey.get(nextIntentKey);\n if (!job) {\n job = {\n id: this.nextJobId++,\n kind: 'apply_states',\n intentKey: nextIntentKey,\n status: 'pending',\n targetStates: [...targetStates],\n targetStatesKey,\n pendingGraphics: new Set(),\n orderedGraphics: [],\n config: context.config,\n contextOwner: context.contextOwner,\n contextOwnerId: context.contextOwnerId,\n configFingerprint: context.configFingerprint,\n createdAt: Date.now(),\n processedCount: 0\n };\n this.jobsByIntentKey.set(nextIntentKey, job);\n this.perfMonitor?.incrementCounter('deferredJobsCreated');\n this.perfMonitor?.updateBatchPending(this.jobsByIntentKey.size);\n } else {\n this.perfMonitor?.incrementCounter('deferredJobsCoalesced');\n }\n\n if (!job.pendingGraphics.has(graphic)) {\n job.pendingGraphics.add(graphic);\n job.orderedGraphics.push(graphic);\n this.pendingIntentByGraphic.set(graphic, nextIntentKey);\n this.perfMonitor?.recordAllocation('batchEntriesCreated');\n this.perfMonitor?.updateMaxGraphicsInJob(job.pendingGraphics.size);\n }\n\n this.ensureJobRunning(job);\n }\n\n private removeGraphicFromPending(graphic: IGraphic): void {\n const prevIntentKey = this.pendingIntentByGraphic.get(graphic);\n if (!prevIntentKey) {\n return;\n }\n this.removeGraphicFromIntentJob(graphic, prevIntentKey);\n }\n\n private removeGraphicFromIntentJob(graphic: IGraphic, intentKey: StateBatchIntentKey): void {\n const job = this.jobsByIntentKey.get(intentKey);\n if (!job) {\n this.pendingIntentByGraphic.delete(graphic);\n return;\n }\n\n job.pendingGraphics.delete(graphic);\n if (this.pendingIntentByGraphic.get(graphic) === intentKey) {\n this.pendingIntentByGraphic.delete(graphic);\n }\n\n if (job.pendingGraphics.size === 0 && job.status !== 'completed') {\n job.status = 'cancelled';\n this.jobsByIntentKey.delete(intentKey);\n this.perfMonitor?.incrementCounter('deferredJobsCancelled');\n this.perfMonitor?.recordEvent('deferred-job-cancel', {\n intentKey,\n jobId: job.id\n });\n this.perfMonitor?.updateBatchPending(this.jobsByIntentKey.size);\n }\n }\n\n private ensureJobRunning(job: IStateBatchJob): void {\n if (this.runningJobs.has(job.intentKey)) {\n return;\n }\n\n const runner = this.runJob(job).then(\n () => {\n this.runningJobs.delete(job.intentKey);\n },\n () => {\n this.runningJobs.delete(job.intentKey);\n }\n );\n\n this.runningJobs.set(job.intentKey, runner);\n }\n\n private async runJob(job: IStateBatchJob): Promise<void> {\n if ((job.status as string) === 'cancelled') {\n return;\n }\n\n await this.waitForNextFrame();\n if ((job.status as string) === 'cancelled') {\n return;\n }\n\n job.status = 'running';\n this.perfMonitor?.recordEvent('deferred-job-start', {\n intentKey: job.intentKey,\n jobId: job.id\n });\n\n let index = 0;\n let frameStart = performance.now();\n let processedInFrame = 0;\n let committedInSlice = 0;\n\n while (index < job.orderedGraphics.length) {\n if ((job.status as string) === 'cancelled') {\n return;\n }\n\n if (\n processedInFrame > 0 &&\n (processedInFrame >= job.config.maxGraphicsPerFrame || performance.now() - frameStart >= job.config.frameBudget)\n ) {\n this.perfMonitor?.incrementCounter('deferredBudgetYields');\n this.perfMonitor?.recordCost('batchSlice', performance.now() - frameStart);\n this.perfMonitor?.recordEvent('deferred-job-yield', {\n intentKey: job.intentKey,\n jobId: job.id,\n processedInFrame\n });\n if (committedInSlice > 0) {\n this.stage.renderNextFrame();\n }\n await this.waitForNextFrame();\n frameStart = performance.now();\n processedInFrame = 0;\n committedInSlice = 0;\n }\n\n const graphic = job.orderedGraphics[index++];\n\n if (!job.pendingGraphics.has(graphic)) {\n continue;\n }\n\n if (!isRenderableGraphic(graphic)) {\n job.pendingGraphics.delete(graphic);\n if (this.pendingIntentByGraphic.get(graphic) === job.intentKey) {\n this.pendingIntentByGraphic.delete(graphic);\n }\n continue;\n }\n\n if (this.pendingIntentByGraphic.get(graphic) !== job.intentKey) {\n job.pendingGraphics.delete(graphic);\n continue;\n }\n\n const nextEligibility = this.resolveEligibility(graphic, job.targetStates, true, false);\n if (!nextEligibility.eligible) {\n job.pendingGraphics.delete(graphic);\n this.pendingIntentByGraphic.delete(graphic);\n this.commitSynchronously(graphic, job.targetStates);\n continue;\n }\n\n const nextIntentKey = createIntentKey(\n nextEligibility.context.contextOwnerId,\n nextEligibility.context.configFingerprint,\n nextEligibility.targetStatesKey\n );\n\n if (nextIntentKey !== job.intentKey) {\n job.pendingGraphics.delete(graphic);\n this.pendingIntentByGraphic.delete(graphic);\n this.enqueueDeferredIntent(graphic, job.targetStates, nextEligibility.context, nextEligibility.targetStatesKey);\n continue;\n }\n\n this.commitSynchronously(graphic, job.targetStates);\n job.pendingGraphics.delete(graphic);\n this.pendingIntentByGraphic.delete(graphic);\n job.processedCount += 1;\n processedInFrame += 1;\n committedInSlice += 1;\n this.perfMonitor?.incrementCounter('deferredGraphicsCommitted');\n }\n\n if (processedInFrame > 0) {\n this.perfMonitor?.recordCost('batchSlice', performance.now() - frameStart);\n this.stage.renderNextFrame();\n }\n\n if (job.pendingGraphics.size === 0 && this.jobsByIntentKey.get(job.intentKey) === job) {\n job.status = 'completed';\n this.jobsByIntentKey.delete(job.intentKey);\n this.perfMonitor?.incrementCounter('deferredJobsCompleted');\n this.perfMonitor?.recordEvent('deferred-job-complete', {\n intentKey: job.intentKey,\n jobId: job.id,\n processedCount: job.processedCount\n });\n this.perfMonitor?.updateBatchPending(this.jobsByIntentKey.size);\n }\n }\n\n private waitForNextFrame(): Promise<void> {\n const stageGlobal = (this.stage as any).global;\n if (stageGlobal?.getSpecifiedPerformanceRAF) {\n return stageGlobal.getSpecifiedPerformanceRAF((this.stage as any).rafId).wait();\n }\n\n return new Promise(resolve => {\n stageGlobal?.getSpecifiedRequestAnimationFrame((this.stage as any).rafId)(() => resolve());\n });\n }\n\n private commitSynchronously(graphic: IGraphic, targetStates: string[]): void {\n if (!isRenderableGraphic(graphic)) {\n return;\n }\n\n if (!targetStates.length) {\n graphic.clearStates(false);\n return;\n }\n\n graphic.useStates(targetStates, false);\n }\n}\n"]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { CompiledStateDefinition, StateDefinitionsInput } from './state-definition';
|
|
2
|
+
export declare class StateDefinitionCompiler<T extends Record<string, any> = Record<string, any>> {
|
|
3
|
+
compile(definitions?: StateDefinitionsInput<T>): Map<string, CompiledStateDefinition<T>>;
|
|
4
|
+
private normalizeDefinition;
|
|
5
|
+
private expandRelationClosure;
|
|
6
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
}), exports.StateDefinitionCompiler = void 0;
|
|
6
|
+
|
|
7
|
+
const FULL_DEFINITION_KEYS = new Set([ "name", "patch", "priority", "exclude", "suppress", "resolver", "declaredAffectedKeys" ]);
|
|
8
|
+
|
|
9
|
+
function isPlainObject(value) {
|
|
10
|
+
return null != value && "object" == typeof value && !Array.isArray(value);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
function normalizePatch(value) {
|
|
14
|
+
return null == value ? void 0 : value;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
class StateDefinitionCompiler {
|
|
18
|
+
compile(definitions = {}) {
|
|
19
|
+
const normalizedEntries = Object.keys(definitions).map((name => [ name, this.normalizeDefinition(name, definitions[name]) ])), rankOrder = normalizedEntries.map((([, definition]) => definition)).sort(((left, right) => {
|
|
20
|
+
var _a, _b;
|
|
21
|
+
const leftPriority = null !== (_a = left.priority) && void 0 !== _a ? _a : 0, rightPriority = null !== (_b = right.priority) && void 0 !== _b ? _b : 0;
|
|
22
|
+
return leftPriority !== rightPriority ? leftPriority - rightPriority : left.name.localeCompare(right.name);
|
|
23
|
+
})), rankMap = new Map;
|
|
24
|
+
rankOrder.forEach(((definition, index) => {
|
|
25
|
+
rankMap.set(definition.name, index);
|
|
26
|
+
}));
|
|
27
|
+
const compiled = new Map;
|
|
28
|
+
return normalizedEntries.forEach((([, definition]) => {
|
|
29
|
+
var _a, _b, _c, _d;
|
|
30
|
+
const declaredAffectedKeys = definition.declaredAffectedKeys ? new Set(Array.from(definition.declaredAffectedKeys)) : void 0, staticAffectedKeys = definition.patch ? new Set(Object.keys(definition.patch)) : new Set, affectedKeys = new Set(staticAffectedKeys);
|
|
31
|
+
null == declaredAffectedKeys || declaredAffectedKeys.forEach((key => affectedKeys.add(key))),
|
|
32
|
+
compiled.set(definition.name, {
|
|
33
|
+
name: definition.name,
|
|
34
|
+
priority: null !== (_a = definition.priority) && void 0 !== _a ? _a : 0,
|
|
35
|
+
rank: null !== (_b = rankMap.get(definition.name)) && void 0 !== _b ? _b : 0,
|
|
36
|
+
patch: normalizePatch(definition.patch),
|
|
37
|
+
resolver: definition.resolver,
|
|
38
|
+
declaredAffectedKeys: declaredAffectedKeys,
|
|
39
|
+
exclude: new Set(null !== (_c = definition.exclude) && void 0 !== _c ? _c : []),
|
|
40
|
+
suppress: new Set(null !== (_d = definition.suppress) && void 0 !== _d ? _d : []),
|
|
41
|
+
hasResolver: "function" == typeof definition.resolver,
|
|
42
|
+
affectedKeys: affectedKeys
|
|
43
|
+
});
|
|
44
|
+
})), this.expandRelationClosure(compiled, "exclude"), this.expandRelationClosure(compiled, "suppress"),
|
|
45
|
+
compiled;
|
|
46
|
+
}
|
|
47
|
+
normalizeDefinition(name, value) {
|
|
48
|
+
var _a, _b;
|
|
49
|
+
if (null == value) return {
|
|
50
|
+
name: name,
|
|
51
|
+
priority: 0,
|
|
52
|
+
patch: void 0
|
|
53
|
+
};
|
|
54
|
+
if ((isPlainObject(value) ? Object.keys(value) : []).some((key => FULL_DEFINITION_KEYS.has(key)))) {
|
|
55
|
+
const definition = value;
|
|
56
|
+
return {
|
|
57
|
+
name: null !== (_a = definition.name) && void 0 !== _a ? _a : name,
|
|
58
|
+
priority: null !== (_b = definition.priority) && void 0 !== _b ? _b : 0,
|
|
59
|
+
rank: definition.rank,
|
|
60
|
+
patch: normalizePatch(definition.patch),
|
|
61
|
+
resolver: definition.resolver,
|
|
62
|
+
declaredAffectedKeys: definition.declaredAffectedKeys,
|
|
63
|
+
exclude: definition.exclude,
|
|
64
|
+
suppress: definition.suppress
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
return {
|
|
68
|
+
name: name,
|
|
69
|
+
priority: 0,
|
|
70
|
+
patch: value
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
expandRelationClosure(compiled, relation) {
|
|
74
|
+
const rawRelationMap = new Map;
|
|
75
|
+
compiled.forEach(((definition, name) => {
|
|
76
|
+
rawRelationMap.set(name, new Set(definition[relation]));
|
|
77
|
+
})), compiled.forEach(((definition, origin) => {
|
|
78
|
+
const closure = new Set, walk = (stateName, stack) => {
|
|
79
|
+
const nextStates = rawRelationMap.get(stateName);
|
|
80
|
+
nextStates && nextStates.size && nextStates.forEach((nextState => {
|
|
81
|
+
nextState !== origin ? stack.includes(nextState) ? console.warn(`[StateDefinitionCompiler] circular ${relation} relation detected: ${stack.join(" -> ")} -> ${nextState}`) : closure.has(nextState) || (closure.add(nextState),
|
|
82
|
+
walk(nextState, stack.concat(nextState))) : console.warn(`[StateDefinitionCompiler] circular ${relation} relation detected: ${stack.join(" -> ")} -> ${origin}`);
|
|
83
|
+
}));
|
|
84
|
+
};
|
|
85
|
+
walk(origin, [ origin ]), definition[relation] = closure;
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
exports.StateDefinitionCompiler = StateDefinitionCompiler;
|
|
91
|
+
//# sourceMappingURL=state-definition-compiler.js.map
|