polen 0.10.0-next.10 → 0.10.0-next.12

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 (328) hide show
  1. package/build/api/builder/builder.js +1 -1
  2. package/build/api/builder/builder.js.map +1 -1
  3. package/build/api/config/load.js +1 -1
  4. package/build/api/config/load.js.map +1 -1
  5. package/build/api/vite/plugins/build.js +1 -1
  6. package/build/api/vite/plugins/build.js.map +1 -1
  7. package/build/api/vite/plugins/core.d.ts.map +1 -1
  8. package/build/api/vite/plugins/core.js +0 -2
  9. package/build/api/vite/plugins/core.js.map +1 -1
  10. package/build/api/vite/plugins/pages.js +1 -1
  11. package/build/api/vite/plugins/pages.js.map +1 -1
  12. package/build/exports/components.d.ts +4 -1
  13. package/build/exports/components.d.ts.map +1 -1
  14. package/build/exports/components.js +4 -1
  15. package/build/exports/components.js.map +1 -1
  16. package/build/lib/demos/config-schema.d.ts +6 -6
  17. package/build/lib/github-actions/runner.js +2 -2
  18. package/build/lib/github-actions/runner.js.map +1 -1
  19. package/build/lib/graphql-document/$$.d.ts +5 -0
  20. package/build/lib/graphql-document/$$.d.ts.map +1 -0
  21. package/build/lib/graphql-document/$$.js +5 -0
  22. package/build/lib/graphql-document/$$.js.map +1 -0
  23. package/build/lib/graphql-document/$.d.ts +2 -0
  24. package/build/lib/graphql-document/$.d.ts.map +1 -0
  25. package/build/lib/graphql-document/$.js +2 -0
  26. package/build/lib/graphql-document/$.js.map +1 -0
  27. package/build/lib/graphql-document/analysis.d.ts +44 -0
  28. package/build/lib/graphql-document/analysis.d.ts.map +1 -0
  29. package/build/lib/graphql-document/analysis.js +361 -0
  30. package/build/lib/graphql-document/analysis.js.map +1 -0
  31. package/build/lib/graphql-document/components/GraphQLDocument.d.ts +42 -0
  32. package/build/lib/graphql-document/components/GraphQLDocument.d.ts.map +1 -0
  33. package/build/lib/graphql-document/components/GraphQLDocument.js +173 -0
  34. package/build/lib/graphql-document/components/GraphQLDocument.js.map +1 -0
  35. package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.d.ts +7 -0
  36. package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.d.ts.map +1 -0
  37. package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.js +45 -0
  38. package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.js.map +1 -0
  39. package/build/lib/graphql-document/components/HoverTooltip.d.ts +35 -0
  40. package/build/lib/graphql-document/components/HoverTooltip.d.ts.map +1 -0
  41. package/build/lib/graphql-document/components/HoverTooltip.js +132 -0
  42. package/build/lib/graphql-document/components/HoverTooltip.js.map +1 -0
  43. package/build/lib/graphql-document/components/IdentifierLink.d.ts +37 -0
  44. package/build/lib/graphql-document/components/IdentifierLink.d.ts.map +1 -0
  45. package/build/lib/graphql-document/components/IdentifierLink.js +141 -0
  46. package/build/lib/graphql-document/components/IdentifierLink.js.map +1 -0
  47. package/build/lib/graphql-document/components/index.d.ts +5 -0
  48. package/build/lib/graphql-document/components/index.d.ts.map +1 -0
  49. package/build/lib/graphql-document/components/index.js +5 -0
  50. package/build/lib/graphql-document/components/index.js.map +1 -0
  51. package/build/lib/graphql-document/example.d.ts +25 -0
  52. package/build/lib/graphql-document/example.d.ts.map +1 -0
  53. package/build/lib/graphql-document/example.js +140 -0
  54. package/build/lib/graphql-document/example.js.map +1 -0
  55. package/build/lib/graphql-document/graphql-document.d.ts +35 -0
  56. package/build/lib/graphql-document/graphql-document.d.ts.map +1 -0
  57. package/build/lib/graphql-document/graphql-document.js +36 -0
  58. package/build/lib/graphql-document/graphql-document.js.map +1 -0
  59. package/build/lib/graphql-document/positioning-simple.d.ts +68 -0
  60. package/build/lib/graphql-document/positioning-simple.d.ts.map +1 -0
  61. package/build/lib/graphql-document/positioning-simple.js +197 -0
  62. package/build/lib/graphql-document/positioning-simple.js.map +1 -0
  63. package/build/lib/graphql-document/schema-context.d.ts +8 -0
  64. package/build/lib/graphql-document/schema-context.d.ts.map +1 -0
  65. package/build/lib/graphql-document/schema-context.js +11 -0
  66. package/build/lib/graphql-document/schema-context.js.map +1 -0
  67. package/build/lib/graphql-document/schema-integration-example.d.ts +27 -0
  68. package/build/lib/graphql-document/schema-integration-example.d.ts.map +1 -0
  69. package/build/lib/graphql-document/schema-integration-example.js +297 -0
  70. package/build/lib/graphql-document/schema-integration-example.js.map +1 -0
  71. package/build/lib/graphql-document/schema-integration.d.ts +135 -0
  72. package/build/lib/graphql-document/schema-integration.d.ts.map +1 -0
  73. package/build/lib/graphql-document/schema-integration.js +328 -0
  74. package/build/lib/graphql-document/schema-integration.js.map +1 -0
  75. package/build/lib/graphql-document/types.d.ts +117 -0
  76. package/build/lib/graphql-document/types.d.ts.map +1 -0
  77. package/build/lib/graphql-document/types.js +2 -0
  78. package/build/lib/graphql-document/types.js.map +1 -0
  79. package/build/template/components/ArgumentAnnotation.js +10 -0
  80. package/build/template/components/ArgumentAnnotation.js.map +1 -0
  81. package/build/template/components/ArgumentList.js +9 -0
  82. package/build/template/components/ArgumentList.js.map +1 -0
  83. package/build/template/components/ArgumentListAnnotation.js +15 -0
  84. package/build/template/components/ArgumentListAnnotation.js.map +1 -0
  85. package/build/template/components/Changelog.js +44 -0
  86. package/build/template/components/Changelog.js.map +1 -0
  87. package/build/template/components/{CodeBlock.jsx → CodeBlock.js} +4 -5
  88. package/build/template/components/{CodeBlock.jsx.map → CodeBlock.js.map} +1 -1
  89. package/build/template/components/CodeBlockEnhancer.d.ts +2 -0
  90. package/build/template/components/CodeBlockEnhancer.d.ts.map +1 -0
  91. package/build/template/components/CodeBlockEnhancer.js +175 -0
  92. package/build/template/components/CodeBlockEnhancer.js.map +1 -0
  93. package/build/template/components/DeprecationReason.js +9 -0
  94. package/build/template/components/DeprecationReason.js.map +1 -0
  95. package/build/template/components/Description.js +9 -0
  96. package/build/template/components/Description.js.map +1 -0
  97. package/build/template/components/Field.js +14 -0
  98. package/build/template/components/Field.js.map +1 -0
  99. package/build/template/components/{FieldList.jsx → FieldList.js} +4 -5
  100. package/build/template/components/FieldList.js.map +1 -0
  101. package/build/template/components/{FieldListSection.jsx → FieldListSection.js} +4 -6
  102. package/build/template/components/FieldListSection.js.map +1 -0
  103. package/build/template/components/HamburgerMenu.js +30 -0
  104. package/build/template/components/HamburgerMenu.js.map +1 -0
  105. package/build/template/components/Link.d.ts +1 -1
  106. package/build/template/components/{Link.jsx → Link.js} +4 -5
  107. package/build/template/components/Link.js.map +1 -0
  108. package/build/template/components/Logo.js +20 -0
  109. package/build/template/components/Logo.js.map +1 -0
  110. package/build/template/components/MDXComponents.d.ts +11 -0
  111. package/build/template/components/MDXComponents.d.ts.map +1 -0
  112. package/build/template/components/MDXComponents.js +70 -0
  113. package/build/template/components/MDXComponents.js.map +1 -0
  114. package/build/template/components/{Markdown.jsx → Markdown.js} +3 -2
  115. package/build/template/components/Markdown.js.map +1 -0
  116. package/build/template/components/MissingSchema.d.ts +1 -1
  117. package/build/template/components/MissingSchema.d.ts.map +1 -1
  118. package/build/template/components/MissingSchema.js +5 -0
  119. package/build/template/components/MissingSchema.js.map +1 -0
  120. package/build/template/components/NamedType.js +12 -0
  121. package/build/template/components/NamedType.js.map +1 -0
  122. package/build/template/components/NotFound.js +7 -0
  123. package/build/template/components/NotFound.js.map +1 -0
  124. package/build/template/components/{RadixLink.jsx → RadixLink.js} +1 -1
  125. package/build/template/components/RadixLink.js.map +1 -0
  126. package/build/template/components/TestComponent.d.ts +5 -0
  127. package/build/template/components/TestComponent.d.ts.map +1 -0
  128. package/build/template/components/TestComponent.js +7 -0
  129. package/build/template/components/TestComponent.js.map +1 -0
  130. package/build/template/components/Texts/{MinorHeading.jsx → MinorHeading.js} +4 -3
  131. package/build/template/components/Texts/MinorHeading.js.map +1 -0
  132. package/build/template/components/Texts/texts.js +1 -1
  133. package/build/template/components/Texts/texts.js.map +1 -1
  134. package/build/template/components/ThemeToggle.js +9 -0
  135. package/build/template/components/ThemeToggle.js.map +1 -0
  136. package/build/template/components/{TypeAnnotation.jsx → TypeAnnotation.js} +8 -18
  137. package/build/template/components/TypeAnnotation.js.map +1 -0
  138. package/build/template/components/TypeFieldsLinkList.js +9 -0
  139. package/build/template/components/TypeFieldsLinkList.js.map +1 -0
  140. package/build/template/components/TypeIndex.js +17 -0
  141. package/build/template/components/TypeIndex.js.map +1 -0
  142. package/build/template/components/content/$$.d.ts +1 -0
  143. package/build/template/components/content/$$.d.ts.map +1 -1
  144. package/build/template/components/content/$$.js +1 -0
  145. package/build/template/components/content/$$.js.map +1 -1
  146. package/build/template/components/content/GraphQLDocumentWithSchema.d.ts +8 -0
  147. package/build/template/components/content/GraphQLDocumentWithSchema.d.ts.map +1 -0
  148. package/build/template/components/content/GraphQLDocumentWithSchema.js +16 -0
  149. package/build/template/components/content/GraphQLDocumentWithSchema.js.map +1 -0
  150. package/build/template/components/content/GraphQLDocumentWrapper.d.ts +7 -0
  151. package/build/template/components/content/GraphQLDocumentWrapper.d.ts.map +1 -0
  152. package/build/template/components/content/GraphQLDocumentWrapper.js +62 -0
  153. package/build/template/components/content/GraphQLDocumentWrapper.js.map +1 -0
  154. package/build/template/components/graphql/graphql.d.ts +2 -2
  155. package/build/template/components/graphql/graphql.js +3 -0
  156. package/build/template/components/graphql/graphql.js.map +1 -0
  157. package/build/template/components/graphql/index.d.ts +1 -1
  158. package/build/template/components/graphql/index.js +1 -1
  159. package/build/template/components/graphql/index.js.map +1 -1
  160. package/build/template/components/graphql/{type-kind-icon.jsx → type-kind-icon.js} +3 -2
  161. package/build/template/components/graphql/type-kind-icon.js.map +1 -0
  162. package/build/template/components/graphql/type-link.js +11 -0
  163. package/build/template/components/graphql/type-link.js.map +1 -0
  164. package/build/template/components/sidebar/Sidebar.d.ts +1 -1
  165. package/build/template/components/sidebar/Sidebar.d.ts.map +1 -1
  166. package/build/template/components/sidebar/Sidebar.js +11 -0
  167. package/build/template/components/sidebar/Sidebar.js.map +1 -0
  168. package/build/template/components/sidebar/{SidebarItem.jsx → SidebarItem.js} +15 -32
  169. package/build/template/components/sidebar/SidebarItem.js.map +1 -0
  170. package/build/template/components/sidebar/ToggleButton.d.ts +1 -1
  171. package/build/template/components/sidebar/ToggleButton.d.ts.map +1 -1
  172. package/build/template/components/sidebar/ToggleButton.js +5 -0
  173. package/build/template/components/sidebar/ToggleButton.js.map +1 -0
  174. package/build/template/contexts/{ThemeContext.jsx → ThemeContext.js} +3 -4
  175. package/build/template/contexts/{ThemeContext.jsx.map → ThemeContext.js.map} +1 -1
  176. package/build/template/entry.client.d.ts +1 -0
  177. package/build/template/entry.client.d.ts.map +1 -1
  178. package/build/template/{entry.client.jsx → entry.client.js} +5 -6
  179. package/build/template/entry.client.js.map +1 -0
  180. package/build/template/routes/changelog.d.ts +1 -1
  181. package/build/template/routes/{changelog.jsx → changelog.js} +5 -4
  182. package/build/template/routes/changelog.js.map +1 -0
  183. package/build/template/routes/{index.jsx → index.js} +3 -2
  184. package/build/template/routes/index.js.map +1 -0
  185. package/build/template/routes/reference.$type.$field.d.ts +1 -1
  186. package/build/template/routes/{reference.$type.$field.jsx → reference.$type.$field.js} +6 -5
  187. package/build/template/routes/reference.$type.$field.js.map +1 -0
  188. package/build/template/routes/reference.$type.d.ts +1 -1
  189. package/build/template/routes/{reference.$type.jsx → reference.$type.js} +6 -5
  190. package/build/template/routes/reference.$type.js.map +1 -0
  191. package/build/template/routes/reference.d.ts +2 -2
  192. package/build/template/routes/reference.d.ts.map +1 -1
  193. package/build/template/routes/{reference.jsx → reference.js} +7 -12
  194. package/build/template/routes/reference.js.map +1 -0
  195. package/build/template/routes/root.d.ts +2 -2
  196. package/build/template/routes/root.d.ts.map +1 -1
  197. package/build/template/routes/root.js +286 -0
  198. package/build/template/routes/root.js.map +1 -0
  199. package/build/template/routes.js +5 -0
  200. package/build/template/routes.js.map +1 -0
  201. package/build/template/server/app.js +1 -1
  202. package/build/template/server/app.js.map +1 -1
  203. package/build/template/server/{render-page.jsx → render-page.js} +3 -4
  204. package/build/template/server/render-page.js.map +1 -0
  205. package/build/template/server/ssg/generate.js +1 -1
  206. package/build/template/server/ssg/generate.js.map +1 -1
  207. package/build/template/server/ssg/get-route-paths.js +1 -1
  208. package/build/template/server/ssg/get-route-paths.js.map +1 -1
  209. package/build/template/server/view.js +1 -1
  210. package/build/template/server/view.js.map +1 -1
  211. package/package.json +56 -8
  212. package/src/api/vite/plugins/core.ts +0 -3
  213. package/src/api/vite/plugins/pages.ts +1 -1
  214. package/src/exports/components.ts +4 -1
  215. package/src/lib/graphql-document/$$.ts +4 -0
  216. package/src/lib/graphql-document/$.test.ts +132 -0
  217. package/src/lib/graphql-document/$.ts +1 -0
  218. package/src/lib/graphql-document/README.md +102 -0
  219. package/src/lib/graphql-document/analysis.ts +415 -0
  220. package/src/lib/graphql-document/components/GraphQLDocument.tsx +284 -0
  221. package/src/lib/graphql-document/components/GraphQLDocument.unit.test.ts +188 -0
  222. package/src/lib/graphql-document/components/GraphQLDocumentWithSchema.tsx +70 -0
  223. package/src/lib/graphql-document/components/HoverTooltip.tsx +282 -0
  224. package/src/lib/graphql-document/components/IdentifierLink.tsx +221 -0
  225. package/src/lib/graphql-document/components/index.ts +4 -0
  226. package/src/lib/graphql-document/demo.md +155 -0
  227. package/src/lib/graphql-document/example.ts +163 -0
  228. package/src/lib/graphql-document/graphql-document.ts +37 -0
  229. package/src/lib/graphql-document/positioning-simple.test.ts +252 -0
  230. package/src/lib/graphql-document/positioning-simple.ts +271 -0
  231. package/src/lib/graphql-document/schema-context.tsx +20 -0
  232. package/src/lib/graphql-document/schema-integration-example.ts +341 -0
  233. package/src/lib/graphql-document/schema-integration.test.ts +365 -0
  234. package/src/lib/graphql-document/schema-integration.ts +497 -0
  235. package/src/lib/graphql-document/types.ts +129 -0
  236. package/src/template/components/ArgumentAnnotation.tsx +1 -1
  237. package/src/template/components/ArgumentList.tsx +1 -1
  238. package/src/template/components/ArgumentListAnnotation.tsx +2 -2
  239. package/src/template/components/CodeBlockEnhancer.tsx +192 -0
  240. package/src/template/components/DeprecationReason.tsx +1 -1
  241. package/src/template/components/Description.tsx +1 -1
  242. package/src/template/components/Field.tsx +4 -4
  243. package/src/template/components/FieldList.tsx +1 -1
  244. package/src/template/components/FieldListSection.tsx +1 -1
  245. package/src/template/components/Link.tsx +2 -2
  246. package/src/template/components/MDXComponents.tsx +101 -0
  247. package/src/template/components/NamedType.tsx +2 -2
  248. package/src/template/components/TestComponent.tsx +6 -0
  249. package/src/template/components/TypeAnnotation.tsx +1 -1
  250. package/src/template/components/TypeFieldsLinkList.tsx +1 -1
  251. package/src/template/components/TypeIndex.tsx +1 -1
  252. package/src/template/components/content/$$.ts +1 -0
  253. package/src/template/components/content/GraphQLDocumentWithSchema.tsx +18 -0
  254. package/src/template/components/content/GraphQLDocumentWrapper.tsx +82 -0
  255. package/src/template/components/graphql/graphql.tsx +2 -2
  256. package/src/template/components/graphql/index.ts +1 -1
  257. package/src/template/components/graphql/type-link.tsx +2 -2
  258. package/src/template/components/sidebar/SidebarItem.tsx +4 -4
  259. package/src/template/entry.client.tsx +2 -2
  260. package/src/template/routes/changelog.tsx +1 -1
  261. package/src/template/routes/reference.$type.$field.tsx +3 -3
  262. package/src/template/routes/reference.$type.tsx +3 -3
  263. package/src/template/routes/reference.tsx +6 -10
  264. package/src/template/routes/root.tsx +145 -5
  265. package/src/template/routes.tsx +1 -1
  266. package/src/template/server/app.ts +1 -1
  267. package/src/template/server/ssg/generate.ts +1 -1
  268. package/src/template/server/ssg/get-route-paths.ts +1 -1
  269. package/src/template/server/view.ts +1 -1
  270. package/src/template/styles/code-block.css +32 -0
  271. package/build/template/components/ArgumentAnnotation.jsx +0 -16
  272. package/build/template/components/ArgumentAnnotation.jsx.map +0 -1
  273. package/build/template/components/ArgumentList.jsx +0 -16
  274. package/build/template/components/ArgumentList.jsx.map +0 -1
  275. package/build/template/components/ArgumentListAnnotation.jsx +0 -23
  276. package/build/template/components/ArgumentListAnnotation.jsx.map +0 -1
  277. package/build/template/components/Changelog.jsx +0 -68
  278. package/build/template/components/Changelog.jsx.map +0 -1
  279. package/build/template/components/DeprecationReason.jsx +0 -10
  280. package/build/template/components/DeprecationReason.jsx.map +0 -1
  281. package/build/template/components/Description.jsx +0 -10
  282. package/build/template/components/Description.jsx.map +0 -1
  283. package/build/template/components/Field.jsx +0 -22
  284. package/build/template/components/Field.jsx.map +0 -1
  285. package/build/template/components/FieldList.jsx.map +0 -1
  286. package/build/template/components/FieldListSection.jsx.map +0 -1
  287. package/build/template/components/HamburgerMenu.jsx +0 -53
  288. package/build/template/components/HamburgerMenu.jsx.map +0 -1
  289. package/build/template/components/Link.jsx.map +0 -1
  290. package/build/template/components/Logo.jsx +0 -29
  291. package/build/template/components/Logo.jsx.map +0 -1
  292. package/build/template/components/Markdown.jsx.map +0 -1
  293. package/build/template/components/MissingSchema.jsx +0 -4
  294. package/build/template/components/MissingSchema.jsx.map +0 -1
  295. package/build/template/components/NamedType.jsx +0 -17
  296. package/build/template/components/NamedType.jsx.map +0 -1
  297. package/build/template/components/NotFound.jsx +0 -26
  298. package/build/template/components/NotFound.jsx.map +0 -1
  299. package/build/template/components/RadixLink.jsx.map +0 -1
  300. package/build/template/components/Texts/MinorHeading.jsx.map +0 -1
  301. package/build/template/components/ThemeToggle.jsx +0 -10
  302. package/build/template/components/ThemeToggle.jsx.map +0 -1
  303. package/build/template/components/TypeAnnotation.jsx.map +0 -1
  304. package/build/template/components/TypeFieldsLinkList.jsx +0 -17
  305. package/build/template/components/TypeFieldsLinkList.jsx.map +0 -1
  306. package/build/template/components/TypeIndex.jsx +0 -27
  307. package/build/template/components/TypeIndex.jsx.map +0 -1
  308. package/build/template/components/graphql/graphql.jsx +0 -3
  309. package/build/template/components/graphql/graphql.jsx.map +0 -1
  310. package/build/template/components/graphql/type-kind-icon.jsx.map +0 -1
  311. package/build/template/components/graphql/type-link.jsx +0 -16
  312. package/build/template/components/graphql/type-link.jsx.map +0 -1
  313. package/build/template/components/sidebar/Sidebar.jsx +0 -15
  314. package/build/template/components/sidebar/Sidebar.jsx.map +0 -1
  315. package/build/template/components/sidebar/SidebarItem.jsx.map +0 -1
  316. package/build/template/components/sidebar/ToggleButton.jsx +0 -6
  317. package/build/template/components/sidebar/ToggleButton.jsx.map +0 -1
  318. package/build/template/entry.client.jsx.map +0 -1
  319. package/build/template/routes/changelog.jsx.map +0 -1
  320. package/build/template/routes/index.jsx.map +0 -1
  321. package/build/template/routes/reference.$type.$field.jsx.map +0 -1
  322. package/build/template/routes/reference.$type.jsx.map +0 -1
  323. package/build/template/routes/reference.jsx.map +0 -1
  324. package/build/template/routes/root.jsx +0 -204
  325. package/build/template/routes/root.jsx.map +0 -1
  326. package/build/template/routes.jsx +0 -5
  327. package/build/template/routes.jsx.map +0 -1
  328. package/build/template/server/render-page.jsx.map +0 -1
@@ -0,0 +1,221 @@
1
+ import type { React } from '#dep/react/index'
2
+ import { useState } from 'react'
3
+ import type { DOMPosition } from '../positioning-simple.ts'
4
+ import type { SchemaResolution } from '../schema-integration.ts'
5
+ import type { Identifier } from '../types.ts'
6
+ import { HoverTooltip } from './HoverTooltip.tsx'
7
+
8
+ /**
9
+ * Props for the IdentifierLink component
10
+ */
11
+ export interface IdentifierLinkProps {
12
+ /** The GraphQL identifier */
13
+ identifier: Identifier
14
+ /** Schema resolution information */
15
+ resolution: SchemaResolution
16
+ /** DOM position for overlay placement */
17
+ position: DOMPosition
18
+ /** Navigation handler */
19
+ onNavigate: (url: string) => void
20
+ /** Whether to show debug visuals */
21
+ debug?: boolean
22
+ /** Whether this tooltip is open */
23
+ isOpen?: boolean
24
+ /** Toggle tooltip open state */
25
+ onToggle?: (open: boolean) => void
26
+ }
27
+
28
+ /**
29
+ * Interactive overlay for a GraphQL identifier
30
+ *
31
+ * Renders an invisible clickable area over the identifier text
32
+ * with hover tooltips and navigation to schema reference pages.
33
+ */
34
+ export const IdentifierLink: React.FC<IdentifierLinkProps> = ({
35
+ identifier,
36
+ resolution,
37
+ position,
38
+ onNavigate,
39
+ debug = false,
40
+ isOpen = false,
41
+ onToggle,
42
+ }) => {
43
+ const [isHovered, setIsHovered] = useState(false)
44
+
45
+ // Use external state if provided, otherwise manage locally
46
+ const showTooltip = isOpen
47
+ const setShowTooltip = (show: boolean) => {
48
+ onToggle?.(show)
49
+ }
50
+
51
+ // Determine visual state
52
+ const isClickable = resolution.exists
53
+ const hasError = !resolution.exists && (identifier.kind === 'Type' || identifier.kind === 'Field')
54
+ const isDeprecated = !!resolution.deprecated
55
+
56
+ // Build class names
57
+ const classNames = [
58
+ 'graphql-identifier-overlay',
59
+ `graphql-${identifier.kind.toLowerCase()}`,
60
+ isClickable && 'graphql-clickable',
61
+ hasError && 'graphql-error',
62
+ isDeprecated && 'graphql-deprecated',
63
+ isHovered && 'graphql-hovered',
64
+ showTooltip && 'graphql-tooltip-open',
65
+ debug && 'graphql-debug',
66
+ ].filter(Boolean).join(' ')
67
+
68
+ const handleClick = (e: React.MouseEvent) => {
69
+ e.preventDefault()
70
+ e.stopPropagation()
71
+
72
+ // Toggle tooltip on click
73
+ setShowTooltip(!showTooltip)
74
+ }
75
+
76
+ const handleNavigate = (e: React.MouseEvent) => {
77
+ e.preventDefault()
78
+ e.stopPropagation()
79
+ if (isClickable) {
80
+ onNavigate(resolution.referenceUrl)
81
+ }
82
+ }
83
+
84
+ return (
85
+ <>
86
+ {isClickable
87
+ ? (
88
+ <a
89
+ href={resolution.referenceUrl}
90
+ className={classNames + ' graphql-identifier-link'}
91
+ style={{
92
+ position: 'absolute',
93
+ top: position.top,
94
+ left: position.left,
95
+ width: position.width,
96
+ height: position.height,
97
+ cursor: 'pointer',
98
+ zIndex: 10,
99
+ pointerEvents: 'auto',
100
+ display: 'block',
101
+ textDecoration: 'none',
102
+ // Debug mode visual
103
+ ...(debug && {
104
+ backgroundColor: hasError ? 'rgba(239, 68, 68, 0.1)' : 'rgba(59, 130, 246, 0.1)',
105
+ border: `1px solid ${hasError ? 'rgba(239, 68, 68, 0.3)' : 'rgba(59, 130, 246, 0.3)'}`,
106
+ }),
107
+ }}
108
+ onClick={handleClick}
109
+ onMouseEnter={() => setIsHovered(true)}
110
+ onMouseLeave={() => setIsHovered(false)}
111
+ aria-label={`${identifier.kind} ${identifier.name} - Click to view documentation`}
112
+ data-graphql-identifier={identifier.name}
113
+ data-graphql-kind={identifier.kind}
114
+ />
115
+ )
116
+ : (
117
+ <div
118
+ className={classNames}
119
+ style={{
120
+ position: 'absolute',
121
+ top: position.top,
122
+ left: position.left,
123
+ width: position.width,
124
+ height: position.height,
125
+ cursor: 'pointer', // Make it clickable even for errors
126
+ zIndex: 10,
127
+ pointerEvents: 'auto',
128
+ // Debug mode visual
129
+ ...(debug && {
130
+ backgroundColor: 'rgba(239, 68, 68, 0.1)',
131
+ border: `1px solid rgba(239, 68, 68, 0.3)`,
132
+ }),
133
+ }}
134
+ onClick={handleClick} // Add click handler for errors too
135
+ onMouseEnter={() => setIsHovered(true)}
136
+ onMouseLeave={() => setIsHovered(false)}
137
+ role='button'
138
+ aria-label={`${identifier.kind} ${identifier.name} - Click to view information`}
139
+ data-graphql-identifier={identifier.name}
140
+ data-graphql-kind={identifier.kind}
141
+ />
142
+ )}
143
+
144
+ {/* Tooltip - show on click, not hover */}
145
+ {showTooltip && (
146
+ <HoverTooltip
147
+ identifier={identifier}
148
+ documentation={resolution.documentation || {
149
+ description: hasError
150
+ ? `${identifier.kind} "${identifier.name}" not found in schema. This ${identifier.kind.toLowerCase()} does not exist in the current GraphQL schema.`
151
+ : `${identifier.kind}: ${identifier.name}`,
152
+ typeInfo: identifier.kind,
153
+ }}
154
+ position={position}
155
+ hasError={hasError}
156
+ referenceUrl={resolution.referenceUrl}
157
+ onClose={() => setShowTooltip(false)}
158
+ onNavigate={isClickable ? () => onNavigate(resolution.referenceUrl) : undefined}
159
+ />
160
+ )}
161
+ </>
162
+ )
163
+ }
164
+
165
+ /**
166
+ * Default styles for identifier overlays
167
+ *
168
+ * These can be included in the document or overridden by custom styles.
169
+ */
170
+ export const identifierLinkStyles = `
171
+ .graphql-identifier-overlay {
172
+ /* Base styles for all overlays */
173
+ transition: background-color 0.2s ease;
174
+ }
175
+
176
+ .graphql-identifier-overlay.graphql-clickable:hover {
177
+ /* Subtle highlight on hover for clickable identifiers */
178
+ background-color: rgba(59, 130, 246, 0.05);
179
+ }
180
+
181
+ .graphql-identifier-overlay.graphql-error {
182
+ /* Error indicator */
183
+ border-bottom: 2px wavy red;
184
+ }
185
+
186
+ .graphql-identifier-overlay.graphql-deprecated {
187
+ /* Deprecated indicator */
188
+ text-decoration: line-through;
189
+ opacity: 0.7;
190
+ }
191
+
192
+ .graphql-identifier-overlay.graphql-debug {
193
+ /* Debug mode makes overlays visible */
194
+ background-color: rgba(59, 130, 246, 0.1) !important;
195
+ border: 1px solid rgba(59, 130, 246, 0.3) !important;
196
+ }
197
+
198
+ /* Kind-specific styles */
199
+ .graphql-identifier-overlay.graphql-type {
200
+ /* Type identifiers */
201
+ }
202
+
203
+ .graphql-identifier-overlay.graphql-field {
204
+ /* Field identifiers */
205
+ }
206
+
207
+ .graphql-identifier-overlay.graphql-argument {
208
+ /* Argument identifiers */
209
+ font-style: italic;
210
+ }
211
+
212
+ .graphql-identifier-overlay.graphql-variable {
213
+ /* Variable identifiers */
214
+ color: var(--purple-11);
215
+ }
216
+
217
+ .graphql-identifier-overlay.graphql-directive {
218
+ /* Directive identifiers */
219
+ color: var(--amber-11);
220
+ }
221
+ `
@@ -0,0 +1,4 @@
1
+ export * from './GraphQLDocument.tsx'
2
+ export * from './GraphQLDocumentWithSchema.tsx'
3
+ export * from './HoverTooltip.tsx'
4
+ export * from './IdentifierLink.tsx'
@@ -0,0 +1,155 @@
1
+ # GraphQL Document Component Demo
2
+
3
+ This page demonstrates the interactive GraphQL Document component that transforms static code blocks into rich, interactive documentation.
4
+
5
+ ## Basic Query Example
6
+
7
+ Hover over the identifiers below to see type information and documentation. Click on types and fields to navigate to their reference pages.
8
+
9
+ ```graphql
10
+ query GetUser($id: ID!) {
11
+ user(id: $id) {
12
+ id
13
+ name
14
+ email
15
+ posts(first: 10) {
16
+ id
17
+ title
18
+ content
19
+ author {
20
+ name
21
+ }
22
+ }
23
+ }
24
+ }
25
+ ```
26
+
27
+ ## Mutation Example
28
+
29
+ This mutation creates a new post. Notice how the component provides information about input types and return values.
30
+
31
+ ```graphql
32
+ mutation CreatePost($input: CreatePostInput!) {
33
+ createPost(input: $input) {
34
+ id
35
+ title
36
+ content
37
+ createdAt
38
+ author {
39
+ id
40
+ name
41
+ }
42
+ }
43
+ }
44
+ ```
45
+
46
+ ## Subscription Example
47
+
48
+ Subscriptions work the same way - all GraphQL operations are fully interactive.
49
+
50
+ ```graphql
51
+ subscription OnCommentAdded($postId: ID!) {
52
+ commentAdded(postId: $postId) {
53
+ id
54
+ content
55
+ author {
56
+ name
57
+ avatar
58
+ }
59
+ createdAt
60
+ }
61
+ }
62
+ ```
63
+
64
+ ## Fragment Example
65
+
66
+ Fragments are also supported with full type information and navigation.
67
+
68
+ ```graphql
69
+ fragment UserInfo on User {
70
+ id
71
+ name
72
+ email
73
+ profile {
74
+ bio
75
+ avatar
76
+ website
77
+ }
78
+ }
79
+
80
+ query GetUserWithFragment($id: ID!) {
81
+ user(id: $id) {
82
+ ...UserInfo
83
+ posts {
84
+ id
85
+ title
86
+ }
87
+ }
88
+ }
89
+ ```
90
+
91
+ ## Error Handling
92
+
93
+ The component validates GraphQL against the schema and highlights errors. Try hovering over the invalid field below:
94
+
95
+ ```graphql
96
+ query InvalidQuery {
97
+ user {
98
+ nonExistentField
99
+ name
100
+ }
101
+ }
102
+ ```
103
+
104
+ ## Plain Mode
105
+
106
+ Sometimes you want to show GraphQL without interactivity. Use the `plain` option:
107
+
108
+ ```graphql plain
109
+ query SimpleQuery {
110
+ users {
111
+ name
112
+ }
113
+ }
114
+ ```
115
+
116
+ ## Debug Mode
117
+
118
+ Enable debug mode to see the overlay boundaries:
119
+
120
+ ```graphql debug
121
+ query DebugExample {
122
+ user {
123
+ id
124
+ name
125
+ }
126
+ }
127
+ ```
128
+
129
+ ## Features
130
+
131
+ The GraphQL Document component provides:
132
+
133
+ - **Interactive Navigation**: Click on any type or field to navigate to its reference documentation
134
+ - **Hover Tooltips**: See type information, descriptions, and deprecation warnings
135
+ - **Schema Validation**: Invalid queries are highlighted with error messages
136
+ - **Syntax Highlighting**: Beautiful syntax highlighting with Shiki
137
+ - **Smart Positioning**: Tooltips automatically position themselves to stay within the viewport
138
+ - **Accessibility**: Full keyboard navigation and screen reader support
139
+
140
+ ## Configuration Options
141
+
142
+ ```graphql validate=false
143
+ # This query won't be validated at build time
144
+ query {
145
+ anything {
146
+ goes
147
+ }
148
+ }
149
+ ```
150
+
151
+ Available options:
152
+
153
+ - `plain` - Disable all interactive features
154
+ - `debug` - Show overlay boundaries for debugging
155
+ - `validate=false` - Skip validation for this block
@@ -0,0 +1,163 @@
1
+ /**
2
+ * Example usage of the GraphQL Document Analysis library
3
+ *
4
+ * This demonstrates how to use the foundational layer for extracting
5
+ * identifiers and context from GraphQL documents - the building block
6
+ * for the interactive GraphQL Document Component.
7
+ */
8
+
9
+ import { GraphQLDocument } from './$.ts'
10
+
11
+ // Example GraphQL query with various constructs
12
+ const exampleQuery = `
13
+ query GetPokemonWithAbilities($id: ID!, $limit: Int = 10) {
14
+ pokemon(id: $id) {
15
+ name
16
+ abilities(first: $limit) {
17
+ name
18
+ isHidden
19
+ pokemon {
20
+ name
21
+ }
22
+ }
23
+ ... on ElectricPokemon {
24
+ voltage
25
+ }
26
+ }
27
+ }
28
+
29
+ fragment PokemonBasics on Pokemon {
30
+ name
31
+ type
32
+ level
33
+ }
34
+ `
35
+
36
+ /**
37
+ * Demonstrate basic analysis
38
+ */
39
+ export const analyzeExample = () => {
40
+ console.log('🔍 Analyzing GraphQL Document...\n')
41
+
42
+ const result = GraphQLDocument.analyze(exampleQuery)
43
+
44
+ console.log(`✅ Valid: ${result.isValid}`)
45
+ console.log(`📊 Total identifiers: ${result.identifiers.all.length}`)
46
+ console.log(`🚨 Errors: ${result.errors.length}\n`)
47
+
48
+ // Show identifiers by kind
49
+ for (const [kind, identifiers] of result.identifiers.byKind) {
50
+ console.log(`${getKindEmoji(kind)} ${kind} (${identifiers.length}):`)
51
+ for (const identifier of identifiers) {
52
+ const pos = `${identifier.position.line}:${identifier.position.column}`
53
+ const path = identifier.schemaPath.join(' → ')
54
+ const parent = identifier.parentType ? ` (in ${identifier.parentType})` : ''
55
+ console.log(` • ${identifier.name}${parent} → ${path} @ ${pos}`)
56
+ }
57
+ console.log()
58
+ }
59
+
60
+ return result
61
+ }
62
+
63
+ /**
64
+ * Demonstrate identifier lookup by position
65
+ */
66
+ export const demonstratePositionLookup = () => {
67
+ console.log('📍 Position-based Identifier Lookup...\n')
68
+
69
+ const identifiers = GraphQLDocument.extractIdentifiers(exampleQuery)
70
+
71
+ // Find identifier at a specific position (e.g., cursor position in an editor)
72
+ const targetPosition = 180 // Approximate position of "abilities" field
73
+
74
+ // Find the closest identifier to this position
75
+ let closestIdentifier = null
76
+ let closestDistance = Infinity
77
+
78
+ for (const identifier of identifiers.all) {
79
+ const distance = Math.abs(identifier.position.start - targetPosition)
80
+ if (distance < closestDistance) {
81
+ closestDistance = distance
82
+ closestIdentifier = identifier
83
+ }
84
+ }
85
+
86
+ if (closestIdentifier) {
87
+ console.log(`🎯 Identifier near position ${targetPosition}:`)
88
+ console.log(` Name: ${closestIdentifier.name}`)
89
+ console.log(` Kind: ${closestIdentifier.kind}`)
90
+ console.log(` Schema Path: ${closestIdentifier.schemaPath.join(' → ')}`)
91
+ console.log(` Context: ${JSON.stringify(closestIdentifier.context, null, 2)}`)
92
+ }
93
+ }
94
+
95
+ /**
96
+ * Demonstrate how this enables hyperlink generation
97
+ */
98
+ export const demonstrateHyperlinkGeneration = () => {
99
+ console.log('🔗 Hyperlink Generation Preview...\n')
100
+
101
+ const identifiers = GraphQLDocument.extractIdentifiers(exampleQuery)
102
+
103
+ // Show how each identifier could become a hyperlink
104
+ const typeIdentifiers = identifiers.byKind.get('Type') || []
105
+ const fieldIdentifiers = identifiers.byKind.get('Field') || []
106
+
107
+ console.log('📝 Type References → Schema Links:')
108
+ for (const identifier of typeIdentifiers) {
109
+ const referenceUrl = `/reference/${identifier.name}`
110
+ console.log(` ${identifier.name} → ${referenceUrl}`)
111
+ }
112
+
113
+ console.log('\n📝 Field References → Schema Links:')
114
+ for (const identifier of fieldIdentifiers.slice(0, 5)) { // Show first 5
115
+ const referenceUrl = identifier.parentType
116
+ ? `/reference/${identifier.parentType}#${identifier.name}`
117
+ : `/reference/${identifier.name}`
118
+ console.log(` ${identifier.name} → ${referenceUrl}`)
119
+ }
120
+ }
121
+
122
+ /**
123
+ * Show the foundation for hover tooltips
124
+ */
125
+ export const demonstrateTooltipFoundation = () => {
126
+ console.log('💬 Tooltip Foundation...\n')
127
+
128
+ const identifiers = GraphQLDocument.extractIdentifiers(exampleQuery)
129
+
130
+ // Show context information that would be displayed in tooltips
131
+ const fieldIdentifiers = identifiers.byKind.get('Field') || []
132
+
133
+ for (const identifier of fieldIdentifiers.slice(0, 3)) { // Show first 3
134
+ console.log(`🏷️ ${identifier.name}:`)
135
+ console.log(` Position: Line ${identifier.position.line}, Column ${identifier.position.column}`)
136
+ console.log(` Schema Path: ${identifier.schemaPath.join(' → ')}`)
137
+ console.log(` Parent Type: ${identifier.parentType || 'Root'}`)
138
+ console.log(` Operation: ${identifier.context.operationType || 'None'}`)
139
+ console.log(` Selection Path: ${identifier.context.selectionPath.join(' → ')}`)
140
+ console.log()
141
+ }
142
+ }
143
+
144
+ // Helper function
145
+ function getKindEmoji(kind: string): string {
146
+ const emojis: Record<string, string> = {
147
+ 'Type': '🏷️',
148
+ 'Field': '📋',
149
+ 'Argument': '⚙️',
150
+ 'Variable': '💰',
151
+ 'Directive': '🎯',
152
+ 'Fragment': '🧩',
153
+ }
154
+ return emojis[kind] || '❓'
155
+ }
156
+
157
+ // Run example if executed directly
158
+ if (import.meta.url === `file://${process.argv[1]}`) {
159
+ analyzeExample()
160
+ demonstratePositionLookup()
161
+ demonstrateHyperlinkGeneration()
162
+ demonstrateTooltipFoundation()
163
+ }
@@ -0,0 +1,37 @@
1
+ /**
2
+ * GraphQL Document Component Library
3
+ *
4
+ * Transform static GraphQL code blocks into interactive documentation with
5
+ * hyperlinks, tooltips, and schema validation.
6
+ *
7
+ * ## Features
8
+ * - Hyperlinked identifiers that navigate to reference documentation
9
+ * - Hover tooltips showing type information and descriptions
10
+ * - Schema validation with error highlighting
11
+ * - Build-time GraphQL validation
12
+ * - Support for all GraphQL operations (queries, mutations, subscriptions, fragments)
13
+ *
14
+ * ## Usage
15
+ * ```typescript
16
+ * import { GraphQLDocument } from 'polen/lib/graphql-document'
17
+ *
18
+ * <GraphQLDocument schema={schema}>
19
+ * {`query { user { name } }`}
20
+ * </GraphQLDocument>
21
+ * ```
22
+ *
23
+ * @see {@link GraphQLDocumentWithSchema} for MDX integration
24
+ * @see {@link GraphQLDocument} for the main React component
25
+ */
26
+
27
+ export * from './analysis.ts'
28
+ export * from './components/index.ts'
29
+ export * from './positioning-simple.ts'
30
+ export * from './schema-integration.ts'
31
+ export * from './types.ts'
32
+
33
+ // Re-export key functions for convenience
34
+ export { analyze, analyzer, extractIdentifiers } from './analysis.ts'
35
+ export { GraphQLDocument } from './components/GraphQLDocument.tsx'
36
+ export { createSimpleOverlay, createSimplePositionCalculator } from './positioning-simple.ts'
37
+ export { analyzeWithSchema, createPolenSchemaResolver } from './schema-integration.ts'