react-intlayer 7.6.0-canary.0 → 8.0.0-canary.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (206) hide show
  1. package/dist/assets/markdown/_fixture.md +896 -0
  2. package/dist/cjs/client/IntlayerProvider.cjs +30 -3
  3. package/dist/cjs/client/IntlayerProvider.cjs.map +1 -1
  4. package/dist/cjs/client/format/index.cjs +2 -0
  5. package/dist/cjs/client/format/useIntl.cjs +45 -0
  6. package/dist/cjs/client/format/useIntl.cjs.map +1 -0
  7. package/dist/cjs/client/t.cjs +21 -2
  8. package/dist/cjs/client/t.cjs.map +1 -1
  9. package/dist/cjs/client/useIntlayer.cjs +16 -3
  10. package/dist/cjs/client/useIntlayer.cjs.map +1 -1
  11. package/dist/cjs/client/useLocale.cjs +27 -7
  12. package/dist/cjs/client/useLocale.cjs.map +1 -1
  13. package/dist/cjs/getDictionary.cjs +2 -0
  14. package/dist/cjs/getDictionary.cjs.map +1 -1
  15. package/dist/cjs/getIntlayer.cjs +2 -0
  16. package/dist/cjs/getIntlayer.cjs.map +1 -1
  17. package/dist/cjs/html/HTMLProvider.cjs +18 -0
  18. package/dist/cjs/html/HTMLProvider.cjs.map +1 -0
  19. package/dist/cjs/html/HTMLRenderer.cjs +59 -0
  20. package/dist/cjs/html/HTMLRenderer.cjs.map +1 -0
  21. package/dist/cjs/html/HTMLRendererPlugin.cjs +36 -0
  22. package/dist/cjs/html/HTMLRendererPlugin.cjs.map +1 -0
  23. package/dist/cjs/html/index.cjs +11 -0
  24. package/dist/cjs/html/types.cjs +0 -0
  25. package/dist/cjs/index.cjs +13 -1
  26. package/dist/cjs/markdown/MarkdownProvider.cjs +76 -5
  27. package/dist/cjs/markdown/MarkdownProvider.cjs.map +1 -1
  28. package/dist/cjs/markdown/MarkdownRenderer.cjs +192 -32
  29. package/dist/cjs/markdown/MarkdownRenderer.cjs.map +1 -1
  30. package/dist/cjs/markdown/MarkdownRendererPlugin.cjs +33 -0
  31. package/dist/cjs/markdown/MarkdownRendererPlugin.cjs.map +1 -0
  32. package/dist/cjs/markdown/index.cjs +19 -2
  33. package/dist/cjs/markdown/processor.cjs +61 -0
  34. package/dist/cjs/markdown/processor.cjs.map +1 -0
  35. package/dist/cjs/markdown/runtime.cjs +45 -0
  36. package/dist/cjs/markdown/runtime.cjs.map +1 -0
  37. package/dist/cjs/plugins.cjs +83 -7
  38. package/dist/cjs/plugins.cjs.map +1 -1
  39. package/dist/cjs/reactElement/renderReactElement.cjs +8 -8
  40. package/dist/cjs/reactElement/renderReactElement.cjs.map +1 -1
  41. package/dist/cjs/server/IntlayerServerProvider.cjs +2 -2
  42. package/dist/cjs/server/IntlayerServerProvider.cjs.map +1 -1
  43. package/dist/cjs/server/format/useIntl.cjs +44 -0
  44. package/dist/cjs/server/format/useIntl.cjs.map +1 -0
  45. package/dist/cjs/server/index.cjs +2 -0
  46. package/dist/esm/IntlayerNode.mjs +2 -2
  47. package/dist/esm/IntlayerNode.mjs.map +1 -1
  48. package/dist/esm/client/IntlayerProvider.mjs +30 -3
  49. package/dist/esm/client/IntlayerProvider.mjs.map +1 -1
  50. package/dist/esm/client/format/index.mjs +2 -1
  51. package/dist/esm/client/format/useIntl.mjs +44 -0
  52. package/dist/esm/client/format/useIntl.mjs.map +1 -0
  53. package/dist/esm/client/t.mjs +21 -2
  54. package/dist/esm/client/t.mjs.map +1 -1
  55. package/dist/esm/client/useIntlayer.mjs +16 -3
  56. package/dist/esm/client/useIntlayer.mjs.map +1 -1
  57. package/dist/esm/client/useLocale.mjs +27 -7
  58. package/dist/esm/client/useLocale.mjs.map +1 -1
  59. package/dist/esm/editor/IntlayerEditorProvider.mjs +3 -3
  60. package/dist/esm/editor/IntlayerEditorProvider.mjs.map +1 -1
  61. package/dist/esm/getDictionary.mjs +3 -1
  62. package/dist/esm/getDictionary.mjs.map +1 -1
  63. package/dist/esm/getIntlayer.mjs +3 -1
  64. package/dist/esm/getIntlayer.mjs.map +1 -1
  65. package/dist/esm/html/HTMLProvider.mjs +16 -0
  66. package/dist/esm/html/HTMLProvider.mjs.map +1 -0
  67. package/dist/esm/html/HTMLRenderer.mjs +55 -0
  68. package/dist/esm/html/HTMLRenderer.mjs.map +1 -0
  69. package/dist/esm/html/HTMLRendererPlugin.mjs +35 -0
  70. package/dist/esm/html/HTMLRendererPlugin.mjs.map +1 -0
  71. package/dist/esm/html/index.mjs +5 -0
  72. package/dist/esm/html/types.mjs +0 -0
  73. package/dist/esm/index.mjs +5 -1
  74. package/dist/esm/markdown/MarkdownProvider.mjs +76 -5
  75. package/dist/esm/markdown/MarkdownProvider.mjs.map +1 -1
  76. package/dist/esm/markdown/MarkdownRenderer.mjs +191 -32
  77. package/dist/esm/markdown/MarkdownRenderer.mjs.map +1 -1
  78. package/dist/esm/markdown/MarkdownRendererPlugin.mjs +31 -0
  79. package/dist/esm/markdown/MarkdownRendererPlugin.mjs.map +1 -0
  80. package/dist/esm/markdown/index.mjs +5 -2
  81. package/dist/esm/markdown/processor.mjs +54 -0
  82. package/dist/esm/markdown/processor.mjs.map +1 -0
  83. package/dist/esm/markdown/runtime.mjs +41 -0
  84. package/dist/esm/markdown/runtime.mjs.map +1 -0
  85. package/dist/esm/plugins.mjs +82 -8
  86. package/dist/esm/plugins.mjs.map +1 -1
  87. package/dist/esm/reactElement/renderReactElement.mjs +8 -8
  88. package/dist/esm/reactElement/renderReactElement.mjs.map +1 -1
  89. package/dist/esm/server/IntlayerServerProvider.mjs +2 -2
  90. package/dist/esm/server/IntlayerServerProvider.mjs.map +1 -1
  91. package/dist/esm/server/format/useIntl.mjs +42 -0
  92. package/dist/esm/server/format/useIntl.mjs.map +1 -0
  93. package/dist/esm/server/index.mjs +2 -1
  94. package/dist/types/IntlayerNode.d.ts.map +1 -1
  95. package/dist/types/UI/ContentSelector.d.ts.map +1 -1
  96. package/dist/types/client/IntlayerProvider.d.ts +50 -5
  97. package/dist/types/client/IntlayerProvider.d.ts.map +1 -1
  98. package/dist/types/client/format/index.d.ts +2 -1
  99. package/dist/types/client/format/useCompact.d.ts +2 -3
  100. package/dist/types/client/format/useCompact.d.ts.map +1 -1
  101. package/dist/types/client/format/useCurrency.d.ts +2 -3
  102. package/dist/types/client/format/useCurrency.d.ts.map +1 -1
  103. package/dist/types/client/format/useDate.d.ts +0 -1
  104. package/dist/types/client/format/useDate.d.ts.map +1 -1
  105. package/dist/types/client/format/useIntl.d.ts +92 -0
  106. package/dist/types/client/format/useIntl.d.ts.map +1 -0
  107. package/dist/types/client/format/useList.d.ts +2 -3
  108. package/dist/types/client/format/useList.d.ts.map +1 -1
  109. package/dist/types/client/format/useNumber.d.ts +2 -3
  110. package/dist/types/client/format/useNumber.d.ts.map +1 -1
  111. package/dist/types/client/format/usePercentage.d.ts +2 -3
  112. package/dist/types/client/format/usePercentage.d.ts.map +1 -1
  113. package/dist/types/client/format/useRelativeTime.d.ts +2 -3
  114. package/dist/types/client/format/useRelativeTime.d.ts.map +1 -1
  115. package/dist/types/client/format/useUnit.d.ts +2 -3
  116. package/dist/types/client/format/useUnit.d.ts.map +1 -1
  117. package/dist/types/client/t.d.ts +21 -3
  118. package/dist/types/client/t.d.ts.map +1 -1
  119. package/dist/types/client/useDictionary.d.ts +2 -3
  120. package/dist/types/client/useDictionary.d.ts.map +1 -1
  121. package/dist/types/client/useDictionaryAsync.d.ts +0 -1
  122. package/dist/types/client/useDictionaryAsync.d.ts.map +1 -1
  123. package/dist/types/client/useDictionaryDynamic.d.ts +0 -1
  124. package/dist/types/client/useDictionaryDynamic.d.ts.map +1 -1
  125. package/dist/types/client/useI18n.d.ts +0 -1
  126. package/dist/types/client/useI18n.d.ts.map +1 -1
  127. package/dist/types/client/useIntlayer.d.ts +18 -6
  128. package/dist/types/client/useIntlayer.d.ts.map +1 -1
  129. package/dist/types/client/useLoadDynamic.d.ts.map +1 -1
  130. package/dist/types/client/useLocale.d.ts +21 -1
  131. package/dist/types/client/useLocale.d.ts.map +1 -1
  132. package/dist/types/client/useLocaleBase.d.ts +5 -5
  133. package/dist/types/client/useLocaleBase.d.ts.map +1 -1
  134. package/dist/types/client/useLocaleStorage.d.ts +5 -6
  135. package/dist/types/client/useLocaleStorage.d.ts.map +1 -1
  136. package/dist/types/client/useTraduction.d.ts +0 -1
  137. package/dist/types/client/useTraduction.d.ts.map +1 -1
  138. package/dist/types/editor/ContentSelectorWrapper.d.ts.map +1 -1
  139. package/dist/types/editor/IntlayerEditorProvider.d.ts.map +1 -1
  140. package/dist/types/editor/useEditedContentRenderer.d.ts.map +1 -1
  141. package/dist/types/getDictionary.d.ts.map +1 -1
  142. package/dist/types/getIntlayer.d.ts.map +1 -1
  143. package/dist/types/html/HTMLProvider.d.ts +17 -0
  144. package/dist/types/html/HTMLProvider.d.ts.map +1 -0
  145. package/dist/types/html/HTMLRenderer.d.ts +46 -0
  146. package/dist/types/html/HTMLRenderer.d.ts.map +1 -0
  147. package/dist/types/html/HTMLRendererPlugin.d.ts +15 -0
  148. package/dist/types/html/HTMLRendererPlugin.d.ts.map +1 -0
  149. package/dist/types/html/index.d.ts +5 -0
  150. package/dist/types/html/types.d.ts +26 -0
  151. package/dist/types/html/types.d.ts.map +1 -0
  152. package/dist/types/index.d.ts +8 -2
  153. package/dist/types/index.d.ts.map +1 -1
  154. package/dist/types/markdown/MarkdownProvider.d.ts +42 -3
  155. package/dist/types/markdown/MarkdownProvider.d.ts.map +1 -1
  156. package/dist/types/markdown/MarkdownRenderer.d.ts +251 -11
  157. package/dist/types/markdown/MarkdownRenderer.d.ts.map +1 -1
  158. package/dist/types/markdown/MarkdownRendererPlugin.d.ts +19 -0
  159. package/dist/types/markdown/MarkdownRendererPlugin.d.ts.map +1 -0
  160. package/dist/types/markdown/index.d.ts +6 -3
  161. package/dist/types/markdown/processor.d.ts +92 -0
  162. package/dist/types/markdown/processor.d.ts.map +1 -0
  163. package/dist/types/markdown/runtime.d.ts +19 -0
  164. package/dist/types/markdown/runtime.d.ts.map +1 -0
  165. package/dist/types/plugins.d.ts +35 -13
  166. package/dist/types/plugins.d.ts.map +1 -1
  167. package/dist/types/reactElement/renderReactElement.d.ts +2 -2
  168. package/dist/types/reactElement/renderReactElement.d.ts.map +1 -1
  169. package/dist/types/server/IntlayerServerProvider.d.ts +2 -2
  170. package/dist/types/server/IntlayerServerProvider.d.ts.map +1 -1
  171. package/dist/types/server/format/useCompact.d.ts +0 -1
  172. package/dist/types/server/format/useCompact.d.ts.map +1 -1
  173. package/dist/types/server/format/useCurrency.d.ts +0 -1
  174. package/dist/types/server/format/useCurrency.d.ts.map +1 -1
  175. package/dist/types/server/format/useDate.d.ts +0 -1
  176. package/dist/types/server/format/useDate.d.ts.map +1 -1
  177. package/dist/types/server/format/useIntl.d.ts +92 -0
  178. package/dist/types/server/format/useIntl.d.ts.map +1 -0
  179. package/dist/types/server/format/useList.d.ts +0 -1
  180. package/dist/types/server/format/useList.d.ts.map +1 -1
  181. package/dist/types/server/format/useNumber.d.ts +0 -1
  182. package/dist/types/server/format/useNumber.d.ts.map +1 -1
  183. package/dist/types/server/format/usePercentage.d.ts +0 -1
  184. package/dist/types/server/format/usePercentage.d.ts.map +1 -1
  185. package/dist/types/server/format/useRelativeTime.d.ts +0 -1
  186. package/dist/types/server/format/useRelativeTime.d.ts.map +1 -1
  187. package/dist/types/server/format/useUnit.d.ts +0 -1
  188. package/dist/types/server/format/useUnit.d.ts.map +1 -1
  189. package/dist/types/server/index.d.ts +2 -1
  190. package/dist/types/server/serverContext.d.ts +0 -1
  191. package/dist/types/server/serverContext.d.ts.map +1 -1
  192. package/dist/types/server/t.d.ts +0 -1
  193. package/dist/types/server/t.d.ts.map +1 -1
  194. package/dist/types/server/useDictionary.d.ts +2 -3
  195. package/dist/types/server/useDictionary.d.ts.map +1 -1
  196. package/dist/types/server/useDictionaryAsync.d.ts +2 -3
  197. package/dist/types/server/useDictionaryAsync.d.ts.map +1 -1
  198. package/dist/types/server/useDictionaryDynamic.d.ts +0 -1
  199. package/dist/types/server/useDictionaryDynamic.d.ts.map +1 -1
  200. package/dist/types/server/useI18n.d.ts +0 -1
  201. package/dist/types/server/useI18n.d.ts.map +1 -1
  202. package/dist/types/server/useIntlayer.d.ts +3 -3
  203. package/dist/types/server/useIntlayer.d.ts.map +1 -1
  204. package/dist/types/server/useLoadDynamic.d.ts.map +1 -1
  205. package/dist/types/server/useLocale.d.ts.map +1 -1
  206. package/package.json +22 -12
@@ -1 +1 @@
1
- {"version":3,"file":"getIntlayer.mjs","names":["getIntlayerCore"],"sources":["../../src/getIntlayer.ts"],"sourcesContent":["import { getIntlayer as getIntlayerCore, type Plugins } from '@intlayer/core';\nimport type {\n DeclaredLocales,\n DictionaryKeys,\n DictionaryRegistryContent,\n LocalesValues,\n} from '@intlayer/types';\nimport {\n type DeepTransformContent,\n intlayerNodePlugins,\n markdownPlugin,\n reactNodePlugins,\n} from './plugins';\n\nexport const getIntlayer = <\n T extends DictionaryKeys,\n L extends LocalesValues = DeclaredLocales,\n>(\n key: T,\n locale?: L,\n additionalPlugins?: Plugins[]\n): DeepTransformContent<DictionaryRegistryContent<T>, L> => {\n const plugins: Plugins[] = [\n intlayerNodePlugins,\n reactNodePlugins,\n markdownPlugin,\n ...(additionalPlugins ?? []),\n ];\n\n return getIntlayerCore(key, locale, plugins) as any;\n};\n"],"mappings":";;;;AAcA,MAAa,eAIX,KACA,QACA,sBAC0D;AAQ1D,QAAOA,cAAgB,KAAK,QAPD;EACzB;EACA;EACA;EACA,GAAI,qBAAqB,EAAE;EAC5B,CAE2C"}
1
+ {"version":3,"file":"getIntlayer.mjs","names":["getIntlayerCore"],"sources":["../../src/getIntlayer.ts"],"sourcesContent":["import { getIntlayer as getIntlayerCore, type Plugins } from '@intlayer/core';\nimport type {\n DeclaredLocales,\n DictionaryKeys,\n DictionaryRegistryContent,\n LocalesValues,\n} from '@intlayer/types';\nimport {\n type DeepTransformContent,\n htmlPlugin,\n insertionPlugin,\n intlayerNodePlugins,\n markdownPlugin,\n reactNodePlugins,\n} from './plugins';\n\nexport const getIntlayer = <\n T extends DictionaryKeys,\n L extends LocalesValues = DeclaredLocales,\n>(\n key: T,\n locale?: L,\n additionalPlugins?: Plugins[]\n): DeepTransformContent<DictionaryRegistryContent<T>, L> => {\n const plugins: Plugins[] = [\n intlayerNodePlugins,\n reactNodePlugins,\n insertionPlugin,\n markdownPlugin,\n htmlPlugin,\n ...(additionalPlugins ?? []),\n ];\n\n return getIntlayerCore(key, locale, plugins) as any;\n};\n"],"mappings":";;;;AAgBA,MAAa,eAIX,KACA,QACA,sBAC0D;AAU1D,QAAOA,cAAgB,KAAK,QATD;EACzB;EACA;EACA;EACA;EACA;EACA,GAAI,qBAAqB,EAAE;EAC5B,CAE2C"}
@@ -0,0 +1,16 @@
1
+ 'use client';
2
+
3
+ import { createContext, useContext } from "react";
4
+ import { jsx } from "react/jsx-runtime";
5
+
6
+ //#region src/html/HTMLProvider.tsx
7
+ const HTMLContext = createContext(void 0);
8
+ const useHTMLContext = () => useContext(HTMLContext);
9
+ const HTMLProvider = ({ children, components }) => /* @__PURE__ */ jsx(HTMLContext.Provider, {
10
+ value: { components },
11
+ children
12
+ });
13
+
14
+ //#endregion
15
+ export { HTMLProvider, useHTMLContext };
16
+ //# sourceMappingURL=HTMLProvider.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HTMLProvider.mjs","names":[],"sources":["../../../src/html/HTMLProvider.tsx"],"sourcesContent":["'use client';\n\nimport {\n createContext,\n type FC,\n type PropsWithChildren,\n useContext,\n} from 'react';\n\ntype HTMLContextValue = {\n components?: Record<string, any>;\n};\n\ntype HTMLProviderProps = PropsWithChildren<{\n /**\n * Component overrides for HTML tags.\n */\n components?: Record<string, any>;\n}>;\n\nconst HTMLContext = createContext<HTMLContextValue | undefined>(undefined);\n\nexport const useHTMLContext = () => useContext(HTMLContext);\n\nexport const HTMLProvider: FC<HTMLProviderProps> = ({\n children,\n components,\n}) => (\n <HTMLContext.Provider value={{ components }}>{children}</HTMLContext.Provider>\n);\n"],"mappings":";;;;;;AAoBA,MAAM,cAAc,cAA4C,OAAU;AAE1E,MAAa,uBAAuB,WAAW,YAAY;AAE3D,MAAa,gBAAuC,EAClD,UACA,iBAEA,oBAAC,YAAY;CAAS,OAAO,EAAE,YAAY;CAAG;EAAgC"}
@@ -0,0 +1,55 @@
1
+ 'use client';
2
+
3
+ import { useHTMLContext } from "./HTMLProvider.mjs";
4
+ import { Fragment, createElement } from "react";
5
+ import { jsx } from "react/jsx-runtime";
6
+ import { HTML_TAGS, getHTML } from "@intlayer/core";
7
+
8
+ //#region src/html/HTMLRenderer.tsx
9
+ const createDefaultHTMLComponents = () => {
10
+ const components = {};
11
+ for (const tag of HTML_TAGS) components[tag] = ({ children, ...props }) => createElement(tag, props, children);
12
+ return components;
13
+ };
14
+ const defaultHTMLComponents = createDefaultHTMLComponents();
15
+ /**
16
+ * Renders HTML-like content to JSX with the provided components.
17
+ *
18
+ * This function does not use context from HTMLProvider. Use `useHTMLRenderer`
19
+ * hook if you want to leverage provider context.
20
+ */
21
+ const renderHTML = (content, { components } = {}) => {
22
+ const mergedComponents = {
23
+ ...defaultHTMLComponents,
24
+ ...components
25
+ };
26
+ return /* @__PURE__ */ jsx(Fragment, { children: getHTML(content, Object.fromEntries(Object.entries(mergedComponents).filter(([, Component]) => Component).map(([key, Component]) => [key, (props) => createElement(Component, props)]))) });
27
+ };
28
+ /**
29
+ * Hook that returns a function to render HTML content.
30
+ *
31
+ * This hook considers the configuration from the `HTMLProvider` context if available,
32
+ * falling back to the provided components.
33
+ */
34
+ const useHTMLRenderer = ({ components } = {}) => {
35
+ const context = useHTMLContext();
36
+ return (content) => {
37
+ return renderHTML(content, { components: {
38
+ ...context?.components,
39
+ ...components
40
+ } });
41
+ };
42
+ };
43
+ /**
44
+ * React component that renders HTML-like content to JSX.
45
+ *
46
+ * This component uses the components from the `HTMLProvider` context
47
+ * if available.
48
+ */
49
+ const HTMLRenderer = ({ children = "", components }) => {
50
+ return useHTMLRenderer({ components })(children);
51
+ };
52
+
53
+ //#endregion
54
+ export { HTMLRenderer, defaultHTMLComponents, renderHTML, useHTMLRenderer };
55
+ //# sourceMappingURL=HTMLRenderer.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HTMLRenderer.mjs","names":[],"sources":["../../../src/html/HTMLRenderer.tsx"],"sourcesContent":["'use client';\n\nimport { getHTML, HTML_TAGS } from '@intlayer/core';\nimport { createElement, type FC, Fragment, type JSX } from 'react';\nimport { useHTMLContext } from './HTMLProvider';\nimport type { ReactHTMLComponent } from './types';\n\n/**\n * Type for React HTML tag components.\n */\ntype HTMLTagComponent = ReactHTMLComponent;\n\nconst createDefaultHTMLComponents = (): Record<string, HTMLTagComponent> => {\n const components: Record<string, HTMLTagComponent> = {};\n\n for (const tag of HTML_TAGS) {\n components[tag] = ({ children, ...props }) =>\n createElement(tag, props, children);\n }\n\n return components;\n};\n\nexport const defaultHTMLComponents = createDefaultHTMLComponents();\n\nexport type RenderHTMLProps = {\n /**\n * Component overrides for HTML tags.\n * Allows you to customize how specific HTML elements are rendered.\n */\n components?: Record<string, any>;\n};\n\n/**\n * Renders HTML-like content to JSX with the provided components.\n *\n * This function does not use context from HTMLProvider. Use `useHTMLRenderer`\n * hook if you want to leverage provider context.\n */\nexport const renderHTML = (\n content: string,\n { components }: RenderHTMLProps = {}\n): JSX.Element => {\n const mergedComponents = {\n ...defaultHTMLComponents,\n ...components,\n };\n\n // Wrap all components to ensure they are rendered via React.createElement\n const wrappedComponents = Object.fromEntries(\n Object.entries(mergedComponents)\n .filter(([, Component]) => Component)\n .map(([key, Component]) => [\n key,\n (props: any) => createElement(Component as any, props),\n ])\n );\n\n return <Fragment>{getHTML(content, wrappedComponents)}</Fragment>;\n};\n\n/**\n * Hook that returns a function to render HTML content.\n *\n * This hook considers the configuration from the `HTMLProvider` context if available,\n * falling back to the provided components.\n */\nexport const useHTMLRenderer = ({ components }: RenderHTMLProps = {}) => {\n const context = useHTMLContext();\n\n return (content: string) => {\n return renderHTML(content, {\n components: {\n ...context?.components,\n ...components,\n },\n });\n };\n};\n\nexport type HTMLRendererProps = RenderHTMLProps & {\n /**\n * The HTML content to render as a string.\n */\n children: string;\n};\n\n/**\n * React component that renders HTML-like content to JSX.\n *\n * This component uses the components from the `HTMLProvider` context\n * if available.\n */\nexport const HTMLRenderer: FC<HTMLRendererProps> = ({\n children = '',\n components,\n}) => {\n const render = useHTMLRenderer({ components });\n\n return render(children);\n};\n"],"mappings":";;;;;;;;AAYA,MAAM,oCAAsE;CAC1E,MAAM,aAA+C,EAAE;AAEvD,MAAK,MAAM,OAAO,UAChB,YAAW,QAAQ,EAAE,UAAU,GAAG,YAChC,cAAc,KAAK,OAAO,SAAS;AAGvC,QAAO;;AAGT,MAAa,wBAAwB,6BAA6B;;;;;;;AAgBlE,MAAa,cACX,SACA,EAAE,eAAgC,EAAE,KACpB;CAChB,MAAM,mBAAmB;EACvB,GAAG;EACH,GAAG;EACJ;AAYD,QAAO,oBAAC,sBAAU,QAAQ,SATA,OAAO,YAC/B,OAAO,QAAQ,iBAAiB,CAC7B,QAAQ,GAAG,eAAe,UAAU,CACpC,KAAK,CAAC,KAAK,eAAe,CACzB,MACC,UAAe,cAAc,WAAkB,MAAM,CACvD,CAAC,CACL,CAEoD,GAAY;;;;;;;;AASnE,MAAa,mBAAmB,EAAE,eAAgC,EAAE,KAAK;CACvE,MAAM,UAAU,gBAAgB;AAEhC,SAAQ,YAAoB;AAC1B,SAAO,WAAW,SAAS,EACzB,YAAY;GACV,GAAG,SAAS;GACZ,GAAG;GACJ,EACF,CAAC;;;;;;;;;AAiBN,MAAa,gBAAuC,EAClD,WAAW,IACX,iBACI;AAGJ,QAFe,gBAAgB,EAAE,YAAY,CAAC,CAEhC,SAAS"}
@@ -0,0 +1,35 @@
1
+ 'use client';
2
+
3
+ import { ContentSelectorRenderer } from "../editor/ContentSelectorWrapper.mjs";
4
+ import { useEditedContentRenderer } from "../editor/useEditedContentRenderer.mjs";
5
+ import { useHTMLContext } from "./HTMLProvider.mjs";
6
+ import { defaultHTMLComponents } from "./HTMLRenderer.mjs";
7
+ import { createElement } from "react";
8
+ import { jsx } from "react/jsx-runtime";
9
+ import { getHTML } from "@intlayer/core";
10
+
11
+ //#region src/html/HTMLRendererPlugin.tsx
12
+ const HTMLRendererPlugin = (props) => {
13
+ const { dictionaryKey, keyPath, html, userComponents } = props;
14
+ const globalComponents = useHTMLContext()?.components || {};
15
+ const editedContentContext = useEditedContentRenderer({
16
+ dictionaryKey: dictionaryKey ?? "",
17
+ keyPath: keyPath ?? [],
18
+ children: html
19
+ });
20
+ const contentToRender = typeof editedContentContext === "string" ? editedContentContext : html;
21
+ const mergedComponents = {
22
+ ...defaultHTMLComponents,
23
+ ...globalComponents,
24
+ ...userComponents
25
+ };
26
+ const wrappedComponents = Object.fromEntries(Object.entries(mergedComponents).filter(([, Component]) => Component).map(([key, Component]) => [key, (props) => createElement(Component, props)]));
27
+ return /* @__PURE__ */ jsx(ContentSelectorRenderer, {
28
+ ...props,
29
+ children: getHTML(contentToRender, wrappedComponents)
30
+ });
31
+ };
32
+
33
+ //#endregion
34
+ export { HTMLRendererPlugin };
35
+ //# sourceMappingURL=HTMLRendererPlugin.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HTMLRendererPlugin.mjs","names":[],"sources":["../../../src/html/HTMLRendererPlugin.tsx"],"sourcesContent":["'use client';\n\nimport { getHTML } from '@intlayer/core';\nimport type { KeyPath, Locale } from '@intlayer/types';\nimport { createElement, type FC, type ReactNode } from 'react';\nimport { ContentSelectorRenderer } from '../editor';\nimport { useEditedContentRenderer } from '../editor/useEditedContentRenderer';\nimport { useHTMLContext } from './HTMLProvider';\nimport { defaultHTMLComponents } from './HTMLRenderer';\nimport type { ReactComponentProps } from './types';\n\ntype HTMLRendererPluginProps = {\n dictionaryKey: string;\n keyPath: KeyPath[];\n html: string;\n locale?: Locale;\n userComponents?: Record<string, any>;\n};\n\nexport const HTMLRendererPlugin: FC<HTMLRendererPluginProps> = (\n props\n): ReactNode => {\n const { dictionaryKey, keyPath, html, userComponents } = props;\n const context = useHTMLContext();\n const globalComponents = context?.components || {};\n\n const editedContentContext = useEditedContentRenderer({\n dictionaryKey: dictionaryKey ?? '',\n keyPath: keyPath ?? [],\n children: html,\n });\n\n const contentToRender =\n typeof editedContentContext === 'string' ? editedContentContext : html;\n\n const mergedComponents = {\n ...defaultHTMLComponents,\n ...globalComponents,\n ...userComponents,\n };\n\n // Wrap all components to ensure they are rendered via React.createElement\n // This is important because it allows React to handle the component's lifecycle,\n // hooks, and Babel-injected variables correctly.\n const wrappedComponents = Object.fromEntries(\n Object.entries(mergedComponents)\n .filter(([, Component]) => Component)\n .map(([key, Component]) => [\n key,\n (props: ReactComponentProps) => createElement(Component, props),\n ])\n );\n\n return (\n <ContentSelectorRenderer {...props}>\n {getHTML(contentToRender, wrappedComponents)}\n </ContentSelectorRenderer>\n );\n};\n"],"mappings":";;;;;;;;;;;AAmBA,MAAa,sBACX,UACc;CACd,MAAM,EAAE,eAAe,SAAS,MAAM,mBAAmB;CAEzD,MAAM,mBADU,gBAAgB,EACE,cAAc,EAAE;CAElD,MAAM,uBAAuB,yBAAyB;EACpD,eAAe,iBAAiB;EAChC,SAAS,WAAW,EAAE;EACtB,UAAU;EACX,CAAC;CAEF,MAAM,kBACJ,OAAO,yBAAyB,WAAW,uBAAuB;CAEpE,MAAM,mBAAmB;EACvB,GAAG;EACH,GAAG;EACH,GAAG;EACJ;CAKD,MAAM,oBAAoB,OAAO,YAC/B,OAAO,QAAQ,iBAAiB,CAC7B,QAAQ,GAAG,eAAe,UAAU,CACpC,KAAK,CAAC,KAAK,eAAe,CACzB,MACC,UAA+B,cAAc,WAAW,MAAM,CAChE,CAAC,CACL;AAED,QACE,oBAAC;EAAwB,GAAI;YAC1B,QAAQ,iBAAiB,kBAAkB;GACpB"}
@@ -0,0 +1,5 @@
1
+ import { HTMLProvider, useHTMLContext } from "./HTMLProvider.mjs";
2
+ import { HTMLRenderer, defaultHTMLComponents, renderHTML, useHTMLRenderer } from "./HTMLRenderer.mjs";
3
+ import { HTMLRendererPlugin } from "./HTMLRendererPlugin.mjs";
4
+
5
+ export { HTMLProvider, HTMLRenderer, HTMLRendererPlugin, defaultHTMLComponents, renderHTML, useHTMLContext, useHTMLRenderer };
File without changes
@@ -10,7 +10,11 @@ import { getIntlayer } from "./getIntlayer.mjs";
10
10
  import { useIntlayer } from "./client/useIntlayer.mjs";
11
11
  import { useLocale } from "./client/useLocale.mjs";
12
12
  import { useLocaleBase } from "./client/useLocaleBase.mjs";
13
+ import { HTMLProvider } from "./html/HTMLProvider.mjs";
14
+ import { HTMLRenderer, renderHTML, useHTMLRenderer } from "./html/HTMLRenderer.mjs";
13
15
  import { MarkdownProvider } from "./markdown/MarkdownProvider.mjs";
16
+ import { MarkdownRenderer, renderMarkdown, useMarkdownRenderer } from "./markdown/MarkdownRenderer.mjs";
14
17
  import { getDictionary } from "./getDictionary.mjs";
18
+ import { useIntl } from "./client/format/useIntl.mjs";
15
19
 
16
- export { IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, MarkdownProvider, getDictionary, getIntlayer, localeCookie, localeInStorage, setLocaleCookie, setLocaleInStorage, t, useDictionary, useDictionaryAsync, useDictionaryDynamic, useI18n, useIntlayer, useIntlayerContext, useLoadDynamic, useLocale, useLocaleBase, useLocaleCookie, useLocaleStorage };
20
+ export { HTMLProvider, HTMLRenderer, IntlayerClientContext, IntlayerProvider, IntlayerProviderContent, MarkdownProvider, MarkdownRenderer, getDictionary, getIntlayer, localeCookie, localeInStorage, renderHTML, renderMarkdown, setLocaleCookie, setLocaleInStorage, t, useDictionary, useDictionaryAsync, useDictionaryDynamic, useHTMLRenderer, useI18n, useIntl, useIntlayer, useIntlayerContext, useLoadDynamic, useLocale, useLocaleBase, useLocaleCookie, useLocaleStorage, useMarkdownRenderer };
@@ -1,15 +1,86 @@
1
1
  'use client';
2
2
 
3
+ import { compiler } from "./processor.mjs";
3
4
  import { createContext, useContext } from "react";
4
5
  import { jsx } from "react/jsx-runtime";
5
6
 
6
7
  //#region src/markdown/MarkdownProvider.tsx
7
- const MarkdownContext = createContext({ renderMarkdown: (markdown) => markdown });
8
+ const MarkdownContext = createContext(void 0);
8
9
  const useMarkdownContext = () => useContext(MarkdownContext);
9
- const MarkdownProvider = ({ children, renderMarkdown }) => /* @__PURE__ */ jsx(MarkdownContext.Provider, {
10
- value: { renderMarkdown },
11
- children
12
- });
10
+ const isRenderMarkdownOptions = (override) => {
11
+ return override && typeof override === "object" && ("components" in override || "wrapper" in override || "forceBlock" in override || "forceInline" in override || "preserveFrontmatter" in override || "tagfilter" in override);
12
+ };
13
+ const mergeOptions = (baseOptions, overrides) => {
14
+ if (!overrides) return baseOptions;
15
+ if (!isRenderMarkdownOptions(overrides)) return {
16
+ ...baseOptions,
17
+ components: {
18
+ ...baseOptions.components,
19
+ ...overrides
20
+ }
21
+ };
22
+ const { components: overrideComponents, wrapper, forceBlock, forceInline, preserveFrontmatter, tagfilter, ...componentsFromRest } = overrides;
23
+ const components = overrideComponents || componentsFromRest;
24
+ return {
25
+ ...baseOptions,
26
+ forceBlock: forceBlock ?? baseOptions.forceBlock,
27
+ forceInline: forceInline ?? baseOptions.forceInline,
28
+ preserveFrontmatter: preserveFrontmatter ?? baseOptions.preserveFrontmatter,
29
+ tagfilter: tagfilter ?? baseOptions.tagfilter,
30
+ wrapper: wrapper || baseOptions.wrapper,
31
+ forceWrapper: !!(wrapper || baseOptions.wrapper),
32
+ components: {
33
+ ...baseOptions.components,
34
+ ...components
35
+ }
36
+ };
37
+ };
38
+ /**
39
+ * Provider for the MarkdownRenderer component.
40
+ *
41
+ * It will provide the `renderMarkdown` function to the context, which can be used to render markdown.
42
+ *
43
+ * ```tsx
44
+ * const content = useIntlayer('app');
45
+ *
46
+ * return (
47
+ * <div>
48
+ * {content.markdown} // Will be rendered with the components and options provided to the MarkdownProvider
49
+ * </div>
50
+ * );
51
+ * ```
52
+ *
53
+ * @example
54
+ * ```tsx
55
+ * <MarkdownProvider components={{ h1: CustomHeading }}>
56
+ * <MarkdownRenderer>
57
+ * {markdownContent}
58
+ * </MarkdownRenderer>
59
+ * </MarkdownProvider>
60
+ * ```
61
+ */
62
+ const MarkdownProvider = ({ children, components, wrapper, forceBlock, forceInline, preserveFrontmatter, tagfilter, renderMarkdown: customRenderFn }) => {
63
+ const baseOptions = {
64
+ components,
65
+ forceBlock,
66
+ forceInline,
67
+ wrapper,
68
+ forceWrapper: !!wrapper,
69
+ preserveFrontmatter,
70
+ tagfilter
71
+ };
72
+ const defaultRenderMarkdown = (markdown, overrides) => {
73
+ return compiler(markdown, mergeOptions(baseOptions, overrides));
74
+ };
75
+ const customRenderMarkdownWrapper = (markdown, overrides) => /* @__PURE__ */ jsx(MarkdownContext.Provider, {
76
+ value: void 0,
77
+ children: customRenderFn?.(markdown, overrides)
78
+ });
79
+ return /* @__PURE__ */ jsx(MarkdownContext.Provider, {
80
+ value: { renderMarkdown: customRenderFn ? customRenderMarkdownWrapper : defaultRenderMarkdown },
81
+ children
82
+ });
83
+ };
13
84
 
14
85
  //#endregion
15
86
  export { MarkdownProvider, useMarkdownContext };
@@ -1 +1 @@
1
- {"version":3,"file":"MarkdownProvider.mjs","names":[],"sources":["../../../src/markdown/MarkdownProvider.tsx"],"sourcesContent":["'use client';\n\nimport {\n createContext,\n type FC,\n type PropsWithChildren,\n type ReactNode,\n useContext,\n} from 'react';\n\ntype MarkdownContextValue = {\n renderMarkdown: (markdown: string) => ReactNode;\n};\n\ntype MarkdownProviderProps = PropsWithChildren<MarkdownContextValue>;\n\nconst MarkdownContext = createContext<MarkdownContextValue>({\n renderMarkdown: (markdown: string) => markdown,\n});\n\nexport const useMarkdownContext = () => useContext(MarkdownContext);\n\nexport const MarkdownProvider: FC<MarkdownProviderProps> = ({\n children,\n renderMarkdown,\n}) => (\n <MarkdownContext.Provider value={{ renderMarkdown }}>\n {children}\n </MarkdownContext.Provider>\n);\n"],"mappings":";;;;;;AAgBA,MAAM,kBAAkB,cAAoC,EAC1D,iBAAiB,aAAqB,UACvC,CAAC;AAEF,MAAa,2BAA2B,WAAW,gBAAgB;AAEnE,MAAa,oBAA+C,EAC1D,UACA,qBAEA,oBAAC,gBAAgB;CAAS,OAAO,EAAE,gBAAgB;CAChD;EACwB"}
1
+ {"version":3,"file":"MarkdownProvider.mjs","names":[],"sources":["../../../src/markdown/MarkdownProvider.tsx"],"sourcesContent":["'use client';\n\nimport type { Overrides } from '@intlayer/core';\nimport {\n createContext,\n type FC,\n type PropsWithChildren,\n type ReactNode,\n useContext,\n} from 'react';\nimport { compiler, type MarkdownRendererOptions } from './processor';\n\nexport type MarkdownProviderOptions = {\n /** Forces the compiler to always output content with a block-level wrapper. */\n forceBlock?: boolean;\n /** Forces the compiler to always output content with an inline wrapper. */\n forceInline?: boolean;\n /** Whether to preserve frontmatter in the markdown content. */\n preserveFrontmatter?: boolean;\n /** Whether to use the GitHub Tag Filter for security. */\n tagfilter?: boolean;\n};\n\ntype RenderMarkdownOptions = MarkdownProviderOptions & {\n components?: Overrides;\n wrapper?: FC<any>;\n};\n\ntype MarkdownContextValue = {\n renderMarkdown: (\n markdown: string,\n components?: Overrides | RenderMarkdownOptions\n ) => ReactNode;\n};\n\ntype MarkdownProviderProps = PropsWithChildren<\n MarkdownProviderOptions & {\n components?: Overrides;\n wrapper?: any;\n renderMarkdown?: (\n markdown: string,\n overrides?: Overrides | RenderMarkdownOptions\n ) => ReactNode;\n }\n>;\n\nconst MarkdownContext = createContext<MarkdownContextValue | undefined>(\n undefined\n);\n\nexport const useMarkdownContext = () => useContext(MarkdownContext);\n\n// Pure functions defined outside the component are easier for React Compiler to track\n// and don't need to be recreated on every render.\n\nconst isRenderMarkdownOptions = (\n override: any\n): override is RenderMarkdownOptions => {\n return (\n override &&\n typeof override === 'object' &&\n ('components' in override ||\n 'wrapper' in override ||\n 'forceBlock' in override ||\n 'forceInline' in override ||\n 'preserveFrontmatter' in override ||\n 'tagfilter' in override)\n );\n};\n\nconst mergeOptions = (\n baseOptions: MarkdownRendererOptions,\n overrides?: Overrides | RenderMarkdownOptions\n): MarkdownRendererOptions => {\n if (!overrides) return baseOptions;\n\n if (!isRenderMarkdownOptions(overrides)) {\n // Overrides is just a component map\n return {\n ...baseOptions,\n components: { ...baseOptions.components, ...overrides },\n };\n }\n\n // Overrides is a full options object\n const {\n components: overrideComponents,\n wrapper,\n forceBlock,\n forceInline,\n preserveFrontmatter,\n tagfilter,\n ...componentsFromRest\n } = overrides;\n\n const components = overrideComponents || componentsFromRest;\n\n return {\n ...baseOptions,\n forceBlock: forceBlock ?? baseOptions.forceBlock,\n forceInline: forceInline ?? baseOptions.forceInline,\n preserveFrontmatter: preserveFrontmatter ?? baseOptions.preserveFrontmatter,\n tagfilter: tagfilter ?? baseOptions.tagfilter,\n wrapper: wrapper || baseOptions.wrapper,\n\n forceWrapper: !!(wrapper || baseOptions.wrapper),\n components: { ...baseOptions.components, ...components },\n };\n};\n\n/**\n * Provider for the MarkdownRenderer component.\n *\n * It will provide the `renderMarkdown` function to the context, which can be used to render markdown.\n *\n * ```tsx\n * const content = useIntlayer('app');\n *\n * return (\n * <div>\n * {content.markdown} // Will be rendered with the components and options provided to the MarkdownProvider\n * </div>\n * );\n * ```\n *\n * @example\n * ```tsx\n * <MarkdownProvider components={{ h1: CustomHeading }}>\n * <MarkdownRenderer>\n * {markdownContent}\n * </MarkdownRenderer>\n * </MarkdownProvider>\n * ```\n */\nexport const MarkdownProvider: FC<MarkdownProviderProps> = ({\n children,\n components,\n wrapper,\n forceBlock,\n forceInline,\n preserveFrontmatter,\n tagfilter,\n renderMarkdown: customRenderFn,\n}) => {\n const baseOptions: MarkdownRendererOptions = {\n components,\n forceBlock,\n forceInline,\n wrapper,\n forceWrapper: !!wrapper,\n preserveFrontmatter,\n tagfilter,\n };\n\n // Standard internal renderer\n const defaultRenderMarkdown = (\n markdown: string,\n overrides?: Overrides | RenderMarkdownOptions\n ) => {\n const mergedOptions = mergeOptions(baseOptions, overrides);\n return compiler(markdown, mergedOptions);\n };\n\n // Wrapper for user-provided custom renderer\n // Note: We wrap in a clean Provider to prevent infinite recursion\n const customRenderMarkdownWrapper = (\n markdown: string,\n overrides?: Overrides | RenderMarkdownOptions\n ) => (\n <MarkdownContext.Provider value={undefined}>\n {customRenderFn?.(markdown, overrides)}\n </MarkdownContext.Provider>\n );\n\n return (\n <MarkdownContext.Provider\n value={{\n renderMarkdown: customRenderFn\n ? customRenderMarkdownWrapper\n : defaultRenderMarkdown,\n }}\n >\n {children}\n </MarkdownContext.Provider>\n );\n};\n"],"mappings":";;;;;;;AA8CA,MAAM,kBAAkB,cACtB,OACD;AAED,MAAa,2BAA2B,WAAW,gBAAgB;AAKnE,MAAM,2BACJ,aACsC;AACtC,QACE,YACA,OAAO,aAAa,aACnB,gBAAgB,YACf,aAAa,YACb,gBAAgB,YAChB,iBAAiB,YACjB,yBAAyB,YACzB,eAAe;;AAIrB,MAAM,gBACJ,aACA,cAC4B;AAC5B,KAAI,CAAC,UAAW,QAAO;AAEvB,KAAI,CAAC,wBAAwB,UAAU,CAErC,QAAO;EACL,GAAG;EACH,YAAY;GAAE,GAAG,YAAY;GAAY,GAAG;GAAW;EACxD;CAIH,MAAM,EACJ,YAAY,oBACZ,SACA,YACA,aACA,qBACA,WACA,GAAG,uBACD;CAEJ,MAAM,aAAa,sBAAsB;AAEzC,QAAO;EACL,GAAG;EACH,YAAY,cAAc,YAAY;EACtC,aAAa,eAAe,YAAY;EACxC,qBAAqB,uBAAuB,YAAY;EACxD,WAAW,aAAa,YAAY;EACpC,SAAS,WAAW,YAAY;EAEhC,cAAc,CAAC,EAAE,WAAW,YAAY;EACxC,YAAY;GAAE,GAAG,YAAY;GAAY,GAAG;GAAY;EACzD;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BH,MAAa,oBAA+C,EAC1D,UACA,YACA,SACA,YACA,aACA,qBACA,WACA,gBAAgB,qBACZ;CACJ,MAAM,cAAuC;EAC3C;EACA;EACA;EACA;EACA,cAAc,CAAC,CAAC;EAChB;EACA;EACD;CAGD,MAAM,yBACJ,UACA,cACG;AAEH,SAAO,SAAS,UADM,aAAa,aAAa,UAAU,CAClB;;CAK1C,MAAM,+BACJ,UACA,cAEA,oBAAC,gBAAgB;EAAS,OAAO;YAC9B,iBAAiB,UAAU,UAAU;GACb;AAG7B,QACE,oBAAC,gBAAgB;EACf,OAAO,EACL,gBAAgB,iBACZ,8BACA,uBACL;EAEA;GACwB"}
@@ -1,41 +1,200 @@
1
- 'use client';
2
-
3
- import { useEditedContentRenderer } from "../editor/useEditedContentRenderer.mjs";
1
+ import { compiler } from "./processor.mjs";
4
2
  import { useMarkdownContext } from "./MarkdownProvider.mjs";
5
- import { getContent, getContentNodeByKeyPath, getMarkdownMetadata } from "@intlayer/core";
6
- import { useEditorLocale } from "@intlayer/editor-react";
3
+ import { Fragment, jsx } from "react/jsx-runtime";
7
4
 
8
5
  //#region src/markdown/MarkdownRenderer.tsx
9
- const MarkdownRenderer = ({ dictionaryKey, keyPath, children, locale }) => {
10
- const { renderMarkdown } = useMarkdownContext();
11
- const editedContentContext = useEditedContentRenderer({
12
- dictionaryKey,
13
- keyPath,
14
- children
6
+ /**
7
+ * Renders markdown content to JSX with the provided components and options.
8
+ *
9
+ * This function does not use context from MarkdownProvider. Use `useMarkdownRenderer`
10
+ * hook if you want to leverage provider context.
11
+ *
12
+ * @param content - The markdown string to render
13
+ * @param props - Configuration options for rendering
14
+ * @param props.components - Component overrides for HTML tags
15
+ * @param props.wrapper - Wrapper component for multiple children
16
+ * @returns JSX element representing the rendered markdown
17
+ *
18
+ * @example
19
+ * ```tsx
20
+ * import { renderMarkdown } from '@intlayer/react-intlayer/markdown';
21
+ *
22
+ * const markdown = '# Hello World\n\nThis is **bold** text.';
23
+ * const jsx = renderMarkdown(markdown, {
24
+ * components: {
25
+ * h1: ({ children }) => <h1 className="title">{children}</h1>,
26
+ * },
27
+ * forceBlock: true,
28
+ * });
29
+ * ```
30
+ */
31
+ const renderMarkdown = (content, { components, wrapper, forceBlock, forceInline, preserveFrontmatter, tagfilter } = {}) => {
32
+ return compiler(content, {
33
+ components,
34
+ forceBlock,
35
+ forceInline,
36
+ wrapper,
37
+ forceWrapper: !!wrapper,
38
+ preserveFrontmatter,
39
+ tagfilter
15
40
  });
16
- if (typeof editedContentContext !== "string") {
17
- const transformedEditedContent = getContent(editedContentContext, {
18
- dictionaryKey,
19
- keyPath
20
- }, locale);
21
- if (typeof transformedEditedContent !== "string") {
22
- console.error(`Incorrect Markdown content. Edited Markdown content type: ${typeof transformedEditedContent}. Expected string. Value ${JSON.stringify(transformedEditedContent)}`);
23
- return renderMarkdown(children);
24
- }
25
- return renderMarkdown(transformedEditedContent);
26
- }
27
- return renderMarkdown(editedContentContext);
28
41
  };
29
- const MarkdownMetadataRenderer = ({ dictionaryKey, keyPath, children, metadataKeyPath }) => {
30
- const editedContentContext = useEditedContentRenderer({
31
- dictionaryKey,
32
- keyPath,
33
- children
34
- });
35
- const currentLocale = useEditorLocale();
36
- return getContentNodeByKeyPath(getMarkdownMetadata(editedContentContext), metadataKeyPath, currentLocale);
42
+ /**
43
+ * Hook that returns a function to render markdown content.
44
+ *
45
+ * This hook considers the configuration from the `MarkdownProvider` context if available,
46
+ * falling back to the provided props or default behavior.
47
+ *
48
+ * @param props - Optional configuration that will override context values
49
+ * @param props.components - Component overrides for HTML tags (overrides context)
50
+ * @param props.wrapper - Wrapper component (overrides context)
51
+ * @returns A function that takes markdown content and returns JSX
52
+ *
53
+ * @example
54
+ * ```tsx
55
+ * import { useMarkdownRenderer } from '@intlayer/react-intlayer/markdown';
56
+ *
57
+ * function MyComponent() {
58
+ * const renderMarkdown = useMarkdownRenderer({
59
+ * components: {
60
+ * h1: ({ children }) => <h1 className="custom">{children}</h1>,
61
+ * },
62
+ * });
63
+ *
64
+ * return (
65
+ * <div>
66
+ * {renderMarkdown('# Hello\n\nThis is **markdown**')}
67
+ * </div>
68
+ * );
69
+ * }
70
+ * ```
71
+ *
72
+ * @example
73
+ * ```tsx
74
+ * // With MarkdownProvider context
75
+ * function App() {
76
+ * return (
77
+ * <MarkdownProvider
78
+ * components={{ h1: CustomHeading }}
79
+ * forceBlock={true}
80
+ * >
81
+ * <MyComponent />
82
+ * </MarkdownProvider>
83
+ * );
84
+ * }
85
+ * ```
86
+ */
87
+ const useMarkdownRenderer = ({ components, wrapper, forceBlock, forceInline, preserveFrontmatter, tagfilter } = {}) => {
88
+ const context = useMarkdownContext();
89
+ return (content) => {
90
+ if (context) return context.renderMarkdown(content, {
91
+ components,
92
+ wrapper,
93
+ forceBlock,
94
+ forceInline,
95
+ preserveFrontmatter,
96
+ tagfilter
97
+ });
98
+ return renderMarkdown(content, {
99
+ components,
100
+ wrapper,
101
+ forceBlock,
102
+ forceInline,
103
+ preserveFrontmatter,
104
+ tagfilter
105
+ });
106
+ };
107
+ };
108
+ /**
109
+ * React component that renders markdown content to JSX.
110
+ *
111
+ * This component uses the `renderMarkdown` function from the `MarkdownProvider` context
112
+ * if available. Otherwise, it falls back to the default compiler with provided components
113
+ * and options. You can also provide a custom `renderMarkdown` function prop to override
114
+ * all rendering behavior.
115
+ *
116
+ * @example
117
+ * ```tsx
118
+ * import { MarkdownRenderer } from '@intlayer/react-intlayer/markdown';
119
+ *
120
+ * function MyComponent() {
121
+ * return (
122
+ * <MarkdownRenderer>
123
+ * {`# Hello World
124
+ *
125
+ * This is a paragraph with **bold** and *italic* text.
126
+ *
127
+ * - List item 1
128
+ * - List item 2`}
129
+ * </MarkdownRenderer>
130
+ * );
131
+ * }
132
+ * ```
133
+ *
134
+ * @example
135
+ * ```tsx
136
+ * // With custom components
137
+ * <MarkdownRenderer
138
+ * components={{
139
+ * h1: ({ children }) => <h1 className="text-4xl font-bold">{children}</h1>,
140
+ * a: ({ href, children }) => (
141
+ * <a href={href} className="text-blue-500 hover:underline">
142
+ * {children}
143
+ * </a>
144
+ * ),
145
+ * }}
146
+ * forceBlock={true}
147
+ * >
148
+ * {markdownContent}
149
+ * </MarkdownRenderer>
150
+ * ```
151
+ *
152
+ * @example
153
+ * ```tsx
154
+ * // With MarkdownProvider context
155
+ * function App() {
156
+ * return (
157
+ * <MarkdownProvider
158
+ * components={{ h1: CustomHeading }}
159
+ * forceBlock={true}
160
+ * >
161
+ * <MarkdownRenderer>
162
+ * {markdownContent}
163
+ * </MarkdownRenderer>
164
+ * </MarkdownProvider>
165
+ * );
166
+ * }
167
+ * ```
168
+ */
169
+ const MarkdownRenderer = ({ children = "", components, wrapper, forceBlock, forceInline, preserveFrontmatter, tagfilter, renderMarkdown }) => {
170
+ const context = useMarkdownContext();
171
+ if (renderMarkdown) return /* @__PURE__ */ jsx(Fragment, { children: renderMarkdown(children, {
172
+ components,
173
+ wrapper,
174
+ forceBlock,
175
+ forceInline,
176
+ preserveFrontmatter,
177
+ tagfilter
178
+ }) });
179
+ if (context) return /* @__PURE__ */ jsx(Fragment, { children: context.renderMarkdown(children, {
180
+ components,
181
+ wrapper,
182
+ forceBlock,
183
+ forceInline,
184
+ preserveFrontmatter,
185
+ tagfilter
186
+ }) });
187
+ return /* @__PURE__ */ jsx(Fragment, { children: compiler(children, {
188
+ components,
189
+ forceBlock,
190
+ forceInline,
191
+ wrapper,
192
+ forceWrapper: !!wrapper,
193
+ preserveFrontmatter,
194
+ tagfilter
195
+ }) });
37
196
  };
38
197
 
39
198
  //#endregion
40
- export { MarkdownMetadataRenderer, MarkdownRenderer };
199
+ export { MarkdownRenderer, renderMarkdown, useMarkdownRenderer };
41
200
  //# sourceMappingURL=MarkdownRenderer.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"MarkdownRenderer.mjs","names":[],"sources":["../../../src/markdown/MarkdownRenderer.tsx"],"sourcesContent":["'use client';\n\nimport {\n getContent,\n getContentNodeByKeyPath,\n getMarkdownMetadata,\n} from '@intlayer/core';\nimport { useEditorLocale } from '@intlayer/editor-react';\nimport type { ContentNode, KeyPath, LocalesValues } from '@intlayer/types';\nimport type { FC, ReactNode } from 'react';\nimport { useEditedContentRenderer } from '../editor/useEditedContentRenderer';\nimport { useMarkdownContext } from './MarkdownProvider';\n\ntype MarkdownRendererProps = {\n dictionaryKey: string;\n keyPath: KeyPath[];\n locale?: LocalesValues;\n children: string;\n};\n\nexport const MarkdownRenderer: FC<MarkdownRendererProps> = ({\n dictionaryKey,\n keyPath,\n children,\n locale,\n}): ReactNode => {\n const { renderMarkdown } = useMarkdownContext();\n const editedContentContext = useEditedContentRenderer({\n dictionaryKey,\n keyPath,\n children,\n });\n\n if (typeof editedContentContext !== 'string') {\n const transformedEditedContent = getContent(\n editedContentContext,\n {\n dictionaryKey,\n keyPath,\n },\n locale\n );\n\n if (typeof transformedEditedContent !== 'string') {\n console.error(\n `Incorrect Markdown content. Edited Markdown content type: ${typeof transformedEditedContent}. Expected string. Value ${JSON.stringify(transformedEditedContent)}`\n );\n\n return renderMarkdown(children);\n }\n\n return renderMarkdown(transformedEditedContent);\n }\n\n return renderMarkdown(editedContentContext);\n};\n\ntype MarkdownMetadataRendererProps = MarkdownRendererProps & {\n metadataKeyPath: KeyPath[];\n};\n\nexport const MarkdownMetadataRenderer: FC<MarkdownMetadataRendererProps> = ({\n dictionaryKey,\n keyPath,\n children,\n metadataKeyPath,\n}): ReactNode => {\n const editedContentContext = useEditedContentRenderer({\n dictionaryKey,\n keyPath,\n children,\n });\n const currentLocale = useEditorLocale();\n\n const metadata = getMarkdownMetadata(editedContentContext);\n\n const metadataEl = getContentNodeByKeyPath(\n metadata as ContentNode,\n metadataKeyPath,\n currentLocale\n );\n\n return metadataEl as ReactNode;\n};\n"],"mappings":";;;;;;;;AAoBA,MAAa,oBAA+C,EAC1D,eACA,SACA,UACA,aACe;CACf,MAAM,EAAE,mBAAmB,oBAAoB;CAC/C,MAAM,uBAAuB,yBAAyB;EACpD;EACA;EACA;EACD,CAAC;AAEF,KAAI,OAAO,yBAAyB,UAAU;EAC5C,MAAM,2BAA2B,WAC/B,sBACA;GACE;GACA;GACD,EACD,OACD;AAED,MAAI,OAAO,6BAA6B,UAAU;AAChD,WAAQ,MACN,6DAA6D,OAAO,yBAAyB,2BAA2B,KAAK,UAAU,yBAAyB,GACjK;AAED,UAAO,eAAe,SAAS;;AAGjC,SAAO,eAAe,yBAAyB;;AAGjD,QAAO,eAAe,qBAAqB;;AAO7C,MAAa,4BAA+D,EAC1E,eACA,SACA,UACA,sBACe;CACf,MAAM,uBAAuB,yBAAyB;EACpD;EACA;EACA;EACD,CAAC;CACF,MAAM,gBAAgB,iBAAiB;AAUvC,QANmB,wBAFF,oBAAoB,qBAAqB,EAIxD,iBACA,cACD"}
1
+ {"version":3,"file":"MarkdownRenderer.mjs","names":[],"sources":["../../../src/markdown/MarkdownRenderer.tsx"],"sourcesContent":["import type { Overrides } from '@intlayer/core';\nimport type { FC, JSX, ReactNode } from 'react';\nimport {\n type MarkdownProviderOptions,\n useMarkdownContext,\n} from './MarkdownProvider';\nimport { compiler, type MarkdownRendererOptions } from './processor';\n\n/**\n * Props for rendering markdown content.\n *\n * @example\n * ```tsx\n * const props: RenderMarkdownProps = {\n * components: {\n * h1: ({ children }) => <h1 className=\"text-3xl\">{children}</h1>,\n * p: ({ children }) => <p className=\"text-gray-700\">{children}</p>,\n * },\n * wrapper: ({ children }) => <article>{children}</article>,\n * options: {\n * forceBlock: true,\n * preserveFrontmatter: false,\n * tagfilter: true,\n * },\n * };\n * ```\n */\nexport type RenderMarkdownProps = MarkdownProviderOptions & {\n /**\n * Component overrides for HTML tags.\n * Allows you to customize how specific HTML elements are rendered.\n * Only used if not wrapped in a MarkdownProvider.\n *\n * @example\n * ```tsx\n * components={{\n * h1: ({ children }) => <h1 className=\"title\">{children}</h1>,\n * a: ({ href, children }) => <Link to={href}>{children}</Link>,\n * }}\n * ```\n */\n components?: Overrides;\n /**\n * Wrapper element or component to be used when there are multiple children.\n * Only used if not wrapped in a MarkdownProvider.\n *\n * @example\n * ```tsx\n * wrapper={({ children }) => <div className=\"markdown-content\">{children}</div>}\n * ```\n */\n wrapper?: FC;\n};\n\n/**\n * Renders markdown content to JSX with the provided components and options.\n *\n * This function does not use context from MarkdownProvider. Use `useMarkdownRenderer`\n * hook if you want to leverage provider context.\n *\n * @param content - The markdown string to render\n * @param props - Configuration options for rendering\n * @param props.components - Component overrides for HTML tags\n * @param props.wrapper - Wrapper component for multiple children\n * @returns JSX element representing the rendered markdown\n *\n * @example\n * ```tsx\n * import { renderMarkdown } from '@intlayer/react-intlayer/markdown';\n *\n * const markdown = '# Hello World\\n\\nThis is **bold** text.';\n * const jsx = renderMarkdown(markdown, {\n * components: {\n * h1: ({ children }) => <h1 className=\"title\">{children}</h1>,\n * },\n * forceBlock: true,\n * });\n * ```\n */\nexport const renderMarkdown = (\n content: string,\n {\n components,\n wrapper,\n forceBlock,\n forceInline,\n preserveFrontmatter,\n tagfilter,\n }: RenderMarkdownProps = {}\n): JSX.Element => {\n // Map public options to internal processor options\n const internalOptions: MarkdownRendererOptions = {\n components,\n forceBlock,\n forceInline,\n wrapper,\n forceWrapper: !!wrapper,\n preserveFrontmatter,\n tagfilter,\n };\n\n return compiler(content, internalOptions);\n};\n\n/**\n * Hook that returns a function to render markdown content.\n *\n * This hook considers the configuration from the `MarkdownProvider` context if available,\n * falling back to the provided props or default behavior.\n *\n * @param props - Optional configuration that will override context values\n * @param props.components - Component overrides for HTML tags (overrides context)\n * @param props.wrapper - Wrapper component (overrides context)\n * @returns A function that takes markdown content and returns JSX\n *\n * @example\n * ```tsx\n * import { useMarkdownRenderer } from '@intlayer/react-intlayer/markdown';\n *\n * function MyComponent() {\n * const renderMarkdown = useMarkdownRenderer({\n * components: {\n * h1: ({ children }) => <h1 className=\"custom\">{children}</h1>,\n * },\n * });\n *\n * return (\n * <div>\n * {renderMarkdown('# Hello\\n\\nThis is **markdown**')}\n * </div>\n * );\n * }\n * ```\n *\n * @example\n * ```tsx\n * // With MarkdownProvider context\n * function App() {\n * return (\n * <MarkdownProvider\n * components={{ h1: CustomHeading }}\n * forceBlock={true}\n * >\n * <MyComponent />\n * </MarkdownProvider>\n * );\n * }\n * ```\n */\nexport const useMarkdownRenderer = ({\n components,\n wrapper,\n forceBlock,\n forceInline,\n preserveFrontmatter,\n tagfilter,\n}: RenderMarkdownProps = {}) => {\n const context = useMarkdownContext();\n\n return (content: string) => {\n if (context) {\n return context.renderMarkdown(content, {\n components,\n wrapper,\n forceBlock,\n forceInline,\n preserveFrontmatter,\n tagfilter,\n });\n }\n\n return renderMarkdown(content, {\n components,\n wrapper,\n forceBlock,\n forceInline,\n preserveFrontmatter,\n tagfilter,\n });\n };\n};\n\n/**\n * Props for the MarkdownRenderer component.\n *\n * @example\n * ```tsx\n * const props: MarkdownRendererProps = {\n * children: '# Hello World\\n\\nThis is **bold** text.',\n * components: {\n * h1: ({ children }) => <h1 className=\"title\">{children}</h1>,\n * },\n * wrapper: ({ children }) => <article>{children}</article>,\n * forceBlock: true,\n * };\n * ```\n */\nexport type MarkdownRendererProps = RenderMarkdownProps & {\n /**\n * The markdown content to render as a string.\n *\n * @example\n * ```tsx\n * <MarkdownRenderer>\n * {`# Title\\n\\nParagraph with **bold** text.`}\n * </MarkdownRenderer>\n * ```\n */\n children: string;\n /**\n * Custom render function for markdown.\n * If provided, it will overwrite context and default rendering.\n *\n * @param markdown - The markdown string to render\n * @param options - Optional rendering options\n * @returns React node representing the rendered markdown\n *\n * @example\n * ```tsx\n * <MarkdownRenderer\n * renderMarkdown={(md, opts) => {\n * // Custom rendering logic\n * return <div dangerouslySetInnerHTML={{ __html: customParser(md) }} />;\n * }}\n * >\n * {markdownContent}\n * </MarkdownRenderer>\n * ```\n */\n renderMarkdown?: (\n markdown: string,\n options?: {\n components?: Overrides;\n wrapper?: FC;\n forceBlock?: boolean;\n forceInline?: boolean;\n preserveFrontmatter?: boolean;\n tagfilter?: boolean;\n }\n ) => ReactNode;\n};\n\n/**\n * React component that renders markdown content to JSX.\n *\n * This component uses the `renderMarkdown` function from the `MarkdownProvider` context\n * if available. Otherwise, it falls back to the default compiler with provided components\n * and options. You can also provide a custom `renderMarkdown` function prop to override\n * all rendering behavior.\n *\n * @example\n * ```tsx\n * import { MarkdownRenderer } from '@intlayer/react-intlayer/markdown';\n *\n * function MyComponent() {\n * return (\n * <MarkdownRenderer>\n * {`# Hello World\n *\n * This is a paragraph with **bold** and *italic* text.\n *\n * - List item 1\n * - List item 2`}\n * </MarkdownRenderer>\n * );\n * }\n * ```\n *\n * @example\n * ```tsx\n * // With custom components\n * <MarkdownRenderer\n * components={{\n * h1: ({ children }) => <h1 className=\"text-4xl font-bold\">{children}</h1>,\n * a: ({ href, children }) => (\n * <a href={href} className=\"text-blue-500 hover:underline\">\n * {children}\n * </a>\n * ),\n * }}\n * forceBlock={true}\n * >\n * {markdownContent}\n * </MarkdownRenderer>\n * ```\n *\n * @example\n * ```tsx\n * // With MarkdownProvider context\n * function App() {\n * return (\n * <MarkdownProvider\n * components={{ h1: CustomHeading }}\n * forceBlock={true}\n * >\n * <MarkdownRenderer>\n * {markdownContent}\n * </MarkdownRenderer>\n * </MarkdownProvider>\n * );\n * }\n * ```\n */\nexport const MarkdownRenderer: FC<MarkdownRendererProps> = ({\n children = '',\n components,\n wrapper,\n forceBlock,\n forceInline,\n preserveFrontmatter,\n tagfilter,\n renderMarkdown,\n}) => {\n const context = useMarkdownContext();\n\n if (renderMarkdown) {\n return (\n <>\n {renderMarkdown(children, {\n components,\n wrapper,\n forceBlock,\n forceInline,\n preserveFrontmatter,\n tagfilter,\n })}\n </>\n );\n }\n\n if (context) {\n return (\n <>\n {context.renderMarkdown(children, {\n components,\n wrapper,\n forceBlock,\n forceInline,\n preserveFrontmatter,\n tagfilter,\n })}\n </>\n );\n }\n\n // Map public options to internal processor options\n const internalOptions: MarkdownRendererOptions = {\n components,\n forceBlock,\n forceInline,\n wrapper,\n forceWrapper: !!wrapper,\n preserveFrontmatter,\n tagfilter,\n };\n\n return <>{compiler(children, internalOptions)}</>;\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+EA,MAAa,kBACX,SACA,EACE,YACA,SACA,YACA,aACA,qBACA,cACuB,EAAE,KACX;AAYhB,QAAO,SAAS,SAViC;EAC/C;EACA;EACA;EACA;EACA,cAAc,CAAC,CAAC;EAChB;EACA;EACD,CAEwC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgD3C,MAAa,uBAAuB,EAClC,YACA,SACA,YACA,aACA,qBACA,cACuB,EAAE,KAAK;CAC9B,MAAM,UAAU,oBAAoB;AAEpC,SAAQ,YAAoB;AAC1B,MAAI,QACF,QAAO,QAAQ,eAAe,SAAS;GACrC;GACA;GACA;GACA;GACA;GACA;GACD,CAAC;AAGJ,SAAO,eAAe,SAAS;GAC7B;GACA;GACA;GACA;GACA;GACA;GACD,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6HN,MAAa,oBAA+C,EAC1D,WAAW,IACX,YACA,SACA,YACA,aACA,qBACA,WACA,qBACI;CACJ,MAAM,UAAU,oBAAoB;AAEpC,KAAI,eACF,QACE,0CACG,eAAe,UAAU;EACxB;EACA;EACA;EACA;EACA;EACA;EACD,CAAC,GACD;AAIP,KAAI,QACF,QACE,0CACG,QAAQ,eAAe,UAAU;EAChC;EACA;EACA;EACA;EACA;EACA;EACD,CAAC,GACD;AAeP,QAAO,0CAAG,SAAS,UAV8B;EAC/C;EACA;EACA;EACA;EACA,cAAc,CAAC,CAAC;EAChB;EACA;EACD,CAE4C,GAAI"}
@@ -0,0 +1,31 @@
1
+ 'use client';
2
+
3
+ import { useEditedContentRenderer } from "../editor/useEditedContentRenderer.mjs";
4
+ import { useMarkdownContext } from "./MarkdownProvider.mjs";
5
+ import { getContentNodeByKeyPath, getMarkdownMetadata } from "@intlayer/core";
6
+ import { useEditorLocale } from "@intlayer/editor-react";
7
+
8
+ //#region src/markdown/MarkdownRendererPlugin.tsx
9
+ const MarkdownRendererPlugin = (props) => {
10
+ const { dictionaryKey, keyPath, children, locale, ...components } = props;
11
+ const renderMarkdown = useMarkdownContext()?.renderMarkdown ?? ((md) => md);
12
+ const editedContentContext = useEditedContentRenderer({
13
+ dictionaryKey,
14
+ keyPath,
15
+ children
16
+ });
17
+ return renderMarkdown(typeof editedContentContext === "string" ? editedContentContext : children, components);
18
+ };
19
+ const MarkdownMetadataRenderer = ({ dictionaryKey, keyPath, children, metadataKeyPath }) => {
20
+ const editedContentContext = useEditedContentRenderer({
21
+ dictionaryKey,
22
+ keyPath,
23
+ children
24
+ });
25
+ const currentLocale = useEditorLocale();
26
+ return getContentNodeByKeyPath(getMarkdownMetadata(editedContentContext), metadataKeyPath, currentLocale);
27
+ };
28
+
29
+ //#endregion
30
+ export { MarkdownMetadataRenderer, MarkdownRendererPlugin };
31
+ //# sourceMappingURL=MarkdownRendererPlugin.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarkdownRendererPlugin.mjs","names":[],"sources":["../../../src/markdown/MarkdownRendererPlugin.tsx"],"sourcesContent":["'use client';\n\nimport { getContentNodeByKeyPath, getMarkdownMetadata } from '@intlayer/core';\nimport { useEditorLocale } from '@intlayer/editor-react';\nimport type { ContentNode, KeyPath, LocalesValues } from '@intlayer/types';\nimport type { FC, ReactNode } from 'react';\nimport { useEditedContentRenderer } from '../editor/useEditedContentRenderer';\nimport { useMarkdownContext } from './MarkdownProvider';\n\ntype MarkdownRendererPluginProps = {\n dictionaryKey: string;\n keyPath: KeyPath[];\n locale?: LocalesValues;\n children: string;\n [key: string]: any;\n};\n\nexport const MarkdownRendererPlugin: FC<MarkdownRendererPluginProps> = (\n props\n): ReactNode => {\n const { dictionaryKey, keyPath, children, locale, ...components } = props;\n const context = useMarkdownContext();\n const renderMarkdown = context?.renderMarkdown ?? ((md) => md);\n const editedContentContext = useEditedContentRenderer({\n dictionaryKey,\n keyPath,\n children,\n });\n\n const contentToRender =\n typeof editedContentContext === 'string' ? editedContentContext : children;\n\n return renderMarkdown(contentToRender, components);\n};\n\ntype MarkdownMetadataRendererProps = MarkdownRendererPluginProps & {\n metadataKeyPath: KeyPath[];\n};\n\nexport const MarkdownMetadataRenderer: FC<MarkdownMetadataRendererProps> = ({\n dictionaryKey,\n keyPath,\n children,\n metadataKeyPath,\n}): ReactNode => {\n const editedContentContext = useEditedContentRenderer({\n dictionaryKey,\n keyPath,\n children,\n });\n const currentLocale = useEditorLocale();\n\n const metadata = getMarkdownMetadata(editedContentContext);\n\n const metadataEl = getContentNodeByKeyPath(\n metadata as ContentNode,\n metadataKeyPath,\n currentLocale\n );\n\n return metadataEl as ReactNode;\n};\n"],"mappings":";;;;;;;;AAiBA,MAAa,0BACX,UACc;CACd,MAAM,EAAE,eAAe,SAAS,UAAU,QAAQ,GAAG,eAAe;CAEpE,MAAM,iBADU,oBAAoB,EACJ,oBAAoB,OAAO;CAC3D,MAAM,uBAAuB,yBAAyB;EACpD;EACA;EACA;EACD,CAAC;AAKF,QAAO,eAFL,OAAO,yBAAyB,WAAW,uBAAuB,UAE7B,WAAW;;AAOpD,MAAa,4BAA+D,EAC1E,eACA,SACA,UACA,sBACe;CACf,MAAM,uBAAuB,yBAAyB;EACpD;EACA;EACA;EACD,CAAC;CACF,MAAM,gBAAgB,iBAAiB;AAUvC,QANmB,wBAFF,oBAAoB,qBAAqB,EAIxD,iBACA,cACD"}
@@ -1,4 +1,7 @@
1
+ import { LegacyMarkdownRenderer, RuleType, compile, compileMarkdown, compiler, sanitizer as defaultSanitizer, slugify as defaultSlugify } from "./processor.mjs";
1
2
  import { MarkdownProvider, useMarkdownContext } from "./MarkdownProvider.mjs";
2
- import { MarkdownMetadataRenderer, MarkdownRenderer } from "./MarkdownRenderer.mjs";
3
+ import { MarkdownRenderer, renderMarkdown, useMarkdownRenderer } from "./MarkdownRenderer.mjs";
4
+ import { MarkdownMetadataRenderer, MarkdownRendererPlugin } from "./MarkdownRendererPlugin.mjs";
5
+ import { createReactRuntime, reactRuntime } from "./runtime.mjs";
3
6
 
4
- export { MarkdownMetadataRenderer, MarkdownProvider, MarkdownRenderer, useMarkdownContext };
7
+ export { LegacyMarkdownRenderer, MarkdownMetadataRenderer, MarkdownProvider, MarkdownRenderer, MarkdownRendererPlugin, RuleType, compile, compileMarkdown, compiler, createReactRuntime, reactRuntime, renderMarkdown, defaultSanitizer as sanitizer, defaultSlugify as slugify, useMarkdownContext, useMarkdownRenderer };
@@ -0,0 +1,54 @@
1
+ import { Fragment, cloneElement, createElement } from "react";
2
+ import { RuleType, compile as compile$1, sanitizer as defaultSanitizer, slugify as defaultSlugify } from "@intlayer/core";
3
+
4
+ //#region src/markdown/processor.tsx
5
+ /**
6
+ * Default React runtime for markdown rendering.
7
+ */
8
+ const DEFAULT_RUNTIME = {
9
+ createElement,
10
+ cloneElement,
11
+ Fragment,
12
+ normalizeProps: (_tag, props) => props
13
+ };
14
+ /**
15
+ * Compile markdown to React elements.
16
+ * This is the primary export - use this for new code.
17
+ */
18
+ const compileMarkdown = (markdown = "", options = {}) => {
19
+ const { createElement: customCreateElement, disableAutoLink, disableParsingRawHTML, enforceAtxHeadings, forceBlock, forceInline, forceWrapper, namedCodesToUnicode, components, renderRule, sanitizer, slugify, wrapper, preserveFrontmatter, tagfilter } = options;
20
+ return compile$1(markdown, {
21
+ runtime: customCreateElement ? {
22
+ ...DEFAULT_RUNTIME,
23
+ createElement: customCreateElement
24
+ } : DEFAULT_RUNTIME,
25
+ components,
26
+ namedCodesToUnicode,
27
+ sanitizer,
28
+ slugify
29
+ }, {
30
+ disableAutoLink,
31
+ disableParsingRawHTML,
32
+ enforceAtxHeadings,
33
+ forceBlock,
34
+ forceInline,
35
+ forceWrapper,
36
+ renderRule,
37
+ wrapper,
38
+ preserveFrontmatter,
39
+ tagfilter
40
+ });
41
+ };
42
+ const compiler = compileMarkdown;
43
+ const compile = compileMarkdown;
44
+ /**
45
+ * React component that renders markdown to JSX (legacy).
46
+ */
47
+ const LegacyMarkdownRenderer = ({ children = "", options, ...props }) => {
48
+ if (process.env.NODE_ENV !== "production" && typeof children !== "string") console.error("intlayer: <Markdown> component only accepts a single string as a child, received:", children);
49
+ return cloneElement(compiler(children, options), props);
50
+ };
51
+
52
+ //#endregion
53
+ export { LegacyMarkdownRenderer, RuleType, compile, compileMarkdown, compiler, defaultSanitizer as sanitizer, defaultSlugify as slugify };
54
+ //# sourceMappingURL=processor.mjs.map