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.
- package/build/api/builder/builder.js +1 -1
- package/build/api/builder/builder.js.map +1 -1
- package/build/api/config/load.js +1 -1
- package/build/api/config/load.js.map +1 -1
- package/build/api/vite/plugins/build.js +1 -1
- package/build/api/vite/plugins/build.js.map +1 -1
- package/build/api/vite/plugins/core.d.ts.map +1 -1
- package/build/api/vite/plugins/core.js +0 -2
- package/build/api/vite/plugins/core.js.map +1 -1
- package/build/api/vite/plugins/pages.js +1 -1
- package/build/api/vite/plugins/pages.js.map +1 -1
- package/build/exports/components.d.ts +4 -1
- package/build/exports/components.d.ts.map +1 -1
- package/build/exports/components.js +4 -1
- package/build/exports/components.js.map +1 -1
- package/build/lib/demos/config-schema.d.ts +6 -6
- package/build/lib/github-actions/runner.js +2 -2
- package/build/lib/github-actions/runner.js.map +1 -1
- package/build/lib/graphql-document/$$.d.ts +5 -0
- package/build/lib/graphql-document/$$.d.ts.map +1 -0
- package/build/lib/graphql-document/$$.js +5 -0
- package/build/lib/graphql-document/$$.js.map +1 -0
- package/build/lib/graphql-document/$.d.ts +2 -0
- package/build/lib/graphql-document/$.d.ts.map +1 -0
- package/build/lib/graphql-document/$.js +2 -0
- package/build/lib/graphql-document/$.js.map +1 -0
- package/build/lib/graphql-document/analysis.d.ts +44 -0
- package/build/lib/graphql-document/analysis.d.ts.map +1 -0
- package/build/lib/graphql-document/analysis.js +361 -0
- package/build/lib/graphql-document/analysis.js.map +1 -0
- package/build/lib/graphql-document/components/GraphQLDocument.d.ts +42 -0
- package/build/lib/graphql-document/components/GraphQLDocument.d.ts.map +1 -0
- package/build/lib/graphql-document/components/GraphQLDocument.js +173 -0
- package/build/lib/graphql-document/components/GraphQLDocument.js.map +1 -0
- package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.d.ts +7 -0
- package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.d.ts.map +1 -0
- package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.js +45 -0
- package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.js.map +1 -0
- package/build/lib/graphql-document/components/HoverTooltip.d.ts +35 -0
- package/build/lib/graphql-document/components/HoverTooltip.d.ts.map +1 -0
- package/build/lib/graphql-document/components/HoverTooltip.js +132 -0
- package/build/lib/graphql-document/components/HoverTooltip.js.map +1 -0
- package/build/lib/graphql-document/components/IdentifierLink.d.ts +37 -0
- package/build/lib/graphql-document/components/IdentifierLink.d.ts.map +1 -0
- package/build/lib/graphql-document/components/IdentifierLink.js +141 -0
- package/build/lib/graphql-document/components/IdentifierLink.js.map +1 -0
- package/build/lib/graphql-document/components/index.d.ts +5 -0
- package/build/lib/graphql-document/components/index.d.ts.map +1 -0
- package/build/lib/graphql-document/components/index.js +5 -0
- package/build/lib/graphql-document/components/index.js.map +1 -0
- package/build/lib/graphql-document/example.d.ts +25 -0
- package/build/lib/graphql-document/example.d.ts.map +1 -0
- package/build/lib/graphql-document/example.js +140 -0
- package/build/lib/graphql-document/example.js.map +1 -0
- package/build/lib/graphql-document/graphql-document.d.ts +35 -0
- package/build/lib/graphql-document/graphql-document.d.ts.map +1 -0
- package/build/lib/graphql-document/graphql-document.js +36 -0
- package/build/lib/graphql-document/graphql-document.js.map +1 -0
- package/build/lib/graphql-document/positioning-simple.d.ts +68 -0
- package/build/lib/graphql-document/positioning-simple.d.ts.map +1 -0
- package/build/lib/graphql-document/positioning-simple.js +197 -0
- package/build/lib/graphql-document/positioning-simple.js.map +1 -0
- package/build/lib/graphql-document/schema-context.d.ts +8 -0
- package/build/lib/graphql-document/schema-context.d.ts.map +1 -0
- package/build/lib/graphql-document/schema-context.js +11 -0
- package/build/lib/graphql-document/schema-context.js.map +1 -0
- package/build/lib/graphql-document/schema-integration-example.d.ts +27 -0
- package/build/lib/graphql-document/schema-integration-example.d.ts.map +1 -0
- package/build/lib/graphql-document/schema-integration-example.js +297 -0
- package/build/lib/graphql-document/schema-integration-example.js.map +1 -0
- package/build/lib/graphql-document/schema-integration.d.ts +135 -0
- package/build/lib/graphql-document/schema-integration.d.ts.map +1 -0
- package/build/lib/graphql-document/schema-integration.js +328 -0
- package/build/lib/graphql-document/schema-integration.js.map +1 -0
- package/build/lib/graphql-document/types.d.ts +117 -0
- package/build/lib/graphql-document/types.d.ts.map +1 -0
- package/build/lib/graphql-document/types.js +2 -0
- package/build/lib/graphql-document/types.js.map +1 -0
- package/build/template/components/ArgumentAnnotation.js +10 -0
- package/build/template/components/ArgumentAnnotation.js.map +1 -0
- package/build/template/components/ArgumentList.js +9 -0
- package/build/template/components/ArgumentList.js.map +1 -0
- package/build/template/components/ArgumentListAnnotation.js +15 -0
- package/build/template/components/ArgumentListAnnotation.js.map +1 -0
- package/build/template/components/Changelog.js +44 -0
- package/build/template/components/Changelog.js.map +1 -0
- package/build/template/components/{CodeBlock.jsx → CodeBlock.js} +4 -5
- package/build/template/components/{CodeBlock.jsx.map → CodeBlock.js.map} +1 -1
- package/build/template/components/CodeBlockEnhancer.d.ts +2 -0
- package/build/template/components/CodeBlockEnhancer.d.ts.map +1 -0
- package/build/template/components/CodeBlockEnhancer.js +175 -0
- package/build/template/components/CodeBlockEnhancer.js.map +1 -0
- package/build/template/components/DeprecationReason.js +9 -0
- package/build/template/components/DeprecationReason.js.map +1 -0
- package/build/template/components/Description.js +9 -0
- package/build/template/components/Description.js.map +1 -0
- package/build/template/components/Field.js +14 -0
- package/build/template/components/Field.js.map +1 -0
- package/build/template/components/{FieldList.jsx → FieldList.js} +4 -5
- package/build/template/components/FieldList.js.map +1 -0
- package/build/template/components/{FieldListSection.jsx → FieldListSection.js} +4 -6
- package/build/template/components/FieldListSection.js.map +1 -0
- package/build/template/components/HamburgerMenu.js +30 -0
- package/build/template/components/HamburgerMenu.js.map +1 -0
- package/build/template/components/Link.d.ts +1 -1
- package/build/template/components/{Link.jsx → Link.js} +4 -5
- package/build/template/components/Link.js.map +1 -0
- package/build/template/components/Logo.js +20 -0
- package/build/template/components/Logo.js.map +1 -0
- package/build/template/components/MDXComponents.d.ts +11 -0
- package/build/template/components/MDXComponents.d.ts.map +1 -0
- package/build/template/components/MDXComponents.js +70 -0
- package/build/template/components/MDXComponents.js.map +1 -0
- package/build/template/components/{Markdown.jsx → Markdown.js} +3 -2
- package/build/template/components/Markdown.js.map +1 -0
- package/build/template/components/MissingSchema.d.ts +1 -1
- package/build/template/components/MissingSchema.d.ts.map +1 -1
- package/build/template/components/MissingSchema.js +5 -0
- package/build/template/components/MissingSchema.js.map +1 -0
- package/build/template/components/NamedType.js +12 -0
- package/build/template/components/NamedType.js.map +1 -0
- package/build/template/components/NotFound.js +7 -0
- package/build/template/components/NotFound.js.map +1 -0
- package/build/template/components/{RadixLink.jsx → RadixLink.js} +1 -1
- package/build/template/components/RadixLink.js.map +1 -0
- package/build/template/components/TestComponent.d.ts +5 -0
- package/build/template/components/TestComponent.d.ts.map +1 -0
- package/build/template/components/TestComponent.js +7 -0
- package/build/template/components/TestComponent.js.map +1 -0
- package/build/template/components/Texts/{MinorHeading.jsx → MinorHeading.js} +4 -3
- package/build/template/components/Texts/MinorHeading.js.map +1 -0
- package/build/template/components/Texts/texts.js +1 -1
- package/build/template/components/Texts/texts.js.map +1 -1
- package/build/template/components/ThemeToggle.js +9 -0
- package/build/template/components/ThemeToggle.js.map +1 -0
- package/build/template/components/{TypeAnnotation.jsx → TypeAnnotation.js} +8 -18
- package/build/template/components/TypeAnnotation.js.map +1 -0
- package/build/template/components/TypeFieldsLinkList.js +9 -0
- package/build/template/components/TypeFieldsLinkList.js.map +1 -0
- package/build/template/components/TypeIndex.js +17 -0
- package/build/template/components/TypeIndex.js.map +1 -0
- package/build/template/components/content/$$.d.ts +1 -0
- package/build/template/components/content/$$.d.ts.map +1 -1
- package/build/template/components/content/$$.js +1 -0
- package/build/template/components/content/$$.js.map +1 -1
- package/build/template/components/content/GraphQLDocumentWithSchema.d.ts +8 -0
- package/build/template/components/content/GraphQLDocumentWithSchema.d.ts.map +1 -0
- package/build/template/components/content/GraphQLDocumentWithSchema.js +16 -0
- package/build/template/components/content/GraphQLDocumentWithSchema.js.map +1 -0
- package/build/template/components/content/GraphQLDocumentWrapper.d.ts +7 -0
- package/build/template/components/content/GraphQLDocumentWrapper.d.ts.map +1 -0
- package/build/template/components/content/GraphQLDocumentWrapper.js +62 -0
- package/build/template/components/content/GraphQLDocumentWrapper.js.map +1 -0
- package/build/template/components/graphql/graphql.d.ts +2 -2
- package/build/template/components/graphql/graphql.js +3 -0
- package/build/template/components/graphql/graphql.js.map +1 -0
- package/build/template/components/graphql/index.d.ts +1 -1
- package/build/template/components/graphql/index.js +1 -1
- package/build/template/components/graphql/index.js.map +1 -1
- package/build/template/components/graphql/{type-kind-icon.jsx → type-kind-icon.js} +3 -2
- package/build/template/components/graphql/type-kind-icon.js.map +1 -0
- package/build/template/components/graphql/type-link.js +11 -0
- package/build/template/components/graphql/type-link.js.map +1 -0
- package/build/template/components/sidebar/Sidebar.d.ts +1 -1
- package/build/template/components/sidebar/Sidebar.d.ts.map +1 -1
- package/build/template/components/sidebar/Sidebar.js +11 -0
- package/build/template/components/sidebar/Sidebar.js.map +1 -0
- package/build/template/components/sidebar/{SidebarItem.jsx → SidebarItem.js} +15 -32
- package/build/template/components/sidebar/SidebarItem.js.map +1 -0
- package/build/template/components/sidebar/ToggleButton.d.ts +1 -1
- package/build/template/components/sidebar/ToggleButton.d.ts.map +1 -1
- package/build/template/components/sidebar/ToggleButton.js +5 -0
- package/build/template/components/sidebar/ToggleButton.js.map +1 -0
- package/build/template/contexts/{ThemeContext.jsx → ThemeContext.js} +3 -4
- package/build/template/contexts/{ThemeContext.jsx.map → ThemeContext.js.map} +1 -1
- package/build/template/entry.client.d.ts +1 -0
- package/build/template/entry.client.d.ts.map +1 -1
- package/build/template/{entry.client.jsx → entry.client.js} +5 -6
- package/build/template/entry.client.js.map +1 -0
- package/build/template/routes/changelog.d.ts +1 -1
- package/build/template/routes/{changelog.jsx → changelog.js} +5 -4
- package/build/template/routes/changelog.js.map +1 -0
- package/build/template/routes/{index.jsx → index.js} +3 -2
- package/build/template/routes/index.js.map +1 -0
- package/build/template/routes/reference.$type.$field.d.ts +1 -1
- package/build/template/routes/{reference.$type.$field.jsx → reference.$type.$field.js} +6 -5
- package/build/template/routes/reference.$type.$field.js.map +1 -0
- package/build/template/routes/reference.$type.d.ts +1 -1
- package/build/template/routes/{reference.$type.jsx → reference.$type.js} +6 -5
- package/build/template/routes/reference.$type.js.map +1 -0
- package/build/template/routes/reference.d.ts +2 -2
- package/build/template/routes/reference.d.ts.map +1 -1
- package/build/template/routes/{reference.jsx → reference.js} +7 -12
- package/build/template/routes/reference.js.map +1 -0
- package/build/template/routes/root.d.ts +2 -2
- package/build/template/routes/root.d.ts.map +1 -1
- package/build/template/routes/root.js +286 -0
- package/build/template/routes/root.js.map +1 -0
- package/build/template/routes.js +5 -0
- package/build/template/routes.js.map +1 -0
- package/build/template/server/app.js +1 -1
- package/build/template/server/app.js.map +1 -1
- package/build/template/server/{render-page.jsx → render-page.js} +3 -4
- package/build/template/server/render-page.js.map +1 -0
- package/build/template/server/ssg/generate.js +1 -1
- package/build/template/server/ssg/generate.js.map +1 -1
- package/build/template/server/ssg/get-route-paths.js +1 -1
- package/build/template/server/ssg/get-route-paths.js.map +1 -1
- package/build/template/server/view.js +1 -1
- package/build/template/server/view.js.map +1 -1
- package/package.json +56 -8
- package/src/api/vite/plugins/core.ts +0 -3
- package/src/api/vite/plugins/pages.ts +1 -1
- package/src/exports/components.ts +4 -1
- package/src/lib/graphql-document/$$.ts +4 -0
- package/src/lib/graphql-document/$.test.ts +132 -0
- package/src/lib/graphql-document/$.ts +1 -0
- package/src/lib/graphql-document/README.md +102 -0
- package/src/lib/graphql-document/analysis.ts +415 -0
- package/src/lib/graphql-document/components/GraphQLDocument.tsx +284 -0
- package/src/lib/graphql-document/components/GraphQLDocument.unit.test.ts +188 -0
- package/src/lib/graphql-document/components/GraphQLDocumentWithSchema.tsx +70 -0
- package/src/lib/graphql-document/components/HoverTooltip.tsx +282 -0
- package/src/lib/graphql-document/components/IdentifierLink.tsx +221 -0
- package/src/lib/graphql-document/components/index.ts +4 -0
- package/src/lib/graphql-document/demo.md +155 -0
- package/src/lib/graphql-document/example.ts +163 -0
- package/src/lib/graphql-document/graphql-document.ts +37 -0
- package/src/lib/graphql-document/positioning-simple.test.ts +252 -0
- package/src/lib/graphql-document/positioning-simple.ts +271 -0
- package/src/lib/graphql-document/schema-context.tsx +20 -0
- package/src/lib/graphql-document/schema-integration-example.ts +341 -0
- package/src/lib/graphql-document/schema-integration.test.ts +365 -0
- package/src/lib/graphql-document/schema-integration.ts +497 -0
- package/src/lib/graphql-document/types.ts +129 -0
- package/src/template/components/ArgumentAnnotation.tsx +1 -1
- package/src/template/components/ArgumentList.tsx +1 -1
- package/src/template/components/ArgumentListAnnotation.tsx +2 -2
- package/src/template/components/CodeBlockEnhancer.tsx +192 -0
- package/src/template/components/DeprecationReason.tsx +1 -1
- package/src/template/components/Description.tsx +1 -1
- package/src/template/components/Field.tsx +4 -4
- package/src/template/components/FieldList.tsx +1 -1
- package/src/template/components/FieldListSection.tsx +1 -1
- package/src/template/components/Link.tsx +2 -2
- package/src/template/components/MDXComponents.tsx +101 -0
- package/src/template/components/NamedType.tsx +2 -2
- package/src/template/components/TestComponent.tsx +6 -0
- package/src/template/components/TypeAnnotation.tsx +1 -1
- package/src/template/components/TypeFieldsLinkList.tsx +1 -1
- package/src/template/components/TypeIndex.tsx +1 -1
- package/src/template/components/content/$$.ts +1 -0
- package/src/template/components/content/GraphQLDocumentWithSchema.tsx +18 -0
- package/src/template/components/content/GraphQLDocumentWrapper.tsx +82 -0
- package/src/template/components/graphql/graphql.tsx +2 -2
- package/src/template/components/graphql/index.ts +1 -1
- package/src/template/components/graphql/type-link.tsx +2 -2
- package/src/template/components/sidebar/SidebarItem.tsx +4 -4
- package/src/template/entry.client.tsx +2 -2
- package/src/template/routes/changelog.tsx +1 -1
- package/src/template/routes/reference.$type.$field.tsx +3 -3
- package/src/template/routes/reference.$type.tsx +3 -3
- package/src/template/routes/reference.tsx +6 -10
- package/src/template/routes/root.tsx +145 -5
- package/src/template/routes.tsx +1 -1
- package/src/template/server/app.ts +1 -1
- package/src/template/server/ssg/generate.ts +1 -1
- package/src/template/server/ssg/get-route-paths.ts +1 -1
- package/src/template/server/view.ts +1 -1
- package/src/template/styles/code-block.css +32 -0
- package/build/template/components/ArgumentAnnotation.jsx +0 -16
- package/build/template/components/ArgumentAnnotation.jsx.map +0 -1
- package/build/template/components/ArgumentList.jsx +0 -16
- package/build/template/components/ArgumentList.jsx.map +0 -1
- package/build/template/components/ArgumentListAnnotation.jsx +0 -23
- package/build/template/components/ArgumentListAnnotation.jsx.map +0 -1
- package/build/template/components/Changelog.jsx +0 -68
- package/build/template/components/Changelog.jsx.map +0 -1
- package/build/template/components/DeprecationReason.jsx +0 -10
- package/build/template/components/DeprecationReason.jsx.map +0 -1
- package/build/template/components/Description.jsx +0 -10
- package/build/template/components/Description.jsx.map +0 -1
- package/build/template/components/Field.jsx +0 -22
- package/build/template/components/Field.jsx.map +0 -1
- package/build/template/components/FieldList.jsx.map +0 -1
- package/build/template/components/FieldListSection.jsx.map +0 -1
- package/build/template/components/HamburgerMenu.jsx +0 -53
- package/build/template/components/HamburgerMenu.jsx.map +0 -1
- package/build/template/components/Link.jsx.map +0 -1
- package/build/template/components/Logo.jsx +0 -29
- package/build/template/components/Logo.jsx.map +0 -1
- package/build/template/components/Markdown.jsx.map +0 -1
- package/build/template/components/MissingSchema.jsx +0 -4
- package/build/template/components/MissingSchema.jsx.map +0 -1
- package/build/template/components/NamedType.jsx +0 -17
- package/build/template/components/NamedType.jsx.map +0 -1
- package/build/template/components/NotFound.jsx +0 -26
- package/build/template/components/NotFound.jsx.map +0 -1
- package/build/template/components/RadixLink.jsx.map +0 -1
- package/build/template/components/Texts/MinorHeading.jsx.map +0 -1
- package/build/template/components/ThemeToggle.jsx +0 -10
- package/build/template/components/ThemeToggle.jsx.map +0 -1
- package/build/template/components/TypeAnnotation.jsx.map +0 -1
- package/build/template/components/TypeFieldsLinkList.jsx +0 -17
- package/build/template/components/TypeFieldsLinkList.jsx.map +0 -1
- package/build/template/components/TypeIndex.jsx +0 -27
- package/build/template/components/TypeIndex.jsx.map +0 -1
- package/build/template/components/graphql/graphql.jsx +0 -3
- package/build/template/components/graphql/graphql.jsx.map +0 -1
- package/build/template/components/graphql/type-kind-icon.jsx.map +0 -1
- package/build/template/components/graphql/type-link.jsx +0 -16
- package/build/template/components/graphql/type-link.jsx.map +0 -1
- package/build/template/components/sidebar/Sidebar.jsx +0 -15
- package/build/template/components/sidebar/Sidebar.jsx.map +0 -1
- package/build/template/components/sidebar/SidebarItem.jsx.map +0 -1
- package/build/template/components/sidebar/ToggleButton.jsx +0 -6
- package/build/template/components/sidebar/ToggleButton.jsx.map +0 -1
- package/build/template/entry.client.jsx.map +0 -1
- package/build/template/routes/changelog.jsx.map +0 -1
- package/build/template/routes/index.jsx.map +0 -1
- package/build/template/routes/reference.$type.$field.jsx.map +0 -1
- package/build/template/routes/reference.$type.jsx.map +0 -1
- package/build/template/routes/reference.jsx.map +0 -1
- package/build/template/routes/root.jsx +0 -204
- package/build/template/routes/root.jsx.map +0 -1
- package/build/template/routes.jsx +0 -5
- package/build/template/routes.jsx.map +0 -1
- 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,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'
|