@visactor/vrender-core 1.1.0-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.
Files changed (1018) hide show
  1. package/cjs/allocator/canvas-allocate.js +5 -7
  2. package/cjs/allocator/canvas-allocate.js.map +1 -1
  3. package/cjs/allocator/graphic-allocate.js +17 -17
  4. package/cjs/allocator/graphic-allocate.js.map +1 -1
  5. package/cjs/application.d.ts +19 -18
  6. package/cjs/application.js +1 -31
  7. package/cjs/application.js.map +1 -1
  8. package/cjs/canvas/conical-gradient.js +2 -2
  9. package/cjs/canvas/conical-gradient.js.map +1 -1
  10. package/cjs/canvas/constants.js +2 -1
  11. package/cjs/canvas/contributions/base-canvas.js +2 -2
  12. package/cjs/canvas/contributions/base-canvas.js.map +1 -1
  13. package/cjs/canvas/empty-context.js +1 -2
  14. package/cjs/canvas/util.d.ts +2 -3
  15. package/cjs/canvas/util.js +17 -7
  16. package/cjs/canvas/util.js.map +1 -1
  17. package/cjs/common/contribution-provider.d.ts +27 -0
  18. package/cjs/common/contribution-provider.js +51 -0
  19. package/cjs/common/contribution-provider.js.map +1 -0
  20. package/cjs/common/diff.js +1 -2
  21. package/cjs/common/enums.d.ts +2 -0
  22. package/cjs/common/enums.js +3 -1
  23. package/cjs/common/enums.js.map +1 -1
  24. package/cjs/common/event-listener-manager.d.ts +18 -1
  25. package/cjs/common/event-listener-manager.js +40 -10
  26. package/cjs/common/event-listener-manager.js.map +1 -1
  27. package/cjs/common/event-transformer.js +41 -5
  28. package/cjs/common/event-transformer.js.map +1 -1
  29. package/cjs/common/explicit-binding.d.ts +5 -0
  30. package/cjs/common/explicit-binding.js +16 -0
  31. package/cjs/common/explicit-binding.js.map +1 -0
  32. package/cjs/common/performance-raf.d.ts +1 -0
  33. package/cjs/common/performance-raf.js +7 -2
  34. package/cjs/common/performance-raf.js.map +1 -1
  35. package/cjs/common/seg-context.js +1 -2
  36. package/cjs/common/sort.js +2 -1
  37. package/cjs/core/application.js +1 -1
  38. package/cjs/core/camera.js +1 -1
  39. package/cjs/core/constants.js +1 -1
  40. package/cjs/core/contributions/env/modules.d.ts +4 -0
  41. package/cjs/core/contributions/env/modules.js +14 -0
  42. package/cjs/core/contributions/env/modules.js.map +1 -0
  43. package/cjs/core/contributions/layerHandler/canvas2d-contribution.js +2 -2
  44. package/cjs/core/contributions/layerHandler/canvas2d-contribution.js.map +1 -1
  45. package/cjs/core/contributions/layerHandler/empty-contribution.js +2 -2
  46. package/cjs/core/contributions/layerHandler/empty-contribution.js.map +1 -1
  47. package/cjs/core/contributions/layerHandler/modules.d.ts +4 -0
  48. package/cjs/core/contributions/layerHandler/modules.js +14 -0
  49. package/cjs/core/contributions/layerHandler/modules.js.map +1 -0
  50. package/cjs/core/contributions/layerHandler/offscreen2d-contribution.js +2 -2
  51. package/cjs/core/contributions/layerHandler/offscreen2d-contribution.js.map +1 -1
  52. package/cjs/core/contributions/modules.d.ts +2 -1
  53. package/cjs/core/contributions/modules.js +20 -2
  54. package/cjs/core/contributions/modules.js.map +1 -1
  55. package/cjs/core/contributions/textMeasure/modules.d.ts +4 -0
  56. package/cjs/core/contributions/textMeasure/modules.js +15 -0
  57. package/cjs/core/contributions/textMeasure/modules.js.map +1 -0
  58. package/cjs/core/core-modules.d.ts +4 -0
  59. package/cjs/core/core-modules.js +19 -0
  60. package/cjs/core/core-modules.js.map +1 -0
  61. package/cjs/core/global-module.d.ts +1 -0
  62. package/cjs/core/global-module.js +3 -0
  63. package/cjs/core/global-module.js.map +1 -0
  64. package/cjs/core/global.d.ts +4 -2
  65. package/cjs/core/global.js +8 -5
  66. package/cjs/core/global.js.map +1 -1
  67. package/cjs/core/graphic-utils.d.ts +3 -4
  68. package/cjs/core/graphic-utils.js +4 -5
  69. package/cjs/core/graphic-utils.js.map +1 -1
  70. package/cjs/core/layer-service.d.ts +7 -2
  71. package/cjs/core/layer-service.js +23 -13
  72. package/cjs/core/layer-service.js.map +1 -1
  73. package/cjs/core/layer.d.ts +1 -1
  74. package/cjs/core/layer.js +3 -3
  75. package/cjs/core/layer.js.map +1 -1
  76. package/cjs/core/stage.d.ts +17 -3
  77. package/cjs/core/stage.js +47 -25
  78. package/cjs/core/stage.js.map +1 -1
  79. package/cjs/core/window.d.ts +7 -5
  80. package/cjs/core/window.js +11 -7
  81. package/cjs/core/window.js.map +1 -1
  82. package/cjs/create.d.ts +1 -2
  83. package/cjs/create.js +2 -2
  84. package/cjs/create.js.map +1 -1
  85. package/cjs/entries/app-context.d.ts +30 -0
  86. package/cjs/entries/app-context.js +84 -0
  87. package/cjs/entries/app-context.js.map +1 -0
  88. package/cjs/entries/browser.d.ts +25 -0
  89. package/cjs/entries/browser.js +44 -0
  90. package/cjs/entries/browser.js.map +1 -0
  91. package/cjs/entries/index.d.ts +7 -0
  92. package/cjs/entries/index.js +32 -0
  93. package/cjs/entries/index.js.map +1 -0
  94. package/cjs/entries/miniapp.d.ts +6 -0
  95. package/cjs/entries/miniapp.js +20 -0
  96. package/cjs/entries/miniapp.js.map +1 -0
  97. package/cjs/entries/node.d.ts +6 -0
  98. package/cjs/entries/node.js +20 -0
  99. package/cjs/entries/node.js.map +1 -0
  100. package/cjs/entries/runtime-installer.d.ts +11 -0
  101. package/cjs/entries/runtime-installer.js +111 -0
  102. package/cjs/entries/runtime-installer.js.map +1 -0
  103. package/cjs/entries/types.d.ts +29 -0
  104. package/cjs/entries/types.js.map +1 -0
  105. package/cjs/env-check.js +3 -3
  106. package/cjs/env-check.js.map +1 -1
  107. package/cjs/event/event-manager.js +4 -1
  108. package/cjs/event/event-manager.js.map +1 -1
  109. package/cjs/event/util.d.ts +1 -1
  110. package/cjs/factory/graphic-factory.d.ts +7 -0
  111. package/cjs/factory/graphic-factory.js +23 -0
  112. package/cjs/factory/graphic-factory.js.map +1 -0
  113. package/cjs/factory/index.d.ts +4 -0
  114. package/cjs/factory/index.js +22 -0
  115. package/cjs/factory/index.js.map +1 -0
  116. package/cjs/factory/layer-factory.d.ts +7 -0
  117. package/cjs/factory/layer-factory.js +19 -0
  118. package/cjs/factory/layer-factory.js.map +1 -0
  119. package/cjs/factory/stage-factory.d.ts +8 -0
  120. package/cjs/factory/stage-factory.js +20 -0
  121. package/cjs/factory/stage-factory.js.map +1 -0
  122. package/cjs/factory/types.d.ts +34 -0
  123. package/cjs/factory/types.js +6 -0
  124. package/cjs/factory/types.js.map +1 -0
  125. package/cjs/factory.d.ts +1 -0
  126. package/cjs/factory.js +16 -1
  127. package/cjs/factory.js.map +1 -1
  128. package/cjs/global.d.ts +2 -0
  129. package/cjs/global.js +11 -0
  130. package/cjs/global.js.map +1 -0
  131. package/cjs/graphic/arc.js +3 -3
  132. package/cjs/graphic/arc.js.map +1 -1
  133. package/cjs/graphic/arc3d.js +3 -3
  134. package/cjs/graphic/arc3d.js.map +1 -1
  135. package/cjs/graphic/area.js +3 -3
  136. package/cjs/graphic/area.js.map +1 -1
  137. package/cjs/graphic/bounds.js +3 -3
  138. package/cjs/graphic/bounds.js.map +1 -1
  139. package/cjs/graphic/circle.js +3 -3
  140. package/cjs/graphic/circle.js.map +1 -1
  141. package/cjs/graphic/config.js +7 -1
  142. package/cjs/graphic/config.js.map +1 -1
  143. package/cjs/graphic/glyph.js +9 -3
  144. package/cjs/graphic/glyph.js.map +1 -1
  145. package/cjs/graphic/graphic-creator.d.ts +9 -4
  146. package/cjs/graphic/graphic-creator.js +35 -7
  147. package/cjs/graphic/graphic-creator.js.map +1 -1
  148. package/cjs/graphic/graphic-service/graphic-module.d.ts +4 -0
  149. package/cjs/graphic/graphic-service/graphic-module.js +14 -0
  150. package/cjs/graphic/graphic-service/graphic-module.js.map +1 -0
  151. package/cjs/graphic/graphic-service/graphic-service.d.ts +2 -3
  152. package/cjs/graphic/graphic-service/graphic-service.js +3 -4
  153. package/cjs/graphic/graphic-service/graphic-service.js.map +1 -1
  154. package/cjs/graphic/graphic.d.ts +78 -7
  155. package/cjs/graphic/graphic.js +491 -146
  156. package/cjs/graphic/graphic.js.map +1 -1
  157. package/cjs/graphic/group.d.ts +11 -1
  158. package/cjs/graphic/group.js +49 -13
  159. package/cjs/graphic/group.js.map +1 -1
  160. package/cjs/graphic/image.d.ts +1 -0
  161. package/cjs/graphic/image.js +4 -3
  162. package/cjs/graphic/image.js.map +1 -1
  163. package/cjs/graphic/index.d.ts +3 -0
  164. package/cjs/graphic/index.js +34 -15
  165. package/cjs/graphic/index.js.map +1 -1
  166. package/cjs/graphic/line.js +3 -3
  167. package/cjs/graphic/line.js.map +1 -1
  168. package/cjs/graphic/path.js +3 -3
  169. package/cjs/graphic/path.js.map +1 -1
  170. package/cjs/graphic/polygon.js +3 -3
  171. package/cjs/graphic/polygon.js.map +1 -1
  172. package/cjs/graphic/pyramid3d.js +3 -2
  173. package/cjs/graphic/pyramid3d.js.map +1 -1
  174. package/cjs/graphic/rect.js +3 -3
  175. package/cjs/graphic/rect.js.map +1 -1
  176. package/cjs/graphic/richtext/utils.js +3 -3
  177. package/cjs/graphic/richtext/utils.js.map +1 -1
  178. package/cjs/graphic/richtext.js +4 -4
  179. package/cjs/graphic/richtext.js.map +1 -1
  180. package/cjs/graphic/star.js +3 -3
  181. package/cjs/graphic/star.js.map +1 -1
  182. package/cjs/graphic/state/attribute-update-classifier.d.ts +13 -0
  183. package/cjs/graphic/state/attribute-update-classifier.js +67 -0
  184. package/cjs/graphic/state/attribute-update-classifier.js.map +1 -0
  185. package/cjs/graphic/state/shared-state-refresh.d.ts +6 -0
  186. package/cjs/graphic/state/shared-state-refresh.js +55 -0
  187. package/cjs/graphic/state/shared-state-refresh.js.map +1 -0
  188. package/cjs/graphic/state/shared-state-scope.d.ts +25 -0
  189. package/cjs/graphic/state/shared-state-scope.js +98 -0
  190. package/cjs/graphic/state/shared-state-scope.js.map +1 -0
  191. package/cjs/graphic/state/state-batch-scheduler.d.ts +42 -0
  192. package/cjs/graphic/state/state-batch-scheduler.js +285 -0
  193. package/cjs/graphic/state/state-batch-scheduler.js.map +1 -0
  194. package/cjs/graphic/state/state-definition-compiler.d.ts +6 -0
  195. package/cjs/graphic/state/state-definition-compiler.js +91 -0
  196. package/cjs/graphic/state/state-definition-compiler.js.map +1 -0
  197. package/cjs/graphic/state/state-definition.d.ts +44 -0
  198. package/cjs/graphic/state/state-definition.js +6 -0
  199. package/cjs/graphic/state/state-definition.js.map +1 -0
  200. package/cjs/graphic/state/state-engine.d.ts +38 -0
  201. package/cjs/graphic/state/state-engine.js +220 -0
  202. package/cjs/graphic/state/state-engine.js.map +1 -0
  203. package/cjs/graphic/state/state-model.d.ts +43 -0
  204. package/cjs/graphic/state/state-model.js +143 -0
  205. package/cjs/graphic/state/state-model.js.map +1 -0
  206. package/cjs/graphic/state/state-perf-monitor.d.ts +119 -0
  207. package/cjs/graphic/state/state-perf-monitor.js +217 -0
  208. package/cjs/graphic/state/state-perf-monitor.js.map +1 -0
  209. package/cjs/graphic/state/state-style-resolver.d.ts +22 -0
  210. package/cjs/graphic/state/state-style-resolver.js +73 -0
  211. package/cjs/graphic/state/state-style-resolver.js.map +1 -0
  212. package/cjs/graphic/state/state-transition-orchestrator.d.ts +41 -0
  213. package/cjs/graphic/state/state-transition-orchestrator.js +74 -0
  214. package/cjs/graphic/state/state-transition-orchestrator.js.map +1 -0
  215. package/cjs/graphic/symbol.js +3 -3
  216. package/cjs/graphic/symbol.js.map +1 -1
  217. package/cjs/graphic/text.d.ts +3 -2
  218. package/cjs/graphic/text.js +29 -20
  219. package/cjs/graphic/text.js.map +1 -1
  220. package/cjs/graphic/theme.d.ts +5 -0
  221. package/cjs/graphic/theme.js +7 -0
  222. package/cjs/graphic/theme.js.map +1 -1
  223. package/cjs/graphic/tools.js +2 -2
  224. package/cjs/graphic/tools.js.map +1 -1
  225. package/cjs/graphic/wrap-text.d.ts +1 -1
  226. package/cjs/graphic/wrap-text.js +18 -15
  227. package/cjs/graphic/wrap-text.js.map +1 -1
  228. package/cjs/index.d.ts +26 -4
  229. package/cjs/index.js +83 -45
  230. package/cjs/index.js.map +1 -1
  231. package/cjs/interface/canvas.d.ts +1 -1
  232. package/cjs/interface/canvas.js.map +1 -1
  233. package/cjs/interface/global.d.ts +2 -0
  234. package/cjs/interface/global.js.map +1 -1
  235. package/cjs/interface/graphic/group.d.ts +6 -0
  236. package/cjs/interface/graphic/group.js.map +1 -1
  237. package/cjs/interface/graphic/image.d.ts +7 -1
  238. package/cjs/interface/graphic/image.js.map +1 -1
  239. package/cjs/interface/graphic/theme.d.ts +3 -0
  240. package/cjs/interface/graphic/theme.js.map +1 -1
  241. package/cjs/interface/graphic.d.ts +34 -5
  242. package/cjs/interface/graphic.js.map +1 -1
  243. package/cjs/interface/layer.d.ts +3 -2
  244. package/cjs/interface/layer.js.map +1 -1
  245. package/cjs/interface/plugin.d.ts +2 -0
  246. package/cjs/interface/plugin.js.map +1 -1
  247. package/cjs/interface/render.d.ts +1 -1
  248. package/cjs/interface/render.js.map +1 -1
  249. package/cjs/interface/stage.d.ts +9 -0
  250. package/cjs/interface/stage.js.map +1 -1
  251. package/cjs/interface/theme-service.js.map +1 -1
  252. package/cjs/legacy/binding-context.d.ts +24 -0
  253. package/cjs/legacy/binding-context.js +98 -0
  254. package/cjs/legacy/binding-context.js.map +1 -0
  255. package/cjs/legacy/bootstrap.d.ts +10 -0
  256. package/cjs/legacy/bootstrap.js +72 -0
  257. package/cjs/legacy/bootstrap.js.map +1 -0
  258. package/cjs/legacy/module-types.d.ts +2 -0
  259. package/cjs/legacy/module-types.js +6 -0
  260. package/cjs/legacy/module-types.js.map +1 -0
  261. package/cjs/modules.d.ts +5 -6
  262. package/cjs/modules.js +54 -9
  263. package/cjs/modules.js.map +1 -1
  264. package/cjs/picker/global-picker-service.js +2 -2
  265. package/cjs/picker/global-picker-service.js.map +1 -1
  266. package/cjs/picker/pick-modules.d.ts +5 -0
  267. package/cjs/picker/pick-modules.js +24 -0
  268. package/cjs/picker/pick-modules.js.map +1 -0
  269. package/cjs/picker/picker-service.d.ts +13 -4
  270. package/cjs/picker/picker-service.js +15 -8
  271. package/cjs/picker/picker-service.js.map +1 -1
  272. package/cjs/plugins/base-plugin.d.ts +8 -0
  273. package/cjs/plugins/base-plugin.js +15 -0
  274. package/cjs/plugins/base-plugin.js.map +1 -0
  275. package/cjs/plugins/browser-env-plugin.d.ts +8 -0
  276. package/cjs/plugins/browser-env-plugin.js +24 -0
  277. package/cjs/plugins/browser-env-plugin.js.map +1 -0
  278. package/cjs/plugins/builtin-plugin/auto-refresh-plugin.js +6 -5
  279. package/cjs/plugins/builtin-plugin/auto-refresh-plugin.js.map +1 -1
  280. package/cjs/plugins/builtin-plugin/auto-render-plugin.js.map +1 -1
  281. package/cjs/plugins/builtin-plugin/dirty-bounds-plugin.d.ts +4 -1
  282. package/cjs/plugins/builtin-plugin/dirty-bounds-plugin.js +25 -4
  283. package/cjs/plugins/builtin-plugin/dirty-bounds-plugin.js.map +1 -1
  284. package/cjs/plugins/builtin-plugin/edit-module.js +4 -3
  285. package/cjs/plugins/builtin-plugin/edit-module.js.map +1 -1
  286. package/cjs/plugins/builtin-plugin/flex-layout-plugin.js.map +1 -1
  287. package/cjs/plugins/builtin-plugin/html-attribute-plugin.js +8 -8
  288. package/cjs/plugins/builtin-plugin/html-attribute-plugin.js.map +1 -1
  289. package/cjs/plugins/builtin-plugin/incremental-auto-render-plugin.js +2 -2
  290. package/cjs/plugins/builtin-plugin/incremental-auto-render-plugin.js.map +1 -1
  291. package/cjs/plugins/builtin-plugin/react-attribute-plugin.js +3 -3
  292. package/cjs/plugins/builtin-plugin/react-attribute-plugin.js.map +1 -1
  293. package/cjs/plugins/builtin-plugin/richtext-edit-plugin.js +13 -9
  294. package/cjs/plugins/builtin-plugin/richtext-edit-plugin.js.map +1 -1
  295. package/cjs/plugins/index.d.ts +5 -0
  296. package/cjs/plugins/index.js +23 -0
  297. package/cjs/plugins/index.js.map +1 -0
  298. package/cjs/plugins/picker-plugin.d.ts +7 -0
  299. package/cjs/plugins/picker-plugin.js +19 -0
  300. package/cjs/plugins/picker-plugin.js.map +1 -0
  301. package/cjs/plugins/plugin-modules.d.ts +4 -0
  302. package/cjs/plugins/plugin-modules.js +14 -0
  303. package/cjs/plugins/plugin-modules.js.map +1 -0
  304. package/cjs/plugins/plugin-service.d.ts +16 -2
  305. package/cjs/plugins/plugin-service.js +23 -11
  306. package/cjs/plugins/plugin-service.js.map +1 -1
  307. package/cjs/plugins/renderer-plugin.d.ts +7 -0
  308. package/cjs/plugins/renderer-plugin.js +19 -0
  309. package/cjs/plugins/renderer-plugin.js.map +1 -0
  310. package/cjs/plugins/types.d.ts +28 -0
  311. package/cjs/plugins/types.js +6 -0
  312. package/cjs/plugins/types.js.map +1 -0
  313. package/cjs/register/register-arc.js +1 -1
  314. package/cjs/register/register-arc.js.map +1 -1
  315. package/cjs/register/register-arc3d.js +1 -1
  316. package/cjs/register/register-arc3d.js.map +1 -1
  317. package/cjs/register/register-area.js +1 -1
  318. package/cjs/register/register-area.js.map +1 -1
  319. package/cjs/register/register-circle.js +1 -1
  320. package/cjs/register/register-circle.js.map +1 -1
  321. package/cjs/register/register-glyph.js +1 -1
  322. package/cjs/register/register-glyph.js.map +1 -1
  323. package/cjs/register/register-group.js +1 -1
  324. package/cjs/register/register-group.js.map +1 -1
  325. package/cjs/register/register-image.js +1 -1
  326. package/cjs/register/register-image.js.map +1 -1
  327. package/cjs/register/register-line.js +1 -1
  328. package/cjs/register/register-line.js.map +1 -1
  329. package/cjs/register/register-path.js +1 -1
  330. package/cjs/register/register-path.js.map +1 -1
  331. package/cjs/register/register-polygon.js +1 -1
  332. package/cjs/register/register-polygon.js.map +1 -1
  333. package/cjs/register/register-pyramid3d.js +1 -1
  334. package/cjs/register/register-pyramid3d.js.map +1 -1
  335. package/cjs/register/register-rect.js +1 -1
  336. package/cjs/register/register-rect.js.map +1 -1
  337. package/cjs/register/register-rect3d.js +1 -1
  338. package/cjs/register/register-rect3d.js.map +1 -1
  339. package/cjs/register/register-richtext.js +1 -1
  340. package/cjs/register/register-richtext.js.map +1 -1
  341. package/cjs/register/register-shadowRoot.js +1 -1
  342. package/cjs/register/register-shadowRoot.js.map +1 -1
  343. package/cjs/register/register-star.js +1 -1
  344. package/cjs/register/register-star.js.map +1 -1
  345. package/cjs/register/register-symbol.js +1 -1
  346. package/cjs/register/register-symbol.js.map +1 -1
  347. package/cjs/register/register-text.js +1 -1
  348. package/cjs/register/register-text.js.map +1 -1
  349. package/cjs/register/register-wraptext.js +1 -1
  350. package/cjs/register/register-wraptext.js.map +1 -1
  351. package/cjs/registry/contribution-registry.d.ts +9 -0
  352. package/cjs/registry/contribution-registry.js +33 -0
  353. package/cjs/registry/contribution-registry.js.map +1 -0
  354. package/cjs/registry/index.d.ts +5 -0
  355. package/cjs/registry/index.js +23 -0
  356. package/cjs/registry/index.js.map +1 -0
  357. package/cjs/registry/picker-registry.d.ts +10 -0
  358. package/cjs/registry/picker-registry.js +29 -0
  359. package/cjs/registry/picker-registry.js.map +1 -0
  360. package/cjs/registry/plugin-registry.d.ts +10 -0
  361. package/cjs/registry/plugin-registry.js +29 -0
  362. package/cjs/registry/plugin-registry.js.map +1 -0
  363. package/cjs/registry/renderer-registry.d.ts +11 -0
  364. package/cjs/registry/renderer-registry.js +37 -0
  365. package/cjs/registry/renderer-registry.js.map +1 -0
  366. package/cjs/registry/types.d.ts +34 -0
  367. package/cjs/registry/types.js +6 -0
  368. package/cjs/registry/types.js.map +1 -0
  369. package/cjs/render/contributions/modules.d.ts +2 -0
  370. package/cjs/render/contributions/modules.js +22 -0
  371. package/cjs/render/contributions/modules.js.map +1 -0
  372. package/cjs/render/contributions/render/arc-module.d.ts +4 -0
  373. package/cjs/render/contributions/render/arc-module.js +19 -0
  374. package/cjs/render/contributions/render/arc-module.js.map +1 -0
  375. package/cjs/render/contributions/render/arc-render.d.ts +2 -2
  376. package/cjs/render/contributions/render/arc-render.js +4 -5
  377. package/cjs/render/contributions/render/arc-render.js.map +1 -1
  378. package/cjs/render/contributions/render/arc3d-module.d.ts +4 -0
  379. package/cjs/render/contributions/render/arc3d-module.js +17 -0
  380. package/cjs/render/contributions/render/arc3d-module.js.map +1 -0
  381. package/cjs/render/contributions/render/area-module.d.ts +4 -0
  382. package/cjs/render/contributions/render/area-module.js +20 -0
  383. package/cjs/render/contributions/render/area-module.js.map +1 -0
  384. package/cjs/render/contributions/render/area-render.d.ts +2 -2
  385. package/cjs/render/contributions/render/area-render.js +4 -5
  386. package/cjs/render/contributions/render/area-render.js.map +1 -1
  387. package/cjs/render/contributions/render/base-render.js +1 -1
  388. package/cjs/render/contributions/render/base-render.js.map +1 -1
  389. package/cjs/render/contributions/render/circle-module.d.ts +4 -0
  390. package/cjs/render/contributions/render/circle-module.js +19 -0
  391. package/cjs/render/contributions/render/circle-module.js.map +1 -0
  392. package/cjs/render/contributions/render/circle-render.d.ts +2 -2
  393. package/cjs/render/contributions/render/circle-render.js +4 -5
  394. package/cjs/render/contributions/render/circle-render.js.map +1 -1
  395. package/cjs/render/contributions/render/contributions/base-contribution-render.d.ts +29 -11
  396. package/cjs/render/contributions/render/contributions/base-contribution-render.js +150 -39
  397. package/cjs/render/contributions/render/contributions/base-contribution-render.js.map +1 -1
  398. package/cjs/render/contributions/render/contributions/base-texture-contribution-render.d.ts +4 -2
  399. package/cjs/render/contributions/render/contributions/base-texture-contribution-render.js +84 -31
  400. package/cjs/render/contributions/render/contributions/base-texture-contribution-render.js.map +1 -1
  401. package/cjs/render/contributions/render/contributions/group-contribution-render.js +8 -6
  402. package/cjs/render/contributions/render/contributions/group-contribution-render.js.map +1 -1
  403. package/cjs/render/contributions/render/contributions/image-contribution-render.d.ts +2 -1
  404. package/cjs/render/contributions/render/contributions/image-contribution-render.js.map +1 -1
  405. package/cjs/render/contributions/render/contributions/text-contribution-render.js +20 -16
  406. package/cjs/render/contributions/render/contributions/text-contribution-render.js.map +1 -1
  407. package/cjs/render/contributions/render/draw-contribution.d.ts +13 -4
  408. package/cjs/render/contributions/render/draw-contribution.js +37 -13
  409. package/cjs/render/contributions/render/draw-contribution.js.map +1 -1
  410. package/cjs/render/contributions/render/draw-interceptor.js +2 -3
  411. package/cjs/render/contributions/render/draw-interceptor.js.map +1 -1
  412. package/cjs/render/contributions/render/glyph-module.d.ts +4 -0
  413. package/cjs/render/contributions/render/glyph-module.js +17 -0
  414. package/cjs/render/contributions/render/glyph-module.js.map +1 -0
  415. package/cjs/render/contributions/render/group-render.d.ts +2 -2
  416. package/cjs/render/contributions/render/group-render.js +3 -5
  417. package/cjs/render/contributions/render/group-render.js.map +1 -1
  418. package/cjs/render/contributions/render/image-module.d.ts +4 -0
  419. package/cjs/render/contributions/render/image-module.js +18 -0
  420. package/cjs/render/contributions/render/image-module.js.map +1 -0
  421. package/cjs/render/contributions/render/image-render.d.ts +16 -3
  422. package/cjs/render/contributions/render/image-render.js +101 -24
  423. package/cjs/render/contributions/render/image-render.js.map +1 -1
  424. package/cjs/render/contributions/render/incremental-draw-contribution.d.ts +5 -3
  425. package/cjs/render/contributions/render/incremental-draw-contribution.js +5 -7
  426. package/cjs/render/contributions/render/incremental-draw-contribution.js.map +1 -1
  427. package/cjs/render/contributions/render/index.d.ts +4 -12
  428. package/cjs/render/contributions/render/index.js +7 -11
  429. package/cjs/render/contributions/render/index.js.map +1 -1
  430. package/cjs/render/contributions/render/line-module.d.ts +4 -0
  431. package/cjs/render/contributions/render/line-module.js +19 -0
  432. package/cjs/render/contributions/render/line-module.js.map +1 -0
  433. package/cjs/render/contributions/render/module.d.ts +4 -0
  434. package/cjs/render/contributions/render/module.js +27 -0
  435. package/cjs/render/contributions/render/module.js.map +1 -0
  436. package/cjs/render/contributions/render/path-module.d.ts +4 -0
  437. package/cjs/render/contributions/render/path-module.js +19 -0
  438. package/cjs/render/contributions/render/path-module.js.map +1 -0
  439. package/cjs/render/contributions/render/path-render.d.ts +2 -2
  440. package/cjs/render/contributions/render/path-render.js +4 -5
  441. package/cjs/render/contributions/render/path-render.js.map +1 -1
  442. package/cjs/render/contributions/render/polygon-module.d.ts +4 -0
  443. package/cjs/render/contributions/render/polygon-module.js +18 -0
  444. package/cjs/render/contributions/render/polygon-module.js.map +1 -0
  445. package/cjs/render/contributions/render/polygon-render.d.ts +2 -2
  446. package/cjs/render/contributions/render/polygon-render.js +4 -5
  447. package/cjs/render/contributions/render/polygon-render.js.map +1 -1
  448. package/cjs/render/contributions/render/pyramid3d-module.d.ts +4 -0
  449. package/cjs/render/contributions/render/pyramid3d-module.js +17 -0
  450. package/cjs/render/contributions/render/pyramid3d-module.js.map +1 -0
  451. package/cjs/render/contributions/render/rect-module.d.ts +4 -0
  452. package/cjs/render/contributions/render/rect-module.js +23 -0
  453. package/cjs/render/contributions/render/rect-module.js.map +1 -0
  454. package/cjs/render/contributions/render/rect-render.d.ts +2 -2
  455. package/cjs/render/contributions/render/rect-render.js +4 -5
  456. package/cjs/render/contributions/render/rect-render.js.map +1 -1
  457. package/cjs/render/contributions/render/rect3d-module.d.ts +4 -0
  458. package/cjs/render/contributions/render/rect3d-module.js +17 -0
  459. package/cjs/render/contributions/render/rect3d-module.js.map +1 -0
  460. package/cjs/render/contributions/render/rect3d-render.js.map +1 -1
  461. package/cjs/render/contributions/render/render-slector.js.map +1 -1
  462. package/cjs/render/contributions/render/richtext-module.d.ts +4 -0
  463. package/cjs/render/contributions/render/richtext-module.js +17 -0
  464. package/cjs/render/contributions/render/richtext-module.js.map +1 -0
  465. package/cjs/render/contributions/render/star-module.d.ts +4 -0
  466. package/cjs/render/contributions/render/star-module.js +18 -0
  467. package/cjs/render/contributions/render/star-module.js.map +1 -0
  468. package/cjs/render/contributions/render/star-render.d.ts +2 -2
  469. package/cjs/render/contributions/render/star-render.js +4 -5
  470. package/cjs/render/contributions/render/star-render.js.map +1 -1
  471. package/cjs/render/contributions/render/symbol-module.d.ts +4 -0
  472. package/cjs/render/contributions/render/symbol-module.js +19 -0
  473. package/cjs/render/contributions/render/symbol-module.js.map +1 -0
  474. package/cjs/render/contributions/render/symbol-render.d.ts +2 -2
  475. package/cjs/render/contributions/render/symbol-render.js +4 -5
  476. package/cjs/render/contributions/render/symbol-render.js.map +1 -1
  477. package/cjs/render/contributions/render/symbol.d.ts +0 -2
  478. package/cjs/render/contributions/render/symbol.js +1 -3
  479. package/cjs/render/contributions/render/symbol.js.map +1 -1
  480. package/cjs/render/contributions/render/text-module.d.ts +4 -0
  481. package/cjs/render/contributions/render/text-module.js +18 -0
  482. package/cjs/render/contributions/render/text-module.js.map +1 -0
  483. package/cjs/render/contributions/render/text-render.d.ts +2 -2
  484. package/cjs/render/contributions/render/text-render.js +4 -5
  485. package/cjs/render/contributions/render/text-render.js.map +1 -1
  486. package/cjs/render/render-modules.d.ts +4 -0
  487. package/cjs/render/render-modules.js +14 -0
  488. package/cjs/render/render-modules.js.map +1 -0
  489. package/cjs/render/render-service.d.ts +1 -1
  490. package/cjs/render/render-service.js +3 -1
  491. package/cjs/render/render-service.js.map +1 -1
  492. package/cjs/resource-loader/loader.js +6 -6
  493. package/cjs/resource-loader/loader.js.map +1 -1
  494. package/dist/index.es.js +23953 -20200
  495. package/es/allocator/canvas-allocate.js +6 -8
  496. package/es/allocator/canvas-allocate.js.map +1 -1
  497. package/es/allocator/graphic-allocate.js +17 -17
  498. package/es/allocator/graphic-allocate.js.map +1 -1
  499. package/es/application.d.ts +19 -18
  500. package/es/application.js +1 -39
  501. package/es/application.js.map +1 -1
  502. package/es/canvas/conical-gradient.js +2 -2
  503. package/es/canvas/conical-gradient.js.map +1 -1
  504. package/es/canvas/constants.js +2 -1
  505. package/es/canvas/contributions/base-canvas.js +2 -2
  506. package/es/canvas/contributions/base-canvas.js.map +1 -1
  507. package/es/canvas/empty-context.js +1 -2
  508. package/es/canvas/util.d.ts +2 -3
  509. package/es/canvas/util.js +16 -8
  510. package/es/canvas/util.js.map +1 -1
  511. package/es/common/contribution-provider.d.ts +27 -0
  512. package/es/common/contribution-provider.js +43 -0
  513. package/es/common/contribution-provider.js.map +1 -0
  514. package/es/common/diff.js +1 -2
  515. package/es/common/enums.d.ts +2 -0
  516. package/es/common/enums.js +3 -1
  517. package/es/common/enums.js.map +1 -1
  518. package/es/common/event-listener-manager.d.ts +18 -1
  519. package/es/common/event-listener-manager.js +40 -10
  520. package/es/common/event-listener-manager.js.map +1 -1
  521. package/es/common/event-transformer.js +41 -5
  522. package/es/common/event-transformer.js.map +1 -1
  523. package/es/common/explicit-binding.d.ts +5 -0
  524. package/es/common/explicit-binding.js +10 -0
  525. package/es/common/explicit-binding.js.map +1 -0
  526. package/es/common/performance-raf.d.ts +1 -0
  527. package/es/common/performance-raf.js +7 -2
  528. package/es/common/performance-raf.js.map +1 -1
  529. package/es/common/seg-context.js +1 -2
  530. package/es/common/sort.js +2 -1
  531. package/es/core/application.js +1 -1
  532. package/es/core/camera.js +1 -1
  533. package/es/core/constants.js +1 -1
  534. package/es/core/contributions/env/modules.d.ts +4 -0
  535. package/es/core/contributions/env/modules.js +10 -0
  536. package/es/core/contributions/env/modules.js.map +1 -0
  537. package/es/core/contributions/layerHandler/canvas2d-contribution.js +2 -2
  538. package/es/core/contributions/layerHandler/canvas2d-contribution.js.map +1 -1
  539. package/es/core/contributions/layerHandler/empty-contribution.js +2 -2
  540. package/es/core/contributions/layerHandler/empty-contribution.js.map +1 -1
  541. package/es/core/contributions/layerHandler/modules.d.ts +4 -0
  542. package/es/core/contributions/layerHandler/modules.js +10 -0
  543. package/es/core/contributions/layerHandler/modules.js.map +1 -0
  544. package/es/core/contributions/layerHandler/offscreen2d-contribution.js +2 -2
  545. package/es/core/contributions/layerHandler/offscreen2d-contribution.js.map +1 -1
  546. package/es/core/contributions/modules.d.ts +2 -1
  547. package/es/core/contributions/modules.js +15 -1
  548. package/es/core/contributions/modules.js.map +1 -1
  549. package/es/core/contributions/textMeasure/modules.d.ts +4 -0
  550. package/es/core/contributions/textMeasure/modules.js +11 -0
  551. package/es/core/contributions/textMeasure/modules.js.map +1 -0
  552. package/es/core/core-modules.d.ts +4 -0
  553. package/es/core/core-modules.js +24 -0
  554. package/es/core/core-modules.js.map +1 -0
  555. package/es/core/global-module.d.ts +1 -0
  556. package/es/core/global-module.js +3 -0
  557. package/es/core/global-module.js.map +1 -0
  558. package/es/core/global.d.ts +4 -2
  559. package/es/core/global.js +7 -8
  560. package/es/core/global.js.map +1 -1
  561. package/es/core/graphic-utils.d.ts +3 -4
  562. package/es/core/graphic-utils.js +6 -11
  563. package/es/core/graphic-utils.js.map +1 -1
  564. package/es/core/layer-service.d.ts +7 -2
  565. package/es/core/layer-service.js +23 -17
  566. package/es/core/layer-service.js.map +1 -1
  567. package/es/core/layer.d.ts +1 -1
  568. package/es/core/layer.js +3 -3
  569. package/es/core/layer.js.map +1 -1
  570. package/es/core/stage.d.ts +17 -3
  571. package/es/core/stage.js +58 -30
  572. package/es/core/stage.js.map +1 -1
  573. package/es/core/window.d.ts +7 -5
  574. package/es/core/window.js +11 -9
  575. package/es/core/window.js.map +1 -1
  576. package/es/create.d.ts +1 -2
  577. package/es/create.js +4 -2
  578. package/es/create.js.map +1 -1
  579. package/es/entries/app-context.d.ts +30 -0
  580. package/es/entries/app-context.js +86 -0
  581. package/es/entries/app-context.js.map +1 -0
  582. package/es/entries/browser.d.ts +25 -0
  583. package/es/entries/browser.js +36 -0
  584. package/es/entries/browser.js.map +1 -0
  585. package/es/entries/index.d.ts +7 -0
  586. package/es/entries/index.js +14 -0
  587. package/es/entries/index.js.map +1 -0
  588. package/es/entries/miniapp.d.ts +6 -0
  589. package/es/entries/miniapp.js +12 -0
  590. package/es/entries/miniapp.js.map +1 -0
  591. package/es/entries/node.d.ts +6 -0
  592. package/es/entries/node.js +12 -0
  593. package/es/entries/node.js.map +1 -0
  594. package/es/entries/runtime-installer.d.ts +11 -0
  595. package/es/entries/runtime-installer.js +130 -0
  596. package/es/entries/runtime-installer.js.map +1 -0
  597. package/es/entries/types.d.ts +29 -0
  598. package/es/entries/types.js.map +1 -0
  599. package/es/env-check.js +3 -3
  600. package/es/env-check.js.map +1 -1
  601. package/es/event/event-manager.js +4 -1
  602. package/es/event/event-manager.js.map +1 -1
  603. package/es/event/util.d.ts +1 -1
  604. package/es/factory/graphic-factory.d.ts +7 -0
  605. package/es/factory/graphic-factory.js +15 -0
  606. package/es/factory/graphic-factory.js.map +1 -0
  607. package/es/factory/index.d.ts +4 -0
  608. package/es/factory/index.js +8 -0
  609. package/es/factory/index.js.map +1 -0
  610. package/es/factory/layer-factory.d.ts +7 -0
  611. package/es/factory/layer-factory.js +11 -0
  612. package/es/factory/layer-factory.js.map +1 -0
  613. package/es/factory/stage-factory.d.ts +8 -0
  614. package/es/factory/stage-factory.js +12 -0
  615. package/es/factory/stage-factory.js.map +1 -0
  616. package/es/factory/types.d.ts +34 -0
  617. package/es/factory/types.js +2 -0
  618. package/es/factory/types.js.map +1 -0
  619. package/es/factory.d.ts +1 -0
  620. package/es/factory.js +2 -0
  621. package/es/factory.js.map +1 -1
  622. package/es/global.d.ts +2 -0
  623. package/es/global.js +10 -0
  624. package/es/global.js.map +1 -0
  625. package/es/graphic/arc.js +3 -3
  626. package/es/graphic/arc.js.map +1 -1
  627. package/es/graphic/arc3d.js +4 -3
  628. package/es/graphic/arc3d.js.map +1 -1
  629. package/es/graphic/area.js +3 -3
  630. package/es/graphic/area.js.map +1 -1
  631. package/es/graphic/bounds.js +3 -3
  632. package/es/graphic/bounds.js.map +1 -1
  633. package/es/graphic/circle.js +3 -3
  634. package/es/graphic/circle.js.map +1 -1
  635. package/es/graphic/config.js +7 -1
  636. package/es/graphic/config.js.map +1 -1
  637. package/es/graphic/glyph.js +9 -3
  638. package/es/graphic/glyph.js.map +1 -1
  639. package/es/graphic/graphic-creator.d.ts +9 -4
  640. package/es/graphic/graphic-creator.js +32 -5
  641. package/es/graphic/graphic-creator.js.map +1 -1
  642. package/es/graphic/graphic-service/graphic-module.d.ts +4 -0
  643. package/es/graphic/graphic-service/graphic-module.js +12 -0
  644. package/es/graphic/graphic-service/graphic-module.js.map +1 -0
  645. package/es/graphic/graphic-service/graphic-service.d.ts +2 -3
  646. package/es/graphic/graphic-service/graphic-service.js +3 -5
  647. package/es/graphic/graphic-service/graphic-service.js.map +1 -1
  648. package/es/graphic/graphic.d.ts +78 -7
  649. package/es/graphic/graphic.js +490 -140
  650. package/es/graphic/graphic.js.map +1 -1
  651. package/es/graphic/group.d.ts +11 -1
  652. package/es/graphic/group.js +49 -13
  653. package/es/graphic/group.js.map +1 -1
  654. package/es/graphic/image.d.ts +1 -0
  655. package/es/graphic/image.js +5 -4
  656. package/es/graphic/image.js.map +1 -1
  657. package/es/graphic/index.d.ts +3 -0
  658. package/es/graphic/index.js +4 -0
  659. package/es/graphic/index.js.map +1 -1
  660. package/es/graphic/line.js +3 -3
  661. package/es/graphic/line.js.map +1 -1
  662. package/es/graphic/path.js +3 -3
  663. package/es/graphic/path.js.map +1 -1
  664. package/es/graphic/polygon.js +3 -3
  665. package/es/graphic/polygon.js.map +1 -1
  666. package/es/graphic/pyramid3d.js +2 -2
  667. package/es/graphic/pyramid3d.js.map +1 -1
  668. package/es/graphic/rect.js +3 -3
  669. package/es/graphic/rect.js.map +1 -1
  670. package/es/graphic/richtext/utils.js +3 -3
  671. package/es/graphic/richtext/utils.js.map +1 -1
  672. package/es/graphic/richtext.js +4 -4
  673. package/es/graphic/richtext.js.map +1 -1
  674. package/es/graphic/star.js +3 -3
  675. package/es/graphic/star.js.map +1 -1
  676. package/es/graphic/state/attribute-update-classifier.d.ts +13 -0
  677. package/es/graphic/state/attribute-update-classifier.js +61 -0
  678. package/es/graphic/state/attribute-update-classifier.js.map +1 -0
  679. package/es/graphic/state/shared-state-refresh.d.ts +6 -0
  680. package/es/graphic/state/shared-state-refresh.js +46 -0
  681. package/es/graphic/state/shared-state-refresh.js.map +1 -0
  682. package/es/graphic/state/shared-state-scope.d.ts +25 -0
  683. package/es/graphic/state/shared-state-scope.js +90 -0
  684. package/es/graphic/state/shared-state-scope.js.map +1 -0
  685. package/es/graphic/state/state-batch-scheduler.d.ts +42 -0
  686. package/es/graphic/state/state-batch-scheduler.js +278 -0
  687. package/es/graphic/state/state-batch-scheduler.js.map +1 -0
  688. package/es/graphic/state/state-definition-compiler.d.ts +6 -0
  689. package/es/graphic/state/state-definition-compiler.js +83 -0
  690. package/es/graphic/state/state-definition-compiler.js.map +1 -0
  691. package/es/graphic/state/state-definition.d.ts +44 -0
  692. package/es/graphic/state/state-definition.js +2 -0
  693. package/es/graphic/state/state-definition.js.map +1 -0
  694. package/es/graphic/state/state-engine.d.ts +38 -0
  695. package/es/graphic/state/state-engine.js +212 -0
  696. package/es/graphic/state/state-engine.js.map +1 -0
  697. package/es/graphic/state/state-model.d.ts +43 -0
  698. package/es/graphic/state/state-model.js +135 -0
  699. package/es/graphic/state/state-model.js.map +1 -0
  700. package/es/graphic/state/state-perf-monitor.d.ts +119 -0
  701. package/es/graphic/state/state-perf-monitor.js +207 -0
  702. package/es/graphic/state/state-perf-monitor.js.map +1 -0
  703. package/es/graphic/state/state-style-resolver.d.ts +22 -0
  704. package/es/graphic/state/state-style-resolver.js +65 -0
  705. package/es/graphic/state/state-style-resolver.js.map +1 -0
  706. package/es/graphic/state/state-transition-orchestrator.d.ts +41 -0
  707. package/es/graphic/state/state-transition-orchestrator.js +68 -0
  708. package/es/graphic/state/state-transition-orchestrator.js.map +1 -0
  709. package/es/graphic/symbol.js +3 -3
  710. package/es/graphic/symbol.js.map +1 -1
  711. package/es/graphic/text.d.ts +3 -2
  712. package/es/graphic/text.js +28 -19
  713. package/es/graphic/text.js.map +1 -1
  714. package/es/graphic/theme.d.ts +5 -0
  715. package/es/graphic/theme.js +7 -0
  716. package/es/graphic/theme.js.map +1 -1
  717. package/es/graphic/tools.js +2 -2
  718. package/es/graphic/tools.js.map +1 -1
  719. package/es/graphic/wrap-text.d.ts +1 -1
  720. package/es/graphic/wrap-text.js +20 -15
  721. package/es/graphic/wrap-text.js.map +1 -1
  722. package/es/index.d.ts +26 -4
  723. package/es/index.js +49 -5
  724. package/es/index.js.map +1 -1
  725. package/es/interface/canvas.d.ts +1 -1
  726. package/es/interface/canvas.js.map +1 -1
  727. package/es/interface/global.d.ts +2 -0
  728. package/es/interface/global.js.map +1 -1
  729. package/es/interface/graphic/group.d.ts +6 -0
  730. package/es/interface/graphic/group.js.map +1 -1
  731. package/es/interface/graphic/image.d.ts +7 -1
  732. package/es/interface/graphic/image.js.map +1 -1
  733. package/es/interface/graphic/theme.d.ts +3 -0
  734. package/es/interface/graphic/theme.js.map +1 -1
  735. package/es/interface/graphic.d.ts +34 -5
  736. package/es/interface/graphic.js.map +1 -1
  737. package/es/interface/layer.d.ts +3 -2
  738. package/es/interface/layer.js.map +1 -1
  739. package/es/interface/plugin.d.ts +2 -0
  740. package/es/interface/plugin.js.map +1 -1
  741. package/es/interface/render.d.ts +1 -1
  742. package/es/interface/render.js.map +1 -1
  743. package/es/interface/stage.d.ts +9 -0
  744. package/es/interface/stage.js.map +1 -1
  745. package/es/interface/theme-service.js.map +1 -1
  746. package/es/legacy/binding-context.d.ts +24 -0
  747. package/es/legacy/binding-context.js +90 -0
  748. package/es/legacy/binding-context.js.map +1 -0
  749. package/es/legacy/bootstrap.d.ts +10 -0
  750. package/es/legacy/bootstrap.js +73 -0
  751. package/es/legacy/bootstrap.js.map +1 -0
  752. package/es/legacy/module-types.d.ts +2 -0
  753. package/es/legacy/module-types.js +2 -0
  754. package/es/legacy/module-types.js.map +1 -0
  755. package/es/modules.d.ts +5 -6
  756. package/es/modules.js +44 -14
  757. package/es/modules.js.map +1 -1
  758. package/es/picker/global-picker-service.js +2 -2
  759. package/es/picker/global-picker-service.js.map +1 -1
  760. package/es/picker/pick-modules.d.ts +5 -0
  761. package/es/picker/pick-modules.js +18 -0
  762. package/es/picker/pick-modules.js.map +1 -0
  763. package/es/picker/picker-service.d.ts +13 -4
  764. package/es/picker/picker-service.js +16 -11
  765. package/es/picker/picker-service.js.map +1 -1
  766. package/es/plugins/base-plugin.d.ts +8 -0
  767. package/es/plugins/base-plugin.js +7 -0
  768. package/es/plugins/base-plugin.js.map +1 -0
  769. package/es/plugins/browser-env-plugin.d.ts +8 -0
  770. package/es/plugins/browser-env-plugin.js +16 -0
  771. package/es/plugins/browser-env-plugin.js.map +1 -0
  772. package/es/plugins/builtin-plugin/auto-refresh-plugin.js +6 -6
  773. package/es/plugins/builtin-plugin/auto-refresh-plugin.js.map +1 -1
  774. package/es/plugins/builtin-plugin/auto-render-plugin.js.map +1 -1
  775. package/es/plugins/builtin-plugin/dirty-bounds-plugin.d.ts +4 -1
  776. package/es/plugins/builtin-plugin/dirty-bounds-plugin.js +26 -3
  777. package/es/plugins/builtin-plugin/dirty-bounds-plugin.js.map +1 -1
  778. package/es/plugins/builtin-plugin/edit-module.js +3 -3
  779. package/es/plugins/builtin-plugin/edit-module.js.map +1 -1
  780. package/es/plugins/builtin-plugin/flex-layout-plugin.js.map +1 -1
  781. package/es/plugins/builtin-plugin/html-attribute-plugin.js +8 -8
  782. package/es/plugins/builtin-plugin/html-attribute-plugin.js.map +1 -1
  783. package/es/plugins/builtin-plugin/incremental-auto-render-plugin.js +2 -2
  784. package/es/plugins/builtin-plugin/incremental-auto-render-plugin.js.map +1 -1
  785. package/es/plugins/builtin-plugin/react-attribute-plugin.js +3 -3
  786. package/es/plugins/builtin-plugin/react-attribute-plugin.js.map +1 -1
  787. package/es/plugins/builtin-plugin/richtext-edit-plugin.js +9 -7
  788. package/es/plugins/builtin-plugin/richtext-edit-plugin.js.map +1 -1
  789. package/es/plugins/index.d.ts +5 -0
  790. package/es/plugins/index.js +10 -0
  791. package/es/plugins/index.js.map +1 -0
  792. package/es/plugins/picker-plugin.d.ts +7 -0
  793. package/es/plugins/picker-plugin.js +11 -0
  794. package/es/plugins/picker-plugin.js.map +1 -0
  795. package/es/plugins/plugin-modules.d.ts +4 -0
  796. package/es/plugins/plugin-modules.js +14 -0
  797. package/es/plugins/plugin-modules.js.map +1 -0
  798. package/es/plugins/plugin-service.d.ts +16 -2
  799. package/es/plugins/plugin-service.js +24 -12
  800. package/es/plugins/plugin-service.js.map +1 -1
  801. package/es/plugins/renderer-plugin.d.ts +7 -0
  802. package/es/plugins/renderer-plugin.js +11 -0
  803. package/es/plugins/renderer-plugin.js.map +1 -0
  804. package/es/plugins/types.d.ts +28 -0
  805. package/es/plugins/types.js +2 -0
  806. package/es/plugins/types.js.map +1 -0
  807. package/es/register/register-arc.js +2 -2
  808. package/es/register/register-arc.js.map +1 -1
  809. package/es/register/register-arc3d.js +2 -2
  810. package/es/register/register-arc3d.js.map +1 -1
  811. package/es/register/register-area.js +2 -2
  812. package/es/register/register-area.js.map +1 -1
  813. package/es/register/register-circle.js +2 -2
  814. package/es/register/register-circle.js.map +1 -1
  815. package/es/register/register-glyph.js +2 -2
  816. package/es/register/register-glyph.js.map +1 -1
  817. package/es/register/register-group.js +2 -2
  818. package/es/register/register-group.js.map +1 -1
  819. package/es/register/register-image.js +2 -2
  820. package/es/register/register-image.js.map +1 -1
  821. package/es/register/register-line.js +2 -2
  822. package/es/register/register-line.js.map +1 -1
  823. package/es/register/register-path.js +2 -2
  824. package/es/register/register-path.js.map +1 -1
  825. package/es/register/register-polygon.js +2 -2
  826. package/es/register/register-polygon.js.map +1 -1
  827. package/es/register/register-pyramid3d.js +2 -2
  828. package/es/register/register-pyramid3d.js.map +1 -1
  829. package/es/register/register-rect.js +2 -2
  830. package/es/register/register-rect.js.map +1 -1
  831. package/es/register/register-rect3d.js +2 -2
  832. package/es/register/register-rect3d.js.map +1 -1
  833. package/es/register/register-richtext.js +2 -2
  834. package/es/register/register-richtext.js.map +1 -1
  835. package/es/register/register-shadowRoot.js +2 -2
  836. package/es/register/register-shadowRoot.js.map +1 -1
  837. package/es/register/register-star.js +2 -2
  838. package/es/register/register-star.js.map +1 -1
  839. package/es/register/register-symbol.js +2 -2
  840. package/es/register/register-symbol.js.map +1 -1
  841. package/es/register/register-text.js +2 -2
  842. package/es/register/register-text.js.map +1 -1
  843. package/es/register/register-wraptext.js +2 -2
  844. package/es/register/register-wraptext.js.map +1 -1
  845. package/es/registry/contribution-registry.d.ts +9 -0
  846. package/es/registry/contribution-registry.js +25 -0
  847. package/es/registry/contribution-registry.js.map +1 -0
  848. package/es/registry/index.d.ts +5 -0
  849. package/es/registry/index.js +10 -0
  850. package/es/registry/index.js.map +1 -0
  851. package/es/registry/picker-registry.d.ts +10 -0
  852. package/es/registry/picker-registry.js +21 -0
  853. package/es/registry/picker-registry.js.map +1 -0
  854. package/es/registry/plugin-registry.d.ts +10 -0
  855. package/es/registry/plugin-registry.js +21 -0
  856. package/es/registry/plugin-registry.js.map +1 -0
  857. package/es/registry/renderer-registry.d.ts +11 -0
  858. package/es/registry/renderer-registry.js +29 -0
  859. package/es/registry/renderer-registry.js.map +1 -0
  860. package/es/registry/types.d.ts +34 -0
  861. package/es/registry/types.js +2 -0
  862. package/es/registry/types.js.map +1 -0
  863. package/es/render/contributions/modules.d.ts +2 -0
  864. package/es/render/contributions/modules.js +8 -0
  865. package/es/render/contributions/modules.js.map +1 -0
  866. package/es/render/contributions/render/arc-module.d.ts +4 -0
  867. package/es/render/contributions/render/arc-module.js +21 -0
  868. package/es/render/contributions/render/arc-module.js.map +1 -0
  869. package/es/render/contributions/render/arc-render.d.ts +2 -2
  870. package/es/render/contributions/render/arc-render.js +3 -8
  871. package/es/render/contributions/render/arc-render.js.map +1 -1
  872. package/es/render/contributions/render/arc3d-module.d.ts +4 -0
  873. package/es/render/contributions/render/arc3d-module.js +13 -0
  874. package/es/render/contributions/render/arc3d-module.js.map +1 -0
  875. package/es/render/contributions/render/area-module.d.ts +4 -0
  876. package/es/render/contributions/render/area-module.js +23 -0
  877. package/es/render/contributions/render/area-module.js.map +1 -0
  878. package/es/render/contributions/render/area-render.d.ts +2 -2
  879. package/es/render/contributions/render/area-render.js +3 -8
  880. package/es/render/contributions/render/area-render.js.map +1 -1
  881. package/es/render/contributions/render/base-render.js +1 -1
  882. package/es/render/contributions/render/base-render.js.map +1 -1
  883. package/es/render/contributions/render/circle-module.d.ts +4 -0
  884. package/es/render/contributions/render/circle-module.js +21 -0
  885. package/es/render/contributions/render/circle-module.js.map +1 -0
  886. package/es/render/contributions/render/circle-render.d.ts +2 -2
  887. package/es/render/contributions/render/circle-render.js +3 -8
  888. package/es/render/contributions/render/circle-render.js.map +1 -1
  889. package/es/render/contributions/render/contributions/base-contribution-render.d.ts +29 -11
  890. package/es/render/contributions/render/contributions/base-contribution-render.js +142 -41
  891. package/es/render/contributions/render/contributions/base-contribution-render.js.map +1 -1
  892. package/es/render/contributions/render/contributions/base-texture-contribution-render.d.ts +4 -2
  893. package/es/render/contributions/render/contributions/base-texture-contribution-render.js +85 -30
  894. package/es/render/contributions/render/contributions/base-texture-contribution-render.js.map +1 -1
  895. package/es/render/contributions/render/contributions/group-contribution-render.js +9 -7
  896. package/es/render/contributions/render/contributions/group-contribution-render.js.map +1 -1
  897. package/es/render/contributions/render/contributions/image-contribution-render.d.ts +2 -1
  898. package/es/render/contributions/render/contributions/image-contribution-render.js.map +1 -1
  899. package/es/render/contributions/render/contributions/text-contribution-render.js +20 -16
  900. package/es/render/contributions/render/contributions/text-contribution-render.js.map +1 -1
  901. package/es/render/contributions/render/draw-contribution.d.ts +13 -4
  902. package/es/render/contributions/render/draw-contribution.js +40 -19
  903. package/es/render/contributions/render/draw-contribution.js.map +1 -1
  904. package/es/render/contributions/render/draw-interceptor.js +2 -3
  905. package/es/render/contributions/render/draw-interceptor.js.map +1 -1
  906. package/es/render/contributions/render/glyph-module.d.ts +4 -0
  907. package/es/render/contributions/render/glyph-module.js +13 -0
  908. package/es/render/contributions/render/glyph-module.js.map +1 -0
  909. package/es/render/contributions/render/group-render.d.ts +2 -2
  910. package/es/render/contributions/render/group-render.js +3 -9
  911. package/es/render/contributions/render/group-render.js.map +1 -1
  912. package/es/render/contributions/render/image-module.d.ts +4 -0
  913. package/es/render/contributions/render/image-module.js +20 -0
  914. package/es/render/contributions/render/image-module.js.map +1 -0
  915. package/es/render/contributions/render/image-render.d.ts +16 -3
  916. package/es/render/contributions/render/image-render.js +95 -25
  917. package/es/render/contributions/render/image-render.js.map +1 -1
  918. package/es/render/contributions/render/incremental-draw-contribution.d.ts +5 -3
  919. package/es/render/contributions/render/incremental-draw-contribution.js +4 -12
  920. package/es/render/contributions/render/incremental-draw-contribution.js.map +1 -1
  921. package/es/render/contributions/render/index.d.ts +4 -12
  922. package/es/render/contributions/render/index.js +8 -24
  923. package/es/render/contributions/render/index.js.map +1 -1
  924. package/es/render/contributions/render/line-module.d.ts +4 -0
  925. package/es/render/contributions/render/line-module.js +16 -0
  926. package/es/render/contributions/render/line-module.js.map +1 -0
  927. package/es/render/contributions/render/module.d.ts +4 -0
  928. package/es/render/contributions/render/module.js +28 -0
  929. package/es/render/contributions/render/module.js.map +1 -0
  930. package/es/render/contributions/render/path-module.d.ts +4 -0
  931. package/es/render/contributions/render/path-module.js +21 -0
  932. package/es/render/contributions/render/path-module.js.map +1 -0
  933. package/es/render/contributions/render/path-render.d.ts +2 -2
  934. package/es/render/contributions/render/path-render.js +3 -8
  935. package/es/render/contributions/render/path-render.js.map +1 -1
  936. package/es/render/contributions/render/polygon-module.d.ts +4 -0
  937. package/es/render/contributions/render/polygon-module.js +20 -0
  938. package/es/render/contributions/render/polygon-module.js.map +1 -0
  939. package/es/render/contributions/render/polygon-render.d.ts +2 -2
  940. package/es/render/contributions/render/polygon-render.js +3 -8
  941. package/es/render/contributions/render/polygon-render.js.map +1 -1
  942. package/es/render/contributions/render/pyramid3d-module.d.ts +4 -0
  943. package/es/render/contributions/render/pyramid3d-module.js +13 -0
  944. package/es/render/contributions/render/pyramid3d-module.js.map +1 -0
  945. package/es/render/contributions/render/rect-module.d.ts +4 -0
  946. package/es/render/contributions/render/rect-module.js +23 -0
  947. package/es/render/contributions/render/rect-module.js.map +1 -0
  948. package/es/render/contributions/render/rect-render.d.ts +2 -2
  949. package/es/render/contributions/render/rect-render.js +3 -8
  950. package/es/render/contributions/render/rect-render.js.map +1 -1
  951. package/es/render/contributions/render/rect3d-module.d.ts +4 -0
  952. package/es/render/contributions/render/rect3d-module.js +13 -0
  953. package/es/render/contributions/render/rect3d-module.js.map +1 -0
  954. package/es/render/contributions/render/rect3d-render.js.map +1 -1
  955. package/es/render/contributions/render/render-slector.js.map +1 -1
  956. package/es/render/contributions/render/richtext-module.d.ts +4 -0
  957. package/es/render/contributions/render/richtext-module.js +13 -0
  958. package/es/render/contributions/render/richtext-module.js.map +1 -0
  959. package/es/render/contributions/render/star-module.d.ts +4 -0
  960. package/es/render/contributions/render/star-module.js +17 -0
  961. package/es/render/contributions/render/star-module.js.map +1 -0
  962. package/es/render/contributions/render/star-render.d.ts +2 -2
  963. package/es/render/contributions/render/star-render.js +3 -8
  964. package/es/render/contributions/render/star-render.js.map +1 -1
  965. package/es/render/contributions/render/symbol-module.d.ts +4 -0
  966. package/es/render/contributions/render/symbol-module.js +21 -0
  967. package/es/render/contributions/render/symbol-module.js.map +1 -0
  968. package/es/render/contributions/render/symbol-render.d.ts +2 -2
  969. package/es/render/contributions/render/symbol-render.js +3 -8
  970. package/es/render/contributions/render/symbol-render.js.map +1 -1
  971. package/es/render/contributions/render/symbol.d.ts +0 -2
  972. package/es/render/contributions/render/symbol.js +0 -4
  973. package/es/render/contributions/render/symbol.js.map +1 -1
  974. package/es/render/contributions/render/text-module.d.ts +4 -0
  975. package/es/render/contributions/render/text-module.js +20 -0
  976. package/es/render/contributions/render/text-module.js.map +1 -0
  977. package/es/render/contributions/render/text-render.d.ts +2 -2
  978. package/es/render/contributions/render/text-render.js +2 -7
  979. package/es/render/contributions/render/text-render.js.map +1 -1
  980. package/es/render/render-modules.d.ts +4 -0
  981. package/es/render/render-modules.js +10 -0
  982. package/es/render/render-modules.js.map +1 -0
  983. package/es/render/render-service.d.ts +1 -1
  984. package/es/render/render-service.js +3 -1
  985. package/es/render/render-service.js.map +1 -1
  986. package/es/resource-loader/loader.js +6 -6
  987. package/es/resource-loader/loader.js.map +1 -1
  988. package/package.json +8 -7
  989. package/cjs/common/registry/contribution-registry.d.ts +0 -24
  990. package/cjs/common/registry/contribution-registry.js +0 -61
  991. package/cjs/common/registry/contribution-registry.js.map +0 -1
  992. package/cjs/common/registry/index.d.ts +0 -5
  993. package/cjs/common/registry/index.js +0 -34
  994. package/cjs/common/registry/index.js.map +0 -1
  995. package/cjs/common/registry/service-registry.d.ts +0 -16
  996. package/cjs/common/registry/service-registry.js +0 -57
  997. package/cjs/common/registry/service-registry.js.map +0 -1
  998. package/cjs/common/registry/types.d.ts +0 -1
  999. package/cjs/common/registry/types.js.map +0 -1
  1000. package/cjs/register-modules.d.ts +0 -9
  1001. package/cjs/register-modules.js +0 -79
  1002. package/cjs/register-modules.js.map +0 -1
  1003. package/es/common/registry/contribution-registry.d.ts +0 -24
  1004. package/es/common/registry/contribution-registry.js +0 -55
  1005. package/es/common/registry/contribution-registry.js.map +0 -1
  1006. package/es/common/registry/index.d.ts +0 -5
  1007. package/es/common/registry/index.js +0 -4
  1008. package/es/common/registry/index.js.map +0 -1
  1009. package/es/common/registry/service-registry.d.ts +0 -16
  1010. package/es/common/registry/service-registry.js +0 -51
  1011. package/es/common/registry/service-registry.js.map +0 -1
  1012. package/es/common/registry/types.d.ts +0 -1
  1013. package/es/common/registry/types.js.map +0 -1
  1014. package/es/register-modules.d.ts +0 -9
  1015. package/es/register-modules.js +0 -117
  1016. package/es/register-modules.js.map +0 -1
  1017. /package/cjs/{common/registry → entries}/types.js +0 -0
  1018. /package/es/{common/registry → entries}/types.js +0 -0
@@ -0,0 +1,61 @@
1
+ export var UpdateCategory;
2
+
3
+ !function(UpdateCategory) {
4
+ UpdateCategory[UpdateCategory.NONE = 0] = "NONE", UpdateCategory[UpdateCategory.PAINT = 1] = "PAINT",
5
+ UpdateCategory[UpdateCategory.SHAPE = 2] = "SHAPE", UpdateCategory[UpdateCategory.BOUNDS = 4] = "BOUNDS",
6
+ UpdateCategory[UpdateCategory.TRANSFORM = 8] = "TRANSFORM", UpdateCategory[UpdateCategory.LAYOUT = 16] = "LAYOUT",
7
+ UpdateCategory[UpdateCategory.PICK = 32] = "PICK";
8
+ }(UpdateCategory || (UpdateCategory = {}));
9
+
10
+ export const ATTRIBUTE_CATEGORY = {
11
+ fill: UpdateCategory.PAINT,
12
+ opacity: UpdateCategory.PAINT,
13
+ fillOpacity: UpdateCategory.PAINT,
14
+ strokeOpacity: UpdateCategory.PAINT,
15
+ lineDash: UpdateCategory.PAINT,
16
+ lineDashOffset: UpdateCategory.PAINT,
17
+ lineCap: UpdateCategory.PAINT,
18
+ lineJoin: UpdateCategory.PAINT,
19
+ miterLimit: UpdateCategory.PAINT,
20
+ shadowColor: UpdateCategory.PAINT,
21
+ x: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,
22
+ y: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,
23
+ scaleX: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,
24
+ scaleY: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,
25
+ angle: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,
26
+ anchor: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,
27
+ anchor3d: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,
28
+ postMatrix: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,
29
+ layout: UpdateCategory.LAYOUT,
30
+ zIndex: UpdateCategory.PAINT,
31
+ visible: UpdateCategory.PAINT | UpdateCategory.PICK,
32
+ lineWidth: UpdateCategory.SHAPE | UpdateCategory.BOUNDS | UpdateCategory.PICK,
33
+ width: UpdateCategory.SHAPE | UpdateCategory.BOUNDS,
34
+ height: UpdateCategory.SHAPE | UpdateCategory.BOUNDS
35
+ };
36
+
37
+ const ATTRIBUTE_DELTA_CLASSIFIER = {
38
+ stroke: (prev, next) => (null != prev && !1 !== prev) !== (null != next && !1 !== next) ? UpdateCategory.PAINT | UpdateCategory.BOUNDS | UpdateCategory.PICK : UpdateCategory.PAINT,
39
+ shadowBlur: (prev, next) => {
40
+ const prevBlur = Number(null != prev ? prev : 0), nextBlur = Number(null != next ? next : 0);
41
+ return prevBlur !== nextBlur && (prevBlur > 0 || nextBlur > 0) ? UpdateCategory.PAINT | UpdateCategory.BOUNDS : UpdateCategory.PAINT;
42
+ }
43
+ };
44
+
45
+ export function classifyAttributeDelta(key, prev, next) {
46
+ var _a;
47
+ const dynamicClassifier = ATTRIBUTE_DELTA_CLASSIFIER[key];
48
+ return dynamicClassifier ? dynamicClassifier(prev, next) : null !== (_a = ATTRIBUTE_CATEGORY[key]) && void 0 !== _a ? _a : UpdateCategory.PAINT;
49
+ }
50
+
51
+ export function classifyAffectedKeyConservatively(key) {
52
+ var _a;
53
+ return "stroke" === key ? UpdateCategory.PAINT | UpdateCategory.BOUNDS | UpdateCategory.PICK : "shadowBlur" === key ? UpdateCategory.PAINT | UpdateCategory.BOUNDS : null !== (_a = ATTRIBUTE_CATEGORY[key]) && void 0 !== _a ? _a : UpdateCategory.PAINT;
54
+ }
55
+
56
+ export function classifyAffectedKeys(keys) {
57
+ let category = UpdateCategory.NONE;
58
+ for (const key of keys) category |= classifyAffectedKeyConservatively(key);
59
+ return category;
60
+ }
61
+ //# sourceMappingURL=attribute-update-classifier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/graphic/state/attribute-update-classifier.ts"],"names":[],"mappings":"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","file":"attribute-update-classifier.js","sourcesContent":["export enum UpdateCategory {\n NONE = 0,\n PAINT = 1 << 0,\n SHAPE = 1 << 1,\n BOUNDS = 1 << 2,\n TRANSFORM = 1 << 3,\n LAYOUT = 1 << 4,\n PICK = 1 << 5\n}\n\ntype AttributeDeltaClassifier = (prev: unknown, next: unknown) => UpdateCategory;\n\nexport const ATTRIBUTE_CATEGORY: Record<string, UpdateCategory> = {\n fill: UpdateCategory.PAINT,\n opacity: UpdateCategory.PAINT,\n fillOpacity: UpdateCategory.PAINT,\n strokeOpacity: UpdateCategory.PAINT,\n lineDash: UpdateCategory.PAINT,\n lineDashOffset: UpdateCategory.PAINT,\n lineCap: UpdateCategory.PAINT,\n lineJoin: UpdateCategory.PAINT,\n miterLimit: UpdateCategory.PAINT,\n shadowColor: UpdateCategory.PAINT,\n x: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,\n y: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,\n scaleX: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,\n scaleY: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,\n angle: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,\n anchor: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,\n anchor3d: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,\n postMatrix: UpdateCategory.TRANSFORM | UpdateCategory.BOUNDS,\n layout: UpdateCategory.LAYOUT,\n zIndex: UpdateCategory.PAINT,\n visible: UpdateCategory.PAINT | UpdateCategory.PICK,\n lineWidth: UpdateCategory.SHAPE | UpdateCategory.BOUNDS | UpdateCategory.PICK,\n width: UpdateCategory.SHAPE | UpdateCategory.BOUNDS,\n height: UpdateCategory.SHAPE | UpdateCategory.BOUNDS\n};\n\nconst ATTRIBUTE_DELTA_CLASSIFIER: Record<string, AttributeDeltaClassifier> = {\n stroke: (prev, next) => {\n const prevEnabled = prev != null && prev !== false;\n const nextEnabled = next != null && next !== false;\n if (prevEnabled !== nextEnabled) {\n return UpdateCategory.PAINT | UpdateCategory.BOUNDS | UpdateCategory.PICK;\n }\n return UpdateCategory.PAINT;\n },\n shadowBlur: (prev, next) => {\n const prevBlur = Number(prev ?? 0);\n const nextBlur = Number(next ?? 0);\n if (prevBlur !== nextBlur && (prevBlur > 0 || nextBlur > 0)) {\n return UpdateCategory.PAINT | UpdateCategory.BOUNDS;\n }\n return UpdateCategory.PAINT;\n }\n};\n\nexport function classifyAttributeDelta(key: string, prev: unknown, next: unknown): UpdateCategory {\n const dynamicClassifier = ATTRIBUTE_DELTA_CLASSIFIER[key];\n if (dynamicClassifier) {\n return dynamicClassifier(prev, next);\n }\n\n return ATTRIBUTE_CATEGORY[key] ?? UpdateCategory.PAINT;\n}\n\nexport function classifyAffectedKeyConservatively(key: string): UpdateCategory {\n if (key === 'stroke') {\n return UpdateCategory.PAINT | UpdateCategory.BOUNDS | UpdateCategory.PICK;\n }\n\n if (key === 'shadowBlur') {\n return UpdateCategory.PAINT | UpdateCategory.BOUNDS;\n }\n\n return ATTRIBUTE_CATEGORY[key] ?? UpdateCategory.PAINT;\n}\n\nexport function classifyAffectedKeys(keys: Iterable<string>): UpdateCategory {\n let category = UpdateCategory.NONE;\n for (const key of keys) {\n category |= classifyAffectedKeyConservatively(key);\n }\n return category;\n}\n"]}
@@ -0,0 +1,6 @@
1
+ import type { IGraphic, IStage } from '../../interface';
2
+ import type { SharedStateScope } from './shared-state-scope';
3
+ export declare function scheduleStageSharedStateRefresh(stage: IStage | undefined): void;
4
+ export declare function enqueueGraphicSharedStateRefresh(stage: IStage | undefined, graphic: IGraphic): void;
5
+ export declare function markScopeActiveDescendantsDirty<T extends Record<string, any> = Record<string, any>>(scope: SharedStateScope<T>, stage?: IStage): void;
6
+ export declare function flushStageSharedStateRefresh(stage: IStage): void;
@@ -0,0 +1,46 @@
1
+ import { getStageStatePerfMonitor } from "./state-perf-monitor";
2
+
3
+ export function scheduleStageSharedStateRefresh(stage) {
4
+ var _a;
5
+ stage && "released" !== stage.releaseStatus && (null === (_a = getStageStatePerfMonitor(stage)) || void 0 === _a || _a.recordRefresh("renderScheduled"),
6
+ stage.renderNextFrame());
7
+ }
8
+
9
+ export function enqueueGraphicSharedStateRefresh(stage, graphic) {
10
+ var _a;
11
+ if (!stage) return;
12
+ const pending = null !== (_a = stage._pendingSharedStateRefreshGraphics) && void 0 !== _a ? _a : stage._pendingSharedStateRefreshGraphics = new Set;
13
+ if (!pending.has(graphic)) {
14
+ pending.add(graphic);
15
+ const perfMonitor = getStageStatePerfMonitor(stage);
16
+ null == perfMonitor || perfMonitor.recordRefresh("queuedGraphics"), null == perfMonitor || perfMonitor.recordAllocation("refreshQueuePushes");
17
+ }
18
+ }
19
+
20
+ export function markScopeActiveDescendantsDirty(scope, stage) {
21
+ let marked = !1;
22
+ scope.subtreeActiveDescendants.forEach((graphic => {
23
+ var _a;
24
+ graphic.sharedStateDirty = !0;
25
+ enqueueGraphicSharedStateRefresh(null !== (_a = null != stage ? stage : graphic.stage) && void 0 !== _a ? _a : scope.ownerStage, graphic),
26
+ marked = !0;
27
+ })), marked && scheduleStageSharedStateRefresh(null != stage ? stage : scope.ownerStage);
28
+ }
29
+
30
+ export function flushStageSharedStateRefresh(stage) {
31
+ const pending = stage._pendingSharedStateRefreshGraphics;
32
+ if (!pending || !pending.size) return;
33
+ const perfMonitor = getStageStatePerfMonitor(stage), start = perfMonitor ? performance.now() : 0, graphics = Array.from(pending.values());
34
+ pending.clear(), null == perfMonitor || perfMonitor.recordRefresh("flushedGraphics", graphics.length),
35
+ graphics.forEach((graphic => {
36
+ if ("released" === graphic.releaseStatus) return;
37
+ if (graphic.stage !== stage) return;
38
+ const refresh = graphic.refreshSharedStateBeforeRender;
39
+ "function" == typeof refresh && (refresh.call(graphic), null == perfMonitor || perfMonitor.incrementCounter("sharedRefreshCommits"));
40
+ })), perfMonitor && (perfMonitor.recordCost("sharedRefresh", performance.now() - start),
41
+ perfMonitor.recordEvent("shared-refresh-flush", {
42
+ stageId: stage._uid,
43
+ flushedGraphics: graphics.length
44
+ }));
45
+ }
46
+ //# sourceMappingURL=shared-state-refresh.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/graphic/state/shared-state-refresh.ts"],"names":[],"mappings":"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","file":"shared-state-refresh.js","sourcesContent":["import type { IGraphic, IStage } from '../../interface';\nimport type { SharedStateScope } from './shared-state-scope';\nimport { getStageStatePerfMonitor } from './state-perf-monitor';\n\nexport function scheduleStageSharedStateRefresh(stage: IStage | undefined): void {\n if (!stage || (stage as any).releaseStatus === 'released') {\n return;\n }\n\n getStageStatePerfMonitor(stage)?.recordRefresh('renderScheduled');\n stage.renderNextFrame();\n}\n\nexport function enqueueGraphicSharedStateRefresh(stage: IStage | undefined, graphic: IGraphic): void {\n if (!stage) {\n return;\n }\n\n const pending =\n ((stage as any)._pendingSharedStateRefreshGraphics as Set<IGraphic> | undefined) ??\n (((stage as any)._pendingSharedStateRefreshGraphics = new Set<IGraphic>()) as Set<IGraphic>);\n\n if (!pending.has(graphic)) {\n pending.add(graphic);\n const perfMonitor = getStageStatePerfMonitor(stage);\n perfMonitor?.recordRefresh('queuedGraphics');\n perfMonitor?.recordAllocation('refreshQueuePushes');\n }\n}\n\nexport function markScopeActiveDescendantsDirty<T extends Record<string, any> = Record<string, any>>(\n scope: SharedStateScope<T>,\n stage?: IStage\n): void {\n let marked = false;\n scope.subtreeActiveDescendants.forEach(graphic => {\n (graphic as any).sharedStateDirty = true;\n const ownerStage = stage ?? graphic.stage ?? scope.ownerStage;\n enqueueGraphicSharedStateRefresh(ownerStage, graphic);\n marked = true;\n });\n\n if (marked) {\n scheduleStageSharedStateRefresh(stage ?? scope.ownerStage);\n }\n}\n\nexport function flushStageSharedStateRefresh(stage: IStage): void {\n const pending = (stage as any)._pendingSharedStateRefreshGraphics as Set<IGraphic> | undefined;\n if (!pending || !pending.size) {\n return;\n }\n\n const perfMonitor = getStageStatePerfMonitor(stage);\n const start = perfMonitor ? performance.now() : 0;\n const graphics = Array.from(pending.values());\n pending.clear();\n perfMonitor?.recordRefresh('flushedGraphics', graphics.length);\n\n graphics.forEach(graphic => {\n if ((graphic as any).releaseStatus === 'released') {\n return;\n }\n if (graphic.stage !== stage) {\n return;\n }\n\n const refresh = (graphic as any).refreshSharedStateBeforeRender;\n if (typeof refresh === 'function') {\n refresh.call(graphic);\n perfMonitor?.incrementCounter('sharedRefreshCommits');\n }\n });\n\n if (perfMonitor) {\n perfMonitor.recordCost('sharedRefresh', performance.now() - start);\n perfMonitor.recordEvent('shared-refresh-flush', {\n stageId: (stage as any)._uid,\n flushedGraphics: graphics.length\n });\n }\n}\n"]}
@@ -0,0 +1,25 @@
1
+ import type { IGraphic, IStage } from '../../interface';
2
+ import type { IGroup } from '../../interface/graphic/group';
3
+ import type { CompiledStateDefinition, StateDefinitionsInput } from './state-definition';
4
+ export interface SharedStateScope<T extends Record<string, any> = Record<string, any>> {
5
+ ownerKind: 'group' | 'root';
6
+ ownerGroup?: IGroup;
7
+ ownerStage?: IStage;
8
+ parentScope?: SharedStateScope<T>;
9
+ themeStateDefinitions?: StateDefinitionsInput<T>;
10
+ localStateDefinitions?: StateDefinitionsInput<T>;
11
+ effectiveSourceDefinitions: StateDefinitionsInput<T>;
12
+ effectiveCompiledDefinitions: Map<string, CompiledStateDefinition<T>>;
13
+ revision: number;
14
+ parentRevisionAtBuild?: number;
15
+ dirty: boolean;
16
+ subtreeActiveDescendants: Set<IGraphic>;
17
+ }
18
+ export declare function createRootSharedStateScope<T extends Record<string, any> = Record<string, any>>(stage: IStage, themeStateDefinitions?: StateDefinitionsInput<T>): SharedStateScope<T>;
19
+ export declare function createGroupSharedStateScope<T extends Record<string, any> = Record<string, any>>(group: IGroup, parentScope?: SharedStateScope<T>, localStateDefinitions?: StateDefinitionsInput<T>): SharedStateScope<T>;
20
+ export declare function setSharedStateScopeParent<T extends Record<string, any> = Record<string, any>>(scope: SharedStateScope<T>, parentScope?: SharedStateScope<T>): boolean;
21
+ export declare function setSharedStateScopeLocalDefinitions<T extends Record<string, any> = Record<string, any>>(scope: SharedStateScope<T>, localStateDefinitions?: StateDefinitionsInput<T>): boolean;
22
+ export declare function setRootSharedStateScopeThemeDefinitions<T extends Record<string, any> = Record<string, any>>(scope: SharedStateScope<T>, themeStateDefinitions?: StateDefinitionsInput<T>): boolean;
23
+ export declare function rebuildSharedStateScope<T extends Record<string, any> = Record<string, any>>(scope: SharedStateScope<T>): SharedStateScope<T>;
24
+ export declare function ensureSharedStateScopeFresh<T extends Record<string, any> = Record<string, any>>(scope?: SharedStateScope<T>): SharedStateScope<T> | undefined;
25
+ export declare function collectSharedStateScopeChain<T extends Record<string, any> = Record<string, any>>(scope?: SharedStateScope<T>): SharedStateScope<T>[];
@@ -0,0 +1,90 @@
1
+ import { StateDefinitionCompiler } from "./state-definition-compiler";
2
+
3
+ import { getStageStatePerfMonitor } from "./state-perf-monitor";
4
+
5
+ const compiler = new StateDefinitionCompiler;
6
+
7
+ function copyDefinitions(definitions) {
8
+ return definitions ? Object.assign({}, definitions) : {};
9
+ }
10
+
11
+ function buildEffectiveSourceDefinitions(parentScope, localStateDefinitions, themeStateDefinitions) {
12
+ const merged = copyDefinitions(parentScope ? parentScope.effectiveSourceDefinitions : themeStateDefinitions);
13
+ return localStateDefinitions && Object.keys(localStateDefinitions).forEach((stateName => {
14
+ merged[stateName] = localStateDefinitions[stateName];
15
+ })), merged;
16
+ }
17
+
18
+ function initializeScope(scope, revision = 0) {
19
+ var _a;
20
+ const effectiveSourceDefinitions = buildEffectiveSourceDefinitions(scope.parentScope, scope.localStateDefinitions, scope.themeStateDefinitions);
21
+ return scope.effectiveSourceDefinitions = effectiveSourceDefinitions, scope.effectiveCompiledDefinitions = compiler.compile(effectiveSourceDefinitions),
22
+ scope.parentRevisionAtBuild = null === (_a = scope.parentScope) || void 0 === _a ? void 0 : _a.revision,
23
+ scope.revision = revision, scope.dirty = !1, scope;
24
+ }
25
+
26
+ export function createRootSharedStateScope(stage, themeStateDefinitions) {
27
+ return initializeScope({
28
+ ownerKind: "root",
29
+ ownerStage: stage,
30
+ themeStateDefinitions: themeStateDefinitions,
31
+ effectiveSourceDefinitions: {},
32
+ effectiveCompiledDefinitions: new Map,
33
+ revision: 0,
34
+ dirty: !1,
35
+ subtreeActiveDescendants: new Set
36
+ }, 0);
37
+ }
38
+
39
+ export function createGroupSharedStateScope(group, parentScope, localStateDefinitions) {
40
+ return initializeScope({
41
+ ownerKind: "group",
42
+ ownerGroup: group,
43
+ ownerStage: group.stage,
44
+ parentScope: parentScope,
45
+ localStateDefinitions: localStateDefinitions,
46
+ effectiveSourceDefinitions: {},
47
+ effectiveCompiledDefinitions: new Map,
48
+ revision: 0,
49
+ dirty: !1,
50
+ subtreeActiveDescendants: new Set
51
+ }, 0);
52
+ }
53
+
54
+ export function setSharedStateScopeParent(scope, parentScope) {
55
+ return scope.parentScope !== parentScope && (scope.parentScope = parentScope, scope.dirty = !0,
56
+ !0);
57
+ }
58
+
59
+ export function setSharedStateScopeLocalDefinitions(scope, localStateDefinitions) {
60
+ return scope.localStateDefinitions !== localStateDefinitions && (scope.localStateDefinitions = localStateDefinitions,
61
+ rebuildSharedStateScope(scope), !0);
62
+ }
63
+
64
+ export function setRootSharedStateScopeThemeDefinitions(scope, themeStateDefinitions) {
65
+ return scope.themeStateDefinitions !== themeStateDefinitions && (scope.themeStateDefinitions = themeStateDefinitions,
66
+ rebuildSharedStateScope(scope), !0);
67
+ }
68
+
69
+ export function rebuildSharedStateScope(scope) {
70
+ var _a;
71
+ const effectiveSourceDefinitions = buildEffectiveSourceDefinitions(scope.parentScope, scope.localStateDefinitions, scope.themeStateDefinitions);
72
+ return scope.effectiveSourceDefinitions = effectiveSourceDefinitions, scope.effectiveCompiledDefinitions = compiler.compile(effectiveSourceDefinitions),
73
+ scope.parentRevisionAtBuild = null === (_a = scope.parentScope) || void 0 === _a ? void 0 : _a.revision,
74
+ scope.revision += 1, scope.dirty = !1, scope;
75
+ }
76
+
77
+ export function ensureSharedStateScopeFresh(scope) {
78
+ var _a;
79
+ if (scope) return null === (_a = getStageStatePerfMonitor(scope.ownerStage)) || void 0 === _a || _a.recordRefresh("ensureFreshCalls"),
80
+ scope.parentScope && ensureSharedStateScopeFresh(scope.parentScope), (scope.dirty || scope.parentScope && scope.parentRevisionAtBuild !== scope.parentScope.revision) && rebuildSharedStateScope(scope),
81
+ scope;
82
+ }
83
+
84
+ export function collectSharedStateScopeChain(scope) {
85
+ const chain = [];
86
+ let current = scope;
87
+ for (;current; ) chain.push(current), current = current.parentScope;
88
+ return chain;
89
+ }
90
+ //# 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,278 @@
1
+ var __awaiter = this && this.__awaiter || function(thisArg, _arguments, P, generator) {
2
+ return new (P || (P = Promise))((function(resolve, reject) {
3
+ function fulfilled(value) {
4
+ try {
5
+ step(generator.next(value));
6
+ } catch (e) {
7
+ reject(e);
8
+ }
9
+ }
10
+ function rejected(value) {
11
+ try {
12
+ step(generator.throw(value));
13
+ } catch (e) {
14
+ reject(e);
15
+ }
16
+ }
17
+ function step(result) {
18
+ var value;
19
+ result.done ? resolve(result.value) : (value = result.value, value instanceof P ? value : new P((function(resolve) {
20
+ resolve(value);
21
+ }))).then(fulfilled, rejected);
22
+ }
23
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
24
+ }));
25
+ };
26
+
27
+ import { UpdateCategory, classifyAffectedKeys } from "./attribute-update-classifier";
28
+
29
+ import { fingerprintDeferredStateConfig, normalizeDeferredStateConfig, normalizeDeferredStateOwnerConfig } from "./state-perf-monitor";
30
+
31
+ function isRenderableGraphic(graphic) {
32
+ return !!graphic.stage && "released" !== graphic.releaseStatus;
33
+ }
34
+
35
+ function createTargetStatesKey(targetStates) {
36
+ return targetStates.length ? targetStates.join("|") : "__clear__";
37
+ }
38
+
39
+ function createIntentKey(contextOwnerId, configFingerprint, targetStatesKey) {
40
+ return `${contextOwnerId}:${configFingerprint}:${targetStatesKey}`;
41
+ }
42
+
43
+ function hasMeaningfulDeferredConfig(config) {
44
+ const normalized = normalizeDeferredStateOwnerConfig(config);
45
+ return !!normalized && (null != normalized.localEnabled || null != normalized.deferred);
46
+ }
47
+
48
+ function getGraphicCompiledDefinitions(graphic) {
49
+ const graphicAny = graphic;
50
+ if ("function" == typeof graphicAny.resolveEffectiveCompiledDefinitions) {
51
+ const result = graphicAny.resolveEffectiveCompiledDefinitions();
52
+ return {
53
+ compiledDefinitions: result.compiledDefinitions,
54
+ stateProxyEligibility: result.stateProxyEligibility
55
+ };
56
+ }
57
+ return {};
58
+ }
59
+
60
+ function getCurrentStateNames(graphic) {
61
+ var _a, _b;
62
+ return null !== (_b = null === (_a = graphic.currentStates) || void 0 === _a ? void 0 : _a.slice()) && void 0 !== _b ? _b : [];
63
+ }
64
+
65
+ export class StateBatchScheduler {
66
+ constructor(stage, perfMonitor) {
67
+ this.stage = stage, this.perfMonitor = perfMonitor, this.jobsByIntentKey = new Map,
68
+ this.pendingIntentByGraphic = new Map, this.nextJobId = 1, this.runningJobs = new Map;
69
+ }
70
+ schedule(graphics, targetStates) {
71
+ const batchOperation = graphics.length > 1;
72
+ graphics.forEach((graphic => {
73
+ const eligibility = this.resolveEligibility(graphic, targetStates, batchOperation, !0);
74
+ if ("reason" in eligibility) return this.removeGraphicFromPending(graphic), void ("graphic_unavailable" !== eligibility.reason && this.commitSynchronously(graphic, targetStates));
75
+ this.enqueueDeferredIntent(graphic, targetStates, eligibility.context, eligibility.targetStatesKey);
76
+ }));
77
+ }
78
+ release() {
79
+ var _a;
80
+ this.jobsByIntentKey.forEach((job => {
81
+ job.status = "cancelled";
82
+ })), this.jobsByIntentKey.clear(), this.pendingIntentByGraphic.clear(), this.runningJobs.clear(),
83
+ null === (_a = this.perfMonitor) || void 0 === _a || _a.updateBatchPending(0);
84
+ }
85
+ resolveEligibility(graphic, targetStates, batchOperation, recordObservability) {
86
+ var _a, _b, _c, _d, _e, _f;
87
+ if (!isRenderableGraphic(graphic)) return recordObservability && (null === (_a = this.perfMonitor) || void 0 === _a || _a.recordDeferredIneligible("graphic_unavailable")),
88
+ {
89
+ eligible: !1,
90
+ reason: "graphic_unavailable"
91
+ };
92
+ if (!batchOperation) return recordObservability && (null === (_b = this.perfMonitor) || void 0 === _b || _b.recordDeferredIneligible("non_batch_operation")),
93
+ {
94
+ eligible: !1,
95
+ reason: "non_batch_operation"
96
+ };
97
+ const context = this.resolveDeferredContext(graphic);
98
+ if (!context) return recordObservability && (null === (_c = this.perfMonitor) || void 0 === _c || _c.recordDeferredIneligible("graphic_unavailable")),
99
+ {
100
+ eligible: !1,
101
+ reason: "graphic_unavailable"
102
+ };
103
+ if (!context.config.enabled) {
104
+ const normalizedOwnerConfig = normalizeDeferredStateOwnerConfig(context.contextOwner.deferredStateConfig), reason = !1 === (null == normalizedOwnerConfig ? void 0 : normalizedOwnerConfig.localEnabled) ? "context_disabled" : "config_disabled";
105
+ return recordObservability && (null === (_d = this.perfMonitor) || void 0 === _d || _d.recordDeferredIneligible(reason)),
106
+ {
107
+ eligible: !1,
108
+ reason: reason
109
+ };
110
+ }
111
+ const classification = this.classifyGraphicTargetStates(graphic, targetStates);
112
+ return classification.reason ? (recordObservability && (null === (_e = this.perfMonitor) || void 0 === _e || _e.recordDeferredIneligible(classification.reason)),
113
+ {
114
+ eligible: !1,
115
+ reason: classification.reason
116
+ }) : classification.category !== UpdateCategory.PAINT ? (recordObservability && (null === (_f = this.perfMonitor) || void 0 === _f || _f.recordDeferredIneligible("mixed_update_category")),
117
+ {
118
+ eligible: !1,
119
+ reason: "mixed_update_category"
120
+ }) : {
121
+ eligible: !0,
122
+ context: context,
123
+ targetStatesKey: createTargetStatesKey(targetStates)
124
+ };
125
+ }
126
+ resolveDeferredContext(graphic) {
127
+ var _a;
128
+ const stage = graphic.stage;
129
+ if (!stage) return;
130
+ let owner = stage, config = normalizeDeferredStateConfig(void 0);
131
+ const ownerConfigs = [ stage ], parents = [];
132
+ let parent = graphic.parent;
133
+ for (;parent && parent !== stage; ) parents.push(parent), parent = parent.parent;
134
+ parents.reverse().forEach((current => ownerConfigs.push(current))), ownerConfigs.forEach((current => {
135
+ const deferredStateConfig = normalizeDeferredStateOwnerConfig(current.deferredStateConfig);
136
+ deferredStateConfig && (deferredStateConfig.deferred && (config = Object.assign(Object.assign({}, config), deferredStateConfig.deferred)),
137
+ null != deferredStateConfig.localEnabled && (config.enabled = deferredStateConfig.localEnabled),
138
+ hasMeaningfulDeferredConfig(current.deferredStateConfig) && (owner = current));
139
+ }));
140
+ const normalized = normalizeDeferredStateConfig(config);
141
+ return {
142
+ contextOwner: owner,
143
+ contextOwnerId: null !== (_a = owner._uid) && void 0 !== _a ? _a : 0,
144
+ config: normalized,
145
+ configFingerprint: fingerprintDeferredStateConfig(normalized)
146
+ };
147
+ }
148
+ classifyGraphicTargetStates(graphic, targetStates) {
149
+ const {compiledDefinitions: compiledDefinitions, stateProxyEligibility: stateProxyEligibility} = getGraphicCompiledDefinitions(graphic), candidateStates = Array.from(new Set([ ...getCurrentStateNames(graphic), ...targetStates ]));
150
+ let category = UpdateCategory.NONE;
151
+ return candidateStates.forEach((stateName => {
152
+ if (null == stateProxyEligibility ? void 0 : stateProxyEligibility(stateName)) return void (category = UpdateCategory.NONE);
153
+ const definition = null == compiledDefinitions ? void 0 : compiledDefinitions.get(stateName);
154
+ definition && (definition.hasResolver && 0 === definition.affectedKeys.size ? category = UpdateCategory.NONE : category |= classifyAffectedKeys(definition.affectedKeys));
155
+ })), candidateStates.some((stateName => null == stateProxyEligibility ? void 0 : stateProxyEligibility(stateName))) || candidateStates.some((stateName => {
156
+ const definition = null == compiledDefinitions ? void 0 : compiledDefinitions.get(stateName);
157
+ return !!(null == definition ? void 0 : definition.hasResolver) && 0 === definition.affectedKeys.size;
158
+ })) ? {
159
+ category: UpdateCategory.NONE,
160
+ reason: "resolver_unstable_keys"
161
+ } : {
162
+ category: category === UpdateCategory.NONE ? UpdateCategory.PAINT : category
163
+ };
164
+ }
165
+ enqueueDeferredIntent(graphic, targetStates, context, targetStatesKey) {
166
+ var _a, _b, _c, _d, _e, _f;
167
+ const nextIntentKey = createIntentKey(context.contextOwnerId, context.configFingerprint, targetStatesKey), prevIntentKey = this.pendingIntentByGraphic.get(graphic);
168
+ if (prevIntentKey === nextIntentKey) return void (null === (_a = this.perfMonitor) || void 0 === _a || _a.incrementCounter("deferredJobsCoalesced"));
169
+ prevIntentKey && this.removeGraphicFromIntentJob(graphic, prevIntentKey);
170
+ let job = this.jobsByIntentKey.get(nextIntentKey);
171
+ job ? null === (_d = this.perfMonitor) || void 0 === _d || _d.incrementCounter("deferredJobsCoalesced") : (job = {
172
+ id: this.nextJobId++,
173
+ kind: "apply_states",
174
+ intentKey: nextIntentKey,
175
+ status: "pending",
176
+ targetStates: [ ...targetStates ],
177
+ targetStatesKey: targetStatesKey,
178
+ pendingGraphics: new Set,
179
+ orderedGraphics: [],
180
+ config: context.config,
181
+ contextOwner: context.contextOwner,
182
+ contextOwnerId: context.contextOwnerId,
183
+ configFingerprint: context.configFingerprint,
184
+ createdAt: Date.now(),
185
+ processedCount: 0
186
+ }, this.jobsByIntentKey.set(nextIntentKey, job), null === (_b = this.perfMonitor) || void 0 === _b || _b.incrementCounter("deferredJobsCreated"),
187
+ null === (_c = this.perfMonitor) || void 0 === _c || _c.updateBatchPending(this.jobsByIntentKey.size)),
188
+ job.pendingGraphics.has(graphic) || (job.pendingGraphics.add(graphic), job.orderedGraphics.push(graphic),
189
+ this.pendingIntentByGraphic.set(graphic, nextIntentKey), null === (_e = this.perfMonitor) || void 0 === _e || _e.recordAllocation("batchEntriesCreated"),
190
+ null === (_f = this.perfMonitor) || void 0 === _f || _f.updateMaxGraphicsInJob(job.pendingGraphics.size)),
191
+ this.ensureJobRunning(job);
192
+ }
193
+ removeGraphicFromPending(graphic) {
194
+ const prevIntentKey = this.pendingIntentByGraphic.get(graphic);
195
+ prevIntentKey && this.removeGraphicFromIntentJob(graphic, prevIntentKey);
196
+ }
197
+ removeGraphicFromIntentJob(graphic, intentKey) {
198
+ var _a, _b, _c;
199
+ const job = this.jobsByIntentKey.get(intentKey);
200
+ job ? (job.pendingGraphics.delete(graphic), this.pendingIntentByGraphic.get(graphic) === intentKey && this.pendingIntentByGraphic.delete(graphic),
201
+ 0 === job.pendingGraphics.size && "completed" !== job.status && (job.status = "cancelled",
202
+ this.jobsByIntentKey.delete(intentKey), null === (_a = this.perfMonitor) || void 0 === _a || _a.incrementCounter("deferredJobsCancelled"),
203
+ null === (_b = this.perfMonitor) || void 0 === _b || _b.recordEvent("deferred-job-cancel", {
204
+ intentKey: intentKey,
205
+ jobId: job.id
206
+ }), null === (_c = this.perfMonitor) || void 0 === _c || _c.updateBatchPending(this.jobsByIntentKey.size))) : this.pendingIntentByGraphic.delete(graphic);
207
+ }
208
+ ensureJobRunning(job) {
209
+ if (this.runningJobs.has(job.intentKey)) return;
210
+ const runner = this.runJob(job).then((() => {
211
+ this.runningJobs.delete(job.intentKey);
212
+ }), (() => {
213
+ this.runningJobs.delete(job.intentKey);
214
+ }));
215
+ this.runningJobs.set(job.intentKey, runner);
216
+ }
217
+ runJob(job) {
218
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j;
219
+ return __awaiter(this, void 0, void 0, (function*() {
220
+ if ("cancelled" === job.status) return;
221
+ if (yield this.waitForNextFrame(), "cancelled" === job.status) return;
222
+ job.status = "running", null === (_a = this.perfMonitor) || void 0 === _a || _a.recordEvent("deferred-job-start", {
223
+ intentKey: job.intentKey,
224
+ jobId: job.id
225
+ });
226
+ let index = 0, frameStart = performance.now(), processedInFrame = 0, committedInSlice = 0;
227
+ for (;index < job.orderedGraphics.length; ) {
228
+ if ("cancelled" === job.status) return;
229
+ processedInFrame > 0 && (processedInFrame >= job.config.maxGraphicsPerFrame || performance.now() - frameStart >= job.config.frameBudget) && (null === (_b = this.perfMonitor) || void 0 === _b || _b.incrementCounter("deferredBudgetYields"),
230
+ null === (_c = this.perfMonitor) || void 0 === _c || _c.recordCost("batchSlice", performance.now() - frameStart),
231
+ null === (_d = this.perfMonitor) || void 0 === _d || _d.recordEvent("deferred-job-yield", {
232
+ intentKey: job.intentKey,
233
+ jobId: job.id,
234
+ processedInFrame: processedInFrame
235
+ }), committedInSlice > 0 && this.stage.renderNextFrame(), yield this.waitForNextFrame(),
236
+ frameStart = performance.now(), processedInFrame = 0, committedInSlice = 0);
237
+ const graphic = job.orderedGraphics[index++];
238
+ if (!job.pendingGraphics.has(graphic)) continue;
239
+ if (!isRenderableGraphic(graphic)) {
240
+ job.pendingGraphics.delete(graphic), this.pendingIntentByGraphic.get(graphic) === job.intentKey && this.pendingIntentByGraphic.delete(graphic);
241
+ continue;
242
+ }
243
+ if (this.pendingIntentByGraphic.get(graphic) !== job.intentKey) {
244
+ job.pendingGraphics.delete(graphic);
245
+ continue;
246
+ }
247
+ const nextEligibility = this.resolveEligibility(graphic, job.targetStates, !0, !1);
248
+ if (!nextEligibility.eligible) {
249
+ job.pendingGraphics.delete(graphic), this.pendingIntentByGraphic.delete(graphic),
250
+ this.commitSynchronously(graphic, job.targetStates);
251
+ continue;
252
+ }
253
+ createIntentKey(nextEligibility.context.contextOwnerId, nextEligibility.context.configFingerprint, nextEligibility.targetStatesKey) === job.intentKey ? (this.commitSynchronously(graphic, job.targetStates),
254
+ job.pendingGraphics.delete(graphic), this.pendingIntentByGraphic.delete(graphic),
255
+ job.processedCount += 1, processedInFrame += 1, committedInSlice += 1, null === (_e = this.perfMonitor) || void 0 === _e || _e.incrementCounter("deferredGraphicsCommitted")) : (job.pendingGraphics.delete(graphic),
256
+ this.pendingIntentByGraphic.delete(graphic), this.enqueueDeferredIntent(graphic, job.targetStates, nextEligibility.context, nextEligibility.targetStatesKey));
257
+ }
258
+ processedInFrame > 0 && (null === (_f = this.perfMonitor) || void 0 === _f || _f.recordCost("batchSlice", performance.now() - frameStart),
259
+ this.stage.renderNextFrame()), 0 === job.pendingGraphics.size && this.jobsByIntentKey.get(job.intentKey) === job && (job.status = "completed",
260
+ this.jobsByIntentKey.delete(job.intentKey), null === (_g = this.perfMonitor) || void 0 === _g || _g.incrementCounter("deferredJobsCompleted"),
261
+ null === (_h = this.perfMonitor) || void 0 === _h || _h.recordEvent("deferred-job-complete", {
262
+ intentKey: job.intentKey,
263
+ jobId: job.id,
264
+ processedCount: job.processedCount
265
+ }), null === (_j = this.perfMonitor) || void 0 === _j || _j.updateBatchPending(this.jobsByIntentKey.size));
266
+ }));
267
+ }
268
+ waitForNextFrame() {
269
+ const stageGlobal = this.stage.global;
270
+ return (null == stageGlobal ? void 0 : stageGlobal.getSpecifiedPerformanceRAF) ? stageGlobal.getSpecifiedPerformanceRAF(this.stage.rafId).wait() : new Promise((resolve => {
271
+ null == stageGlobal || stageGlobal.getSpecifiedRequestAnimationFrame(this.stage.rafId)((() => resolve()));
272
+ }));
273
+ }
274
+ commitSynchronously(graphic, targetStates) {
275
+ isRenderableGraphic(graphic) && (targetStates.length ? graphic.useStates(targetStates, !1) : graphic.clearStates(!1));
276
+ }
277
+ }
278
+ //# sourceMappingURL=state-batch-scheduler.js.map