@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,266 @@
1
+ ---
2
+ id: "g2-core-chart-init"
3
+ title: "G2 Chart 初始化与基础配置"
4
+ description: |
5
+ 介绍 G2 v5 中 Chart 对象的创建方式、必填与可选参数、
6
+ 自适应尺寸、主题配置及生命周期管理。
7
+ 必须使用 Spec 声明式写法(chart.options({})),禁止使用链式 API。
8
+
9
+ library: "g2"
10
+ version: "5.x"
11
+ category: "core"
12
+ tags:
13
+ - "Chart"
14
+ - "初始化"
15
+ - "容器"
16
+ - "autoFit"
17
+ - "主题"
18
+ - "生命周期"
19
+ - "init"
20
+ - "spec"
21
+ - "options"
22
+
23
+ related:
24
+ - "g2-core-encode-channel"
25
+ - "g2-core-data-binding"
26
+ - "g2-core-lifecycle"
27
+ - "g2-theme-builtin"
28
+
29
+ use_cases:
30
+ - "开始创建任何 G2 图表"
31
+ - "配置图表画布尺寸和容器"
32
+ - "设置全局主题和内边距"
33
+
34
+ anti_patterns:
35
+ - "不要在同一个容器上多次 new Chart(会产生多个画布)"
36
+ - "禁止使用链式 API(chart.interval().encode()...)"
37
+ - "禁止在同一图表中多次调用 chart.options({})(后者会覆盖前者,应合并为一次调用)"
38
+
39
+ difficulty: "beginner"
40
+ completeness: "partial"
41
+ created: "2024-01-01"
42
+ updated: "2025-03-27"
43
+ author: "antv-team"
44
+ source_url: "https://g2.antv.antgroup.com/manual/core/chart"
45
+ ---
46
+
47
+ ## 核心概念
48
+
49
+ `Chart` 是 G2 中最顶层的容器对象,负责管理画布、视图、坐标系和渲染。
50
+
51
+ **必须使用 Spec 模式**:通过 `chart.options({})` 一次性传入完整描述对象,结构清晰,易于序列化和动态生成。
52
+
53
+ **禁止使用链式 API**:`chart.interval().encode()` 等链式调用禁止使用。
54
+
55
+ ## 最小可运行示例(Spec 模式)
56
+
57
+ ```javascript
58
+ import { Chart } from '@antv/g2';
59
+
60
+ const chart = new Chart({
61
+ container: 'container',
62
+ width: 640,
63
+ height: 480,
64
+ });
65
+
66
+ chart.options({
67
+ type: 'line', // Mark 类型
68
+ data: [
69
+ { x: 1, y: 10 },
70
+ { x: 2, y: 30 },
71
+ { x: 3, y: 20 },
72
+ ],
73
+ encode: { x: 'x', y: 'y' },
74
+ });
75
+
76
+ chart.render();
77
+ ```
78
+
79
+ ## 完整 Chart 容器配置项
80
+
81
+ ```javascript
82
+ import { Chart } from '@antv/g2';
83
+
84
+ const chart = new Chart({
85
+ // ── 必填 ──────────────────────────────
86
+ container: 'container', // string | HTMLElement:DOM 容器
87
+
88
+ // ── 尺寸 ──────────────────────────────
89
+ width: 640, // 画布宽度(px),默认 640
90
+ height: 480, // 画布高度(px),默认 480
91
+ autoFit: true, // 自动适应容器尺寸(忽略 width/height)
92
+
93
+ // ── 内边距 ────────────────────────────
94
+ padding: 'auto', // 'auto' | number | [top, right, bottom, left]
95
+ paddingTop: 40,
96
+ paddingRight: 20,
97
+ paddingBottom: 40,
98
+ paddingLeft: 60,
99
+ inset: 0, // 数据区域内缩(防止数据点紧贴边缘)
100
+
101
+ // ── 主题 ──────────────────────────────
102
+ theme: 'classic', // 'classic' | 'classicDark' | 'academy'
103
+
104
+ // ── 渲染器 ────────────────────────────
105
+ renderer: undefined, // 默认 Canvas,可传入 SVG 渲染器
106
+
107
+ // ── 像素比 ────────────────────────────
108
+ devicePixelRatio: window.devicePixelRatio,
109
+ });
110
+ ```
111
+
112
+ ## Spec 模式完整结构
113
+
114
+ ```javascript
115
+ chart.options({
116
+ // Mark 类型
117
+ type: 'interval',
118
+
119
+ // 数据,不同 Mark 直接存在结构上的差异,优先使用对应 mark 中的数据结构
120
+ data: [...],
121
+
122
+ // 视觉通道映射
123
+ encode: {
124
+ x: 'genre',
125
+ y: 'sold',
126
+ color: 'genre',
127
+ },
128
+
129
+ // 数据变换
130
+ transform: [{ type: 'stackY' }],
131
+
132
+ // 比例尺
133
+ scale: {
134
+ y: { domain: [0, 500] },
135
+ color: { range: ['#1890ff', '#52c41a'] },
136
+ },
137
+
138
+ // 坐标系
139
+ coordinate: { transform: [{ type: 'transpose' }] },
140
+
141
+ // 样式
142
+ style: { radius: 4 },
143
+
144
+ // 数据标签
145
+ labels: [{ text: 'sold', position: 'outside' }],
146
+
147
+ // Tooltip
148
+ tooltip: { title: 'genre', items: [{ field: 'sold', name: '销量' }] },
149
+
150
+ // 坐标轴
151
+ axis: {
152
+ x: { title: '游戏类型' },
153
+ y: { title: '销量' },
154
+ },
155
+
156
+ // 图例
157
+ legend: {
158
+ color: { position: 'top' },
159
+ },
160
+ });
161
+ ```
162
+
163
+ ## Spec 模式标准写法
164
+
165
+ ```javascript
166
+ // ✅ 正确:Spec 模式(唯一推荐写法)
167
+ chart.options({
168
+ type: 'interval',
169
+ data: [...],
170
+ encode: { x: 'genre', y: 'sold', color: 'genre' },
171
+ style: { radius: 4 },
172
+ });
173
+
174
+ // ❌ 禁止:链式 API 模式
175
+ chart.interval()
176
+ .data([...])
177
+ .encode('x', 'genre')
178
+ .encode('y', 'sold')
179
+ .encode('color', 'genre')
180
+ .style({ radius: 4 });
181
+ ```
182
+
183
+
184
+ ## 响应式自适应
185
+
186
+ ```javascript
187
+ // autoFit:宽度跟随容器,高度可固定
188
+ const chart = new Chart({
189
+ container: 'container',
190
+ autoFit: true,
191
+ height: 400,
192
+ });
193
+
194
+ chart.options({ type: 'line', data: [...], encode: { x: 'x', y: 'y' } });
195
+ chart.render();
196
+ ```
197
+
198
+ ## 生命周期
199
+
200
+ ```javascript
201
+ // 初次渲染
202
+ chart.render();
203
+
204
+ // 更新 Spec 后重新渲染(changeData 只更新数据)
205
+ chart.options({ type: 'bar', newData, encode: { x: 'x', y: 'y' } });
206
+ chart.render();
207
+
208
+ // 仅更新数据(性能更好)
209
+ chart.changeData(newData);
210
+
211
+ // 销毁
212
+ chart.destroy();
213
+
214
+ // 事件监听
215
+ chart.on('afterrender', () => console.log('渲染完成'));
216
+ ```
217
+
218
+ ## 常见错误与修正
219
+
220
+ ### 错误 0:多次调用 chart.options({})
221
+ ```javascript
222
+ // ❌ 错误:第二次 options() 会完全覆盖第一次,导致配置丢失
223
+ chart.options({ type: 'interval', encode: { x: 'genre', y: 'sold' } });
224
+ chart.options({ style: { radius: 4 } }); // 前面的 type/encode 丢失!
225
+
226
+ // ✅ 正确:所有配置合并为一次 chart.options({}) 调用
227
+ chart.options({
228
+ type: 'interval',
229
+ encode: { x: 'genre', y: 'sold' },
230
+ style: { radius: 4 },
231
+ });
232
+ ```
233
+
234
+
235
+ ### 错误 1:container 指向不存在的 ID
236
+ ```javascript
237
+ // ❌ 错误:DOM 还未加载
238
+ const chart = new Chart({ container: 'chart' });
239
+
240
+ // ✅ 正确:确保 DOM 已存在
241
+ document.addEventListener('DOMContentLoaded', () => {
242
+ const chart = new Chart({ container: 'chart', width: 640, height: 400 });
243
+ chart.options({ type: 'line', [...], encode: { x: 'x', y: 'y' } });
244
+ chart.render();
245
+ });
246
+ ```
247
+
248
+ ### 错误 2:重复初始化同一容器
249
+ ```javascript
250
+ // ❌ 错误:会创建两个画布叠加
251
+ const chart1 = new Chart({ container: 'container' });
252
+ const chart2 = new Chart({ container: 'container' });
253
+
254
+ // ✅ 正确:先销毁旧实例
255
+ chart1.destroy();
256
+ const chart2 = new Chart({ container: 'container' });
257
+ ```
258
+
259
+ ### 错误 3:autoFit 与固定宽度混用
260
+ ```javascript
261
+ // ❌ 错误:autoFit 会覆盖 width
262
+ const chart = new Chart({ container: 'c', autoFit: true, width: 640 });
263
+
264
+ // ✅ 正确:autoFit 时只设 height
265
+ const chart = new Chart({ container: 'c', autoFit: true, height: 400 });
266
+ ```
@@ -0,0 +1,197 @@
1
+ ---
2
+ id: "g2-core-encode-channel"
3
+ title: "G2 encode 通道系统详解"
4
+ description: |
5
+ encode 是 G2 v5 的核心数据映射机制,将数据字段映射到视觉通道(位置、颜色、大小、形状等)。
6
+ 在 Spec 模式中,encode 是 options 对象中的一个字段;在链式 API 中通过 .encode() 方法调用。
7
+
8
+ library: "g2"
9
+ version: "5.x"
10
+ category: "core"
11
+ tags:
12
+ - "encode"
13
+ - "通道"
14
+ - "channel"
15
+ - "数据映射"
16
+ - "x"
17
+ - "y"
18
+ - "color"
19
+ - "size"
20
+ - "shape"
21
+ - "spec"
22
+
23
+ related:
24
+ - "g2-core-chart-init"
25
+ - "g2-scale-linear"
26
+ - "g2-scale-ordinal"
27
+ - "g2-core-data-binding"
28
+
29
+ use_cases:
30
+ - "将数据字段映射到图表的视觉属性"
31
+ - "理解 Spec 模式中 encode 对象的结构"
32
+ - "配置多通道映射"
33
+
34
+ difficulty: "beginner"
35
+ completeness: "partial"
36
+ created: "2024-01-01"
37
+ updated: "2025-03-01"
38
+ author: "antv-team"
39
+ source_url: "https://g2.antv.antgroup.com/manual/core/encode"
40
+ ---
41
+
42
+ ## 核心概念
43
+
44
+ **通道(Channel)** 是图形属性的抽象。在 Spec 模式中,`encode` 是 `options` 对象的一个字段,
45
+ 其中每个 key 是通道名,value 是数据字段名(字符串)或常量。
46
+
47
+ ## 通用通道列表
48
+
49
+ | 通道 | 说明 | 常见 Mark |
50
+ |------|------|-----------|
51
+ | `x` | X 轴位置 | 所有 Mark |
52
+ | `y` | Y 轴位置 | 所有 Mark |
53
+ | `color` | 颜色(fill + stroke) | 所有 Mark |
54
+ | `size` | 大小/粗细 | Point、Link、Line |
55
+ | `shape` | 形状 | Point、Interval |
56
+ | `opacity` | 透明度 | 所有 Mark |
57
+ | `series` | 系列分组(不影响颜色) | Line、Area |
58
+ | `key` | 动画时元素匹配键 | 所有 Mark |
59
+
60
+ ## 基本用法(Spec 模式)
61
+
62
+ ```javascript
63
+ import { Chart } from '@antv/g2';
64
+
65
+ const chart = new Chart({ container: 'container', width: 640, height: 480 });
66
+
67
+ chart.options({
68
+ type: 'interval',
69
+ data: [
70
+ { city: '北京', gdp: 3.6 },
71
+ { city: '上海', gdp: 4.0 },
72
+ { city: '广州', gdp: 2.8 },
73
+ ],
74
+ encode: {
75
+ x: 'city', // 分类轴:自动使用 Band Scale
76
+ y: 'gdp', // 数值轴:自动使用 Linear Scale
77
+ color: 'city', // 颜色区分
78
+ },
79
+ });
80
+
81
+ chart.render();
82
+ ```
83
+
84
+ ## 典型场景示例
85
+
86
+ ### 时间 x 轴(折线图)
87
+
88
+ ```javascript
89
+ chart.options({
90
+ type: 'line',
91
+ data: [
92
+ { date: new Date('2024-01-01'), value: 100 },
93
+ { date: new Date('2024-02-01'), value: 130 },
94
+ { date: new Date('2024-03-01'), value: 110 },
95
+ ],
96
+ encode: {
97
+ x: 'date', // Date 对象自动使用 Time Scale
98
+ y: 'value',
99
+ color: 'series', // 多系列折线
100
+ },
101
+ });
102
+ ```
103
+
104
+ ### 双数值轴 + 气泡图(多通道映射)
105
+
106
+ ```javascript
107
+ chart.options({
108
+ type: 'point',
109
+ data: [
110
+ { income: 30000, lifeExpect: 72, population: 1400, country: 'China' },
111
+ { income: 60000, lifeExpect: 79, population: 330, country: 'USA' },
112
+ { income: 45000, lifeExpect: 84, population: 125, country: 'Japan' },
113
+ ],
114
+ encode: {
115
+ x: 'income',
116
+ y: 'lifeExpect',
117
+ size: 'population', // 气泡大小
118
+ color: 'country',
119
+ shape: 'point',
120
+ },
121
+ scale: {
122
+ size: { range: [10, 60] },
123
+ },
124
+ });
125
+ ```
126
+
127
+ ### 函数映射(高级)
128
+
129
+ ```javascript
130
+ chart.options({
131
+ type: 'point',
132
+ data: [...],
133
+ encode: {
134
+ x: 'date',
135
+ y: 'value',
136
+ // value 是函数时:动态计算通道值
137
+ color: (d) => d.value > 100 ? 'red' : 'blue',
138
+ size: (d) => Math.sqrt(d.count),
139
+ },
140
+ });
141
+ ```
142
+
143
+ ## encode 字段值类型说明
144
+
145
+ | 值类型 | 含义 | 示例 |
146
+ |--------|------|------|
147
+ | `string`(字段名)| 映射数据字段 | `'genre'` |
148
+ | `string`(颜色/形状常量)| 所有元素相同值 | `'#1890ff'`、`'circle'` |
149
+ | `number` | 所有元素相同数值 | `10`(size 常量) |
150
+ | `function` | 动态计算 | `(d) => d.val * 2` |
151
+
152
+ > **判断规则**:`encode.color` 传入 `'genre'` → 视为字段名;传入 `'#1890ff'` → 视为颜色常量(以 `#` 开头或合法 CSS 颜色名)。`encode.size` 传入 `10`(数字)→ 常量。
153
+
154
+ ## G2 v4 → v5 Spec 迁移对照
155
+
156
+ | G2 v4 链式 | G2 v5 Spec encode 字段 |
157
+ |-----------|------------------------|
158
+ | `.position('x*y')` | `encode: { x: 'x', y: 'y' }` |
159
+ | `.color('type')` | `encode: { color: 'type' }` |
160
+ | `.size('count')` | `encode: { size: 'count' }` |
161
+ | `.shape('circle')` | `encode: { shape: 'circle' }` |
162
+ | `.opacity('rate')` | `encode: { opacity: 'rate' }` |
163
+
164
+ ## 常见错误与修正
165
+
166
+ ### 错误 1:encode 写在了 style 里
167
+ ```javascript
168
+ // ❌ 错误:style 不做数据映射
169
+ chart.options({
170
+ type: 'interval',
171
+ data: [...],
172
+ style: { color: 'genre' }, // 无效!genre 是字段名,不是颜色值
173
+ });
174
+
175
+ // ✅ 正确:数据映射用 encode,固定样式用 style
176
+ chart.options({
177
+ type: 'interval',
178
+ data: [...],
179
+ encode: { color: 'genre' }, // 数据驱动颜色
180
+ style: { fillOpacity: 0.8 }, // 固定透明度
181
+ });
182
+ ```
183
+
184
+ ### 错误 2:color 与 series 通道混淆
185
+ ```javascript
186
+ // 说明:color 既分组又改颜色;series 只分组不改颜色
187
+ // 多系列折线图推荐用 color:
188
+ chart.options({
189
+ type: 'line',
190
+ encode: {
191
+ x: 'month',
192
+ y: 'value',
193
+ color: 'type', // ✅ 推荐:每条线不同颜色
194
+ // series: 'type', // 只分组,颜色相同(少用)
195
+ },
196
+ });
197
+ ```
@@ -0,0 +1,224 @@
1
+ ---
2
+ id: "g2-core-view-composition"
3
+ title: "G2 视图组合(view + children)"
4
+ description: |
5
+ G2 v5 通过 type: 'view' 容器和 children 数组实现多 Mark 叠加、
6
+ 共享数据、分面(facet)等复合图表。
7
+ 这是 Spec 模式中组合多个图形层的标准方式。
8
+
9
+ library: "g2"
10
+ version: "5.x"
11
+ category: "core"
12
+ tags:
13
+ - "view"
14
+ - "children"
15
+ - "视图组合"
16
+ - "多Mark叠加"
17
+ - "layer"
18
+ - "复合图表"
19
+ - "spec"
20
+
21
+ related:
22
+ - "g2-core-chart-init"
23
+ - "g2-comp-annotation"
24
+ - "g2-comp-facet-rect"
25
+
26
+ use_cases:
27
+ - "在同一坐标系中叠加多种图形(折线+散点、面积+折线)"
28
+ - "为多个子 Mark 共享数据源"
29
+ - "在图表中添加标注层"
30
+
31
+ anti_patterns:
32
+ - "只有单个 Mark 时不需要 view 容器,直接用对应 type 即可"
33
+ - "children 中嵌套 type: 'view'——当某个子 Mark 需要独立数据时,直接在该 Mark 上指定 data 字段,而非再套一层 view + children"
34
+
35
+ difficulty: "intermediate"
36
+ completeness: "full"
37
+ created: "2024-01-01"
38
+ updated: "2025-03-01"
39
+ author: "antv-team"
40
+ source_url: "https://g2.antv.antgroup.com/manual/core/composition/view"
41
+ ---
42
+
43
+ ## 核心概念
44
+
45
+ ```
46
+ chart.options({
47
+ type: 'view', // 容器类型
48
+ [...], // 父级数据(子 Mark 可继承)
49
+ encode: {...}, // 父级编码(子 Mark 可继承)
50
+ children: [ // 子 Mark 列表(按顺序渲染,后面的在上层)
51
+ { type: 'area', ... },
52
+ { type: 'line', ... },
53
+ { type: 'point', ... },
54
+ ],
55
+ });
56
+ ```
57
+
58
+ **数据继承规则**:
59
+ - 子 Mark 若未指定 `data`,继承父级 `data`
60
+ - 子 Mark 若未指定 `encode`,继承父级 `encode` 中对应通道
61
+
62
+ ## 面积 + 折线 + 散点叠加
63
+
64
+ ```javascript
65
+ import { Chart } from '@antv/g2';
66
+
67
+ const chart = new Chart({ container: 'container', width: 700, height: 400 });
68
+
69
+ const data = [
70
+ { month: 'Jan', value: 33 },
71
+ { month: 'Feb', value: 78 },
72
+ { month: 'Mar', value: 56 },
73
+ { month: 'Apr', value: 91 },
74
+ { month: 'May', value: 67 },
75
+ ];
76
+
77
+ chart.options({
78
+ type: 'view',
79
+ data, // 父级数据,三个子 Mark 共享
80
+ encode: { x: 'month', y: 'value' }, // 父级编码,子 Mark 继承
81
+ children: [
82
+ {
83
+ type: 'area',
84
+ style: { fill: '#1890ff', fillOpacity: 0.15 },
85
+ },
86
+ {
87
+ type: 'line',
88
+ style: { stroke: '#1890ff', lineWidth: 2 },
89
+ },
90
+ {
91
+ type: 'point',
92
+ encode: { shape: 'circle' },
93
+ style: { fill: 'white', stroke: '#1890ff', r: 4, lineWidth: 2 },
94
+ },
95
+ ],
96
+ });
97
+
98
+ chart.render();
99
+ ```
100
+
101
+ ## 子 Mark 独立数据(不继承父级)
102
+
103
+ ```javascript
104
+ chart.options({
105
+ type: 'view',
106
+ children: [
107
+ {
108
+ type: 'interval',
109
+ salesData, // 独立数据
110
+ encode: { x: 'month', y: 'revenue' },
111
+ },
112
+ {
113
+ type: 'line',
114
+ trendData, // 独立数据
115
+ encode: { x: 'month', y: 'growth' },
116
+ scale: { y: { key: 'right' } }, // 独立 y 轴
117
+ },
118
+ ],
119
+ });
120
+ ```
121
+
122
+ ## 折线 + 参考线组合
123
+
124
+ ```javascript
125
+ chart.options({
126
+ type: 'view',
127
+ data,
128
+ children: [
129
+ {
130
+ type: 'line',
131
+ encode: { x: 'month', y: 'value' },
132
+ },
133
+ {
134
+ type: 'lineY', // 水平参考线
135
+ [{ threshold: 60 }],
136
+ encode: { y: 'threshold' },
137
+ style: { stroke: 'red', lineDash: [4, 4] },
138
+ labels: [{ text: '目标线', position: 'right', style: { fill: 'red' } }],
139
+ },
140
+ ],
141
+ });
142
+ ```
143
+
144
+ ## 常见错误与修正
145
+
146
+ ### 错误 1:多次调用 options() 覆盖配置
147
+ ```javascript
148
+ // ❌ 错误:每次 options() 调用都会覆盖上一次
149
+ chart.options({ type: 'area', ... });
150
+ chart.options({ type: 'line', ... }); // 覆盖了面积图!
151
+
152
+ // ✅ 正确:用 view + children
153
+ chart.options({
154
+ type: 'view',
155
+ data,
156
+ children: [
157
+ { type: 'area', ... },
158
+ { type: 'line', ... },
159
+ ],
160
+ });
161
+ ```
162
+
163
+ ### 错误 2:children 中嵌套 view(为子 Mark 单独变换数据时的常见误区)
164
+
165
+ ```javascript
166
+ // ❌ 错误:在 children 里再套一层 type:'view' + children
167
+ chart.options({
168
+ type: 'view',
169
+ data,
170
+ children: [
171
+ { type: 'line', encode: { x: 'time', y: 'value' } },
172
+ {
173
+ type: 'view', // ❌ 不必要的嵌套 view
174
+ data: data.map(d => ({ // 只是想用派生数据
175
+ time: d.time,
176
+ min: d.value - 0.1,
177
+ max: d.value + 0.1,
178
+ })),
179
+ children: [
180
+ { type: 'rangeY', encode: { x: 'time', y: 'min', y1: 'max' } },
181
+ ],
182
+ },
183
+ ],
184
+ });
185
+
186
+ // ✅ 正确:直接在子 Mark 上指定 data,无需嵌套 view
187
+ chart.options({
188
+ type: 'view',
189
+ data,
190
+ children: [
191
+ { type: 'line', encode: { x: 'time', y: 'value' } },
192
+ {
193
+ type: 'rangeY',
194
+ data: data.map(d => ({ // ✅ 直接在 Mark 上声明独立 data
195
+ time: d.time,
196
+ min: d.value - 0.1,
197
+ max: d.value + 0.1,
198
+ })),
199
+ encode: { x: 'time', y: 'min', y1: 'max' },
200
+ style: { fillOpacity: 0.1 },
201
+ },
202
+ ],
203
+ });
204
+ ```
205
+
206
+ **规则**:`children` 数组的每个元素必须是 Mark(`line`/`point`/`interval` 等),
207
+ 当某个 Mark 需要独立或派生数据时,在该 Mark 节点上直接写 `data`,而不是再包一层 `view`。
208
+ G2 不支持在 `children` 内嵌套 `view`。
209
+
210
+ ### 错误 3:子 Mark 的 encode 字段名与数据不匹配
211
+ ```javascript
212
+ // ❌ 错误:父级和子级 encode 的字段名应保持一致
213
+ chart.options({
214
+ type: 'view',
215
+ data: [{ month: 'Jan', value: 33 }],
216
+ encode: { x: 'month', y: 'value' },
217
+ children: [
218
+ {
219
+ type: 'point',
220
+ encode: { x: 'date', y: 'amount' }, // 字段名与数据不匹配!
221
+ },
222
+ ],
223
+ });
224
+ ```