@loom-framework/core 0.1.0-alpha.9 → 0.1.0-alpha.91

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 (447) hide show
  1. package/builtin-skills/antd/SKILL.md +266 -0
  2. package/builtin-skills/antv-g2-chart/SKILL.md +1067 -0
  3. package/builtin-skills/antv-g2-chart/references/animations/g2-animation-intro.md +176 -0
  4. package/builtin-skills/antv-g2-chart/references/animations/g2-animation-keyframe.md +149 -0
  5. package/builtin-skills/antv-g2-chart/references/animations/g2-animation-types.md +253 -0
  6. package/builtin-skills/antv-g2-chart/references/components/g2-comp-annotation.md +237 -0
  7. package/builtin-skills/antv-g2-chart/references/components/g2-comp-axis-config.md +648 -0
  8. package/builtin-skills/antv-g2-chart/references/components/g2-comp-axis-radar.md +219 -0
  9. package/builtin-skills/antv-g2-chart/references/components/g2-comp-label-config.md +174 -0
  10. package/builtin-skills/antv-g2-chart/references/components/g2-comp-legend-category.md +278 -0
  11. package/builtin-skills/antv-g2-chart/references/components/g2-comp-legend-config.md +363 -0
  12. package/builtin-skills/antv-g2-chart/references/components/g2-comp-legend-continuous.md +264 -0
  13. package/builtin-skills/antv-g2-chart/references/components/g2-comp-scrollbar.md +276 -0
  14. package/builtin-skills/antv-g2-chart/references/components/g2-comp-slider.md +333 -0
  15. package/builtin-skills/antv-g2-chart/references/components/g2-comp-title.md +149 -0
  16. package/builtin-skills/antv-g2-chart/references/components/g2-comp-tooltip-config.md +358 -0
  17. package/builtin-skills/antv-g2-chart/references/compositions/g2-comp-facet-circle.md +97 -0
  18. package/builtin-skills/antv-g2-chart/references/compositions/g2-comp-facet-rect.md +241 -0
  19. package/builtin-skills/antv-g2-chart/references/compositions/g2-comp-geo-map.md +210 -0
  20. package/builtin-skills/antv-g2-chart/references/compositions/g2-comp-geoview.md +143 -0
  21. package/builtin-skills/antv-g2-chart/references/compositions/g2-comp-repeat-matrix.md +171 -0
  22. package/builtin-skills/antv-g2-chart/references/compositions/g2-comp-space-flex.md +142 -0
  23. package/builtin-skills/antv-g2-chart/references/compositions/g2-comp-space-layer.md +149 -0
  24. package/builtin-skills/antv-g2-chart/references/compositions/g2-comp-timing-keyframe.md +91 -0
  25. package/builtin-skills/antv-g2-chart/references/compositions/g2-comp-view.md +309 -0
  26. package/builtin-skills/antv-g2-chart/references/concepts/g2-concept-chart-selection.md +235 -0
  27. package/builtin-skills/antv-g2-chart/references/concepts/g2-concept-color-theory.md +287 -0
  28. package/builtin-skills/antv-g2-chart/references/concepts/g2-concept-visual-channels.md +180 -0
  29. package/builtin-skills/antv-g2-chart/references/coordinates/g2-coord-cartesian.md +131 -0
  30. package/builtin-skills/antv-g2-chart/references/coordinates/g2-coord-fisheye.md +131 -0
  31. package/builtin-skills/antv-g2-chart/references/coordinates/g2-coord-helix.md +141 -0
  32. package/builtin-skills/antv-g2-chart/references/coordinates/g2-coord-parallel.md +129 -0
  33. package/builtin-skills/antv-g2-chart/references/coordinates/g2-coord-polar.md +143 -0
  34. package/builtin-skills/antv-g2-chart/references/coordinates/g2-coord-radial.md +214 -0
  35. package/builtin-skills/antv-g2-chart/references/coordinates/g2-coord-theta.md +171 -0
  36. package/builtin-skills/antv-g2-chart/references/coordinates/g2-coord-transpose.md +195 -0
  37. package/builtin-skills/antv-g2-chart/references/core/g2-core-chart-init.md +266 -0
  38. package/builtin-skills/antv-g2-chart/references/core/g2-core-encode-channel.md +197 -0
  39. package/builtin-skills/antv-g2-chart/references/core/g2-core-view-composition.md +224 -0
  40. package/builtin-skills/antv-g2-chart/references/data/g2-data-ema.md +190 -0
  41. package/builtin-skills/antv-g2-chart/references/data/g2-data-fetch.md +167 -0
  42. package/builtin-skills/antv-g2-chart/references/data/g2-data-filter.md +212 -0
  43. package/builtin-skills/antv-g2-chart/references/data/g2-data-fold.md +260 -0
  44. package/builtin-skills/antv-g2-chart/references/data/g2-data-format-tabular.md +280 -0
  45. package/builtin-skills/antv-g2-chart/references/data/g2-data-kde.md +426 -0
  46. package/builtin-skills/antv-g2-chart/references/data/g2-data-log.md +140 -0
  47. package/builtin-skills/antv-g2-chart/references/data/g2-data-slice.md +147 -0
  48. package/builtin-skills/antv-g2-chart/references/data/g2-data-sort.md +251 -0
  49. package/builtin-skills/antv-g2-chart/references/data/g2-data-sortby.md +183 -0
  50. package/builtin-skills/antv-g2-chart/references/data/g2-data-transform-patterns.md +394 -0
  51. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-adaptive-filter.md +118 -0
  52. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-brush-axis.md +112 -0
  53. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-brush-filter.md +122 -0
  54. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-brush-x-y-highlight.md +127 -0
  55. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-brush-xy.md +118 -0
  56. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-brush.md +184 -0
  57. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-brushx-filter.md +170 -0
  58. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-brushx-highlight.md +186 -0
  59. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-brushy-filter.md +170 -0
  60. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-brushy-highlight.md +185 -0
  61. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-chart-index.md +127 -0
  62. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-drilldown.md +149 -0
  63. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-element-highlight-by.md +125 -0
  64. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-element-highlight.md +235 -0
  65. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-element-hover-scale.md +109 -0
  66. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-element-point-move.md +152 -0
  67. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-element-select-by.md +133 -0
  68. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-element-select.md +249 -0
  69. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-fisheye.md +117 -0
  70. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-legend-filter.md +130 -0
  71. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-legend-highlight.md +130 -0
  72. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-poptip.md +105 -0
  73. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-scrollbar-filter.md +144 -0
  74. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-slider-filter.md +231 -0
  75. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-slider-wheel.md +138 -0
  76. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-tooltip.md +192 -0
  77. package/builtin-skills/antv-g2-chart/references/interactions/g2-interaction-treemap-drilldown.md +152 -0
  78. package/builtin-skills/antv-g2-chart/references/label-transform/g2-label-transform-contrast-reverse.md +170 -0
  79. package/builtin-skills/antv-g2-chart/references/label-transform/g2-label-transform-exceed-adjust.md +146 -0
  80. package/builtin-skills/antv-g2-chart/references/label-transform/g2-label-transform-overflow-hide.md +185 -0
  81. package/builtin-skills/antv-g2-chart/references/label-transform/g2-label-transform-overflow-stroke.md +147 -0
  82. package/builtin-skills/antv-g2-chart/references/label-transform/g2-label-transform-overlap-dodge-y.md +225 -0
  83. package/builtin-skills/antv-g2-chart/references/label-transform/g2-label-transform-overlap-hide.md +213 -0
  84. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-arc-diagram.md +196 -0
  85. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-arc-donut.md +148 -0
  86. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-arc-pie.md +212 -0
  87. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-area-basic.md +168 -0
  88. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-area-stacked.md +150 -0
  89. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-beeswarm.md +134 -0
  90. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-bi-directional-bar.md +297 -0
  91. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-box-boxplot.md +163 -0
  92. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-boxplot.md +340 -0
  93. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-bullet.md +203 -0
  94. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-cell-heatmap.md +370 -0
  95. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-chord.md +341 -0
  96. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-connector.md +126 -0
  97. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-contourline.md +243 -0
  98. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-density.md +457 -0
  99. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-distribution-curve.md +298 -0
  100. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-funnel.md +329 -0
  101. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-gantt.md +208 -0
  102. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-gauge.md +247 -0
  103. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-heatmap.md +130 -0
  104. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-histogram.md +186 -0
  105. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-image.md +129 -0
  106. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-interval-basic.md +528 -0
  107. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-interval-grouped.md +161 -0
  108. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-interval-normalized.md +147 -0
  109. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-interval-stacked.md +183 -0
  110. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-k-chart.md +237 -0
  111. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-line-basic.md +353 -0
  112. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-line-multi.md +156 -0
  113. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-linex-liney.md +176 -0
  114. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-link.md +134 -0
  115. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-liquid.md +125 -0
  116. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-mosaic.md +257 -0
  117. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-pack.md +424 -0
  118. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-parallel.md +195 -0
  119. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-partition.md +275 -0
  120. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-path.md +135 -0
  121. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-point-bubble.md +138 -0
  122. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-point-scatter.md +177 -0
  123. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-polygon.md +130 -0
  124. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-radar.md +231 -0
  125. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-radial-bar.md +226 -0
  126. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-range-rangey.md +253 -0
  127. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-rangex.md +293 -0
  128. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-rect.md +115 -0
  129. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-regression-curve.md +276 -0
  130. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-rose.md +182 -0
  131. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-sankey.md +217 -0
  132. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-shape.md +160 -0
  133. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-spiral.md +257 -0
  134. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-sunburst.md +327 -0
  135. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-text.md +309 -0
  136. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-tree.md +235 -0
  137. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-treemap.md +426 -0
  138. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-vector.md +108 -0
  139. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-venn.md +204 -0
  140. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-violin.md +307 -0
  141. package/builtin-skills/antv-g2-chart/references/marks/g2-mark-wordcloud.md +155 -0
  142. package/builtin-skills/antv-g2-chart/references/palette/g2-palette-category10.md +196 -0
  143. package/builtin-skills/antv-g2-chart/references/palette/g2-palette-category20.md +238 -0
  144. package/builtin-skills/antv-g2-chart/references/patterns/g2-pattern-performance.md +181 -0
  145. package/builtin-skills/antv-g2-chart/references/patterns/g2-pattern-responsive.md +232 -0
  146. package/builtin-skills/antv-g2-chart/references/patterns/g2-pattern-v4-to-v5.md +223 -0
  147. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-band.md +127 -0
  148. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-linear.md +259 -0
  149. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-log.md +226 -0
  150. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-ordinal.md +135 -0
  151. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-point.md +242 -0
  152. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-pow-sqrt.md +124 -0
  153. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-quantile-quantize.md +119 -0
  154. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-sequential.md +267 -0
  155. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-threshold.md +133 -0
  156. package/builtin-skills/antv-g2-chart/references/scales/g2-scale-time.md +159 -0
  157. package/builtin-skills/antv-g2-chart/references/themes/g2-theme-builtin.md +192 -0
  158. package/builtin-skills/antv-g2-chart/references/themes/g2-theme-custom.md +183 -0
  159. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-bin.md +153 -0
  160. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-binx.md +133 -0
  161. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-diffy.md +130 -0
  162. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-dodgex.md +90 -0
  163. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-flexx.md +115 -0
  164. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-group.md +233 -0
  165. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-groupcolor.md +182 -0
  166. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-groupx.md +265 -0
  167. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-groupy.md +167 -0
  168. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-jitter.md +149 -0
  169. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-jitterx.md +177 -0
  170. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-jittery.md +177 -0
  171. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-normalizey.md +83 -0
  172. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-pack.md +164 -0
  173. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-sample.md +143 -0
  174. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-select.md +147 -0
  175. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-selectx.md +179 -0
  176. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-selecty.md +179 -0
  177. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-sort-color.md +115 -0
  178. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-sortx.md +285 -0
  179. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-sorty.md +117 -0
  180. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-stack-enter.md +158 -0
  181. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-stacky.md +218 -0
  182. package/builtin-skills/antv-g2-chart/references/transforms/g2-transform-symmetryy.md +122 -0
  183. package/builtin-skills/app-skill/SKILL.md +27 -0
  184. package/builtin-skills/app-skill/references/data-semantics.md +44 -0
  185. package/builtin-skills/app-skill/references/models.md +31 -0
  186. package/builtin-skills/chart-visualization/SKILL.md +101 -0
  187. package/builtin-skills/loom/SKILL.md +168 -0
  188. package/builtin-skills/loom/references/README.md +128 -0
  189. package/builtin-skills/loom/references/dashboard.md +196 -0
  190. package/builtin-skills/loom/references/data-model.md +78 -0
  191. package/dist/adapter-base.d.ts +29 -0
  192. package/dist/adapter-base.d.ts.map +1 -0
  193. package/dist/adapter-base.js +62 -0
  194. package/dist/adapter-base.js.map +1 -0
  195. package/dist/adapter-factory.d.ts +8 -0
  196. package/dist/adapter-factory.d.ts.map +1 -0
  197. package/dist/adapter-factory.js +25 -0
  198. package/dist/adapter-factory.js.map +1 -0
  199. package/dist/adapter-filesystem.d.ts +6 -11
  200. package/dist/adapter-filesystem.d.ts.map +1 -1
  201. package/dist/adapter-filesystem.js +56 -41
  202. package/dist/adapter-filesystem.js.map +1 -1
  203. package/dist/adapter-sqlite.d.ts +6 -23
  204. package/dist/adapter-sqlite.d.ts.map +1 -1
  205. package/dist/adapter-sqlite.js +65 -50
  206. package/dist/adapter-sqlite.js.map +1 -1
  207. package/dist/backend/ai/button-resolver.d.ts +18 -0
  208. package/dist/backend/ai/button-resolver.d.ts.map +1 -0
  209. package/dist/backend/ai/button-resolver.js +58 -0
  210. package/dist/backend/ai/button-resolver.js.map +1 -0
  211. package/dist/backend/ai/engine.d.ts +52 -0
  212. package/dist/backend/ai/engine.d.ts.map +1 -0
  213. package/dist/backend/ai/engine.js +186 -0
  214. package/dist/backend/ai/engine.js.map +1 -0
  215. package/dist/backend/ai/index.d.ts +11 -0
  216. package/dist/backend/ai/index.d.ts.map +1 -0
  217. package/dist/backend/ai/index.js +8 -0
  218. package/dist/backend/ai/index.js.map +1 -0
  219. package/dist/backend/ai/output-parser.d.ts +29 -0
  220. package/dist/backend/ai/output-parser.d.ts.map +1 -0
  221. package/dist/backend/ai/output-parser.js +247 -0
  222. package/dist/backend/ai/output-parser.js.map +1 -0
  223. package/dist/backend/ai/session-manager.d.ts +103 -0
  224. package/dist/backend/ai/session-manager.d.ts.map +1 -0
  225. package/dist/backend/ai/session-manager.js +298 -0
  226. package/dist/backend/ai/session-manager.js.map +1 -0
  227. package/dist/backend/index.d.ts +61 -0
  228. package/dist/backend/index.d.ts.map +1 -0
  229. package/dist/backend/index.js +161 -0
  230. package/dist/backend/index.js.map +1 -0
  231. package/dist/backend/observe/index.d.ts +6 -0
  232. package/dist/backend/observe/index.d.ts.map +1 -0
  233. package/dist/backend/observe/index.js +5 -0
  234. package/dist/backend/observe/index.js.map +1 -0
  235. package/dist/backend/observe/logger.d.ts +28 -0
  236. package/dist/backend/observe/logger.d.ts.map +1 -0
  237. package/dist/backend/observe/logger.js +80 -0
  238. package/dist/backend/observe/logger.js.map +1 -0
  239. package/dist/backend/observe/types.d.ts +26 -0
  240. package/dist/backend/observe/types.d.ts.map +1 -0
  241. package/dist/backend/observe/types.js +7 -0
  242. package/dist/backend/observe/types.js.map +1 -0
  243. package/dist/backend/routes/chat.d.ts +31 -0
  244. package/dist/backend/routes/chat.d.ts.map +1 -0
  245. package/dist/backend/routes/chat.js +426 -0
  246. package/dist/backend/routes/chat.js.map +1 -0
  247. package/dist/backend/routes/data.d.ts +13 -0
  248. package/dist/backend/routes/data.d.ts.map +1 -0
  249. package/dist/backend/routes/data.js +134 -0
  250. package/dist/backend/routes/data.js.map +1 -0
  251. package/dist/backend/routes/health.d.ts +7 -0
  252. package/dist/backend/routes/health.d.ts.map +1 -0
  253. package/dist/backend/routes/health.js +15 -0
  254. package/dist/backend/routes/health.js.map +1 -0
  255. package/dist/backend/routes/index.d.ts +11 -0
  256. package/dist/backend/routes/index.d.ts.map +1 -0
  257. package/dist/backend/routes/index.js +9 -0
  258. package/dist/backend/routes/index.js.map +1 -0
  259. package/dist/backend/routes/skills.d.ts +16 -0
  260. package/dist/backend/routes/skills.d.ts.map +1 -0
  261. package/dist/backend/routes/skills.js +590 -0
  262. package/dist/backend/routes/skills.js.map +1 -0
  263. package/dist/backend/routes/upload.d.ts +24 -0
  264. package/dist/backend/routes/upload.d.ts.map +1 -0
  265. package/dist/backend/routes/upload.js +67 -0
  266. package/dist/backend/routes/upload.js.map +1 -0
  267. package/dist/bin.d.ts +8 -0
  268. package/dist/bin.d.ts.map +1 -0
  269. package/dist/bin.js +12 -0
  270. package/dist/bin.js.map +1 -0
  271. package/dist/capability-generator.d.ts +21 -6
  272. package/dist/capability-generator.d.ts.map +1 -1
  273. package/dist/capability-generator.js +88 -261
  274. package/dist/capability-generator.js.map +1 -1
  275. package/dist/cli/commands/build.d.ts +11 -0
  276. package/dist/cli/commands/build.d.ts.map +1 -0
  277. package/dist/cli/commands/build.js +170 -0
  278. package/dist/cli/commands/build.js.map +1 -0
  279. package/dist/cli/commands/data.d.ts +12 -0
  280. package/dist/cli/commands/data.d.ts.map +1 -0
  281. package/dist/cli/commands/data.js +158 -0
  282. package/dist/cli/commands/data.js.map +1 -0
  283. package/dist/cli/commands/dev.d.ts +9 -0
  284. package/dist/cli/commands/dev.d.ts.map +1 -0
  285. package/dist/cli/commands/dev.js +114 -0
  286. package/dist/cli/commands/dev.js.map +1 -0
  287. package/dist/cli/commands/generate-capabilities.d.ts +8 -0
  288. package/dist/cli/commands/generate-capabilities.d.ts.map +1 -0
  289. package/dist/cli/commands/generate-capabilities.js +40 -0
  290. package/dist/cli/commands/generate-capabilities.js.map +1 -0
  291. package/dist/cli/commands/generate-cli-command.d.ts +8 -0
  292. package/dist/cli/commands/generate-cli-command.d.ts.map +1 -0
  293. package/dist/cli/commands/generate-cli-command.js +64 -0
  294. package/dist/cli/commands/generate-cli-command.js.map +1 -0
  295. package/dist/cli/commands/generate-dashboard.d.ts +9 -0
  296. package/dist/cli/commands/generate-dashboard.d.ts.map +1 -0
  297. package/dist/cli/commands/generate-dashboard.js +466 -0
  298. package/dist/cli/commands/generate-dashboard.js.map +1 -0
  299. package/dist/cli/commands/generate-page.d.ts +9 -0
  300. package/dist/cli/commands/generate-page.d.ts.map +1 -0
  301. package/dist/cli/commands/generate-page.js +352 -0
  302. package/dist/cli/commands/generate-page.js.map +1 -0
  303. package/dist/cli/commands/generate-skill.d.ts +8 -0
  304. package/dist/cli/commands/generate-skill.d.ts.map +1 -0
  305. package/dist/cli/commands/generate-skill.js +75 -0
  306. package/dist/cli/commands/generate-skill.js.map +1 -0
  307. package/dist/cli/commands/generate.d.ts +6 -0
  308. package/dist/cli/commands/generate.d.ts.map +1 -0
  309. package/dist/cli/commands/generate.js +19 -0
  310. package/dist/cli/commands/generate.js.map +1 -0
  311. package/dist/cli/commands/init.d.ts +8 -0
  312. package/dist/cli/commands/init.d.ts.map +1 -0
  313. package/dist/cli/commands/init.js +301 -0
  314. package/dist/cli/commands/init.js.map +1 -0
  315. package/dist/cli/commands/observe.d.ts +9 -0
  316. package/dist/cli/commands/observe.d.ts.map +1 -0
  317. package/dist/cli/commands/observe.js +142 -0
  318. package/dist/cli/commands/observe.js.map +1 -0
  319. package/dist/cli/commands/skill.d.ts +9 -0
  320. package/dist/cli/commands/skill.d.ts.map +1 -0
  321. package/dist/cli/commands/skill.js +186 -0
  322. package/dist/cli/commands/skill.js.map +1 -0
  323. package/dist/cli/generators/capability-generator.d.ts +35 -0
  324. package/dist/cli/generators/capability-generator.d.ts.map +1 -0
  325. package/dist/cli/generators/capability-generator.js +115 -0
  326. package/dist/cli/generators/capability-generator.js.map +1 -0
  327. package/dist/cli/helpers/app-tsx-wiring.d.ts +19 -0
  328. package/dist/cli/helpers/app-tsx-wiring.d.ts.map +1 -0
  329. package/dist/cli/helpers/app-tsx-wiring.js +143 -0
  330. package/dist/cli/helpers/app-tsx-wiring.js.map +1 -0
  331. package/dist/cli/helpers/column-template.d.ts +18 -0
  332. package/dist/cli/helpers/column-template.d.ts.map +1 -0
  333. package/dist/cli/helpers/column-template.js +151 -0
  334. package/dist/cli/helpers/column-template.js.map +1 -0
  335. package/dist/cli/helpers/duration.d.ts +5 -0
  336. package/dist/cli/helpers/duration.d.ts.map +1 -0
  337. package/dist/cli/helpers/duration.js +19 -0
  338. package/dist/cli/helpers/duration.js.map +1 -0
  339. package/dist/cli/helpers/field-template.d.ts +14 -0
  340. package/dist/cli/helpers/field-template.d.ts.map +1 -0
  341. package/dist/cli/helpers/field-template.js +101 -0
  342. package/dist/cli/helpers/field-template.js.map +1 -0
  343. package/dist/cli/helpers/naming.d.ts +12 -0
  344. package/dist/cli/helpers/naming.d.ts.map +1 -0
  345. package/dist/cli/helpers/naming.js +25 -0
  346. package/dist/cli/helpers/naming.js.map +1 -0
  347. package/dist/cli/index.d.ts +9 -0
  348. package/dist/cli/index.d.ts.map +1 -0
  349. package/dist/cli/index.js +33 -0
  350. package/dist/cli/index.js.map +1 -0
  351. package/dist/cli/templates/backend-entry.d.ts +5 -0
  352. package/dist/cli/templates/backend-entry.d.ts.map +1 -0
  353. package/dist/cli/templates/backend-entry.js +17 -0
  354. package/dist/cli/templates/backend-entry.js.map +1 -0
  355. package/dist/cli/templates/frontend-entry.d.ts +11 -0
  356. package/dist/cli/templates/frontend-entry.d.ts.map +1 -0
  357. package/dist/cli/templates/frontend-entry.js +70 -0
  358. package/dist/cli/templates/frontend-entry.js.map +1 -0
  359. package/dist/cli/templates/gitignore.d.ts +5 -0
  360. package/dist/cli/templates/gitignore.d.ts.map +1 -0
  361. package/dist/cli/templates/gitignore.js +13 -0
  362. package/dist/cli/templates/gitignore.js.map +1 -0
  363. package/dist/cli/templates/index.d.ts +12 -0
  364. package/dist/cli/templates/index.d.ts.map +1 -0
  365. package/dist/cli/templates/index.js +12 -0
  366. package/dist/cli/templates/index.js.map +1 -0
  367. package/dist/cli/templates/loom-config.d.ts +10 -0
  368. package/dist/cli/templates/loom-config.d.ts.map +1 -0
  369. package/dist/cli/templates/loom-config.js +31 -0
  370. package/dist/cli/templates/loom-config.js.map +1 -0
  371. package/dist/cli/templates/package-json.d.ts +9 -0
  372. package/dist/cli/templates/package-json.d.ts.map +1 -0
  373. package/dist/cli/templates/package-json.js +40 -0
  374. package/dist/cli/templates/package-json.js.map +1 -0
  375. package/dist/cli/templates/readme.d.ts +9 -0
  376. package/dist/cli/templates/readme.d.ts.map +1 -0
  377. package/dist/cli/templates/readme.js +47 -0
  378. package/dist/cli/templates/readme.js.map +1 -0
  379. package/dist/cli/templates/tsconfig.d.ts +6 -0
  380. package/dist/cli/templates/tsconfig.d.ts.map +1 -0
  381. package/dist/cli/templates/tsconfig.js +41 -0
  382. package/dist/cli/templates/tsconfig.js.map +1 -0
  383. package/dist/cli/templates/vite-config.d.ts +5 -0
  384. package/dist/cli/templates/vite-config.d.ts.map +1 -0
  385. package/dist/cli/templates/vite-config.js +24 -0
  386. package/dist/cli/templates/vite-config.js.map +1 -0
  387. package/dist/cli/utils.d.ts +10 -0
  388. package/dist/cli/utils.d.ts.map +1 -0
  389. package/dist/cli/utils.js +31 -0
  390. package/dist/cli/utils.js.map +1 -0
  391. package/dist/commands.d.ts +1 -5
  392. package/dist/commands.d.ts.map +1 -1
  393. package/dist/commands.js +0 -11
  394. package/dist/commands.js.map +1 -1
  395. package/dist/config.d.ts +21 -52
  396. package/dist/config.d.ts.map +1 -1
  397. package/dist/config.js +8 -9
  398. package/dist/config.js.map +1 -1
  399. package/dist/dashboard-config.d.ts +117 -0
  400. package/dist/dashboard-config.d.ts.map +1 -0
  401. package/dist/dashboard-config.js +59 -0
  402. package/dist/dashboard-config.js.map +1 -0
  403. package/dist/index.d.ts +9 -4
  404. package/dist/index.d.ts.map +1 -1
  405. package/dist/index.js +8 -2
  406. package/dist/index.js.map +1 -1
  407. package/dist/server-bin.d.ts +12 -0
  408. package/dist/server-bin.d.ts.map +1 -0
  409. package/dist/server-bin.js +43 -0
  410. package/dist/server-bin.js.map +1 -0
  411. package/dist/types/adapter.d.ts +28 -0
  412. package/dist/types/adapter.d.ts.map +1 -0
  413. package/dist/types/adapter.js +5 -0
  414. package/dist/types/adapter.js.map +1 -0
  415. package/dist/types/ai.d.ts +52 -0
  416. package/dist/types/ai.d.ts.map +1 -0
  417. package/dist/types/ai.js +5 -0
  418. package/dist/types/ai.js.map +1 -0
  419. package/dist/types/chat.d.ts +46 -0
  420. package/dist/types/chat.d.ts.map +1 -0
  421. package/dist/types/chat.js +5 -0
  422. package/dist/types/chat.js.map +1 -0
  423. package/dist/types/command.d.ts +25 -0
  424. package/dist/types/command.d.ts.map +1 -0
  425. package/dist/types/command.js +5 -0
  426. package/dist/types/command.js.map +1 -0
  427. package/dist/types/config.d.ts +30 -0
  428. package/dist/types/config.d.ts.map +1 -0
  429. package/dist/types/config.js +5 -0
  430. package/dist/types/config.js.map +1 -0
  431. package/dist/types/dashboard.d.ts +42 -0
  432. package/dist/types/dashboard.d.ts.map +1 -0
  433. package/dist/types/dashboard.js +5 -0
  434. package/dist/types/dashboard.js.map +1 -0
  435. package/dist/types/index.d.ts +14 -0
  436. package/dist/types/index.d.ts.map +1 -0
  437. package/dist/types/index.js +8 -0
  438. package/dist/types/index.js.map +1 -0
  439. package/dist/types/model.d.ts +59 -0
  440. package/dist/types/model.d.ts.map +1 -0
  441. package/dist/types/model.js +5 -0
  442. package/dist/types/model.js.map +1 -0
  443. package/dist/types.d.ts +4 -199
  444. package/dist/types.d.ts.map +1 -1
  445. package/dist/types.js +4 -3
  446. package/dist/types.js.map +1 -1
  447. package/package.json +18 -3
@@ -0,0 +1,426 @@
1
+ ---
2
+ id: "g2-mark-treemap"
3
+ title: "G2 矩形树图(treemap)"
4
+ description: |
5
+ G2 v5 内置 treemap Mark,用矩形面积表示层级数据中各节点的占比,
6
+ 数据采用嵌套的 children 树形结构,通过 encode.value 映射叶节点数值,
7
+ 支持多种 tile 布局算法和层级钻取交互。
8
+
9
+ library: "g2"
10
+ version: "5.x"
11
+ category: "marks"
12
+ tags:
13
+ - "矩形树图"
14
+ - "treemap"
15
+ - "层级数据"
16
+ - "占比"
17
+ - "hierarchy"
18
+ - "树形"
19
+ - "spec"
20
+
21
+ related:
22
+ - "g2-mark-arc-pie"
23
+ - "g2-mark-sankey"
24
+ - "g2-core-chart-init"
25
+
26
+ use_cases:
27
+ - "展示文件目录/磁盘占用大小"
28
+ - "产品类别的销售额占比(多层级)"
29
+ - "证券市场板块涨跌热力图"
30
+
31
+ difficulty: "intermediate"
32
+ completeness: "full"
33
+ created: "2024-01-01"
34
+ updated: "2025-03-01"
35
+ author: "antv-team"
36
+ source_url: "https://g2.antv.antgroup.com/examples/graph/hierarchy/#treemap"
37
+ ---
38
+
39
+ ## 最小可运行示例
40
+
41
+ ```javascript
42
+ import { Chart } from '@antv/g2';
43
+
44
+ const chart = new Chart({
45
+ container: 'container',
46
+ width: 800,
47
+ height: 500,
48
+ });
49
+
50
+ // 树形嵌套数据
51
+ const data = {
52
+ name: 'root',
53
+ children: [
54
+ {
55
+ name: '技术',
56
+ children: [
57
+ { name: '前端', value: 120 },
58
+ { name: '后端', value: 180 },
59
+ { name: '算法', value: 80 },
60
+ ],
61
+ },
62
+ {
63
+ name: '产品',
64
+ children: [
65
+ { name: '移动端', value: 95 },
66
+ { name: 'Web', value: 60 },
67
+ ],
68
+ },
69
+ {
70
+ name: '设计',
71
+ children: [
72
+ { name: 'UI', value: 70 },
73
+ { name: 'UX', value: 45 },
74
+ ],
75
+ },
76
+ ],
77
+ };
78
+
79
+ chart.options({
80
+ type: 'treemap',
81
+ data: {
82
+ value: data
83
+ },
84
+ encode: {
85
+ value: 'value', // 叶节点数值字段
86
+ },
87
+ layout: {
88
+ tile: 'treemapSquarify', // 布局算法(默认)
89
+ paddingInner: 2, // 矩形间距
90
+ },
91
+ style: {
92
+ labelText: (d) => d.data?.name || '',
93
+ labelFill: '#fff',
94
+ labelFontSize: 13,
95
+ fillOpacity: 0.85,
96
+ },
97
+ legend: false,
98
+ });
99
+
100
+ chart.render();
101
+ ```
102
+
103
+ ## 数据配置形式说明
104
+
105
+ **为什么 treemap 使用 ` { value: data }` 而不是 `data`?**
106
+
107
+ 层次数据是**对象**(包含 name/children),不是数组,必须使用完整形式:
108
+
109
+ ```javascript
110
+ // ❌ 错误:层次数据不是数组,不能用简写
111
+ chart.options({
112
+ type: 'treemap',
113
+ data: hierarchyData, // ❌ 不工作
114
+ });
115
+
116
+ // ✅ 正确:层次数据必须用完整形式
117
+ chart.options({
118
+ type: 'treemap',
119
+ data: { value: hierarchyData }, // ✅
120
+ });
121
+ ```
122
+
123
+ **简写形式仅适用于数组数据**(满足三个条件:内联、是数组、无 transform)。
124
+
125
+ ---
126
+
127
+ ## 完整配置项
128
+
129
+ ```javascript
130
+ chart.options({
131
+ type: 'treemap',
132
+ data: {
133
+ value: hierarchicalData
134
+ },
135
+ encode: {
136
+ value: 'value', // 叶节点数值字段(决定矩形面积)
137
+ },
138
+ layout: {
139
+ // tile 算法选择:
140
+ // 'treemapSquarify'(默认,接近正方形)
141
+ // 'treemapBinary'(二叉分割)
142
+ // 'treemapDice'(横向分割)
143
+ // 'treemapSlice'(纵向分割)
144
+ // 'treemapSliceDice'(交替分割)
145
+ tile: 'treemapSquarify',
146
+ paddingInner: 2, // 同层矩形间距(px)
147
+ paddingOuter: 4, // 外边距
148
+ paddingTop: 20, // 顶部留白(用于父节点标签)
149
+ ratio: 1.618, // 黄金比例(treemapSquarify 专用)
150
+ ignoreParentValue: true, // 忽略父节点自身 value
151
+ },
152
+ style: {
153
+ // 矩形标签
154
+ labelText: (d) => d.data?.name,
155
+ labelFill: '#fff',
156
+ labelFontSize: 12,
157
+ labelPosition: 'top-left', // 标签位置
158
+ fillOpacity: 0.8,
159
+ stroke: '#fff',
160
+ lineWidth: 1,
161
+ },
162
+ });
163
+ ```
164
+
165
+ ## 多层级标签(父节点 + 叶节点)
166
+
167
+ ```javascript
168
+ chart.options({
169
+ type: 'treemap',
170
+ data: {
171
+ value: data
172
+ },
173
+ encode: { value: 'value' },
174
+ layout: {
175
+ tile: 'treemapSquarify',
176
+ paddingInner: 3,
177
+ paddingTop: 24, // 为父节点标题留空间
178
+ },
179
+ style: {
180
+ // 叶节点显示名称
181
+ labelText: (d) => {
182
+ // path 是从根到当前节点的路径数组
183
+ return d.depth > 1 ? d.data?.name : '';
184
+ },
185
+ // 父节点(depth=1)用大标签
186
+ labelFontSize: (d) => d.depth === 1 ? 14 : 11,
187
+ labelFontWeight: (d) => d.depth === 1 ? 'bold' : 'normal',
188
+ labelFill: '#fff',
189
+ fillOpacity: (d) => d.depth === 1 ? 0.6 : 0.85,
190
+ },
191
+ });
192
+ ```
193
+
194
+ ## 股票板块热力图(市场涨跌)
195
+
196
+ ```javascript
197
+ const marketData = {
198
+ name: 'A股',
199
+ children: [
200
+ {
201
+ name: '科技',
202
+ children: [
203
+ { name: '华为', value: 1200, change: 3.5 },
204
+ { name: '腾讯', value: 980, change: -1.2 },
205
+ { name: '阿里', value: 850, change: 0.8 },
206
+ ],
207
+ },
208
+ {
209
+ name: '金融',
210
+ children: [
211
+ { name: '工行', value: 2100, change: 1.1 },
212
+ { name: '建行', value: 1800, change: -0.5 },
213
+ ],
214
+ },
215
+ ],
216
+ };
217
+
218
+ chart.options({
219
+ type: 'treemap',
220
+ data: {
221
+ value: marketData
222
+ },
223
+ encode: {
224
+ value: 'value',
225
+ // 颜色按涨跌幅映射
226
+ color: (d) => d.data?.change ?? 0,
227
+ },
228
+ scale: {
229
+ color: {
230
+ type: 'diverging',
231
+ palette: 'RdYlGn', // 红(跌)→ 黄(平)→ 绿(涨)
232
+ domain: [-5, 0, 5],
233
+ },
234
+ },
235
+ style: {
236
+ labelText: (d) =>
237
+ d.data?.name && d.data?.change != null
238
+ ? `${d.data.name}\n${d.data.change > 0 ? '+' : ''}${d.data.change}%`
239
+ : d.data?.name || '',
240
+ labelFill: '#fff',
241
+ labelFontSize: 12,
242
+ },
243
+ legend: { color: { position: 'top' } },
244
+ });
245
+ ```
246
+
247
+ ## 常见错误与修正
248
+
249
+ ### 错误 1:数据格式非树形结构
250
+
251
+ ```javascript
252
+ // ❌ 错误:treemap 需要树形嵌套数据,不能用平坦数组
253
+ chart.options({
254
+ type: 'treemap',
255
+ data: [
256
+ { name: '前端', value: 120, parent: '技术' }, // ❌ 平坦格式
257
+ ],
258
+ });
259
+
260
+ // ✅ 正确:需要 children 嵌套结构
261
+ chart.options({
262
+ type: 'treemap',
263
+ data: {
264
+ value: {
265
+ name: 'root',
266
+ children: [
267
+ {
268
+ name: '技术',
269
+ children: [
270
+ { name: '前端', value: 120 }, // ✅ 叶节点有 value
271
+ ],
272
+ },
273
+ ],
274
+ },
275
+ },
276
+ encode: { value: 'value' },
277
+ });
278
+ ```
279
+
280
+ ### 错误 2:encode.value 字段名与数据不匹配
281
+
282
+ ```javascript
283
+ // ❌ 错误:数据中叶节点字段是 size,但 encode.value 写的是 value
284
+ const data = {
285
+ value: { name: 'root', children: [{ name: 'A', size: 100 }] }
286
+ };
287
+ chart.options({
288
+ encode: { value: 'value' }, // ❌ 字段名不匹配
289
+ });
290
+
291
+ // ✅ 正确
292
+ chart.options({
293
+ encode: { value: 'size' }, // ✅ 与数据字段一致
294
+ });
295
+ ```
296
+
297
+ ---
298
+
299
+ ## 节点数据访问规则(重要!)
300
+
301
+ 层次结构图中,回调函数接收到的参数 `d` **不是原始数据对象**,而是 G2 用 d3-hierarchy 包装后的层次节点,**原始数据在 `d.data` 中**。
302
+
303
+ ### 为什么 `encode.color: 'growth'` 不起作用?
304
+
305
+ **根本原因**:当 encode 是字符串时,G2 内部做的是 `datum[fieldName]`,直接访问节点对象的属性。对于层次 mark,`datum` 是层次节点(hierarchy node),不是原始数据对象:
306
+
307
+ ```
308
+ d['growth'] → undefined ❌(层次节点没有 growth 属性)
309
+ d.data['growth'] → 3.5 ✅(原始数据在 d.data 上)
310
+ ```
311
+
312
+ **特例**:`encode.value: 'value'` 看起来用字符串也能工作,是因为 G2 对层次 mark 的 `value` 通道做了**专项处理**,直接读取节点的 `value` 属性(d3-hierarchy 计算后的值)。其他通道(`color`、`shape` 等)没有这个特殊处理,字符串会直接 `datum[field]` 导致 `undefined`。
313
+
314
+ ```javascript
315
+ // ❌ encode.color: 'growth' 的内部执行等价于:
316
+ const color = datum['growth'] // datum 是层次节点,'growth' 不在节点上 → undefined
317
+ // 结果:所有矩形使用相同颜色
318
+
319
+ // ✅ 使用回调才能正确访问:
320
+ const color = datum.data?.['growth'] // datum.data 才是原始数据对象
321
+ ```
322
+
323
+ ### 回调参数 d 的结构
324
+
325
+ ```javascript
326
+ // d 是 d3-hierarchy 节点,结构如下:
327
+ {
328
+ value: 100, // 节点数值(d3 计算的叶子值之和)
329
+ depth: 2, // 层级深度(0 = 根节点)
330
+ height: 0, // 子树高度(叶子节点为 0)
331
+ { // ← 原始数据在这里!
332
+ name: '前端',
333
+ value: 120,
334
+ growth: 3.5,
335
+ // ... 其它自定义字段
336
+ },
337
+ path: ['root', '技术', '前端'], // 从根到当前节点的路径
338
+ }
339
+ ```
340
+
341
+ ### encode 中访问字段
342
+
343
+ ```javascript
344
+ // ❌ 错误:字符串字段名对 color/shape 等通道不起作用,返回 undefined
345
+ encode: {
346
+ value: 'value', // ✅ value 通道有专项处理,字符串可用
347
+ color: 'growth', // ❌ 等价于 d['growth'] = undefined,所有矩形颜色相同
348
+ }
349
+
350
+ // ✅ 正确:除 value 外的所有通道必须用回调函数
351
+ encode: {
352
+ value: 'value',
353
+ color: (d) => d.data?.growth, // ✅ 通过 d.data 访问原始字段
354
+ }
355
+ ```
356
+
357
+ ### 常用着色策略
358
+
359
+ ```javascript
360
+ // 按父节点着色(推荐,同门类同色,视觉分组清晰)
361
+ color: (d) => d.path?.[1] || d.data?.name
362
+
363
+ // 按层级深度着色
364
+ color: (d) => d.depth
365
+
366
+ // 按自定义字段着色
367
+ color: (d) => d.data?.growth
368
+ color: (d) => d.data?.category
369
+
370
+ // 按数值着色(连续色板)
371
+ color: (d) => d.value
372
+ ```
373
+
374
+ ### 配合 scale 自定义颜色
375
+
376
+ ```javascript
377
+ encode: {
378
+ value: 'value',
379
+ color: (d) => d.data?.growth,
380
+ },
381
+ scale: {
382
+ color: {
383
+ type: 'diverging',
384
+ palette: 'RdYlGn',
385
+ domain: [-5, 0, 5],
386
+ },
387
+ }
388
+ ```
389
+
390
+ ### 错误 3:encode.color 使用字符串字段名导致所有矩形颜色相同
391
+
392
+ ```javascript
393
+ // ❌ 错误:color: 'growth' 等价于 d['growth'],层次节点上没有 growth 属性 → undefined
394
+ chart.options({
395
+ type: 'treemap',
396
+ data: { value: data },
397
+ encode: {
398
+ value: 'value',
399
+ color: 'growth', // ❌ d['growth'] = undefined → 所有矩形显示相同颜色
400
+ },
401
+ });
402
+
403
+ // ✅ 正确:color 必须用回调函数,通过 d.data 访问原始字段
404
+ chart.options({
405
+ type: 'treemap',
406
+ data: { value: data },
407
+ encode: {
408
+ value: 'value',
409
+ color: (d) => d.data?.growth, // ✅ 按涨跌幅着色
410
+ },
411
+ });
412
+ ```
413
+
414
+ ### 错误 4:labels/style 中使用 d.name 导致 undefined
415
+
416
+ ```javascript
417
+ // ❌ 错误:treemap 节点的原始字段在 d.data 中,d.name 是 undefined
418
+ style: {
419
+ labelText: (d) => d.name, // ❌ d.name 是 undefined
420
+ }
421
+
422
+ // ✅ 正确:通过 d.data 访问原始数据字段
423
+ style: {
424
+ labelText: (d) => d.data?.name || '', // ✅
425
+ }
426
+ ```
@@ -0,0 +1,108 @@
1
+ ---
2
+ id: "g2-mark-vector"
3
+ title: "G2 向量图(vector)"
4
+ description: |
5
+ vector mark 在每个数据点绘制一个有方向和大小的箭头,
6
+ 用于展示风场、水流方向等具有方向和强度的场数据。
7
+ encode 中用 rotate 通道控制方向(角度),size 通道控制长度。
8
+
9
+ library: "g2"
10
+ version: "5.x"
11
+ category: "marks"
12
+ tags:
13
+ - "vector"
14
+ - "向量"
15
+ - "方向场"
16
+ - "风场"
17
+ - "箭头"
18
+ - "流场"
19
+
20
+ related:
21
+ - "g2-mark-point-scatter"
22
+ - "g2-core-encode-channel"
23
+
24
+ use_cases:
25
+ - "风场可视化(风向和风速)"
26
+ - "流体力学模拟结果展示"
27
+ - "梯度场、力场可视化"
28
+
29
+ difficulty: "advanced"
30
+ completeness: "full"
31
+ created: "2025-03-24"
32
+ updated: "2025-03-24"
33
+ author: "antv-team"
34
+ source_url: "https://g2.antv.antgroup.com/examples/general/point/#vector"
35
+ ---
36
+
37
+ ## 最小可运行示例(风场)
38
+
39
+ ```javascript
40
+ import { Chart } from '@antv/g2';
41
+
42
+ // 模拟风场数据:每个格点有位置、风向(角度)和风速(大小)
43
+ const data = [];
44
+ for (let x = 0; x < 10; x++) {
45
+ for (let y = 0; y < 10; y++) {
46
+ const angle = (x * 30 + y * 15) % 360; // 风向(度)
47
+ const speed = 2 + Math.random() * 8; // 风速
48
+ data.push({ x, y, angle, speed });
49
+ }
50
+ }
51
+
52
+ const chart = new Chart({ container: 'container', width: 600, height: 600 });
53
+
54
+ chart.options({
55
+ type: 'vector',
56
+ data,
57
+ encode: {
58
+ x: 'x',
59
+ y: 'y',
60
+ rotate: 'angle', // 箭头旋转角度(度,0=向右,顺时针)
61
+ size: 'speed', // 箭头长度(映射到速度)
62
+ color: 'speed', // 颜色映射风速
63
+ },
64
+ scale: {
65
+ color: { type: 'sequential', palette: 'viridis' },
66
+ size: { range: [6, 24] },
67
+ },
68
+ style: {
69
+ arrow: true, // 显示箭头
70
+ },
71
+ legend: { color: { title: '风速 (m/s)' } },
72
+ });
73
+
74
+ chart.render();
75
+ ```
76
+
77
+ ## 配置项
78
+
79
+ ```javascript
80
+ chart.options({
81
+ type: 'vector',
82
+ data,
83
+ encode: {
84
+ x: 'x',
85
+ y: 'y',
86
+ rotate: 'direction', // 方向角度字段(0°=向右,顺时针增加)
87
+ size: 'magnitude', // 向量长度字段
88
+ color: 'intensity', // 颜色编码字段(可选)
89
+ },
90
+ style: {
91
+ arrow: true, // 是否显示箭头,默认 true
92
+ arrowSize: 6, // 箭头头部大小(px)
93
+ },
94
+ });
95
+ ```
96
+
97
+ ## 常见错误与修正
98
+
99
+ ### 错误:rotate 是弧度而不是角度
100
+ ```javascript
101
+ // ❌ 如果原始数据是弧度,直接用 rotate 通道会导致方向错误
102
+ const data = [{ ..., direction: Math.PI / 4 }]; // 弧度
103
+ chart.options({ encode: { rotate: 'direction' } }); // ❌ G2 期望角度
104
+
105
+ // ✅ 将弧度转换为角度
106
+ const data = data.map(d => ({ ...d, dirDeg: (d.direction * 180) / Math.PI }));
107
+ chart.options({ encode: { rotate: 'dirDeg' } }); // ✅ 角度值
108
+ ```