@prismicio/react 2.9.0 → 3.0.0-alpha.0

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 (191) hide show
  1. package/README.md +10 -11
  2. package/dist/PrismicImage.d.ts +18 -633
  3. package/dist/PrismicImage.js +32 -33
  4. package/dist/PrismicImage.js.map +1 -1
  5. package/dist/PrismicLink.d.ts +77 -6
  6. package/dist/PrismicLink.js +42 -7
  7. package/dist/PrismicLink.js.map +1 -1
  8. package/dist/PrismicRichText.d.ts +117 -4
  9. package/dist/PrismicRichText.js +74 -8
  10. package/dist/PrismicRichText.js.map +1 -1
  11. package/dist/PrismicText.d.ts +8 -13
  12. package/dist/PrismicText.js +15 -16
  13. package/dist/PrismicText.js.map +1 -1
  14. package/dist/PrismicToolbar.d.ts +2 -12
  15. package/dist/PrismicToolbar.js +8 -10
  16. package/dist/PrismicToolbar.js.map +1 -1
  17. package/dist/SliceZone.d.ts +16 -70
  18. package/dist/SliceZone.js +16 -37
  19. package/dist/SliceZone.js.map +1 -1
  20. package/dist/index.d.ts +13 -21
  21. package/dist/index.js +2 -29
  22. package/dist/index.js.map +1 -1
  23. package/dist/lib/devMsg.d.ts +2 -2
  24. package/dist/lib/devMsg.js +2 -2
  25. package/dist/lib/devMsg.js.map +1 -1
  26. package/dist/package.json.js +1 -1
  27. package/package.json +53 -70
  28. package/src/PrismicImage.tsx +80 -65
  29. package/src/PrismicLink.tsx +196 -26
  30. package/src/PrismicRichText.tsx +333 -33
  31. package/src/PrismicText.tsx +25 -30
  32. package/src/PrismicToolbar.tsx +10 -30
  33. package/src/SliceZone.tsx +58 -150
  34. package/src/index.ts +17 -53
  35. package/src/lib/devMsg.ts +3 -3
  36. package/dist/PrismicImage.cjs +0 -68
  37. package/dist/PrismicImage.cjs.map +0 -1
  38. package/dist/PrismicLink.cjs +0 -29
  39. package/dist/PrismicLink.cjs.map +0 -1
  40. package/dist/PrismicProvider.cjs +0 -41
  41. package/dist/PrismicProvider.cjs.map +0 -1
  42. package/dist/PrismicProvider.d.ts +0 -83
  43. package/dist/PrismicProvider.js +0 -24
  44. package/dist/PrismicProvider.js.map +0 -1
  45. package/dist/PrismicRichText.cjs +0 -30
  46. package/dist/PrismicRichText.cjs.map +0 -1
  47. package/dist/PrismicText.cjs +0 -44
  48. package/dist/PrismicText.cjs.map +0 -1
  49. package/dist/PrismicToolbar.cjs +0 -43
  50. package/dist/PrismicToolbar.cjs.map +0 -1
  51. package/dist/SliceZone.cjs +0 -53
  52. package/dist/SliceZone.cjs.map +0 -1
  53. package/dist/_node_modules/@prismicio/client/dist/errors/PrismicError.cjs +0 -16
  54. package/dist/_node_modules/@prismicio/client/dist/errors/PrismicError.cjs.map +0 -1
  55. package/dist/_node_modules/@prismicio/client/dist/errors/PrismicError.js +0 -16
  56. package/dist/_node_modules/@prismicio/client/dist/errors/PrismicError.js.map +0 -1
  57. package/dist/_node_modules/@prismicio/client/dist/getToolbarSrc.cjs +0 -13
  58. package/dist/_node_modules/@prismicio/client/dist/getToolbarSrc.cjs.map +0 -1
  59. package/dist/_node_modules/@prismicio/client/dist/getToolbarSrc.js +0 -13
  60. package/dist/_node_modules/@prismicio/client/dist/getToolbarSrc.js.map +0 -1
  61. package/dist/_node_modules/@prismicio/client/dist/helpers/asImagePixelDensitySrcSet.cjs +0 -22
  62. package/dist/_node_modules/@prismicio/client/dist/helpers/asImagePixelDensitySrcSet.cjs.map +0 -1
  63. package/dist/_node_modules/@prismicio/client/dist/helpers/asImagePixelDensitySrcSet.js +0 -22
  64. package/dist/_node_modules/@prismicio/client/dist/helpers/asImagePixelDensitySrcSet.js.map +0 -1
  65. package/dist/_node_modules/@prismicio/client/dist/helpers/asImageWidthSrcSet.cjs +0 -46
  66. package/dist/_node_modules/@prismicio/client/dist/helpers/asImageWidthSrcSet.cjs.map +0 -1
  67. package/dist/_node_modules/@prismicio/client/dist/helpers/asImageWidthSrcSet.js +0 -46
  68. package/dist/_node_modules/@prismicio/client/dist/helpers/asImageWidthSrcSet.js.map +0 -1
  69. package/dist/_node_modules/@prismicio/client/dist/helpers/asLink.cjs +0 -47
  70. package/dist/_node_modules/@prismicio/client/dist/helpers/asLink.cjs.map +0 -1
  71. package/dist/_node_modules/@prismicio/client/dist/helpers/asLink.js +0 -47
  72. package/dist/_node_modules/@prismicio/client/dist/helpers/asLink.js.map +0 -1
  73. package/dist/_node_modules/@prismicio/client/dist/helpers/asLinkAttrs.cjs +0 -28
  74. package/dist/_node_modules/@prismicio/client/dist/helpers/asLinkAttrs.cjs.map +0 -1
  75. package/dist/_node_modules/@prismicio/client/dist/helpers/asLinkAttrs.js +0 -28
  76. package/dist/_node_modules/@prismicio/client/dist/helpers/asLinkAttrs.js.map +0 -1
  77. package/dist/_node_modules/@prismicio/client/dist/helpers/asText.cjs +0 -21
  78. package/dist/_node_modules/@prismicio/client/dist/helpers/asText.cjs.map +0 -1
  79. package/dist/_node_modules/@prismicio/client/dist/helpers/asText.js +0 -21
  80. package/dist/_node_modules/@prismicio/client/dist/helpers/asText.js.map +0 -1
  81. package/dist/_node_modules/@prismicio/client/dist/helpers/documentToLinkField.cjs +0 -27
  82. package/dist/_node_modules/@prismicio/client/dist/helpers/documentToLinkField.cjs.map +0 -1
  83. package/dist/_node_modules/@prismicio/client/dist/helpers/documentToLinkField.js +0 -27
  84. package/dist/_node_modules/@prismicio/client/dist/helpers/documentToLinkField.js.map +0 -1
  85. package/dist/_node_modules/@prismicio/client/dist/helpers/isFilled.cjs +0 -24
  86. package/dist/_node_modules/@prismicio/client/dist/helpers/isFilled.cjs.map +0 -1
  87. package/dist/_node_modules/@prismicio/client/dist/helpers/isFilled.js +0 -24
  88. package/dist/_node_modules/@prismicio/client/dist/helpers/isFilled.js.map +0 -1
  89. package/dist/_node_modules/@prismicio/client/dist/isRepositoryName.cjs +0 -7
  90. package/dist/_node_modules/@prismicio/client/dist/isRepositoryName.cjs.map +0 -1
  91. package/dist/_node_modules/@prismicio/client/dist/isRepositoryName.js +0 -7
  92. package/dist/_node_modules/@prismicio/client/dist/isRepositoryName.js.map +0 -1
  93. package/dist/_node_modules/@prismicio/client/dist/lib/isInternalURL.cjs +0 -9
  94. package/dist/_node_modules/@prismicio/client/dist/lib/isInternalURL.cjs.map +0 -1
  95. package/dist/_node_modules/@prismicio/client/dist/lib/isInternalURL.js +0 -9
  96. package/dist/_node_modules/@prismicio/client/dist/lib/isInternalURL.js.map +0 -1
  97. package/dist/_node_modules/@prismicio/client/dist/richtext/asText.cjs +0 -13
  98. package/dist/_node_modules/@prismicio/client/dist/richtext/asText.cjs.map +0 -1
  99. package/dist/_node_modules/@prismicio/client/dist/richtext/asText.js +0 -13
  100. package/dist/_node_modules/@prismicio/client/dist/richtext/asText.js.map +0 -1
  101. package/dist/_node_modules/@prismicio/client/dist/types/value/link.cjs +0 -10
  102. package/dist/_node_modules/@prismicio/client/dist/types/value/link.cjs.map +0 -1
  103. package/dist/_node_modules/@prismicio/client/dist/types/value/link.js +0 -10
  104. package/dist/_node_modules/@prismicio/client/dist/types/value/link.js.map +0 -1
  105. package/dist/_node_modules/imgix-url-builder/dist/buildPixelDensitySrcSet.cjs +0 -10
  106. package/dist/_node_modules/imgix-url-builder/dist/buildPixelDensitySrcSet.cjs.map +0 -1
  107. package/dist/_node_modules/imgix-url-builder/dist/buildPixelDensitySrcSet.js +0 -10
  108. package/dist/_node_modules/imgix-url-builder/dist/buildPixelDensitySrcSet.js.map +0 -1
  109. package/dist/_node_modules/imgix-url-builder/dist/buildURL.cjs +0 -29
  110. package/dist/_node_modules/imgix-url-builder/dist/buildURL.cjs.map +0 -1
  111. package/dist/_node_modules/imgix-url-builder/dist/buildURL.js +0 -29
  112. package/dist/_node_modules/imgix-url-builder/dist/buildURL.js.map +0 -1
  113. package/dist/_node_modules/imgix-url-builder/dist/buildWidthSrcSet.cjs +0 -10
  114. package/dist/_node_modules/imgix-url-builder/dist/buildWidthSrcSet.cjs.map +0 -1
  115. package/dist/_node_modules/imgix-url-builder/dist/buildWidthSrcSet.js +0 -10
  116. package/dist/_node_modules/imgix-url-builder/dist/buildWidthSrcSet.js.map +0 -1
  117. package/dist/clientHooks.cjs +0 -40
  118. package/dist/clientHooks.cjs.map +0 -1
  119. package/dist/clientHooks.d.ts +0 -321
  120. package/dist/clientHooks.js +0 -40
  121. package/dist/clientHooks.js.map +0 -1
  122. package/dist/index.cjs +0 -48
  123. package/dist/index.cjs.map +0 -1
  124. package/dist/lib/devMsg.cjs +0 -8
  125. package/dist/lib/devMsg.cjs.map +0 -1
  126. package/dist/lib/isInternalURL.cjs +0 -9
  127. package/dist/lib/isInternalURL.cjs.map +0 -1
  128. package/dist/lib/isInternalURL.d.ts +0 -8
  129. package/dist/lib/isInternalURL.js +0 -9
  130. package/dist/lib/isInternalURL.js.map +0 -1
  131. package/dist/lib/pascalCase.cjs +0 -10
  132. package/dist/lib/pascalCase.cjs.map +0 -1
  133. package/dist/lib/pascalCase.d.ts +0 -26
  134. package/dist/lib/pascalCase.js +0 -10
  135. package/dist/lib/pascalCase.js.map +0 -1
  136. package/dist/package.json.cjs +0 -5
  137. package/dist/package.json.cjs.map +0 -1
  138. package/dist/react-server/PrismicLink.cjs +0 -59
  139. package/dist/react-server/PrismicLink.cjs.map +0 -1
  140. package/dist/react-server/PrismicLink.d.ts +0 -77
  141. package/dist/react-server/PrismicLink.js +0 -42
  142. package/dist/react-server/PrismicLink.js.map +0 -1
  143. package/dist/react-server/PrismicRichText.cjs +0 -97
  144. package/dist/react-server/PrismicRichText.cjs.map +0 -1
  145. package/dist/react-server/PrismicRichText.d.ts +0 -104
  146. package/dist/react-server/PrismicRichText.js +0 -79
  147. package/dist/react-server/PrismicRichText.js.map +0 -1
  148. package/dist/react-server/index.d.ts +0 -4
  149. package/dist/react-server/unsupported.cjs +0 -97
  150. package/dist/react-server/unsupported.cjs.map +0 -1
  151. package/dist/react-server/unsupported.d.ts +0 -22
  152. package/dist/react-server/unsupported.js +0 -97
  153. package/dist/react-server/unsupported.js.map +0 -1
  154. package/dist/react-server.cjs +0 -44
  155. package/dist/react-server.cjs.map +0 -1
  156. package/dist/react-server.js +0 -41
  157. package/dist/react-server.js.map +0 -1
  158. package/dist/types.d.ts +0 -19
  159. package/dist/usePrismicClient.cjs +0 -13
  160. package/dist/usePrismicClient.cjs.map +0 -1
  161. package/dist/usePrismicClient.d.ts +0 -11
  162. package/dist/usePrismicClient.js +0 -13
  163. package/dist/usePrismicClient.js.map +0 -1
  164. package/dist/usePrismicContext.cjs +0 -26
  165. package/dist/usePrismicContext.cjs.map +0 -1
  166. package/dist/usePrismicContext.d.ts +0 -8
  167. package/dist/usePrismicContext.js +0 -9
  168. package/dist/usePrismicContext.js.map +0 -1
  169. package/dist/usePrismicPreviewResolver.cjs +0 -44
  170. package/dist/usePrismicPreviewResolver.cjs.map +0 -1
  171. package/dist/usePrismicPreviewResolver.d.ts +0 -45
  172. package/dist/usePrismicPreviewResolver.js +0 -27
  173. package/dist/usePrismicPreviewResolver.js.map +0 -1
  174. package/dist/useStatefulPrismicClientMethod.cjs +0 -91
  175. package/dist/useStatefulPrismicClientMethod.cjs.map +0 -1
  176. package/dist/useStatefulPrismicClientMethod.d.ts +0 -44
  177. package/dist/useStatefulPrismicClientMethod.js +0 -74
  178. package/dist/useStatefulPrismicClientMethod.js.map +0 -1
  179. package/src/PrismicProvider.tsx +0 -132
  180. package/src/clientHooks.ts +0 -472
  181. package/src/lib/isInternalURL.ts +0 -14
  182. package/src/lib/pascalCase.ts +0 -79
  183. package/src/react-server/PrismicLink.tsx +0 -197
  184. package/src/react-server/PrismicRichText.tsx +0 -283
  185. package/src/react-server/index.ts +0 -38
  186. package/src/react-server/unsupported.ts +0 -184
  187. package/src/types.ts +0 -23
  188. package/src/usePrismicClient.ts +0 -30
  189. package/src/usePrismicContext.ts +0 -13
  190. package/src/usePrismicPreviewResolver.ts +0 -93
  191. package/src/useStatefulPrismicClientMethod.ts +0 -196
@@ -1,197 +0,0 @@
1
- import * as React from "react";
2
- import {
3
- LinkField,
4
- LinkResolverFunction,
5
- PrismicDocument,
6
- asLinkAttrs,
7
- AsLinkAttrsConfig,
8
- } from "@prismicio/client";
9
-
10
- import { devMsg } from "../lib/devMsg";
11
- import { isInternalURL } from "../lib/isInternalURL";
12
-
13
- /**
14
- * The default component rendered for internal and external links.
15
- */
16
- export const defaultComponent = "a";
17
-
18
- /**
19
- * Props provided to a component when rendered with `<PrismicLink>`.
20
- */
21
- export interface LinkProps {
22
- /**
23
- * The URL to link.
24
- */
25
- href: string;
26
-
27
- /**
28
- * The `target` attribute for anchor elements. If the Prismic field is
29
- * configured to open in a new window, this prop defaults to `_blank`.
30
- */
31
- target?: React.HTMLAttributeAnchorTarget;
32
-
33
- /**
34
- * The `rel` attribute for anchor elements. If the `target` prop is set to
35
- * `"_blank"`, this prop defaults to `"noopener noreferrer"`.
36
- */
37
- rel?: string;
38
-
39
- /**
40
- * Children for the component. *
41
- */
42
- children?: React.ReactNode;
43
- }
44
-
45
- export type PrismicLinkProps<
46
- InternalComponentProps = React.ComponentProps<typeof defaultComponent>,
47
- ExternalComponentProps = React.ComponentProps<typeof defaultComponent>,
48
- > = Omit<
49
- InternalComponentProps & ExternalComponentProps,
50
- "rel" | "href" | "children"
51
- > & {
52
- /**
53
- * The `rel` attribute for the link. By default, `"noreferrer"` is provided if
54
- * the link's URL is external. This prop can be provided a function to use the
55
- * link's metadata to determine the `rel` value.
56
- */
57
- rel?: string | AsLinkAttrsConfig["rel"];
58
-
59
- /**
60
- * The Link Resolver used to resolve links.
61
- *
62
- * @remarks
63
- * If your app uses Route Resolvers when querying for your Prismic
64
- * repository's content, a Link Resolver does not need to be provided.
65
- * @see Learn about Link Resolvers and Route Resolvers {@link https://prismic.io/docs/core-concepts/link-resolver-route-resolver}
66
- */
67
- linkResolver?: LinkResolverFunction;
68
-
69
- /**
70
- * The component rendered for internal URLs. Defaults to `<a>`.
71
- *
72
- * If your app uses a client-side router that requires a special Link
73
- * component, provide the Link component to this prop.
74
- */
75
- internalComponent?: React.ElementType<InternalComponentProps>;
76
-
77
- /**
78
- * The component rendered for external URLs. Defaults to `<a>`.
79
- */
80
- externalComponent?: React.ComponentType<ExternalComponentProps>;
81
-
82
- /**
83
- * The children to render for the link. If no children are provided, the
84
- * link's `text` property will be used.
85
- */
86
- children?: React.ReactNode;
87
- } & (
88
- | {
89
- document: PrismicDocument | null | undefined;
90
- href?: never;
91
- field?: never;
92
- }
93
- | {
94
- field: LinkField | null | undefined;
95
- href?: never;
96
- document?: never;
97
- }
98
- | {
99
- href: LinkProps["href"];
100
- field?: LinkField | null | undefined;
101
- document?: never;
102
- }
103
- );
104
-
105
- export const PrismicLink = React.forwardRef(function PrismicLink<
106
- InternalComponentProps = React.ComponentProps<typeof defaultComponent>,
107
- ExternalComponentProps = React.ComponentProps<typeof defaultComponent>,
108
- >(
109
- props: PrismicLinkProps<InternalComponentProps, ExternalComponentProps>,
110
- ref: React.ForwardedRef<Element>,
111
- ): JSX.Element {
112
- const {
113
- field,
114
- document: doc,
115
- linkResolver,
116
- internalComponent,
117
- externalComponent,
118
- children,
119
- ...restProps
120
- } = props;
121
-
122
- if (
123
- typeof process !== "undefined" &&
124
- process.env.NODE_ENV === "development"
125
- ) {
126
- if (field) {
127
- if (!field.link_type) {
128
- console.error(
129
- `[PrismicLink] This "field" prop value caused an error to be thrown.\n`,
130
- field,
131
- );
132
- throw new Error(
133
- `[PrismicLink] The provided field is missing required properties to properly render a link. The link will not render. For more details, see ${devMsg(
134
- "missing-link-properties",
135
- )}`,
136
- );
137
- } else if (
138
- ("text" in field
139
- ? Object.keys(field).length > 2
140
- : Object.keys(field).length > 1) &&
141
- !("url" in field || "uid" in field || "id" in field)
142
- ) {
143
- console.warn(
144
- `[PrismicLink] The provided field is missing required properties to properly render a link. The link may not render correctly. For more details, see ${devMsg(
145
- "missing-link-properties",
146
- )}`,
147
- field,
148
- );
149
- }
150
- } else if (doc) {
151
- if (!("url" in doc || "id" in doc)) {
152
- console.warn(
153
- `[PrismicLink] The provided document is missing required properties to properly render a link. The link may not render correctly. For more details, see ${devMsg(
154
- "missing-link-properties",
155
- )}`,
156
- doc,
157
- );
158
- }
159
- }
160
- }
161
-
162
- const {
163
- href: computedHref,
164
- rel: computedRel,
165
- ...attrs
166
- } = asLinkAttrs(field ?? doc, {
167
- linkResolver,
168
- rel: typeof restProps.rel === "function" ? restProps.rel : undefined,
169
- });
170
-
171
- let rel: string | undefined = computedRel;
172
- if ("rel" in restProps && typeof restProps.rel !== "function") {
173
- rel = restProps.rel;
174
- }
175
-
176
- const href = ("href" in restProps ? restProps.href : computedHref) || "";
177
-
178
- const InternalComponent = (internalComponent ||
179
- defaultComponent) as React.ComponentType<LinkProps>;
180
- const ExternalComponent = (externalComponent ||
181
- defaultComponent) as React.ComponentType<LinkProps>;
182
- const Component =
183
- href && isInternalURL(href) ? InternalComponent : ExternalComponent;
184
-
185
- return (
186
- <Component ref={ref} {...attrs} {...restProps} href={href} rel={rel}>
187
- {"children" in props ? children : field?.text}
188
- </Component>
189
- );
190
- }) as <
191
- InternalComponentProps = React.ComponentProps<typeof defaultComponent>,
192
- ExternalComponentProps = React.ComponentProps<typeof defaultComponent>,
193
- >(
194
- props: PrismicLinkProps<InternalComponentProps, ExternalComponentProps> & {
195
- ref?: React.ForwardedRef<Element>;
196
- },
197
- ) => JSX.Element;
@@ -1,283 +0,0 @@
1
- import * as React from "react";
2
- import * as prismic from "@prismicio/client";
3
- import * as prismicR from "@prismicio/richtext";
4
-
5
- import { JSXFunctionSerializer, JSXMapSerializer } from "../types";
6
- import { LinkProps, PrismicLink } from "./PrismicLink";
7
- import { devMsg } from "../lib/devMsg";
8
-
9
- /**
10
- * Props for `<PrismicRichText>`.
11
- */
12
- export type PrismicRichTextProps<
13
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
14
- LinkResolverFunction extends prismic.LinkResolverFunction<any> = prismic.LinkResolverFunction,
15
- > = {
16
- /**
17
- * The Prismic Rich Text field to render.
18
- */
19
- field: prismic.RichTextField | null | undefined;
20
-
21
- /**
22
- * The Link Resolver used to resolve links.
23
- *
24
- * @remarks
25
- * If your app uses Route Resolvers when querying for your Prismic
26
- * repository's content, a Link Resolver does not need to be provided.
27
- * @see Learn about Link Resolvers and Route Resolvers {@link https://prismic.io/docs/core-concepts/link-resolver-route-resolver}
28
- */
29
- linkResolver?: LinkResolverFunction;
30
-
31
- /**
32
- * A map or function that maps a Rich Text block to a React component.
33
- *
34
- * @remarks
35
- * Prefer using a map serializer over the function serializer when possible.
36
- * The map serializer is simpler to maintain.
37
- * @example A map serializer.
38
- *
39
- * ```jsx
40
- * {
41
- * heading1: ({children}) => <Heading>{children}</Heading>
42
- * }
43
- * ```
44
- *
45
- * @example A function serializer.
46
- *
47
- * ```jsx
48
- * (type, node, content, children) => {
49
- * switch (type) {
50
- * case "heading1": {
51
- * return <Heading>{children}</Heading>;
52
- * }
53
- * }
54
- * };
55
- * ```
56
- */
57
- components?: JSXMapSerializer | JSXFunctionSerializer;
58
-
59
- /**
60
- * The React component rendered for links when the URL is internal.
61
- *
62
- * @defaultValue `<a>`
63
- */
64
- internalLinkComponent?: React.ComponentType<LinkProps>;
65
-
66
- /**
67
- * The React component rendered for links when the URL is external.
68
- *
69
- * @defaultValue `<a>`
70
- */
71
- externalLinkComponent?: React.ComponentType<LinkProps>;
72
-
73
- /**
74
- * The value to be rendered when the field is empty. If a fallback is not
75
- * given, `null` will be rendered.
76
- */
77
- fallback?: React.ReactNode;
78
- };
79
-
80
- type CreateDefaultSerializerArgs<
81
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
82
- LinkResolverFunction extends prismic.LinkResolverFunction<any> = prismic.LinkResolverFunction,
83
- > = {
84
- linkResolver: LinkResolverFunction | undefined;
85
- internalLinkComponent?: React.ComponentType<LinkProps>;
86
- externalLinkComponent?: React.ComponentType<LinkProps>;
87
- };
88
-
89
- const createDefaultSerializer = <
90
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
91
- LinkResolverFunction extends prismic.LinkResolverFunction<any>,
92
- >(
93
- args: CreateDefaultSerializerArgs<LinkResolverFunction>,
94
- ): JSXFunctionSerializer =>
95
- prismicR.wrapMapSerializer({
96
- heading1: ({ children, key }) => <h1 key={key}>{children}</h1>,
97
- heading2: ({ children, key }) => <h2 key={key}>{children}</h2>,
98
- heading3: ({ children, key }) => <h3 key={key}>{children}</h3>,
99
- heading4: ({ children, key }) => <h4 key={key}>{children}</h4>,
100
- heading5: ({ children, key }) => <h5 key={key}>{children}</h5>,
101
- heading6: ({ children, key }) => <h6 key={key}>{children}</h6>,
102
- paragraph: ({ children, key }) => <p key={key}>{children}</p>,
103
- preformatted: ({ node, key }) => <pre key={key}>{node.text}</pre>,
104
- strong: ({ children, key }) => <strong key={key}>{children}</strong>,
105
- em: ({ children, key }) => <em key={key}>{children}</em>,
106
- listItem: ({ children, key }) => <li key={key}>{children}</li>,
107
- oListItem: ({ children, key }) => <li key={key}>{children}</li>,
108
- list: ({ children, key }) => <ul key={key}>{children}</ul>,
109
- oList: ({ children, key }) => <ol key={key}>{children}</ol>,
110
- image: ({ node, key }) => {
111
- const img = (
112
- <img
113
- src={node.url}
114
- alt={node.alt ?? undefined}
115
- data-copyright={node.copyright ? node.copyright : undefined}
116
- />
117
- );
118
-
119
- return (
120
- <p key={key} className="block-img">
121
- {node.linkTo ? (
122
- <PrismicLink
123
- linkResolver={args.linkResolver}
124
- internalComponent={args.internalLinkComponent}
125
- externalComponent={args.externalLinkComponent}
126
- field={node.linkTo}
127
- >
128
- {img}
129
- </PrismicLink>
130
- ) : (
131
- img
132
- )}
133
- </p>
134
- );
135
- },
136
- embed: ({ node, key }) => (
137
- <div
138
- key={key}
139
- data-oembed={node.oembed.embed_url}
140
- data-oembed-type={node.oembed.type}
141
- data-oembed-provider={node.oembed.provider_name}
142
- dangerouslySetInnerHTML={{ __html: node.oembed.html ?? "" }}
143
- />
144
- ),
145
- hyperlink: ({ node, children, key }) => (
146
- <PrismicLink
147
- key={key}
148
- field={node.data}
149
- linkResolver={args.linkResolver}
150
- internalComponent={args.internalLinkComponent}
151
- externalComponent={args.externalLinkComponent}
152
- >
153
- {children}
154
- </PrismicLink>
155
- ),
156
- label: ({ node, children, key }) => (
157
- <span key={key} className={node.data.label}>
158
- {children}
159
- </span>
160
- ),
161
- span: ({ text, key }) => {
162
- const result: React.ReactNode[] = [];
163
-
164
- let i = 0;
165
- for (const line of text.split("\n")) {
166
- if (i > 0) {
167
- result.push(<br key={`${i}__break`} />);
168
- }
169
-
170
- result.push(<React.Fragment key={`${i}__line`}>{line}</React.Fragment>);
171
-
172
- i++;
173
- }
174
-
175
- return <React.Fragment key={key}>{result}</React.Fragment>;
176
- },
177
- });
178
-
179
- /**
180
- * React component that renders content from a Prismic Rich Text field. By
181
- * default, HTML elements are rendered for each piece of content. A `heading1`
182
- * block will render an `<h1>` HTML element, for example. Links will use
183
- * `<PrismicLink>` by default which can be customized using the
184
- * `internalLinkComponent` and `externalLinkComponent` props.
185
- *
186
- * To customize the components that are rendered, provide a map or function
187
- * serializer to the `components` prop.
188
- *
189
- * @remarks
190
- * This component returns a React fragment with no wrapping element around the
191
- * content. If you need a wrapper, add a component around `<PrismicRichText>`.
192
- * @example Rendering a Rich Text field using the default HTMl elements.
193
- *
194
- * ```jsx
195
- * <PrismicRichText field={document.data.content} />;
196
- * ```
197
- *
198
- * @example Rendering a Rich Text field using a custom set of React components.
199
- *
200
- * ```jsx
201
- * <PrismicRichText
202
- * field={document.data.content}
203
- * components={{
204
- * heading1: ({ children }) => <Heading>{children}</Heading>,
205
- * }}
206
- * />;
207
- * ```
208
- *
209
- * @param props - Props for the component.
210
- *
211
- * @returns The Rich Text field's content as React components.
212
- *
213
- * @see Learn about Rich Text fields {@link https://prismic.io/docs/core-concepts/rich-text-title}
214
- * @see Learn about Rich Text serializers {@link https://prismic.io/docs/core-concepts/html-serializer}
215
- */
216
- export function PrismicRichText<
217
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
218
- LinkResolverFunction extends prismic.LinkResolverFunction<any>,
219
- >({
220
- linkResolver,
221
- field,
222
- fallback,
223
- components,
224
- externalLinkComponent,
225
- internalLinkComponent,
226
- ...restProps
227
- }: PrismicRichTextProps<LinkResolverFunction>): JSX.Element | null {
228
- return React.useMemo(() => {
229
- if (
230
- typeof process !== "undefined" &&
231
- process.env.NODE_ENV === "development"
232
- ) {
233
- if ("className" in restProps) {
234
- console.warn(
235
- `[PrismicRichText] className cannot be passed to <PrismicRichText> since it renders an array without a wrapping component. For more details, see ${devMsg(
236
- "classname-is-not-a-valid-prop",
237
- )}.`,
238
- field,
239
- );
240
- }
241
- }
242
-
243
- if (prismic.isFilled.richText(field)) {
244
- const serializer = prismicR.composeSerializers(
245
- typeof components === "object"
246
- ? prismicR.wrapMapSerializer(components)
247
- : components,
248
- createDefaultSerializer({
249
- linkResolver,
250
- internalLinkComponent,
251
- externalLinkComponent,
252
- }),
253
- );
254
-
255
- // The serializer is wrapped in a higher-order function
256
- // that automatically applies a key to React Elements
257
- // if one is not already given.
258
- const serialized = prismicR.serialize<JSX.Element>(
259
- field,
260
- (type, node, text, children, key) => {
261
- const result = serializer(type, node, text, children, key);
262
-
263
- if (React.isValidElement(result) && result.key == null) {
264
- return React.cloneElement(result, { key });
265
- } else {
266
- return result;
267
- }
268
- },
269
- );
270
-
271
- return <>{serialized}</>;
272
- } else {
273
- return fallback != null ? <>{fallback}</> : null;
274
- }
275
- }, [
276
- field,
277
- internalLinkComponent,
278
- externalLinkComponent,
279
- components,
280
- linkResolver,
281
- fallback,
282
- ]);
283
- }
@@ -1,38 +0,0 @@
1
- export { PrismicLink } from "./PrismicLink";
2
- export { PrismicRichText } from "./PrismicRichText";
3
-
4
- export {
5
- PrismicProvider,
6
- useAllPrismicDocumentsByEveryTag,
7
- useAllPrismicDocumentsByIDs,
8
- useAllPrismicDocumentsBySomeTags,
9
- useAllPrismicDocumentsByTag,
10
- useAllPrismicDocumentsByType,
11
- useAllPrismicDocumentsByUIDs,
12
- useAllPrismicDocumentsDangerously,
13
- useFirstPrismicDocument,
14
- usePrismicClient,
15
- usePrismicContext,
16
- usePrismicDocumentByID,
17
- usePrismicDocumentByUID,
18
- usePrismicDocuments,
19
- usePrismicDocumentsByEveryTag,
20
- usePrismicDocumentsByIDs,
21
- usePrismicDocumentsBySomeTags,
22
- usePrismicDocumentsByTag,
23
- usePrismicDocumentsByType,
24
- usePrismicDocumentsByUIDs,
25
- usePrismicPreviewResolver,
26
- useSinglePrismicDocument,
27
- } from "./unsupported";
28
-
29
- // The following exports do not have RSC-specific implementations.
30
- // They are aliases for the default package exports.
31
- export {
32
- Element,
33
- PrismicImage,
34
- PrismicText,
35
- PrismicToolbar,
36
- SliceZone,
37
- TODOSliceComponent,
38
- } from "..";
@@ -1,184 +0,0 @@
1
- // Exports in this file are unsupported in the react-server environment.
2
- // All environments should export the same functions to maintian API compatability.
3
-
4
- function buildIncompatibleInServerComponentsErrorMessage(fnName: string) {
5
- return `${fnName} is not supported in Server Components. Remove ${fnName} in Server Components or add the "use client" directive to the component using ${fnName}.`;
6
- }
7
-
8
- function buildIncompatibleQueryHookInServerComponentsErrorMessage(
9
- fnName: string,
10
- ) {
11
- return `${fnName} is not supported in Server Components. Replace ${fnName} in Server Components with direct use of \`@prismicio/client\` (recommended) or add the "use client" directive to the component using the hook.`;
12
- }
13
-
14
- export function PrismicProvider(): JSX.Element {
15
- throw new Error(
16
- buildIncompatibleInServerComponentsErrorMessage("<PrismicProvider>"),
17
- );
18
- }
19
-
20
- export function usePrismicContext() {
21
- throw new Error(
22
- buildIncompatibleInServerComponentsErrorMessage("usePrismicContext()"),
23
- );
24
- }
25
-
26
- export function usePrismicClient() {
27
- throw new Error(
28
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
29
- "usePrismicClient()",
30
- ),
31
- );
32
- }
33
-
34
- export function usePrismicPreviewResolver() {
35
- throw new Error(
36
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
37
- "usePrismicPreviewResolver()",
38
- ),
39
- );
40
- }
41
-
42
- export function useAllPrismicDocumentsDangerously() {
43
- throw new Error(
44
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
45
- "useAllPrismicDocumentsDangerously()",
46
- ),
47
- );
48
- }
49
-
50
- export function useAllPrismicDocumentsByEveryTag() {
51
- throw new Error(
52
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
53
- "useAllPrismicDocumentsByEveryTag()",
54
- ),
55
- );
56
- }
57
-
58
- export function useAllPrismicDocumentsByIDs() {
59
- throw new Error(
60
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
61
- "useAllPrismicDocumentsByIDs()",
62
- ),
63
- );
64
- }
65
-
66
- export function useAllPrismicDocumentsBySomeTags() {
67
- throw new Error(
68
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
69
- "useAllPrismicDocumentsBySomeTags()",
70
- ),
71
- );
72
- }
73
-
74
- export function useAllPrismicDocumentsByTag() {
75
- throw new Error(
76
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
77
- "useAllPrismicDocumentsByTag()",
78
- ),
79
- );
80
- }
81
-
82
- export function useAllPrismicDocumentsByType() {
83
- throw new Error(
84
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
85
- "useAllPrismicDocumentsByType()",
86
- ),
87
- );
88
- }
89
-
90
- export function useAllPrismicDocumentsByUIDs() {
91
- throw new Error(
92
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
93
- "useAllPrismicDocumentsByUIDs()",
94
- ),
95
- );
96
- }
97
-
98
- export function useFirstPrismicDocument() {
99
- throw new Error(
100
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
101
- "useFirstPrismicDocument()",
102
- ),
103
- );
104
- }
105
-
106
- export function usePrismicDocumentByID() {
107
- throw new Error(
108
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
109
- "usePrismicDocumentByID()",
110
- ),
111
- );
112
- }
113
-
114
- export function usePrismicDocumentByUID() {
115
- throw new Error(
116
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
117
- "usePrismicDocumentByUID()",
118
- ),
119
- );
120
- }
121
-
122
- export function usePrismicDocuments() {
123
- throw new Error(
124
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
125
- "usePrismicDocuments()",
126
- ),
127
- );
128
- }
129
-
130
- export function usePrismicDocumentsByEveryTag() {
131
- throw new Error(
132
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
133
- "usePrismicDocumentsByEveryTag()",
134
- ),
135
- );
136
- }
137
-
138
- export function usePrismicDocumentsByIDs() {
139
- throw new Error(
140
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
141
- "usePrismicDocumentsByIDs()",
142
- ),
143
- );
144
- }
145
-
146
- export function usePrismicDocumentsBySomeTags() {
147
- throw new Error(
148
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
149
- "usePrismicDocumentsBySomeTags()",
150
- ),
151
- );
152
- }
153
-
154
- export function usePrismicDocumentsByTag() {
155
- throw new Error(
156
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
157
- "usePrismicDocumentsByTag()",
158
- ),
159
- );
160
- }
161
-
162
- export function usePrismicDocumentsByType() {
163
- throw new Error(
164
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
165
- "usePrismicDocumentsByType()",
166
- ),
167
- );
168
- }
169
-
170
- export function usePrismicDocumentsByUIDs() {
171
- throw new Error(
172
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
173
- "usePrismicDocumentsByUIDs()",
174
- ),
175
- );
176
- }
177
-
178
- export function useSinglePrismicDocument() {
179
- throw new Error(
180
- buildIncompatibleQueryHookInServerComponentsErrorMessage(
181
- "useSinglePrismicDocument()",
182
- ),
183
- );
184
- }