@easyops-cn/a2ui-react 0.0.0 → 0.0.2

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 (604) hide show
  1. package/README.md +12 -8
  2. package/dist/0.8/A2UIRenderer.d.ts +49 -0
  3. package/dist/0.8/A2UIRenderer.test.d.ts +6 -0
  4. package/dist/0.8/components/ComponentRenderer.d.ts +39 -0
  5. package/dist/0.8/components/ComponentRenderer.test.d.ts +6 -0
  6. package/dist/0.8/components/UnknownComponent.d.ts +18 -0
  7. package/dist/0.8/components/display/AudioPlayerComponent.d.ts +5 -0
  8. package/dist/0.8/components/display/DividerComponent.d.ts +5 -0
  9. package/dist/0.8/components/display/IconComponent.d.ts +5 -0
  10. package/dist/0.8/components/display/ImageComponent.d.ts +6 -0
  11. package/dist/0.8/components/display/TextComponent.d.ts +6 -0
  12. package/dist/0.8/components/display/VideoComponent.d.ts +5 -0
  13. package/dist/0.8/components/display/display.test.d.ts +7 -0
  14. package/dist/0.8/components/display/index.d.ts +9 -0
  15. package/dist/0.8/components/index.d.ts +7 -0
  16. package/dist/0.8/components/interactive/ButtonComponent.d.ts +5 -0
  17. package/dist/0.8/components/interactive/CheckBoxComponent.d.ts +5 -0
  18. package/dist/0.8/components/interactive/DateTimeInputComponent.d.ts +5 -0
  19. package/dist/0.8/components/interactive/MultipleChoiceComponent.d.ts +7 -0
  20. package/dist/0.8/components/interactive/SliderComponent.d.ts +5 -0
  21. package/dist/0.8/components/interactive/TextFieldComponent.d.ts +5 -0
  22. package/dist/0.8/components/interactive/index.d.ts +9 -0
  23. package/dist/0.8/components/interactive/interactive.test.d.ts +7 -0
  24. package/dist/0.8/components/layout/CardComponent.d.ts +5 -0
  25. package/dist/0.8/components/layout/ColumnComponent.d.ts +5 -0
  26. package/dist/0.8/components/layout/ListComponent.d.ts +5 -0
  27. package/dist/0.8/components/layout/ModalComponent.d.ts +5 -0
  28. package/dist/0.8/components/layout/RowComponent.d.ts +5 -0
  29. package/dist/0.8/components/layout/TabsComponent.d.ts +5 -0
  30. package/dist/0.8/components/layout/index.d.ts +9 -0
  31. package/dist/0.8/components/layout/layout.test.d.ts +7 -0
  32. package/dist/0.8/contexts/A2UIProvider.d.ts +34 -0
  33. package/dist/0.8/contexts/A2UIProvider.test.d.ts +6 -0
  34. package/dist/0.8/contexts/ActionContext.d.ts +33 -0
  35. package/dist/0.8/contexts/ActionContext.test.d.ts +6 -0
  36. package/dist/0.8/contexts/ComponentsMapContext.d.ts +63 -0
  37. package/dist/0.8/contexts/DataModelContext.d.ts +43 -0
  38. package/dist/0.8/contexts/DataModelContext.test.d.ts +6 -0
  39. package/dist/0.8/contexts/SurfaceContext.d.ts +45 -0
  40. package/dist/0.8/contexts/SurfaceContext.test.d.ts +6 -0
  41. package/dist/0.8/hooks/useA2UIMessageHandler.d.ts +41 -0
  42. package/dist/0.8/hooks/useA2UIMessageHandler.test.d.ts +6 -0
  43. package/{src/0.8/hooks/useComponent.ts → dist/0.8/hooks/useComponent.d.ts} +2 -18
  44. package/dist/0.8/hooks/useComponent.test.d.ts +6 -0
  45. package/dist/0.8/hooks/useDataBinding.d.ts +50 -0
  46. package/dist/0.8/hooks/useDataBinding.test.d.ts +6 -0
  47. package/{src/0.8/hooks/useDispatchAction.ts → dist/0.8/hooks/useDispatchAction.d.ts} +2 -15
  48. package/dist/0.8/hooks/useDispatchAction.test.d.ts +6 -0
  49. package/{src/0.8/hooks/useSurface.ts → dist/0.8/hooks/useSurface.d.ts} +2 -15
  50. package/dist/0.8/hooks/useSurface.test.d.ts +6 -0
  51. package/{src/0.8/index.ts → dist/0.8/index.d.ts} +7 -21
  52. package/{src/0.8/types/index.ts → dist/0.8/types/index.d.ts} +128 -213
  53. package/dist/0.8/utils/dataBinding.d.ts +95 -0
  54. package/dist/0.8/utils/dataBinding.test.d.ts +6 -0
  55. package/dist/0.8/utils/pathUtils.d.ts +63 -0
  56. package/dist/0.8/utils/pathUtils.test.d.ts +6 -0
  57. package/dist/a2ui-react.js +4 -0
  58. package/dist/a2ui-react10.js +54 -0
  59. package/dist/a2ui-react100.js +24 -0
  60. package/dist/a2ui-react101.js +255 -0
  61. package/dist/a2ui-react102.js +163 -0
  62. package/dist/a2ui-react103.js +19 -0
  63. package/dist/a2ui-react104.js +251 -0
  64. package/dist/a2ui-react105.js +61 -0
  65. package/dist/a2ui-react106.js +35 -0
  66. package/dist/a2ui-react107.js +436 -0
  67. package/dist/a2ui-react108.js +16 -0
  68. package/dist/a2ui-react109.js +234 -0
  69. package/dist/a2ui-react11.js +9 -0
  70. package/dist/a2ui-react110.js +6 -0
  71. package/dist/a2ui-react111.js +6 -0
  72. package/dist/a2ui-react112.js +6 -0
  73. package/dist/a2ui-react113.js +239 -0
  74. package/dist/a2ui-react114.js +845 -0
  75. package/dist/a2ui-react115.js +6 -0
  76. package/dist/a2ui-react116.js +10 -0
  77. package/dist/a2ui-react117.js +8 -0
  78. package/dist/a2ui-react118.js +8 -0
  79. package/dist/a2ui-react119.js +20 -0
  80. package/dist/a2ui-react12.js +32 -0
  81. package/dist/a2ui-react120.js +8 -0
  82. package/dist/a2ui-react121.js +8 -0
  83. package/dist/a2ui-react122.js +9 -0
  84. package/dist/a2ui-react123.js +16 -0
  85. package/dist/a2ui-react124.js +18 -0
  86. package/dist/a2ui-react125.js +11 -0
  87. package/dist/a2ui-react126.js +9 -0
  88. package/dist/a2ui-react127.js +13 -0
  89. package/dist/a2ui-react128.js +17 -0
  90. package/dist/a2ui-react129.js +8 -0
  91. package/dist/a2ui-react13.js +36 -0
  92. package/dist/a2ui-react130.js +17 -0
  93. package/dist/a2ui-react131.js +8 -0
  94. package/dist/a2ui-react132.js +10 -0
  95. package/dist/a2ui-react133.js +9 -0
  96. package/dist/a2ui-react134.js +7 -0
  97. package/dist/a2ui-react135.js +9 -0
  98. package/dist/a2ui-react136.js +548 -0
  99. package/dist/a2ui-react137.js +49 -0
  100. package/dist/a2ui-react138.js +20 -0
  101. package/dist/a2ui-react139.js +21 -0
  102. package/dist/a2ui-react14.js +114 -0
  103. package/dist/a2ui-react140.js +11 -0
  104. package/dist/a2ui-react141.js +9 -0
  105. package/dist/a2ui-react142.js +10 -0
  106. package/dist/a2ui-react143.js +8 -0
  107. package/dist/a2ui-react144.js +9 -0
  108. package/dist/a2ui-react145.js +12 -0
  109. package/dist/a2ui-react146.js +8 -0
  110. package/dist/a2ui-react147.js +11 -0
  111. package/dist/a2ui-react148.js +15 -0
  112. package/dist/a2ui-react149.js +8 -0
  113. package/dist/a2ui-react15.js +18 -0
  114. package/dist/a2ui-react150.js +12 -0
  115. package/dist/a2ui-react151.js +10 -0
  116. package/dist/a2ui-react152.js +12 -0
  117. package/dist/a2ui-react153.js +16 -0
  118. package/dist/a2ui-react154.js +8 -0
  119. package/dist/a2ui-react155.js +8 -0
  120. package/dist/a2ui-react156.js +8 -0
  121. package/dist/a2ui-react157.js +7 -0
  122. package/dist/a2ui-react158.js +14 -0
  123. package/dist/a2ui-react159.js +13 -0
  124. package/dist/a2ui-react16.js +19 -0
  125. package/dist/a2ui-react160.js +13 -0
  126. package/dist/a2ui-react161.js +14 -0
  127. package/dist/a2ui-react162.js +14 -0
  128. package/dist/a2ui-react163.js +35 -0
  129. package/dist/a2ui-react164.js +67 -0
  130. package/dist/a2ui-react165.js +11 -0
  131. package/dist/a2ui-react166.js +11 -0
  132. package/dist/a2ui-react167.js +10 -0
  133. package/dist/a2ui-react168.js +13 -0
  134. package/dist/a2ui-react169.js +10 -0
  135. package/dist/a2ui-react17.js +18 -0
  136. package/dist/a2ui-react170.js +10 -0
  137. package/dist/a2ui-react171.js +9 -0
  138. package/dist/a2ui-react172.js +17 -0
  139. package/dist/a2ui-react173.js +21 -0
  140. package/dist/a2ui-react174.js +18 -0
  141. package/dist/a2ui-react175.js +35 -0
  142. package/dist/a2ui-react176.js +14 -0
  143. package/dist/a2ui-react177.js +7 -0
  144. package/dist/a2ui-react178.js +58 -0
  145. package/dist/a2ui-react179.js +25 -0
  146. package/dist/a2ui-react18.js +58 -0
  147. package/dist/a2ui-react180.js +43 -0
  148. package/dist/a2ui-react181.js +63 -0
  149. package/dist/a2ui-react182.js +34 -0
  150. package/dist/a2ui-react183.js +15 -0
  151. package/dist/a2ui-react184.js +67 -0
  152. package/dist/a2ui-react185.js +67 -0
  153. package/dist/a2ui-react186.js +69 -0
  154. package/dist/a2ui-react187.js +69 -0
  155. package/dist/a2ui-react188.js +42 -0
  156. package/dist/a2ui-react189.js +43 -0
  157. package/dist/a2ui-react19.js +58 -0
  158. package/dist/a2ui-react190.js +55 -0
  159. package/dist/a2ui-react191.js +45 -0
  160. package/dist/a2ui-react192.js +41 -0
  161. package/dist/a2ui-react193.js +72 -0
  162. package/dist/a2ui-react194.js +72 -0
  163. package/dist/a2ui-react195.js +97 -0
  164. package/dist/a2ui-react196.js +42 -0
  165. package/dist/a2ui-react197.js +42 -0
  166. package/dist/a2ui-react198.js +42 -0
  167. package/dist/a2ui-react199.js +27 -0
  168. package/dist/a2ui-react2.js +11 -0
  169. package/dist/a2ui-react20.js +51 -0
  170. package/dist/a2ui-react200.js +26 -0
  171. package/dist/a2ui-react201.js +26 -0
  172. package/dist/a2ui-react202.js +27 -0
  173. package/dist/a2ui-react203.js +26 -0
  174. package/dist/a2ui-react204.js +26 -0
  175. package/dist/a2ui-react205.js +16 -0
  176. package/dist/a2ui-react206.js +41 -0
  177. package/dist/a2ui-react207.js +41 -0
  178. package/dist/a2ui-react208.js +16 -0
  179. package/dist/a2ui-react209.js +16 -0
  180. package/dist/a2ui-react21.js +14 -0
  181. package/dist/a2ui-react210.js +32 -0
  182. package/dist/a2ui-react211.js +32 -0
  183. package/dist/a2ui-react212.js +6 -0
  184. package/dist/a2ui-react213.js +9 -0
  185. package/dist/a2ui-react214.js +50 -0
  186. package/dist/a2ui-react215.js +29 -0
  187. package/dist/a2ui-react216.js +68 -0
  188. package/dist/a2ui-react217.js +10 -0
  189. package/dist/a2ui-react218.js +127 -0
  190. package/dist/a2ui-react219.js +17 -0
  191. package/dist/a2ui-react22.js +29 -0
  192. package/dist/a2ui-react220.js +136 -0
  193. package/dist/a2ui-react221.js +13 -0
  194. package/dist/a2ui-react222.js +219 -0
  195. package/dist/a2ui-react223.js +15 -0
  196. package/dist/a2ui-react224.js +36 -0
  197. package/dist/a2ui-react225.js +49 -0
  198. package/dist/a2ui-react226.js +10 -0
  199. package/dist/a2ui-react227.js +52 -0
  200. package/dist/a2ui-react228.js +6 -0
  201. package/dist/a2ui-react229.js +8 -0
  202. package/dist/a2ui-react23.js +25 -0
  203. package/dist/a2ui-react230.js +30 -0
  204. package/dist/a2ui-react231.js +52 -0
  205. package/dist/a2ui-react232.js +11 -0
  206. package/dist/a2ui-react233.js +70 -0
  207. package/dist/a2ui-react234.js +49 -0
  208. package/dist/a2ui-react235.js +27 -0
  209. package/dist/a2ui-react236.js +49 -0
  210. package/dist/a2ui-react237.js +183 -0
  211. package/dist/a2ui-react238.js +70 -0
  212. package/dist/a2ui-react239.js +33 -0
  213. package/dist/a2ui-react24.js +29 -0
  214. package/dist/a2ui-react240.js +11 -0
  215. package/dist/a2ui-react241.js +155 -0
  216. package/dist/a2ui-react242.js +110 -0
  217. package/dist/a2ui-react243.js +22 -0
  218. package/dist/a2ui-react244.js +100 -0
  219. package/dist/a2ui-react245.js +49 -0
  220. package/dist/a2ui-react246.js +14 -0
  221. package/dist/a2ui-react247.js +208 -0
  222. package/dist/a2ui-react248.js +24 -0
  223. package/dist/a2ui-react249.js +402 -0
  224. package/dist/a2ui-react25.js +27 -0
  225. package/dist/a2ui-react250.js +49 -0
  226. package/dist/a2ui-react251.js +49 -0
  227. package/dist/a2ui-react252.js +54 -0
  228. package/dist/a2ui-react253.js +7 -0
  229. package/dist/a2ui-react254.js +7 -0
  230. package/dist/a2ui-react255.js +18 -0
  231. package/dist/a2ui-react256.js +8 -0
  232. package/dist/a2ui-react257.js +10 -0
  233. package/dist/a2ui-react258.js +19 -0
  234. package/dist/a2ui-react259.js +7 -0
  235. package/dist/a2ui-react26.js +44 -0
  236. package/dist/a2ui-react260.js +7 -0
  237. package/dist/a2ui-react261.js +8 -0
  238. package/dist/a2ui-react262.js +8 -0
  239. package/dist/a2ui-react263.js +7 -0
  240. package/dist/a2ui-react264.js +7 -0
  241. package/dist/a2ui-react265.js +9 -0
  242. package/dist/a2ui-react266.js +27 -0
  243. package/dist/a2ui-react267.js +9 -0
  244. package/dist/a2ui-react268.js +7 -0
  245. package/dist/a2ui-react269.js +9 -0
  246. package/dist/a2ui-react27.js +100 -0
  247. package/dist/a2ui-react270.js +8 -0
  248. package/dist/a2ui-react271.js +7 -0
  249. package/dist/a2ui-react272.js +8 -0
  250. package/dist/a2ui-react273.js +7 -0
  251. package/dist/a2ui-react274.js +11 -0
  252. package/dist/a2ui-react275.js +8 -0
  253. package/dist/a2ui-react276.js +7 -0
  254. package/dist/a2ui-react277.js +7 -0
  255. package/dist/a2ui-react278.js +9 -0
  256. package/dist/a2ui-react279.js +148 -0
  257. package/dist/a2ui-react28.js +82 -0
  258. package/dist/a2ui-react280.js +42 -0
  259. package/dist/a2ui-react281.js +7 -0
  260. package/dist/a2ui-react282.js +10 -0
  261. package/dist/a2ui-react283.js +16 -0
  262. package/dist/a2ui-react284.js +10 -0
  263. package/dist/a2ui-react285.js +34 -0
  264. package/dist/a2ui-react286.js +13 -0
  265. package/dist/a2ui-react287.js +13 -0
  266. package/dist/a2ui-react288.js +11 -0
  267. package/dist/a2ui-react289.js +16 -0
  268. package/dist/a2ui-react29.js +43 -0
  269. package/dist/a2ui-react290.js +104 -0
  270. package/dist/a2ui-react291.js +22 -0
  271. package/dist/a2ui-react292.js +56 -0
  272. package/dist/a2ui-react293.js +75 -0
  273. package/dist/a2ui-react294.js +12 -0
  274. package/dist/a2ui-react295.js +23 -0
  275. package/dist/a2ui-react296.js +19 -0
  276. package/dist/a2ui-react297.js +26 -0
  277. package/dist/a2ui-react298.js +9 -0
  278. package/dist/a2ui-react299.js +8 -0
  279. package/dist/a2ui-react3.js +40 -0
  280. package/dist/a2ui-react30.js +41 -0
  281. package/dist/a2ui-react300.js +26 -0
  282. package/dist/a2ui-react301.js +37 -0
  283. package/dist/a2ui-react302.js +18 -0
  284. package/dist/a2ui-react303.js +9 -0
  285. package/dist/a2ui-react304.js +7 -0
  286. package/dist/a2ui-react305.js +7 -0
  287. package/dist/a2ui-react306.js +7 -0
  288. package/dist/a2ui-react307.js +7 -0
  289. package/dist/a2ui-react308.js +6 -0
  290. package/dist/a2ui-react309.js +9 -0
  291. package/dist/a2ui-react31.js +86 -0
  292. package/dist/a2ui-react310.js +26 -0
  293. package/dist/a2ui-react311.js +10 -0
  294. package/dist/a2ui-react312.js +9 -0
  295. package/dist/a2ui-react313.js +8 -0
  296. package/dist/a2ui-react314.js +6 -0
  297. package/dist/a2ui-react315.js +6 -0
  298. package/dist/a2ui-react316.js +7 -0
  299. package/dist/a2ui-react317.js +6 -0
  300. package/dist/a2ui-react318.js +7 -0
  301. package/dist/a2ui-react319.js +6 -0
  302. package/dist/a2ui-react32.js +46 -0
  303. package/dist/a2ui-react320.js +6 -0
  304. package/dist/a2ui-react321.js +6 -0
  305. package/dist/a2ui-react322.js +9 -0
  306. package/dist/a2ui-react323.js +18 -0
  307. package/dist/a2ui-react324.js +31 -0
  308. package/dist/a2ui-react325.js +15 -0
  309. package/dist/a2ui-react326.js +27 -0
  310. package/dist/a2ui-react327.js +31 -0
  311. package/dist/a2ui-react328.js +7 -0
  312. package/dist/a2ui-react329.js +19 -0
  313. package/dist/a2ui-react33.js +44 -0
  314. package/dist/a2ui-react330.js +8 -0
  315. package/dist/a2ui-react331.js +8 -0
  316. package/dist/a2ui-react332.js +61 -0
  317. package/dist/a2ui-react333.js +69 -0
  318. package/dist/a2ui-react334.js +9 -0
  319. package/dist/a2ui-react335.js +7 -0
  320. package/dist/a2ui-react336.js +26 -0
  321. package/dist/a2ui-react337.js +19 -0
  322. package/dist/a2ui-react338.js +10 -0
  323. package/dist/a2ui-react339.js +13 -0
  324. package/dist/a2ui-react34.js +8 -0
  325. package/dist/a2ui-react340.js +13 -0
  326. package/dist/a2ui-react341.js +24 -0
  327. package/dist/a2ui-react342.js +13 -0
  328. package/dist/a2ui-react343.js +12 -0
  329. package/dist/a2ui-react344.js +12 -0
  330. package/dist/a2ui-react345.js +7 -0
  331. package/dist/a2ui-react346.js +8 -0
  332. package/dist/a2ui-react347.js +19 -0
  333. package/dist/a2ui-react348.js +12 -0
  334. package/dist/a2ui-react349.js +21 -0
  335. package/dist/a2ui-react35.js +16 -0
  336. package/dist/a2ui-react350.js +18 -0
  337. package/dist/a2ui-react351.js +15 -0
  338. package/dist/a2ui-react352.js +32 -0
  339. package/dist/a2ui-react353.js +15 -0
  340. package/dist/a2ui-react354.js +28 -0
  341. package/dist/a2ui-react355.js +8 -0
  342. package/dist/a2ui-react356.js +11 -0
  343. package/dist/a2ui-react357.js +22 -0
  344. package/dist/a2ui-react358.js +7 -0
  345. package/dist/a2ui-react359.js +5 -0
  346. package/dist/a2ui-react36.js +23 -0
  347. package/dist/a2ui-react360.js +26 -0
  348. package/dist/a2ui-react361.js +115 -0
  349. package/dist/a2ui-react362.js +18 -0
  350. package/dist/a2ui-react363.js +527 -0
  351. package/dist/a2ui-react364.js +130 -0
  352. package/dist/a2ui-react365.js +136 -0
  353. package/dist/a2ui-react366.js +7 -0
  354. package/dist/a2ui-react367.js +15 -0
  355. package/dist/a2ui-react368.js +67 -0
  356. package/dist/a2ui-react369.js +71 -0
  357. package/dist/a2ui-react37.js +15 -0
  358. package/dist/a2ui-react370.js +11 -0
  359. package/dist/a2ui-react371.js +16 -0
  360. package/dist/a2ui-react372.js +68 -0
  361. package/dist/a2ui-react373.js +6 -0
  362. package/dist/a2ui-react374.js +25 -0
  363. package/dist/a2ui-react375.js +15 -0
  364. package/dist/a2ui-react376.js +30 -0
  365. package/dist/a2ui-react377.js +7 -0
  366. package/dist/a2ui-react378.js +25 -0
  367. package/dist/a2ui-react38.js +10 -0
  368. package/dist/a2ui-react39.js +10 -0
  369. package/dist/a2ui-react4.js +76 -0
  370. package/dist/a2ui-react40.js +14 -0
  371. package/dist/a2ui-react41.js +14 -0
  372. package/dist/a2ui-react42.js +16 -0
  373. package/dist/a2ui-react43.js +12 -0
  374. package/dist/a2ui-react44.js +15 -0
  375. package/dist/a2ui-react45.js +15 -0
  376. package/dist/a2ui-react46.js +9 -0
  377. package/dist/a2ui-react47.js +11 -0
  378. package/dist/a2ui-react48.js +16 -0
  379. package/dist/a2ui-react49.js +10 -0
  380. package/dist/a2ui-react5.js +8 -0
  381. package/dist/a2ui-react50.js +14 -0
  382. package/dist/a2ui-react51.js +9 -0
  383. package/dist/a2ui-react52.js +9 -0
  384. package/dist/a2ui-react53.js +15 -0
  385. package/dist/a2ui-react54.js +17 -0
  386. package/dist/a2ui-react55.js +10 -0
  387. package/dist/a2ui-react56.js +10 -0
  388. package/dist/a2ui-react57.js +10 -0
  389. package/dist/a2ui-react58.js +9 -0
  390. package/dist/a2ui-react59.js +9 -0
  391. package/dist/a2ui-react6.js +28 -0
  392. package/dist/a2ui-react60.js +9 -0
  393. package/dist/a2ui-react61.js +15 -0
  394. package/dist/a2ui-react62.js +10 -0
  395. package/dist/a2ui-react63.js +15 -0
  396. package/dist/a2ui-react64.js +10 -0
  397. package/dist/a2ui-react65.js +14 -0
  398. package/dist/a2ui-react66.js +22 -0
  399. package/dist/a2ui-react67.js +14 -0
  400. package/dist/a2ui-react68.js +10 -0
  401. package/dist/a2ui-react69.js +17 -0
  402. package/dist/a2ui-react7.js +10 -0
  403. package/dist/a2ui-react70.js +15 -0
  404. package/dist/a2ui-react71.js +10 -0
  405. package/dist/a2ui-react72.js +12 -0
  406. package/dist/a2ui-react73.js +9 -0
  407. package/dist/a2ui-react74.js +6 -0
  408. package/dist/a2ui-react75.js +15 -0
  409. package/dist/a2ui-react76.js +11 -0
  410. package/dist/a2ui-react77.js +14 -0
  411. package/dist/a2ui-react78.js +9 -0
  412. package/dist/a2ui-react79.js +9 -0
  413. package/dist/a2ui-react8.js +21 -0
  414. package/dist/a2ui-react80.js +9 -0
  415. package/dist/a2ui-react81.js +10 -0
  416. package/dist/a2ui-react82.js +26 -0
  417. package/dist/a2ui-react83.js +29 -0
  418. package/dist/a2ui-react84.js +67 -0
  419. package/dist/a2ui-react85.js +77 -0
  420. package/dist/a2ui-react86.js +53 -0
  421. package/dist/a2ui-react87.js +31 -0
  422. package/dist/a2ui-react88.js +22 -0
  423. package/dist/a2ui-react89.js +21 -0
  424. package/dist/a2ui-react9.js +88 -0
  425. package/{src/components/ui/textarea.tsx → dist/a2ui-react90.js} +17 -17
  426. package/dist/a2ui-react91.js +176 -0
  427. package/dist/a2ui-react92.js +38 -0
  428. package/dist/a2ui-react93.js +88 -0
  429. package/dist/a2ui-react94.js +9 -0
  430. package/dist/a2ui-react95.js +58 -0
  431. package/dist/a2ui-react96.js +146 -0
  432. package/dist/a2ui-react97.js +63 -0
  433. package/dist/a2ui-react98.js +17 -0
  434. package/dist/a2ui-react99.js +2765 -0
  435. package/dist/components/ui/button.d.ts +10 -0
  436. package/dist/components/ui/calendar.d.ts +8 -0
  437. package/dist/components/ui/card.d.ts +9 -0
  438. package/dist/components/ui/checkbox.d.ts +4 -0
  439. package/dist/components/ui/dialog.d.ts +15 -0
  440. package/dist/components/ui/input.d.ts +3 -0
  441. package/dist/components/ui/label.d.ts +4 -0
  442. package/dist/components/ui/native-select.d.ts +7 -0
  443. package/dist/components/ui/popover.d.ts +7 -0
  444. package/dist/components/ui/select.d.ts +15 -0
  445. package/dist/components/ui/separator.d.ts +4 -0
  446. package/dist/components/ui/slider.d.ts +4 -0
  447. package/dist/components/ui/tabs.d.ts +7 -0
  448. package/dist/components/ui/textarea.d.ts +3 -0
  449. package/dist/index.d.ts +1 -0
  450. package/dist/lib/utils.d.ts +2 -0
  451. package/package.json +10 -2
  452. package/.claude/commands/speckit.analyze.md +0 -184
  453. package/.claude/commands/speckit.checklist.md +0 -294
  454. package/.claude/commands/speckit.clarify.md +0 -181
  455. package/.claude/commands/speckit.constitution.md +0 -82
  456. package/.claude/commands/speckit.implement.md +0 -135
  457. package/.claude/commands/speckit.plan.md +0 -89
  458. package/.claude/commands/speckit.specify.md +0 -256
  459. package/.claude/commands/speckit.tasks.md +0 -137
  460. package/.claude/commands/speckit.taskstoissues.md +0 -30
  461. package/.github/workflows/deploy.yml +0 -69
  462. package/.husky/pre-commit +0 -1
  463. package/.prettierignore +0 -4
  464. package/.prettierrc +0 -7
  465. package/.specify/memory/constitution.md +0 -73
  466. package/.specify/scripts/bash/check-prerequisites.sh +0 -166
  467. package/.specify/scripts/bash/common.sh +0 -156
  468. package/.specify/scripts/bash/create-new-feature.sh +0 -297
  469. package/.specify/scripts/bash/setup-plan.sh +0 -61
  470. package/.specify/scripts/bash/update-agent-context.sh +0 -799
  471. package/.specify/templates/agent-file-template.md +0 -28
  472. package/.specify/templates/checklist-template.md +0 -40
  473. package/.specify/templates/plan-template.md +0 -105
  474. package/.specify/templates/spec-template.md +0 -115
  475. package/.specify/templates/tasks-template.md +0 -250
  476. package/CLAUDE.md +0 -105
  477. package/CONTRIBUTING.md +0 -97
  478. package/components.json +0 -21
  479. package/eslint.config.js +0 -25
  480. package/netlify.toml +0 -50
  481. package/playground/README.md +0 -75
  482. package/playground/index.html +0 -22
  483. package/playground/package.json +0 -32
  484. package/playground/public/favicon.svg +0 -8
  485. package/playground/src/App.css +0 -256
  486. package/playground/src/App.tsx +0 -115
  487. package/playground/src/assets/react.svg +0 -1
  488. package/playground/src/components/ErrorDisplay.tsx +0 -13
  489. package/playground/src/components/ExampleSelector.tsx +0 -64
  490. package/playground/src/components/Header.tsx +0 -47
  491. package/playground/src/components/JsonEditor.tsx +0 -32
  492. package/playground/src/components/Preview.tsx +0 -78
  493. package/playground/src/components/ThemeToggle.tsx +0 -19
  494. package/playground/src/data/examples.ts +0 -1571
  495. package/playground/src/hooks/useTheme.ts +0 -55
  496. package/playground/src/index.css +0 -220
  497. package/playground/src/main.tsx +0 -10
  498. package/playground/tsconfig.app.json +0 -34
  499. package/playground/tsconfig.json +0 -13
  500. package/playground/tsconfig.node.json +0 -26
  501. package/playground/vite.config.ts +0 -31
  502. package/specs/001-a2ui-renderer/checklists/requirements.md +0 -41
  503. package/specs/001-a2ui-renderer/data-model.md +0 -140
  504. package/specs/001-a2ui-renderer/plan.md +0 -123
  505. package/specs/001-a2ui-renderer/quickstart.md +0 -141
  506. package/specs/001-a2ui-renderer/research.md +0 -140
  507. package/specs/001-a2ui-renderer/spec.md +0 -165
  508. package/specs/001-a2ui-renderer/tasks.md +0 -310
  509. package/specs/002-playground/checklists/requirements.md +0 -37
  510. package/specs/002-playground/contracts/components.md +0 -120
  511. package/specs/002-playground/data-model.md +0 -149
  512. package/specs/002-playground/plan.md +0 -73
  513. package/specs/002-playground/quickstart.md +0 -158
  514. package/specs/002-playground/research.md +0 -117
  515. package/specs/002-playground/spec.md +0 -109
  516. package/specs/002-playground/tasks.md +0 -224
  517. package/src/0.8/A2UIRender.test.tsx +0 -793
  518. package/src/0.8/A2UIRender.tsx +0 -142
  519. package/src/0.8/components/ComponentRenderer.test.tsx +0 -373
  520. package/src/0.8/components/ComponentRenderer.tsx +0 -163
  521. package/src/0.8/components/UnknownComponent.tsx +0 -49
  522. package/src/0.8/components/display/AudioPlayerComponent.tsx +0 -37
  523. package/src/0.8/components/display/DividerComponent.tsx +0 -23
  524. package/src/0.8/components/display/IconComponent.tsx +0 -137
  525. package/src/0.8/components/display/ImageComponent.tsx +0 -57
  526. package/src/0.8/components/display/TextComponent.tsx +0 -56
  527. package/src/0.8/components/display/VideoComponent.tsx +0 -31
  528. package/src/0.8/components/display/display.test.tsx +0 -660
  529. package/src/0.8/components/display/index.ts +0 -10
  530. package/src/0.8/components/index.ts +0 -14
  531. package/src/0.8/components/interactive/ButtonComponent.tsx +0 -44
  532. package/src/0.8/components/interactive/CheckBoxComponent.tsx +0 -45
  533. package/src/0.8/components/interactive/DateTimeInputComponent.tsx +0 -176
  534. package/src/0.8/components/interactive/MultipleChoiceComponent.tsx +0 -157
  535. package/src/0.8/components/interactive/SliderComponent.tsx +0 -53
  536. package/src/0.8/components/interactive/TextFieldComponent.tsx +0 -65
  537. package/src/0.8/components/interactive/index.ts +0 -10
  538. package/src/0.8/components/interactive/interactive.test.tsx +0 -618
  539. package/src/0.8/components/layout/CardComponent.tsx +0 -30
  540. package/src/0.8/components/layout/ColumnComponent.tsx +0 -93
  541. package/src/0.8/components/layout/ListComponent.tsx +0 -81
  542. package/src/0.8/components/layout/ModalComponent.tsx +0 -41
  543. package/src/0.8/components/layout/RowComponent.tsx +0 -94
  544. package/src/0.8/components/layout/TabsComponent.tsx +0 -59
  545. package/src/0.8/components/layout/index.ts +0 -10
  546. package/src/0.8/components/layout/layout.test.tsx +0 -558
  547. package/src/0.8/contexts/A2UIProvider.test.tsx +0 -226
  548. package/src/0.8/contexts/A2UIProvider.tsx +0 -54
  549. package/src/0.8/contexts/ActionContext.test.tsx +0 -242
  550. package/src/0.8/contexts/ActionContext.tsx +0 -105
  551. package/src/0.8/contexts/ComponentsMapContext.tsx +0 -125
  552. package/src/0.8/contexts/DataModelContext.test.tsx +0 -335
  553. package/src/0.8/contexts/DataModelContext.tsx +0 -184
  554. package/src/0.8/contexts/SurfaceContext.test.tsx +0 -339
  555. package/src/0.8/contexts/SurfaceContext.tsx +0 -197
  556. package/src/0.8/hooks/useA2UIMessageHandler.test.tsx +0 -399
  557. package/src/0.8/hooks/useA2UIMessageHandler.ts +0 -123
  558. package/src/0.8/hooks/useComponent.test.tsx +0 -148
  559. package/src/0.8/hooks/useDataBinding.test.tsx +0 -334
  560. package/src/0.8/hooks/useDataBinding.ts +0 -99
  561. package/src/0.8/hooks/useDispatchAction.test.tsx +0 -83
  562. package/src/0.8/hooks/useSurface.test.tsx +0 -114
  563. package/src/0.8/schemas/client_to_server.json +0 -50
  564. package/src/0.8/schemas/server_to_client.json +0 -148
  565. package/src/0.8/schemas/standard_catalog_definition.json +0 -661
  566. package/src/0.8/utils/dataBinding.test.ts +0 -443
  567. package/src/0.8/utils/dataBinding.ts +0 -212
  568. package/src/0.8/utils/pathUtils.test.ts +0 -353
  569. package/src/0.8/utils/pathUtils.ts +0 -200
  570. package/src/components/ui/button.tsx +0 -62
  571. package/src/components/ui/calendar.tsx +0 -220
  572. package/src/components/ui/card.tsx +0 -92
  573. package/src/components/ui/checkbox.tsx +0 -30
  574. package/src/components/ui/dialog.tsx +0 -141
  575. package/src/components/ui/input.tsx +0 -21
  576. package/src/components/ui/label.tsx +0 -22
  577. package/src/components/ui/native-select.tsx +0 -53
  578. package/src/components/ui/popover.tsx +0 -46
  579. package/src/components/ui/select.tsx +0 -188
  580. package/src/components/ui/separator.tsx +0 -26
  581. package/src/components/ui/slider.tsx +0 -61
  582. package/src/components/ui/tabs.tsx +0 -64
  583. package/src/index.ts +0 -1
  584. package/src/lib/utils.ts +0 -6
  585. package/tsconfig.json +0 -28
  586. package/vite.config.ts +0 -29
  587. package/vitest.config.ts +0 -22
  588. package/vitest.setup.ts +0 -8
  589. package/website/README.md +0 -4
  590. package/website/assets/favicon.svg +0 -8
  591. package/website/content/.gitkeep +0 -0
  592. package/website/content/index.md +0 -122
  593. package/website/global.d.ts +0 -9
  594. package/website/package.json +0 -17
  595. package/website/plain.config.js +0 -28
  596. package/website/serve.json +0 -6
  597. package/website/src/client/color-mode-switch.css +0 -47
  598. package/website/src/client/index.js +0 -61
  599. package/website/src/client/moon.svg +0 -1
  600. package/website/src/client/sun.svg +0 -1
  601. package/website/src/components/Footer.jsx +0 -9
  602. package/website/src/components/Header.jsx +0 -44
  603. package/website/src/components/Page.jsx +0 -28
  604. package/website/src/global.css +0 -423
@@ -1,256 +0,0 @@
1
- ---
2
- description: Create or update the feature specification from a natural language feature description.
3
- handoffs:
4
- - label: Build Technical Plan
5
- agent: speckit.plan
6
- prompt: Create a plan for the spec. I am building with...
7
- - label: Clarify Spec Requirements
8
- agent: speckit.clarify
9
- prompt: Clarify specification requirements
10
- send: true
11
- ---
12
-
13
- ## User Input
14
-
15
- ```text
16
- $ARGUMENTS
17
- ```
18
-
19
- You **MUST** consider the user input before proceeding (if not empty).
20
-
21
- ## Outline
22
-
23
- The text the user typed after `/speckit.specify` in the triggering message **is** the feature description. Assume you always have it available in this conversation even if `$ARGUMENTS` appears literally below. Do not ask the user to repeat it unless they provided an empty command.
24
-
25
- Given that feature description, do this:
26
-
27
- 1. **Generate a concise short name** (2-4 words) for the branch:
28
- - Analyze the feature description and extract the most meaningful keywords
29
- - Create a 2-4 word short name that captures the essence of the feature
30
- - Use action-noun format when possible (e.g., "add-user-auth", "fix-payment-bug")
31
- - Preserve technical terms and acronyms (OAuth2, API, JWT, etc.)
32
- - Keep it concise but descriptive enough to understand the feature at a glance
33
- - Examples:
34
- - "I want to add user authentication" → "user-auth"
35
- - "Implement OAuth2 integration for the API" → "oauth2-api-integration"
36
- - "Create a dashboard for analytics" → "analytics-dashboard"
37
- - "Fix payment processing timeout bug" → "fix-payment-timeout"
38
-
39
- 2. **Check for existing branches before creating new one**:
40
-
41
- a. First, fetch all remote branches to ensure we have the latest information:
42
-
43
- ```bash
44
- git fetch --all --prune
45
- ```
46
-
47
- b. Find the highest feature number across all sources for the short-name:
48
- - Remote branches: `git ls-remote --heads origin | grep -E 'refs/heads/[0-9]+-<short-name>$'`
49
- - Local branches: `git branch | grep -E '^[* ]*[0-9]+-<short-name>$'`
50
- - Specs directories: Check for directories matching `specs/[0-9]+-<short-name>`
51
-
52
- c. Determine the next available number:
53
- - Extract all numbers from all three sources
54
- - Find the highest number N
55
- - Use N+1 for the new branch number
56
-
57
- d. Run the script `.specify/scripts/bash/create-new-feature.sh --json "$ARGUMENTS"` with the calculated number and short-name:
58
- - Pass `--number N+1` and `--short-name "your-short-name"` along with the feature description
59
- - Bash example: `.specify/scripts/bash/create-new-feature.sh --json "$ARGUMENTS" --json --number 5 --short-name "user-auth" "Add user authentication"`
60
- - PowerShell example: `.specify/scripts/bash/create-new-feature.sh --json "$ARGUMENTS" -Json -Number 5 -ShortName "user-auth" "Add user authentication"`
61
-
62
- **IMPORTANT**:
63
- - Check all three sources (remote branches, local branches, specs directories) to find the highest number
64
- - Only match branches/directories with the exact short-name pattern
65
- - If no existing branches/directories found with this short-name, start with number 1
66
- - You must only ever run this script once per feature
67
- - The JSON is provided in the terminal as output - always refer to it to get the actual content you're looking for
68
- - The JSON output will contain BRANCH_NAME and SPEC_FILE paths
69
- - For single quotes in args like "I'm Groot", use escape syntax: e.g 'I'\''m Groot' (or double-quote if possible: "I'm Groot")
70
-
71
- 3. Load `.specify/templates/spec-template.md` to understand required sections.
72
-
73
- 4. Follow this execution flow:
74
- 1. Parse user description from Input
75
- If empty: ERROR "No feature description provided"
76
- 2. Extract key concepts from description
77
- Identify: actors, actions, data, constraints
78
- 3. For unclear aspects:
79
- - Make informed guesses based on context and industry standards
80
- - Only mark with [NEEDS CLARIFICATION: specific question] if:
81
- - The choice significantly impacts feature scope or user experience
82
- - Multiple reasonable interpretations exist with different implications
83
- - No reasonable default exists
84
- - **LIMIT: Maximum 3 [NEEDS CLARIFICATION] markers total**
85
- - Prioritize clarifications by impact: scope > security/privacy > user experience > technical details
86
- 4. Fill User Scenarios & Testing section
87
- If no clear user flow: ERROR "Cannot determine user scenarios"
88
- 5. Generate Functional Requirements
89
- Each requirement must be testable
90
- Use reasonable defaults for unspecified details (document assumptions in Assumptions section)
91
- 6. Define Success Criteria
92
- Create measurable, technology-agnostic outcomes
93
- Include both quantitative metrics (time, performance, volume) and qualitative measures (user satisfaction, task completion)
94
- Each criterion must be verifiable without implementation details
95
- 7. Identify Key Entities (if data involved)
96
- 8. Return: SUCCESS (spec ready for planning)
97
-
98
- 5. Write the specification to SPEC_FILE using the template structure, replacing placeholders with concrete details derived from the feature description (arguments) while preserving section order and headings.
99
-
100
- 6. **Specification Quality Validation**: After writing the initial spec, validate it against quality criteria:
101
-
102
- a. **Create Spec Quality Checklist**: Generate a checklist file at `FEATURE_DIR/checklists/requirements.md` using the checklist template structure with these validation items:
103
-
104
- ```markdown
105
- # Specification Quality Checklist: [FEATURE NAME]
106
-
107
- **Purpose**: Validate specification completeness and quality before proceeding to planning
108
- **Created**: [DATE]
109
- **Feature**: [Link to spec.md]
110
-
111
- ## Content Quality
112
-
113
- - [ ] No implementation details (languages, frameworks, APIs)
114
- - [ ] Focused on user value and business needs
115
- - [ ] Written for non-technical stakeholders
116
- - [ ] All mandatory sections completed
117
-
118
- ## Requirement Completeness
119
-
120
- - [ ] No [NEEDS CLARIFICATION] markers remain
121
- - [ ] Requirements are testable and unambiguous
122
- - [ ] Success criteria are measurable
123
- - [ ] Success criteria are technology-agnostic (no implementation details)
124
- - [ ] All acceptance scenarios are defined
125
- - [ ] Edge cases are identified
126
- - [ ] Scope is clearly bounded
127
- - [ ] Dependencies and assumptions identified
128
-
129
- ## Feature Readiness
130
-
131
- - [ ] All functional requirements have clear acceptance criteria
132
- - [ ] User scenarios cover primary flows
133
- - [ ] Feature meets measurable outcomes defined in Success Criteria
134
- - [ ] No implementation details leak into specification
135
-
136
- ## Notes
137
-
138
- - Items marked incomplete require spec updates before `/speckit.clarify` or `/speckit.plan`
139
- ```
140
-
141
- b. **Run Validation Check**: Review the spec against each checklist item:
142
- - For each item, determine if it passes or fails
143
- - Document specific issues found (quote relevant spec sections)
144
-
145
- c. **Handle Validation Results**:
146
- - **If all items pass**: Mark checklist complete and proceed to step 6
147
-
148
- - **If items fail (excluding [NEEDS CLARIFICATION])**:
149
- 1. List the failing items and specific issues
150
- 2. Update the spec to address each issue
151
- 3. Re-run validation until all items pass (max 3 iterations)
152
- 4. If still failing after 3 iterations, document remaining issues in checklist notes and warn user
153
-
154
- - **If [NEEDS CLARIFICATION] markers remain**:
155
- 1. Extract all [NEEDS CLARIFICATION: ...] markers from the spec
156
- 2. **LIMIT CHECK**: If more than 3 markers exist, keep only the 3 most critical (by scope/security/UX impact) and make informed guesses for the rest
157
- 3. For each clarification needed (max 3), present options to user in this format:
158
-
159
- ```markdown
160
- ## Question [N]: [Topic]
161
-
162
- **Context**: [Quote relevant spec section]
163
-
164
- **What we need to know**: [Specific question from NEEDS CLARIFICATION marker]
165
-
166
- **Suggested Answers**:
167
-
168
- | Option | Answer | Implications |
169
- | ------ | ------------------------- | ------------------------------------- |
170
- | A | [First suggested answer] | [What this means for the feature] |
171
- | B | [Second suggested answer] | [What this means for the feature] |
172
- | C | [Third suggested answer] | [What this means for the feature] |
173
- | Custom | Provide your own answer | [Explain how to provide custom input] |
174
-
175
- **Your choice**: _[Wait for user response]_
176
- ```
177
-
178
- 4. **CRITICAL - Table Formatting**: Ensure markdown tables are properly formatted:
179
- - Use consistent spacing with pipes aligned
180
- - Each cell should have spaces around content: `| Content |` not `|Content|`
181
- - Header separator must have at least 3 dashes: `|--------|`
182
- - Test that the table renders correctly in markdown preview
183
- 5. Number questions sequentially (Q1, Q2, Q3 - max 3 total)
184
- 6. Present all questions together before waiting for responses
185
- 7. Wait for user to respond with their choices for all questions (e.g., "Q1: A, Q2: Custom - [details], Q3: B")
186
- 8. Update the spec by replacing each [NEEDS CLARIFICATION] marker with the user's selected or provided answer
187
- 9. Re-run validation after all clarifications are resolved
188
-
189
- d. **Update Checklist**: After each validation iteration, update the checklist file with current pass/fail status
190
-
191
- 7. Report completion with branch name, spec file path, checklist results, and readiness for the next phase (`/speckit.clarify` or `/speckit.plan`).
192
-
193
- **NOTE:** The script creates and checks out the new branch and initializes the spec file before writing.
194
-
195
- ## General Guidelines
196
-
197
- ## Quick Guidelines
198
-
199
- - Focus on **WHAT** users need and **WHY**.
200
- - Avoid HOW to implement (no tech stack, APIs, code structure).
201
- - Written for business stakeholders, not developers.
202
- - DO NOT create any checklists that are embedded in the spec. That will be a separate command.
203
-
204
- ### Section Requirements
205
-
206
- - **Mandatory sections**: Must be completed for every feature
207
- - **Optional sections**: Include only when relevant to the feature
208
- - When a section doesn't apply, remove it entirely (don't leave as "N/A")
209
-
210
- ### For AI Generation
211
-
212
- When creating this spec from a user prompt:
213
-
214
- 1. **Make informed guesses**: Use context, industry standards, and common patterns to fill gaps
215
- 2. **Document assumptions**: Record reasonable defaults in the Assumptions section
216
- 3. **Limit clarifications**: Maximum 3 [NEEDS CLARIFICATION] markers - use only for critical decisions that:
217
- - Significantly impact feature scope or user experience
218
- - Have multiple reasonable interpretations with different implications
219
- - Lack any reasonable default
220
- 4. **Prioritize clarifications**: scope > security/privacy > user experience > technical details
221
- 5. **Think like a tester**: Every vague requirement should fail the "testable and unambiguous" checklist item
222
- 6. **Common areas needing clarification** (only if no reasonable default exists):
223
- - Feature scope and boundaries (include/exclude specific use cases)
224
- - User types and permissions (if multiple conflicting interpretations possible)
225
- - Security/compliance requirements (when legally/financially significant)
226
-
227
- **Examples of reasonable defaults** (don't ask about these):
228
-
229
- - Data retention: Industry-standard practices for the domain
230
- - Performance targets: Standard web/mobile app expectations unless specified
231
- - Error handling: User-friendly messages with appropriate fallbacks
232
- - Authentication method: Standard session-based or OAuth2 for web apps
233
- - Integration patterns: RESTful APIs unless specified otherwise
234
-
235
- ### Success Criteria Guidelines
236
-
237
- Success criteria must be:
238
-
239
- 1. **Measurable**: Include specific metrics (time, percentage, count, rate)
240
- 2. **Technology-agnostic**: No mention of frameworks, languages, databases, or tools
241
- 3. **User-focused**: Describe outcomes from user/business perspective, not system internals
242
- 4. **Verifiable**: Can be tested/validated without knowing implementation details
243
-
244
- **Good examples**:
245
-
246
- - "Users can complete checkout in under 3 minutes"
247
- - "System supports 10,000 concurrent users"
248
- - "95% of searches return results in under 1 second"
249
- - "Task completion rate improves by 40%"
250
-
251
- **Bad examples** (implementation-focused):
252
-
253
- - "API response time is under 200ms" (too technical, use "Users see results instantly")
254
- - "Database can handle 1000 TPS" (implementation detail, use user-facing metric)
255
- - "React components render efficiently" (framework-specific)
256
- - "Redis cache hit rate above 80%" (technology-specific)
@@ -1,137 +0,0 @@
1
- ---
2
- description: Generate an actionable, dependency-ordered tasks.md for the feature based on available design artifacts.
3
- handoffs:
4
- - label: Analyze For Consistency
5
- agent: speckit.analyze
6
- prompt: Run a project analysis for consistency
7
- send: true
8
- - label: Implement Project
9
- agent: speckit.implement
10
- prompt: Start the implementation in phases
11
- send: true
12
- ---
13
-
14
- ## User Input
15
-
16
- ```text
17
- $ARGUMENTS
18
- ```
19
-
20
- You **MUST** consider the user input before proceeding (if not empty).
21
-
22
- ## Outline
23
-
24
- 1. **Setup**: Run `.specify/scripts/bash/check-prerequisites.sh --json` from repo root and parse FEATURE_DIR and AVAILABLE_DOCS list. All paths must be absolute. For single quotes in args like "I'm Groot", use escape syntax: e.g 'I'\''m Groot' (or double-quote if possible: "I'm Groot").
25
-
26
- 2. **Load design documents**: Read from FEATURE_DIR:
27
- - **Required**: plan.md (tech stack, libraries, structure), spec.md (user stories with priorities)
28
- - **Optional**: data-model.md (entities), contracts/ (API endpoints), research.md (decisions), quickstart.md (test scenarios)
29
- - Note: Not all projects have all documents. Generate tasks based on what's available.
30
-
31
- 3. **Execute task generation workflow**:
32
- - Load plan.md and extract tech stack, libraries, project structure
33
- - Load spec.md and extract user stories with their priorities (P1, P2, P3, etc.)
34
- - If data-model.md exists: Extract entities and map to user stories
35
- - If contracts/ exists: Map endpoints to user stories
36
- - If research.md exists: Extract decisions for setup tasks
37
- - Generate tasks organized by user story (see Task Generation Rules below)
38
- - Generate dependency graph showing user story completion order
39
- - Create parallel execution examples per user story
40
- - Validate task completeness (each user story has all needed tasks, independently testable)
41
-
42
- 4. **Generate tasks.md**: Use `.specify/templates/tasks-template.md` as structure, fill with:
43
- - Correct feature name from plan.md
44
- - Phase 1: Setup tasks (project initialization)
45
- - Phase 2: Foundational tasks (blocking prerequisites for all user stories)
46
- - Phase 3+: One phase per user story (in priority order from spec.md)
47
- - Each phase includes: story goal, independent test criteria, tests (if requested), implementation tasks
48
- - Final Phase: Polish & cross-cutting concerns
49
- - All tasks must follow the strict checklist format (see Task Generation Rules below)
50
- - Clear file paths for each task
51
- - Dependencies section showing story completion order
52
- - Parallel execution examples per story
53
- - Implementation strategy section (MVP first, incremental delivery)
54
-
55
- 5. **Report**: Output path to generated tasks.md and summary:
56
- - Total task count
57
- - Task count per user story
58
- - Parallel opportunities identified
59
- - Independent test criteria for each story
60
- - Suggested MVP scope (typically just User Story 1)
61
- - Format validation: Confirm ALL tasks follow the checklist format (checkbox, ID, labels, file paths)
62
-
63
- Context for task generation: $ARGUMENTS
64
-
65
- The tasks.md should be immediately executable - each task must be specific enough that an LLM can complete it without additional context.
66
-
67
- ## Task Generation Rules
68
-
69
- **CRITICAL**: Tasks MUST be organized by user story to enable independent implementation and testing.
70
-
71
- **Tests are OPTIONAL**: Only generate test tasks if explicitly requested in the feature specification or if user requests TDD approach.
72
-
73
- ### Checklist Format (REQUIRED)
74
-
75
- Every task MUST strictly follow this format:
76
-
77
- ```text
78
- - [ ] [TaskID] [P?] [Story?] Description with file path
79
- ```
80
-
81
- **Format Components**:
82
-
83
- 1. **Checkbox**: ALWAYS start with `- [ ]` (markdown checkbox)
84
- 2. **Task ID**: Sequential number (T001, T002, T003...) in execution order
85
- 3. **[P] marker**: Include ONLY if task is parallelizable (different files, no dependencies on incomplete tasks)
86
- 4. **[Story] label**: REQUIRED for user story phase tasks only
87
- - Format: [US1], [US2], [US3], etc. (maps to user stories from spec.md)
88
- - Setup phase: NO story label
89
- - Foundational phase: NO story label
90
- - User Story phases: MUST have story label
91
- - Polish phase: NO story label
92
- 5. **Description**: Clear action with exact file path
93
-
94
- **Examples**:
95
-
96
- - ✅ CORRECT: `- [ ] T001 Create project structure per implementation plan`
97
- - ✅ CORRECT: `- [ ] T005 [P] Implement authentication middleware in src/middleware/auth.py`
98
- - ✅ CORRECT: `- [ ] T012 [P] [US1] Create User model in src/models/user.py`
99
- - ✅ CORRECT: `- [ ] T014 [US1] Implement UserService in src/services/user_service.py`
100
- - ❌ WRONG: `- [ ] Create User model` (missing ID and Story label)
101
- - ❌ WRONG: `T001 [US1] Create model` (missing checkbox)
102
- - ❌ WRONG: `- [ ] [US1] Create User model` (missing Task ID)
103
- - ❌ WRONG: `- [ ] T001 [US1] Create model` (missing file path)
104
-
105
- ### Task Organization
106
-
107
- 1. **From User Stories (spec.md)** - PRIMARY ORGANIZATION:
108
- - Each user story (P1, P2, P3...) gets its own phase
109
- - Map all related components to their story:
110
- - Models needed for that story
111
- - Services needed for that story
112
- - Endpoints/UI needed for that story
113
- - If tests requested: Tests specific to that story
114
- - Mark story dependencies (most stories should be independent)
115
-
116
- 2. **From Contracts**:
117
- - Map each contract/endpoint → to the user story it serves
118
- - If tests requested: Each contract → contract test task [P] before implementation in that story's phase
119
-
120
- 3. **From Data Model**:
121
- - Map each entity to the user story(ies) that need it
122
- - If entity serves multiple stories: Put in earliest story or Setup phase
123
- - Relationships → service layer tasks in appropriate story phase
124
-
125
- 4. **From Setup/Infrastructure**:
126
- - Shared infrastructure → Setup phase (Phase 1)
127
- - Foundational/blocking tasks → Foundational phase (Phase 2)
128
- - Story-specific setup → within that story's phase
129
-
130
- ### Phase Structure
131
-
132
- - **Phase 1**: Setup (project initialization)
133
- - **Phase 2**: Foundational (blocking prerequisites - MUST complete before user stories)
134
- - **Phase 3+**: User Stories in priority order (P1, P2, P3...)
135
- - Within each story: Tests (if requested) → Models → Services → Endpoints → Integration
136
- - Each phase should be a complete, independently testable increment
137
- - **Final Phase**: Polish & Cross-Cutting Concerns
@@ -1,30 +0,0 @@
1
- ---
2
- description: Convert existing tasks into actionable, dependency-ordered GitHub issues for the feature based on available design artifacts.
3
- tools: ['github/github-mcp-server/issue_write']
4
- ---
5
-
6
- ## User Input
7
-
8
- ```text
9
- $ARGUMENTS
10
- ```
11
-
12
- You **MUST** consider the user input before proceeding (if not empty).
13
-
14
- ## Outline
15
-
16
- 1. Run `.specify/scripts/bash/check-prerequisites.sh --json --require-tasks --include-tasks` from repo root and parse FEATURE_DIR and AVAILABLE_DOCS list. All paths must be absolute. For single quotes in args like "I'm Groot", use escape syntax: e.g 'I'\''m Groot' (or double-quote if possible: "I'm Groot").
17
- 1. From the executed script, extract the path to **tasks**.
18
- 1. Get the Git remote by running:
19
-
20
- ```bash
21
- git config --get remote.origin.url
22
- ```
23
-
24
- > [!CAUTION]
25
- > ONLY PROCEED TO NEXT STEPS IF THE REMOTE IS A GITHUB URL
26
-
27
- 1. For each task in the list, use the GitHub MCP server to create a new issue in the repository that is representative of the Git remote.
28
-
29
- > [!CAUTION]
30
- > UNDER NO CIRCUMSTANCES EVER CREATE ISSUES IN REPOSITORIES THAT DO NOT MATCH THE REMOTE URL
@@ -1,69 +0,0 @@
1
- name: Deploy to GitHub Pages
2
-
3
- on:
4
- push:
5
- branches:
6
- - main
7
- pull_request:
8
- branches:
9
- - main
10
- workflow_dispatch:
11
-
12
- jobs:
13
- build-and-deploy:
14
- runs-on: ubuntu-latest
15
-
16
- steps:
17
- - name: Checkout
18
- uses: actions/checkout@v4
19
-
20
- - name: Setup Node.js
21
- uses: actions/setup-node@v4
22
- with:
23
- node-version: '22'
24
- cache: 'npm'
25
- registry-url: 'https://registry.npmjs.org'
26
-
27
- - name: Install dependencies
28
- run: npm ci
29
-
30
- - name: Build @easyops-cn/a2ui-react
31
- run: npm run build
32
-
33
- - name: Publish to npm
34
- run: npm publish --access public
35
- env:
36
- NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
37
- if: github.event_name == 'push' && github.ref == 'refs/heads/main'
38
-
39
- - name: Build playground
40
- run: npm run build -w playground
41
-
42
- - name: Build website
43
- run: npm run build -w website
44
-
45
- - name: Copy website dist to build/a2ui-react, and playground dist to build/a2ui-react/playground
46
- run: mkdir -p build && cp -r website/dist build/a2ui-react && cp -r playground/dist build/a2ui-react/playground
47
-
48
- - name: Deploy to Netlify (pull request)
49
- id: netlify-deploy
50
- uses: nwtgck/actions-netlify@v3.0
51
- with:
52
- publish-dir: ./build
53
- production-branch: main
54
- github-token: ${{ secrets.GITHUB_TOKEN }}
55
- deploy-message: "${{ github.event.pull_request.title }}"
56
- netlify-config-path: ./netlify.toml
57
- env:
58
- NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }}
59
- NETLIFY_SITE_ID: ${{ secrets.NETLIFY_SITE_ID }}
60
- timeout-minutes: 2
61
- if: github.event_name == 'pull_request'
62
-
63
- - name: Deploy to GitHub Pages
64
- uses: peaceiris/actions-gh-pages@v4
65
- with:
66
- personal_token: ${{ secrets.GH_TOKEN_EVE }}
67
- publish_dir: ./build/a2ui-react
68
- force_orphan: true
69
- if: github.event_name == 'push' && github.ref == 'refs/heads/main'
package/.husky/pre-commit DELETED
@@ -1 +0,0 @@
1
- npx lint-staged
package/.prettierignore DELETED
@@ -1,4 +0,0 @@
1
- dist
2
- node_modules
3
- coverage
4
- *.log
package/.prettierrc DELETED
@@ -1,7 +0,0 @@
1
- {
2
- "semi": false,
3
- "singleQuote": true,
4
- "tabWidth": 2,
5
- "trailingComma": "es5",
6
- "printWidth": 80
7
- }
@@ -1,73 +0,0 @@
1
- # [PROJECT_NAME] Constitution
2
-
3
- <!-- Example: Spec Constitution, TaskFlow Constitution, etc. -->
4
-
5
- ## Core Principles
6
-
7
- ### [PRINCIPLE_1_NAME]
8
-
9
- <!-- Example: I. Library-First -->
10
-
11
- [PRINCIPLE_1_DESCRIPTION]
12
-
13
- <!-- Example: Every feature starts as a standalone library; Libraries must be self-contained, independently testable, documented; Clear purpose required - no organizational-only libraries -->
14
-
15
- ### [PRINCIPLE_2_NAME]
16
-
17
- <!-- Example: II. CLI Interface -->
18
-
19
- [PRINCIPLE_2_DESCRIPTION]
20
-
21
- <!-- Example: Every library exposes functionality via CLI; Text in/out protocol: stdin/args → stdout, errors → stderr; Support JSON + human-readable formats -->
22
-
23
- ### [PRINCIPLE_3_NAME]
24
-
25
- <!-- Example: III. Test-First (NON-NEGOTIABLE) -->
26
-
27
- [PRINCIPLE_3_DESCRIPTION]
28
-
29
- <!-- Example: TDD mandatory: Tests written → User approved → Tests fail → Then implement; Red-Green-Refactor cycle strictly enforced -->
30
-
31
- ### [PRINCIPLE_4_NAME]
32
-
33
- <!-- Example: IV. Integration Testing -->
34
-
35
- [PRINCIPLE_4_DESCRIPTION]
36
-
37
- <!-- Example: Focus areas requiring integration tests: New library contract tests, Contract changes, Inter-service communication, Shared schemas -->
38
-
39
- ### [PRINCIPLE_5_NAME]
40
-
41
- <!-- Example: V. Observability, VI. Versioning & Breaking Changes, VII. Simplicity -->
42
-
43
- [PRINCIPLE_5_DESCRIPTION]
44
-
45
- <!-- Example: Text I/O ensures debuggability; Structured logging required; Or: MAJOR.MINOR.BUILD format; Or: Start simple, YAGNI principles -->
46
-
47
- ## [SECTION_2_NAME]
48
-
49
- <!-- Example: Additional Constraints, Security Requirements, Performance Standards, etc. -->
50
-
51
- [SECTION_2_CONTENT]
52
-
53
- <!-- Example: Technology stack requirements, compliance standards, deployment policies, etc. -->
54
-
55
- ## [SECTION_3_NAME]
56
-
57
- <!-- Example: Development Workflow, Review Process, Quality Gates, etc. -->
58
-
59
- [SECTION_3_CONTENT]
60
-
61
- <!-- Example: Code review requirements, testing gates, deployment approval process, etc. -->
62
-
63
- ## Governance
64
-
65
- <!-- Example: Constitution supersedes all other practices; Amendments require documentation, approval, migration plan -->
66
-
67
- [GOVERNANCE_RULES]
68
-
69
- <!-- Example: All PRs/reviews must verify compliance; Complexity must be justified; Use [GUIDANCE_FILE] for runtime development guidance -->
70
-
71
- **Version**: [CONSTITUTION_VERSION] | **Ratified**: [RATIFICATION_DATE] | **Last Amended**: [LAST_AMENDED_DATE]
72
-
73
- <!-- Example: Version: 2.1.1 | Ratified: 2025-06-13 | Last Amended: 2025-07-16 -->