@stigmer/react 0.0.71 → 0.0.73

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 (440) hide show
  1. package/agent/AgentEnvForm.d.ts +2 -0
  2. package/agent/AgentEnvForm.d.ts.map +1 -1
  3. package/agent/AgentEnvForm.js.map +1 -1
  4. package/agent/AgentPicker.d.ts +2 -0
  5. package/agent/AgentPicker.d.ts.map +1 -1
  6. package/agent/AgentPicker.js.map +1 -1
  7. package/agent/agentSetupReducer.d.ts +69 -7
  8. package/agent/agentSetupReducer.d.ts.map +1 -1
  9. package/agent/agentSetupReducer.js.map +1 -1
  10. package/agent/useAgentCount.d.ts +2 -0
  11. package/agent/useAgentCount.d.ts.map +1 -1
  12. package/agent/useAgentCount.js.map +1 -1
  13. package/attachment/AttachmentChipList.d.ts +15 -0
  14. package/attachment/AttachmentChipList.d.ts.map +1 -1
  15. package/attachment/AttachmentChipList.js +15 -0
  16. package/attachment/AttachmentChipList.js.map +1 -1
  17. package/attachment/useAttachments.d.ts +14 -0
  18. package/attachment/useAttachments.d.ts.map +1 -1
  19. package/attachment/useAttachments.js.map +1 -1
  20. package/composer/useComposer.d.ts +5 -0
  21. package/composer/useComposer.d.ts.map +1 -1
  22. package/composer/useComposer.js.map +1 -1
  23. package/execution/ExecutionPhaseBadge.d.ts +1 -1
  24. package/execution/ExecutionPhaseBadge.js +1 -1
  25. package/execution/McpToolDetail.d.ts +16 -8
  26. package/execution/McpToolDetail.d.ts.map +1 -1
  27. package/execution/McpToolDetail.js +0 -6
  28. package/execution/McpToolDetail.js.map +1 -1
  29. package/execution/TodoList.d.ts +8 -0
  30. package/execution/TodoList.d.ts.map +1 -1
  31. package/execution/TodoList.js +8 -0
  32. package/execution/TodoList.js.map +1 -1
  33. package/execution/ToolArgsView.d.ts +1 -0
  34. package/execution/ToolArgsView.d.ts.map +1 -1
  35. package/execution/ToolArgsView.js.map +1 -1
  36. package/execution/UsageWidget.d.ts +1 -1
  37. package/execution/UsageWidget.js +1 -1
  38. package/execution/file-path-resolver.d.ts +10 -0
  39. package/execution/file-path-resolver.d.ts.map +1 -1
  40. package/execution/file-path-resolver.js.map +1 -1
  41. package/execution/index.d.ts +1 -1
  42. package/execution/index.d.ts.map +1 -1
  43. package/execution/index.js.map +1 -1
  44. package/execution/useArtifactContent.d.ts +33 -0
  45. package/execution/useArtifactContent.d.ts.map +1 -1
  46. package/execution/useArtifactContent.js +33 -0
  47. package/execution/useArtifactContent.js.map +1 -1
  48. package/execution/useSubmitApproval.d.ts +2 -0
  49. package/execution/useSubmitApproval.d.ts.map +1 -1
  50. package/execution/useSubmitApproval.js.map +1 -1
  51. package/github/GitHubRepoPicker.d.ts +13 -0
  52. package/github/GitHubRepoPicker.d.ts.map +1 -1
  53. package/github/GitHubRepoPicker.js +13 -0
  54. package/github/GitHubRepoPicker.js.map +1 -1
  55. package/github/useGitHubConnection.d.ts +29 -1
  56. package/github/useGitHubConnection.d.ts.map +1 -1
  57. package/github/useGitHubConnection.js +29 -1
  58. package/github/useGitHubConnection.js.map +1 -1
  59. package/github/useGitHubRepos.d.ts +31 -0
  60. package/github/useGitHubRepos.d.ts.map +1 -1
  61. package/github/useGitHubRepos.js +31 -0
  62. package/github/useGitHubRepos.js.map +1 -1
  63. package/github/useGitHubSearch.d.ts +25 -0
  64. package/github/useGitHubSearch.d.ts.map +1 -1
  65. package/github/useGitHubSearch.js +25 -0
  66. package/github/useGitHubSearch.js.map +1 -1
  67. package/iam-policy/GrantAccessForm.d.ts +39 -0
  68. package/iam-policy/GrantAccessForm.d.ts.map +1 -0
  69. package/iam-policy/GrantAccessForm.js +75 -0
  70. package/iam-policy/GrantAccessForm.js.map +1 -0
  71. package/iam-policy/OrgMembersPanel.d.ts +28 -0
  72. package/iam-policy/OrgMembersPanel.d.ts.map +1 -0
  73. package/iam-policy/OrgMembersPanel.js +192 -0
  74. package/iam-policy/OrgMembersPanel.js.map +1 -0
  75. package/iam-policy/RoleSelector.d.ts +37 -0
  76. package/iam-policy/RoleSelector.d.ts.map +1 -0
  77. package/iam-policy/RoleSelector.js +42 -0
  78. package/iam-policy/RoleSelector.js.map +1 -0
  79. package/iam-policy/index.d.ts +12 -0
  80. package/iam-policy/index.d.ts.map +1 -0
  81. package/iam-policy/index.js +12 -0
  82. package/iam-policy/index.js.map +1 -0
  83. package/iam-policy/useCreateIamPolicy.d.ts +35 -0
  84. package/iam-policy/useCreateIamPolicy.d.ts.map +1 -0
  85. package/iam-policy/useCreateIamPolicy.js +46 -0
  86. package/iam-policy/useCreateIamPolicy.js.map +1 -0
  87. package/iam-policy/useDeleteIamPolicy.d.ts +34 -0
  88. package/iam-policy/useDeleteIamPolicy.d.ts.map +1 -0
  89. package/iam-policy/useDeleteIamPolicy.js +45 -0
  90. package/iam-policy/useDeleteIamPolicy.js.map +1 -0
  91. package/iam-policy/useGrantableRoles.d.ts +28 -0
  92. package/iam-policy/useGrantableRoles.d.ts.map +1 -0
  93. package/iam-policy/useGrantableRoles.js +32 -0
  94. package/iam-policy/useGrantableRoles.js.map +1 -0
  95. package/iam-policy/usePrincipalsCount.d.ts +31 -0
  96. package/iam-policy/usePrincipalsCount.d.ts.map +1 -0
  97. package/iam-policy/usePrincipalsCount.js +72 -0
  98. package/iam-policy/usePrincipalsCount.js.map +1 -0
  99. package/iam-policy/useResourceAccess.d.ts +51 -0
  100. package/iam-policy/useResourceAccess.d.ts.map +1 -0
  101. package/iam-policy/useResourceAccess.js +85 -0
  102. package/iam-policy/useResourceAccess.js.map +1 -0
  103. package/iam-policy/useRevokeOrgAccess.d.ts +36 -0
  104. package/iam-policy/useRevokeOrgAccess.d.ts.map +1 -0
  105. package/iam-policy/useRevokeOrgAccess.js +48 -0
  106. package/iam-policy/useRevokeOrgAccess.js.map +1 -0
  107. package/iam-policy/useRoleSelector.d.ts +52 -0
  108. package/iam-policy/useRoleSelector.d.ts.map +1 -0
  109. package/iam-policy/useRoleSelector.js +50 -0
  110. package/iam-policy/useRoleSelector.js.map +1 -0
  111. package/iam-policy/useWhoAmI.d.ts +30 -0
  112. package/iam-policy/useWhoAmI.d.ts.map +1 -0
  113. package/iam-policy/useWhoAmI.js +56 -0
  114. package/iam-policy/useWhoAmI.js.map +1 -0
  115. package/identity-provider/CreateIdentityProviderForm.d.ts +39 -0
  116. package/identity-provider/CreateIdentityProviderForm.d.ts.map +1 -0
  117. package/identity-provider/CreateIdentityProviderForm.js +102 -0
  118. package/identity-provider/CreateIdentityProviderForm.js.map +1 -0
  119. package/identity-provider/IdentityProviderDetailPanel.d.ts +42 -0
  120. package/identity-provider/IdentityProviderDetailPanel.d.ts.map +1 -0
  121. package/identity-provider/IdentityProviderDetailPanel.js +156 -0
  122. package/identity-provider/IdentityProviderDetailPanel.js.map +1 -0
  123. package/identity-provider/IdentityProviderListPanel.d.ts +41 -0
  124. package/identity-provider/IdentityProviderListPanel.d.ts.map +1 -0
  125. package/identity-provider/IdentityProviderListPanel.js +110 -0
  126. package/identity-provider/IdentityProviderListPanel.js.map +1 -0
  127. package/identity-provider/IdentityProviderWizard.d.ts +40 -0
  128. package/identity-provider/IdentityProviderWizard.d.ts.map +1 -0
  129. package/identity-provider/IdentityProviderWizard.js +180 -0
  130. package/identity-provider/IdentityProviderWizard.js.map +1 -0
  131. package/identity-provider/ProviderPicker.d.ts +28 -0
  132. package/identity-provider/ProviderPicker.d.ts.map +1 -0
  133. package/identity-provider/ProviderPicker.js +64 -0
  134. package/identity-provider/ProviderPicker.js.map +1 -0
  135. package/identity-provider/SsoLoginPrompt.d.ts +51 -0
  136. package/identity-provider/SsoLoginPrompt.d.ts.map +1 -0
  137. package/identity-provider/SsoLoginPrompt.js +119 -0
  138. package/identity-provider/SsoLoginPrompt.js.map +1 -0
  139. package/identity-provider/index.d.ts +14 -0
  140. package/identity-provider/index.d.ts.map +1 -0
  141. package/identity-provider/index.js +14 -0
  142. package/identity-provider/index.js.map +1 -0
  143. package/identity-provider/presets.d.ts +65 -0
  144. package/identity-provider/presets.d.ts.map +1 -0
  145. package/identity-provider/presets.js +200 -0
  146. package/identity-provider/presets.js.map +1 -0
  147. package/identity-provider/useCreateIdentityProvider.d.ts +37 -0
  148. package/identity-provider/useCreateIdentityProvider.d.ts.map +1 -0
  149. package/identity-provider/useCreateIdentityProvider.js +48 -0
  150. package/identity-provider/useCreateIdentityProvider.js.map +1 -0
  151. package/identity-provider/useDeleteIdentityProvider.d.ts +34 -0
  152. package/identity-provider/useDeleteIdentityProvider.d.ts.map +1 -0
  153. package/identity-provider/useDeleteIdentityProvider.js +45 -0
  154. package/identity-provider/useDeleteIdentityProvider.js.map +1 -0
  155. package/identity-provider/useIdentityProvider.d.ts +37 -0
  156. package/identity-provider/useIdentityProvider.d.ts.map +1 -0
  157. package/identity-provider/useIdentityProvider.js +62 -0
  158. package/identity-provider/useIdentityProvider.js.map +1 -0
  159. package/identity-provider/useIdentityProviderList.d.ts +48 -0
  160. package/identity-provider/useIdentityProviderList.d.ts.map +1 -0
  161. package/identity-provider/useIdentityProviderList.js +75 -0
  162. package/identity-provider/useIdentityProviderList.js.map +1 -0
  163. package/identity-provider/useOidcDiscovery.d.ts +39 -0
  164. package/identity-provider/useOidcDiscovery.d.ts.map +1 -0
  165. package/identity-provider/useOidcDiscovery.js +76 -0
  166. package/identity-provider/useOidcDiscovery.js.map +1 -0
  167. package/identity-provider/useSsoProvider.d.ts +50 -0
  168. package/identity-provider/useSsoProvider.d.ts.map +1 -0
  169. package/identity-provider/useSsoProvider.js +83 -0
  170. package/identity-provider/useSsoProvider.js.map +1 -0
  171. package/identity-provider/useUpdateIdentityProvider.d.ts +38 -0
  172. package/identity-provider/useUpdateIdentityProvider.d.ts.map +1 -0
  173. package/identity-provider/useUpdateIdentityProvider.js +49 -0
  174. package/identity-provider/useUpdateIdentityProvider.js.map +1 -0
  175. package/index.d.ts +14 -5
  176. package/index.d.ts.map +1 -1
  177. package/index.js +10 -2
  178. package/index.js.map +1 -1
  179. package/internal/CloudFeatureNotice.d.ts +12 -0
  180. package/internal/CloudFeatureNotice.d.ts.map +1 -1
  181. package/internal/CloudFeatureNotice.js +12 -0
  182. package/internal/CloudFeatureNotice.js.map +1 -1
  183. package/invitation/InvitationCreatedAlert.d.ts +35 -0
  184. package/invitation/InvitationCreatedAlert.d.ts.map +1 -0
  185. package/invitation/InvitationCreatedAlert.js +60 -0
  186. package/invitation/InvitationCreatedAlert.js.map +1 -0
  187. package/invitation/InvitationManager.d.ts +44 -0
  188. package/invitation/InvitationManager.d.ts.map +1 -0
  189. package/invitation/InvitationManager.js +248 -0
  190. package/invitation/InvitationManager.js.map +1 -0
  191. package/invitation/InvitationRedemption.d.ts +69 -0
  192. package/invitation/InvitationRedemption.d.ts.map +1 -0
  193. package/invitation/InvitationRedemption.js +140 -0
  194. package/invitation/InvitationRedemption.js.map +1 -0
  195. package/invitation/index.d.ts +17 -0
  196. package/invitation/index.d.ts.map +1 -0
  197. package/invitation/index.js +9 -0
  198. package/invitation/index.js.map +1 -0
  199. package/invitation/useCreateInvitation.d.ts +52 -0
  200. package/invitation/useCreateInvitation.d.ts.map +1 -0
  201. package/invitation/useCreateInvitation.js +55 -0
  202. package/invitation/useCreateInvitation.js.map +1 -0
  203. package/invitation/useInvitationPreview.d.ts +51 -0
  204. package/invitation/useInvitationPreview.d.ts.map +1 -0
  205. package/invitation/useInvitationPreview.js +80 -0
  206. package/invitation/useInvitationPreview.js.map +1 -0
  207. package/invitation/useOrgInvitations.d.ts +36 -0
  208. package/invitation/useOrgInvitations.d.ts.map +1 -0
  209. package/invitation/useOrgInvitations.js +65 -0
  210. package/invitation/useOrgInvitations.js.map +1 -0
  211. package/invitation/useRedeemInvitation.d.ts +47 -0
  212. package/invitation/useRedeemInvitation.d.ts.map +1 -0
  213. package/invitation/useRedeemInvitation.js +53 -0
  214. package/invitation/useRedeemInvitation.js.map +1 -0
  215. package/invitation/useRevokeInvitation.d.ts +35 -0
  216. package/invitation/useRevokeInvitation.d.ts.map +1 -0
  217. package/invitation/useRevokeInvitation.js +47 -0
  218. package/invitation/useRevokeInvitation.js.map +1 -0
  219. package/library/detect-skill-package.d.ts +1 -0
  220. package/library/detect-skill-package.d.ts.map +1 -1
  221. package/library/detect-skill-package.js.map +1 -1
  222. package/library/detect-stigmer-resource.d.ts +1 -0
  223. package/library/detect-stigmer-resource.d.ts.map +1 -1
  224. package/library/detect-stigmer-resource.js.map +1 -1
  225. package/library/parse-resource-yaml.d.ts +4 -0
  226. package/library/parse-resource-yaml.d.ts.map +1 -1
  227. package/library/parse-resource-yaml.js.map +1 -1
  228. package/mcp-server/McpServerDetailView.d.ts +2 -2
  229. package/mcp-server/McpServerDetailView.d.ts.map +1 -1
  230. package/mcp-server/McpServerDetailView.js.map +1 -1
  231. package/mcp-server/index.d.ts +1 -1
  232. package/mcp-server/index.d.ts.map +1 -1
  233. package/mcp-server/index.js.map +1 -1
  234. package/mcp-server/mcpServerSetupReducer.d.ts +54 -0
  235. package/mcp-server/mcpServerSetupReducer.d.ts.map +1 -1
  236. package/mcp-server/mcpServerSetupReducer.js.map +1 -1
  237. package/models/ModelSelector.d.ts +9 -0
  238. package/models/ModelSelector.d.ts.map +1 -1
  239. package/models/ModelSelector.js +9 -0
  240. package/models/ModelSelector.js.map +1 -1
  241. package/models/registry.d.ts +11 -1
  242. package/models/registry.d.ts.map +1 -1
  243. package/models/registry.js.map +1 -1
  244. package/models/useModelRegistry.d.ts +20 -0
  245. package/models/useModelRegistry.d.ts.map +1 -1
  246. package/models/useModelRegistry.js +20 -0
  247. package/models/useModelRegistry.js.map +1 -1
  248. package/organization/OrgProfilePanel.d.ts +31 -0
  249. package/organization/OrgProfilePanel.d.ts.map +1 -0
  250. package/organization/OrgProfilePanel.js +147 -0
  251. package/organization/OrgProfilePanel.js.map +1 -0
  252. package/organization/index.d.ts +6 -0
  253. package/organization/index.d.ts.map +1 -1
  254. package/organization/index.js +3 -0
  255. package/organization/index.js.map +1 -1
  256. package/organization/useOrganization.d.ts +31 -0
  257. package/organization/useOrganization.d.ts.map +1 -0
  258. package/organization/useOrganization.js +56 -0
  259. package/organization/useOrganization.js.map +1 -0
  260. package/organization/useUpdateOrganization.d.ts +40 -0
  261. package/organization/useUpdateOrganization.d.ts.map +1 -0
  262. package/organization/useUpdateOrganization.js +51 -0
  263. package/organization/useUpdateOrganization.js.map +1 -0
  264. package/package.json +4 -4
  265. package/provider.d.ts +1 -0
  266. package/provider.d.ts.map +1 -1
  267. package/provider.js.map +1 -1
  268. package/search/useResourceList.d.ts +4 -2
  269. package/search/useResourceList.d.ts.map +1 -1
  270. package/search/useResourceList.js +2 -1
  271. package/search/useResourceList.js.map +1 -1
  272. package/search/useResourceSearch.d.ts +10 -2
  273. package/search/useResourceSearch.d.ts.map +1 -1
  274. package/search/useResourceSearch.js +2 -1
  275. package/search/useResourceSearch.js.map +1 -1
  276. package/session/group-sessions.d.ts +23 -0
  277. package/session/group-sessions.d.ts.map +1 -1
  278. package/session/group-sessions.js +23 -0
  279. package/session/group-sessions.js.map +1 -1
  280. package/session/index.d.ts +1 -1
  281. package/session/index.d.ts.map +1 -1
  282. package/session/index.js.map +1 -1
  283. package/session/useCreateSession.d.ts +11 -2
  284. package/session/useCreateSession.d.ts.map +1 -1
  285. package/session/useCreateSession.js.map +1 -1
  286. package/session/useSession.d.ts +24 -0
  287. package/session/useSession.d.ts.map +1 -1
  288. package/session/useSession.js +24 -0
  289. package/session/useSession.js.map +1 -1
  290. package/session/useSessionArtifacts.d.ts +1 -0
  291. package/session/useSessionArtifacts.d.ts.map +1 -1
  292. package/session/useSessionArtifacts.js.map +1 -1
  293. package/session/useSessionConversation.d.ts +7 -0
  294. package/session/useSessionConversation.d.ts.map +1 -1
  295. package/session/useSessionConversation.js.map +1 -1
  296. package/session/useSessionExecutions.d.ts +23 -0
  297. package/session/useSessionExecutions.d.ts.map +1 -1
  298. package/session/useSessionExecutions.js +23 -0
  299. package/session/useSessionExecutions.js.map +1 -1
  300. package/session/useSessionList.d.ts +19 -0
  301. package/session/useSessionList.d.ts.map +1 -1
  302. package/session/useSessionList.js +19 -0
  303. package/session/useSessionList.js.map +1 -1
  304. package/session/useSessionWriteBacks.d.ts +1 -0
  305. package/session/useSessionWriteBacks.d.ts.map +1 -1
  306. package/session/useSessionWriteBacks.js.map +1 -1
  307. package/session/useUpdateSession.d.ts +22 -0
  308. package/session/useUpdateSession.d.ts.map +1 -1
  309. package/session/useUpdateSession.js +22 -0
  310. package/session/useUpdateSession.js.map +1 -1
  311. package/skill/SkillPicker.d.ts +15 -0
  312. package/skill/SkillPicker.d.ts.map +1 -1
  313. package/skill/SkillPicker.js +15 -0
  314. package/skill/SkillPicker.js.map +1 -1
  315. package/src/agent/AgentEnvForm.tsx +2 -0
  316. package/src/agent/AgentPicker.tsx +2 -0
  317. package/src/agent/agentSetupReducer.ts +109 -20
  318. package/src/agent/useAgentCount.ts +2 -0
  319. package/src/attachment/AttachmentChipList.tsx +15 -0
  320. package/src/attachment/useAttachments.ts +14 -0
  321. package/src/composer/useComposer.ts +5 -0
  322. package/src/execution/ExecutionPhaseBadge.tsx +1 -1
  323. package/src/execution/McpToolDetail.tsx +18 -6
  324. package/src/execution/TodoList.tsx +8 -0
  325. package/src/execution/ToolArgsView.tsx +1 -0
  326. package/src/execution/UsageWidget.tsx +1 -1
  327. package/src/execution/file-path-resolver.ts +28 -4
  328. package/src/execution/index.ts +5 -1
  329. package/src/execution/useArtifactContent.ts +33 -0
  330. package/src/execution/useSubmitApproval.ts +2 -0
  331. package/src/github/GitHubRepoPicker.tsx +13 -0
  332. package/src/github/useGitHubConnection.ts +29 -1
  333. package/src/github/useGitHubRepos.ts +31 -0
  334. package/src/github/useGitHubSearch.ts +25 -0
  335. package/src/iam-policy/GrantAccessForm.tsx +198 -0
  336. package/src/iam-policy/OrgMembersPanel.tsx +572 -0
  337. package/src/iam-policy/RoleSelector.tsx +105 -0
  338. package/src/iam-policy/index.ts +51 -0
  339. package/src/iam-policy/useCreateIamPolicy.ts +66 -0
  340. package/src/iam-policy/useDeleteIamPolicy.ts +65 -0
  341. package/src/iam-policy/useGrantableRoles.ts +45 -0
  342. package/src/iam-policy/usePrincipalsCount.ts +96 -0
  343. package/src/iam-policy/useResourceAccess.ts +128 -0
  344. package/src/iam-policy/useRevokeOrgAccess.ts +74 -0
  345. package/src/iam-policy/useRoleSelector.ts +97 -0
  346. package/src/iam-policy/useWhoAmI.ts +78 -0
  347. package/src/identity-provider/CreateIdentityProviderForm.tsx +308 -0
  348. package/src/identity-provider/IdentityProviderDetailPanel.tsx +583 -0
  349. package/src/identity-provider/IdentityProviderListPanel.tsx +370 -0
  350. package/src/identity-provider/IdentityProviderWizard.tsx +684 -0
  351. package/src/identity-provider/ProviderPicker.tsx +152 -0
  352. package/src/identity-provider/SsoLoginPrompt.tsx +404 -0
  353. package/src/identity-provider/index.ts +67 -0
  354. package/src/identity-provider/presets.ts +262 -0
  355. package/src/identity-provider/useCreateIdentityProvider.ts +68 -0
  356. package/src/identity-provider/useDeleteIdentityProvider.ts +65 -0
  357. package/src/identity-provider/useIdentityProvider.ts +86 -0
  358. package/src/identity-provider/useIdentityProviderList.ts +100 -0
  359. package/src/identity-provider/useOidcDiscovery.ts +124 -0
  360. package/src/identity-provider/useSsoProvider.ts +99 -0
  361. package/src/identity-provider/useUpdateIdentityProvider.ts +69 -0
  362. package/src/index.ts +121 -1
  363. package/src/internal/CloudFeatureNotice.tsx +12 -0
  364. package/src/invitation/InvitationCreatedAlert.tsx +185 -0
  365. package/src/invitation/InvitationManager.tsx +842 -0
  366. package/src/invitation/InvitationRedemption.tsx +434 -0
  367. package/src/invitation/index.ts +16 -0
  368. package/src/invitation/useCreateInvitation.ts +83 -0
  369. package/src/invitation/useInvitationPreview.ts +103 -0
  370. package/src/invitation/useOrgInvitations.ts +88 -0
  371. package/src/invitation/useRedeemInvitation.ts +82 -0
  372. package/src/invitation/useRevokeInvitation.ts +66 -0
  373. package/src/library/detect-skill-package.ts +4 -1
  374. package/src/library/detect-stigmer-resource.ts +4 -1
  375. package/src/library/parse-resource-yaml.ts +12 -2
  376. package/src/mcp-server/McpServerDetailView.tsx +2 -1
  377. package/src/mcp-server/index.ts +4 -1
  378. package/src/mcp-server/mcpServerSetupReducer.ts +86 -8
  379. package/src/models/ModelSelector.tsx +9 -0
  380. package/src/models/registry.ts +11 -1
  381. package/src/models/useModelRegistry.ts +20 -0
  382. package/src/organization/OrgProfilePanel.tsx +451 -0
  383. package/src/organization/index.ts +6 -0
  384. package/src/organization/useOrganization.ts +79 -0
  385. package/src/organization/useUpdateOrganization.ts +71 -0
  386. package/src/provider.tsx +1 -0
  387. package/src/search/useResourceList.ts +6 -3
  388. package/src/search/useResourceSearch.ts +12 -3
  389. package/src/session/group-sessions.ts +23 -0
  390. package/src/session/index.ts +1 -0
  391. package/src/session/useCreateSession.ts +19 -3
  392. package/src/session/useSession.ts +24 -0
  393. package/src/session/useSessionArtifacts.ts +1 -0
  394. package/src/session/useSessionConversation.ts +7 -0
  395. package/src/session/useSessionExecutions.ts +23 -0
  396. package/src/session/useSessionList.ts +19 -0
  397. package/src/session/useSessionWriteBacks.ts +1 -0
  398. package/src/session/useUpdateSession.ts +22 -0
  399. package/src/skill/SkillPicker.tsx +15 -0
  400. package/src/usage/OrgUsagePanel.tsx +465 -0
  401. package/src/usage/date-range.ts +86 -0
  402. package/src/usage/index.ts +13 -0
  403. package/src/usage/useOrgUsageReport.ts +110 -0
  404. package/src/workspace/FolderBrowser.tsx +9 -0
  405. package/src/workspace/WorkspaceEditor.tsx +17 -0
  406. package/src/workspace/useFolderListing.ts +24 -0
  407. package/src/workspace/useWorkspaceEntries.ts +38 -0
  408. package/styles.css +1 -1
  409. package/usage/OrgUsagePanel.d.ts +24 -0
  410. package/usage/OrgUsagePanel.d.ts.map +1 -0
  411. package/usage/OrgUsagePanel.js +134 -0
  412. package/usage/OrgUsagePanel.js.map +1 -0
  413. package/usage/date-range.d.ts +36 -0
  414. package/usage/date-range.d.ts.map +1 -0
  415. package/usage/date-range.js +69 -0
  416. package/usage/date-range.js.map +1 -0
  417. package/usage/index.d.ts +7 -0
  418. package/usage/index.d.ts.map +1 -0
  419. package/usage/index.js +4 -0
  420. package/usage/index.js.map +1 -0
  421. package/usage/useOrgUsageReport.d.ts +48 -0
  422. package/usage/useOrgUsageReport.d.ts.map +1 -0
  423. package/usage/useOrgUsageReport.js +72 -0
  424. package/usage/useOrgUsageReport.js.map +1 -0
  425. package/workspace/FolderBrowser.d.ts +9 -0
  426. package/workspace/FolderBrowser.d.ts.map +1 -1
  427. package/workspace/FolderBrowser.js +9 -0
  428. package/workspace/FolderBrowser.js.map +1 -1
  429. package/workspace/WorkspaceEditor.d.ts +17 -0
  430. package/workspace/WorkspaceEditor.d.ts.map +1 -1
  431. package/workspace/WorkspaceEditor.js +17 -0
  432. package/workspace/WorkspaceEditor.js.map +1 -1
  433. package/workspace/useFolderListing.d.ts +24 -0
  434. package/workspace/useFolderListing.d.ts.map +1 -1
  435. package/workspace/useFolderListing.js +24 -0
  436. package/workspace/useFolderListing.js.map +1 -1
  437. package/workspace/useWorkspaceEntries.d.ts +38 -0
  438. package/workspace/useWorkspaceEntries.d.ts.map +1 -1
  439. package/workspace/useWorkspaceEntries.js +25 -0
  440. package/workspace/useWorkspaceEntries.js.map +1 -1
@@ -0,0 +1,684 @@
1
+ "use client";
2
+
3
+ import {
4
+ useCallback,
5
+ useState,
6
+ type FormEvent,
7
+ } from "react";
8
+ import { cn } from "@stigmer/theme";
9
+ import { getUserMessage } from "@stigmer/sdk";
10
+ import type { IdentityProvider } from "@stigmer/protos/ai/stigmer/iam/identityprovider/v1/api_pb";
11
+ import { ProviderPicker } from "./ProviderPicker";
12
+ import { useCreateIdentityProvider } from "./useCreateIdentityProvider";
13
+ import { useOidcDiscovery } from "./useOidcDiscovery";
14
+ import type { ProviderPreset, ProviderConfig } from "./presets";
15
+
16
+ /** Props for {@link IdentityProviderWizard}. */
17
+ export interface IdentityProviderWizardProps {
18
+ /** Organization slug — the IdP will be created in this org. */
19
+ readonly org: string;
20
+ /** Fired with the newly created identity provider on success. */
21
+ readonly onCreated?: (idp: IdentityProvider) => void;
22
+ /** Fired when the user cancels the wizard. */
23
+ readonly onCancel?: () => void;
24
+ /** Additional CSS class names for the root container. */
25
+ readonly className?: string;
26
+ }
27
+
28
+ type WizardStep = "pick" | "configure" | "review";
29
+
30
+ /**
31
+ * Multi-step wizard for creating a new identity provider.
32
+ *
33
+ * Guides the user through three steps:
34
+ *
35
+ * 1. **Pick** — select a well-known provider preset or "Custom OIDC"
36
+ * 2. **Configure** — fill in provider-specific variables (e.g., Auth0
37
+ * tenant name) plus the IdP display name and expected audience
38
+ * 3. **Review** — verify auto-populated OIDC configuration, optionally
39
+ * enable SSO, and submit
40
+ *
41
+ * For known presets, URLs are constructed from deterministic templates
42
+ * (no network call). For "Custom OIDC", the wizard attempts OIDC
43
+ * Discovery and falls back to manual entry if the fetch fails.
44
+ *
45
+ * All visual properties flow through `--stgm-*` design tokens.
46
+ *
47
+ * @example
48
+ * ```tsx
49
+ * <IdentityProviderWizard
50
+ * org="acme"
51
+ * onCreated={(idp) => { refetch(); setShowWizard(false); }}
52
+ * onCancel={() => setShowWizard(false)}
53
+ * />
54
+ * ```
55
+ */
56
+ export function IdentityProviderWizard({
57
+ org,
58
+ onCreated,
59
+ onCancel,
60
+ className,
61
+ }: IdentityProviderWizardProps) {
62
+ const { create, isCreating, error: createError, clearError } =
63
+ useCreateIdentityProvider();
64
+ const { discover, isDiscovering, error: discoveryError } =
65
+ useOidcDiscovery();
66
+
67
+ // Step state
68
+ const [step, setStep] = useState<WizardStep>("pick");
69
+ const [preset, setPreset] = useState<ProviderPreset | null>(null);
70
+
71
+ // Configure step
72
+ const [vars, setVars] = useState<Record<string, string>>({});
73
+ const [name, setName] = useState("");
74
+ const [audience, setAudience] = useState("");
75
+
76
+ // Review step
77
+ const [jwksUri, setJwksUri] = useState("");
78
+ const [issuers, setIssuers] = useState("");
79
+ const [userinfoEndpoint, setUserinfoEndpoint] = useState("");
80
+ const [isSso, setIsSso] = useState(false);
81
+ const [oidcClientId, setOidcClientId] = useState("");
82
+ const [discoveryFailed, setDiscoveryFailed] = useState(false);
83
+
84
+ // -- Step transitions ------------------------------------------------
85
+
86
+ const handlePickProvider = useCallback((selected: ProviderPreset) => {
87
+ setPreset(selected);
88
+ setVars(
89
+ Object.fromEntries(selected.variables.map((v) => [v.key, v.options?.[0]?.value ?? ""])),
90
+ );
91
+ setName("");
92
+ setAudience("");
93
+ setStep("configure");
94
+ }, []);
95
+
96
+ const handleBackToPick = useCallback(() => {
97
+ setStep("pick");
98
+ setPreset(null);
99
+ }, []);
100
+
101
+ const populateReview = useCallback((config: ProviderConfig | null) => {
102
+ setJwksUri(config?.jwksUri ?? "");
103
+ setIssuers(config?.allowedIssuers.join(", ") ?? "");
104
+ setUserinfoEndpoint(config?.userinfoEndpoint ?? "");
105
+ setIsSso(false);
106
+ setOidcClientId("");
107
+ setDiscoveryFailed(!config);
108
+ }, []);
109
+
110
+ const handleContinueToReview = useCallback(async () => {
111
+ if (!preset) return;
112
+
113
+ if (preset.id === "custom") {
114
+ const result = await discover(vars.issuerUrl ?? "");
115
+ populateReview(
116
+ result
117
+ ? { ...result, allowedIssuers: [result.issuer] }
118
+ : null,
119
+ );
120
+ } else {
121
+ populateReview(preset.buildConfig(vars));
122
+ }
123
+ setStep("review");
124
+ }, [preset, vars, discover, populateReview]);
125
+
126
+ const handleBackToConfigure = useCallback(() => {
127
+ setStep("configure");
128
+ clearError();
129
+ }, [clearError]);
130
+
131
+ // -- Submit ----------------------------------------------------------
132
+
133
+ const handleSubmit = useCallback(
134
+ async (e: FormEvent) => {
135
+ e.preventDefault();
136
+ clearError();
137
+ try {
138
+ const idp = await create({
139
+ name: name.trim(),
140
+ org,
141
+ displayName: name.trim(),
142
+ jwksUri: jwksUri.trim(),
143
+ allowedIssuers: issuers
144
+ .split(",")
145
+ .map((s) => s.trim())
146
+ .filter(Boolean),
147
+ expectedAudience: audience.trim(),
148
+ userinfoEndpoint: userinfoEndpoint.trim() || undefined,
149
+ ...(isSso && {
150
+ isSsoProvider: true,
151
+ oidcClientId: oidcClientId.trim(),
152
+ }),
153
+ });
154
+ onCreated?.(idp);
155
+ } catch {
156
+ // error state is managed by useCreateIdentityProvider
157
+ }
158
+ },
159
+ [
160
+ name, org, jwksUri, issuers, audience, userinfoEndpoint,
161
+ isSso, oidcClientId, create, clearError, onCreated,
162
+ ],
163
+ );
164
+
165
+ // -- Render ----------------------------------------------------------
166
+
167
+ return (
168
+ <div className={cn("space-y-4", className)}>
169
+ {/* Step indicator */}
170
+ <StepIndicator current={step} />
171
+
172
+ {step === "pick" && (
173
+ <>
174
+ <p className="text-muted-foreground text-xs">
175
+ Choose your identity provider to get started. Known providers
176
+ will have their OIDC configuration auto-populated.
177
+ </p>
178
+ <ProviderPicker onSelect={handlePickProvider} />
179
+ {onCancel && (
180
+ <div className="pt-1">
181
+ <CancelButton onClick={onCancel} />
182
+ </div>
183
+ )}
184
+ </>
185
+ )}
186
+
187
+ {step === "configure" && preset && (
188
+ <ConfigureStep
189
+ preset={preset}
190
+ vars={vars}
191
+ onVarChange={(key, value) =>
192
+ setVars((prev) => ({ ...prev, [key]: value }))
193
+ }
194
+ name={name}
195
+ onNameChange={setName}
196
+ audience={audience}
197
+ onAudienceChange={setAudience}
198
+ isLoading={isDiscovering}
199
+ discoveryError={discoveryError}
200
+ onBack={handleBackToPick}
201
+ onContinue={handleContinueToReview}
202
+ onCancel={onCancel}
203
+ />
204
+ )}
205
+
206
+ {step === "review" && (
207
+ <ReviewStep
208
+ discoveryFailed={discoveryFailed}
209
+ jwksUri={jwksUri}
210
+ onJwksUriChange={setJwksUri}
211
+ issuers={issuers}
212
+ onIssuersChange={setIssuers}
213
+ userinfoEndpoint={userinfoEndpoint}
214
+ onUserinfoEndpointChange={setUserinfoEndpoint}
215
+ isSso={isSso}
216
+ onIsSsoChange={setIsSso}
217
+ oidcClientId={oidcClientId}
218
+ onOidcClientIdChange={setOidcClientId}
219
+ isCreating={isCreating}
220
+ createError={createError}
221
+ onBack={handleBackToConfigure}
222
+ onSubmit={handleSubmit}
223
+ onCancel={onCancel}
224
+ />
225
+ )}
226
+ </div>
227
+ );
228
+ }
229
+
230
+ // ---------------------------------------------------------------------------
231
+ // Step indicator
232
+ // ---------------------------------------------------------------------------
233
+
234
+ const STEPS: { key: WizardStep; label: string }[] = [
235
+ { key: "pick", label: "Provider" },
236
+ { key: "configure", label: "Configure" },
237
+ { key: "review", label: "Review" },
238
+ ];
239
+
240
+ function StepIndicator({ current }: { current: WizardStep }) {
241
+ const currentIdx = STEPS.findIndex((s) => s.key === current);
242
+ return (
243
+ <nav aria-label="Wizard progress" className="flex items-center gap-1.5">
244
+ {STEPS.map((s, i) => {
245
+ const state =
246
+ i < currentIdx ? "done" : i === currentIdx ? "active" : "upcoming";
247
+ return (
248
+ <span key={s.key} className="flex items-center gap-1.5">
249
+ {i > 0 && (
250
+ <span
251
+ className={cn(
252
+ "h-px w-4",
253
+ state === "upcoming" ? "bg-border" : "bg-primary/40",
254
+ )}
255
+ />
256
+ )}
257
+ <span
258
+ className={cn(
259
+ "text-[0.65rem] font-medium",
260
+ state === "active"
261
+ ? "text-primary"
262
+ : state === "done"
263
+ ? "text-muted-foreground"
264
+ : "text-muted-foreground/50",
265
+ )}
266
+ >
267
+ {s.label}
268
+ </span>
269
+ </span>
270
+ );
271
+ })}
272
+ </nav>
273
+ );
274
+ }
275
+
276
+ // ---------------------------------------------------------------------------
277
+ // Configure step (step 2)
278
+ // ---------------------------------------------------------------------------
279
+
280
+ function ConfigureStep({
281
+ preset,
282
+ vars,
283
+ onVarChange,
284
+ name,
285
+ onNameChange,
286
+ audience,
287
+ onAudienceChange,
288
+ isLoading,
289
+ discoveryError,
290
+ onBack,
291
+ onContinue,
292
+ onCancel,
293
+ }: {
294
+ preset: ProviderPreset;
295
+ vars: Record<string, string>;
296
+ onVarChange: (key: string, value: string) => void;
297
+ name: string;
298
+ onNameChange: (v: string) => void;
299
+ audience: string;
300
+ onAudienceChange: (v: string) => void;
301
+ isLoading: boolean;
302
+ discoveryError: Error | null;
303
+ onBack: () => void;
304
+ onContinue: () => void;
305
+ onCancel?: () => void;
306
+ }) {
307
+ const allVarsFilled = preset.variables.every(
308
+ (v) => (vars[v.key] ?? "").trim() !== "",
309
+ );
310
+ const canContinue =
311
+ allVarsFilled &&
312
+ name.trim() !== "" &&
313
+ audience.trim() !== "" &&
314
+ !isLoading;
315
+
316
+ return (
317
+ <div className="space-y-3">
318
+ <p className="text-muted-foreground text-xs">
319
+ {preset.variables.length > 0
320
+ ? `Enter your ${preset.label} details to auto-populate the OIDC configuration.`
321
+ : `${preset.label} configuration is fully automatic — just provide a name and audience.`}
322
+ </p>
323
+
324
+ {/* Provider-specific variables */}
325
+ {preset.variables.map((v) => (
326
+ <FieldInput
327
+ key={v.key}
328
+ id={`stgm-idp-var-${v.key}`}
329
+ label={v.label}
330
+ value={vars[v.key] ?? ""}
331
+ onChange={(val) => onVarChange(v.key, val)}
332
+ placeholder={v.placeholder}
333
+ hint={v.hint}
334
+ disabled={isLoading}
335
+ type={v.type}
336
+ options={v.options}
337
+ />
338
+ ))}
339
+
340
+ <hr className="border-border/40" />
341
+
342
+ {/* Common fields */}
343
+ <FieldInput
344
+ id="stgm-idp-wiz-name"
345
+ label="Display name"
346
+ value={name}
347
+ onChange={onNameChange}
348
+ placeholder="e.g., Acme Corp SSO"
349
+ hint="Human-readable name shown in the UI"
350
+ disabled={isLoading}
351
+ />
352
+
353
+ <FieldInput
354
+ id="stgm-idp-wiz-audience"
355
+ label="Expected audience"
356
+ value={audience}
357
+ onChange={onAudienceChange}
358
+ placeholder="stigmer-api"
359
+ hint="The aud claim value expected in JWTs from this provider"
360
+ disabled={isLoading}
361
+ />
362
+
363
+ {discoveryError && (
364
+ <p className="text-destructive text-[0.65rem]" role="alert">
365
+ {getUserMessage(discoveryError)}
366
+ </p>
367
+ )}
368
+
369
+ <div className="flex items-center gap-2 pt-1">
370
+ <button
371
+ type="button"
372
+ onClick={onContinue}
373
+ disabled={!canContinue}
374
+ className={cn(
375
+ "inline-flex items-center gap-1.5 rounded-md px-3 py-1.5 text-xs font-medium",
376
+ "bg-primary text-primary-foreground hover:bg-primary/90",
377
+ "disabled:pointer-events-none disabled:opacity-40",
378
+ )}
379
+ >
380
+ {isLoading && <SpinnerIcon />}
381
+ Continue
382
+ </button>
383
+ <TextButton onClick={onBack} disabled={isLoading}>
384
+ Back
385
+ </TextButton>
386
+ {onCancel && (
387
+ <CancelButton onClick={onCancel} disabled={isLoading} />
388
+ )}
389
+ </div>
390
+ </div>
391
+ );
392
+ }
393
+
394
+ // ---------------------------------------------------------------------------
395
+ // Review step (step 3)
396
+ // ---------------------------------------------------------------------------
397
+
398
+ function ReviewStep({
399
+ discoveryFailed,
400
+ jwksUri,
401
+ onJwksUriChange,
402
+ issuers,
403
+ onIssuersChange,
404
+ userinfoEndpoint,
405
+ onUserinfoEndpointChange,
406
+ isSso,
407
+ onIsSsoChange,
408
+ oidcClientId,
409
+ onOidcClientIdChange,
410
+ isCreating,
411
+ createError,
412
+ onBack,
413
+ onSubmit,
414
+ onCancel,
415
+ }: {
416
+ discoveryFailed: boolean;
417
+ jwksUri: string;
418
+ onJwksUriChange: (v: string) => void;
419
+ issuers: string;
420
+ onIssuersChange: (v: string) => void;
421
+ userinfoEndpoint: string;
422
+ onUserinfoEndpointChange: (v: string) => void;
423
+ isSso: boolean;
424
+ onIsSsoChange: (v: boolean) => void;
425
+ oidcClientId: string;
426
+ onOidcClientIdChange: (v: string) => void;
427
+ isCreating: boolean;
428
+ createError: Error | null;
429
+ onBack: () => void;
430
+ onSubmit: (e: FormEvent) => void;
431
+ onCancel?: () => void;
432
+ }) {
433
+ const canSubmit =
434
+ jwksUri.trim() !== "" &&
435
+ issuers.trim() !== "" &&
436
+ (!isSso || oidcClientId.trim() !== "") &&
437
+ !isCreating;
438
+
439
+ return (
440
+ <form onSubmit={onSubmit} className="space-y-3">
441
+ {discoveryFailed && (
442
+ <div
443
+ className="rounded-md border border-warning/30 bg-warning/5 px-3 py-2 text-xs text-warning-foreground"
444
+ role="alert"
445
+ >
446
+ Auto-discovery could not reach the provider. Enter the
447
+ configuration manually below.
448
+ </div>
449
+ )}
450
+
451
+ <p className="text-muted-foreground text-xs">
452
+ Review the OIDC configuration. All fields are editable.
453
+ </p>
454
+
455
+ <FieldInput
456
+ id="stgm-idp-wiz-jwks"
457
+ label="JWKS URI"
458
+ value={jwksUri}
459
+ onChange={onJwksUriChange}
460
+ placeholder="https://example.com/.well-known/jwks.json"
461
+ disabled={isCreating}
462
+ required
463
+ />
464
+
465
+ <FieldInput
466
+ id="stgm-idp-wiz-issuers"
467
+ label="Allowed issuers"
468
+ value={issuers}
469
+ onChange={onIssuersChange}
470
+ placeholder="https://issuer.example.com/"
471
+ hint="Comma-separated list of trusted JWT issuer values"
472
+ disabled={isCreating}
473
+ required
474
+ />
475
+
476
+ <FieldInput
477
+ id="stgm-idp-wiz-userinfo"
478
+ label="Userinfo endpoint"
479
+ value={userinfoEndpoint}
480
+ onChange={onUserinfoEndpointChange}
481
+ placeholder="https://example.com/userinfo"
482
+ hint="Optional — used to fetch user profile data during token exchange"
483
+ disabled={isCreating}
484
+ />
485
+
486
+ {/* SSO toggle */}
487
+ <div className="flex items-center gap-2">
488
+ <button
489
+ type="button"
490
+ role="switch"
491
+ aria-checked={isSso}
492
+ onClick={() => onIsSsoChange(!isSso)}
493
+ disabled={isCreating}
494
+ className={cn(
495
+ "relative inline-flex h-5 w-9 shrink-0 cursor-pointer rounded-full border-2 border-transparent transition-colors",
496
+ isSso ? "bg-primary" : "bg-muted",
497
+ "disabled:pointer-events-none disabled:opacity-50",
498
+ )}
499
+ >
500
+ <span
501
+ className={cn(
502
+ "pointer-events-none inline-block h-4 w-4 rounded-full bg-background shadow-sm ring-0 transition-transform",
503
+ isSso ? "translate-x-4" : "translate-x-0",
504
+ )}
505
+ />
506
+ </button>
507
+ <span className="text-xs font-medium text-foreground">
508
+ SSO provider
509
+ </span>
510
+ </div>
511
+
512
+ {isSso && (
513
+ <FieldInput
514
+ id="stgm-idp-wiz-client-id"
515
+ label="OIDC client ID"
516
+ value={oidcClientId}
517
+ onChange={onOidcClientIdChange}
518
+ placeholder="public-client-id"
519
+ hint="Client ID for the PKCE-based Authorization Code flow"
520
+ disabled={isCreating}
521
+ required
522
+ />
523
+ )}
524
+
525
+ {createError && (
526
+ <p className="text-destructive text-[0.65rem]" role="alert">
527
+ {getUserMessage(createError)}
528
+ </p>
529
+ )}
530
+
531
+ <div className="flex items-center gap-2 pt-1">
532
+ <button
533
+ type="submit"
534
+ disabled={!canSubmit}
535
+ className={cn(
536
+ "inline-flex items-center gap-1.5 rounded-md px-3 py-1.5 text-xs font-medium",
537
+ "bg-primary text-primary-foreground hover:bg-primary/90",
538
+ "disabled:pointer-events-none disabled:opacity-40",
539
+ )}
540
+ >
541
+ {isCreating && <SpinnerIcon />}
542
+ Create identity provider
543
+ </button>
544
+ <TextButton onClick={onBack} disabled={isCreating}>
545
+ Back
546
+ </TextButton>
547
+ {onCancel && (
548
+ <CancelButton onClick={onCancel} disabled={isCreating} />
549
+ )}
550
+ </div>
551
+ </form>
552
+ );
553
+ }
554
+
555
+ // ---------------------------------------------------------------------------
556
+ // Shared primitives
557
+ // ---------------------------------------------------------------------------
558
+
559
+ function FieldInput({
560
+ id,
561
+ label,
562
+ value,
563
+ onChange,
564
+ placeholder,
565
+ hint,
566
+ disabled,
567
+ required,
568
+ type = "text",
569
+ options,
570
+ }: {
571
+ id: string;
572
+ label: string;
573
+ value: string;
574
+ onChange: (v: string) => void;
575
+ placeholder: string;
576
+ hint?: string;
577
+ disabled?: boolean;
578
+ required?: boolean;
579
+ type?: "text" | "select";
580
+ options?: readonly { readonly value: string; readonly label: string }[];
581
+ }) {
582
+ return (
583
+ <div className="space-y-1">
584
+ <label htmlFor={id} className="text-xs font-medium text-foreground">
585
+ {label}
586
+ </label>
587
+ {type === "select" && options ? (
588
+ <select
589
+ id={id}
590
+ value={value}
591
+ onChange={(e) => onChange(e.target.value)}
592
+ disabled={disabled}
593
+ className={cn(
594
+ "w-full rounded-md border border-input bg-background px-2.5 py-1.5 text-xs text-foreground",
595
+ "focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring",
596
+ "disabled:pointer-events-none disabled:opacity-50",
597
+ )}
598
+ >
599
+ {options.map((opt) => (
600
+ <option key={opt.value} value={opt.value}>
601
+ {opt.label}
602
+ </option>
603
+ ))}
604
+ </select>
605
+ ) : (
606
+ <input
607
+ id={id}
608
+ type="text"
609
+ value={value}
610
+ onChange={(e) => onChange(e.target.value)}
611
+ placeholder={placeholder}
612
+ disabled={disabled}
613
+ required={required}
614
+ className={cn(
615
+ "w-full rounded-md border border-input bg-background px-2.5 py-1.5 text-xs text-foreground",
616
+ "placeholder:text-muted-foreground",
617
+ "focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring",
618
+ "disabled:pointer-events-none disabled:opacity-50",
619
+ )}
620
+ />
621
+ )}
622
+ {hint && (
623
+ <p className="text-[0.65rem] text-muted-foreground">{hint}</p>
624
+ )}
625
+ </div>
626
+ );
627
+ }
628
+
629
+ function TextButton({
630
+ onClick,
631
+ disabled,
632
+ children,
633
+ }: {
634
+ onClick: () => void;
635
+ disabled?: boolean;
636
+ children: React.ReactNode;
637
+ }) {
638
+ return (
639
+ <button
640
+ type="button"
641
+ onClick={onClick}
642
+ disabled={disabled}
643
+ className={cn(
644
+ "rounded-md px-2.5 py-1.5 text-xs",
645
+ "text-muted-foreground hover:text-foreground hover:bg-accent/50",
646
+ "disabled:pointer-events-none disabled:opacity-50",
647
+ )}
648
+ >
649
+ {children}
650
+ </button>
651
+ );
652
+ }
653
+
654
+ function CancelButton({
655
+ onClick,
656
+ disabled,
657
+ }: {
658
+ onClick: () => void;
659
+ disabled?: boolean;
660
+ }) {
661
+ return (
662
+ <TextButton onClick={onClick} disabled={disabled}>
663
+ Cancel
664
+ </TextButton>
665
+ );
666
+ }
667
+
668
+ function SpinnerIcon() {
669
+ return (
670
+ <svg
671
+ width="12"
672
+ height="12"
673
+ viewBox="0 0 16 16"
674
+ fill="none"
675
+ stroke="currentColor"
676
+ strokeWidth="2"
677
+ strokeLinecap="round"
678
+ className="animate-spin"
679
+ aria-hidden="true"
680
+ >
681
+ <path d="M8 2a6 6 0 1 0 6 6" />
682
+ </svg>
683
+ );
684
+ }