robindoc 3.2.0 → 3.3.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 (172) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +1 -1
  3. package/lib/components/blocks/anchor-heading/index.js.map +1 -1
  4. package/lib/components/blocks/breadcrumbs/index.js +1 -1
  5. package/lib/components/blocks/breadcrumbs/index.js.map +1 -1
  6. package/lib/components/blocks/code-section/index.js.map +1 -1
  7. package/lib/components/blocks/contents/index.js +1 -1
  8. package/lib/components/blocks/contents/index.js.map +1 -1
  9. package/lib/components/blocks/header-menu/index.js +1 -1
  10. package/lib/components/blocks/header-menu/index.js.map +1 -1
  11. package/lib/components/blocks/header-social/index.js +1 -1
  12. package/lib/components/blocks/header-social/index.js.map +1 -1
  13. package/lib/components/blocks/last-modified/index.js +1 -1
  14. package/lib/components/blocks/last-modified/index.js.map +1 -1
  15. package/lib/components/blocks/nav-content-link/index.js +1 -1
  16. package/lib/components/blocks/nav-content-link/index.js.map +1 -1
  17. package/lib/components/blocks/nav-link/index.d.ts +5 -18
  18. package/lib/components/blocks/nav-link/index.d.ts.map +1 -1
  19. package/lib/components/blocks/nav-link/index.js +1 -1
  20. package/lib/components/blocks/nav-link/index.js.map +1 -1
  21. package/lib/components/blocks/no-js/index.js.map +1 -1
  22. package/lib/components/blocks/pagination/index.js.map +1 -1
  23. package/lib/components/blocks/search/index.js +1 -1
  24. package/lib/components/blocks/search/index.js.map +1 -1
  25. package/lib/components/blocks/search/search-modal/index.js +1 -1
  26. package/lib/components/blocks/search/search-modal/index.js.map +1 -1
  27. package/lib/components/blocks/section-dropdown/index.js +1 -1
  28. package/lib/components/blocks/section-dropdown/index.js.map +1 -1
  29. package/lib/components/blocks/theme-detector/index.js +1 -1
  30. package/lib/components/blocks/theme-detector/index.js.map +1 -1
  31. package/lib/components/blocks/theme-styles/index.js +1 -1
  32. package/lib/components/blocks/theme-styles/index.js.map +1 -1
  33. package/lib/components/blocks/theme-switcher/index.js.map +1 -1
  34. package/lib/components/contexts/contents/context.d.ts +0 -1
  35. package/lib/components/contexts/contents/context.d.ts.map +1 -1
  36. package/lib/components/contexts/contents/context.js.map +1 -1
  37. package/lib/components/contexts/contents/provider.js +1 -1
  38. package/lib/components/contexts/contents/provider.js.map +1 -1
  39. package/lib/components/contexts/contents/use-heading-index.js.map +1 -1
  40. package/lib/components/contexts/contents/use-heading-register.js +1 -1
  41. package/lib/components/contexts/contents/use-heading-register.js.map +1 -1
  42. package/lib/components/contexts/navigate/context.d.ts +0 -1
  43. package/lib/components/contexts/navigate/context.d.ts.map +1 -1
  44. package/lib/components/contexts/navigate/context.js.map +1 -1
  45. package/lib/components/contexts/navigate/provider.js +1 -1
  46. package/lib/components/contexts/navigate/provider.js.map +1 -1
  47. package/lib/components/contexts/navigate/use-navigate.js +1 -1
  48. package/lib/components/contexts/navigate/use-navigate.js.map +1 -1
  49. package/lib/components/contexts/reference/context.d.ts +0 -1
  50. package/lib/components/contexts/reference/context.d.ts.map +1 -1
  51. package/lib/components/contexts/reference/context.js.map +1 -1
  52. package/lib/components/contexts/reference/provider.js.map +1 -1
  53. package/lib/components/contexts/reference/use-reference.js.map +1 -1
  54. package/lib/components/elements/article/document.d.ts.map +1 -1
  55. package/lib/components/elements/article/document.js +1 -1
  56. package/lib/components/elements/article/document.js.map +1 -1
  57. package/lib/components/elements/article/index.js.map +1 -1
  58. package/lib/components/elements/article/utils.d.ts +1 -1
  59. package/lib/components/elements/article/utils.d.ts.map +1 -1
  60. package/lib/components/elements/article/utils.js +1 -1
  61. package/lib/components/elements/article/utils.js.map +1 -1
  62. package/lib/components/elements/footer/index.js.map +1 -1
  63. package/lib/components/elements/header/index.js +1 -1
  64. package/lib/components/elements/header/index.js.map +1 -1
  65. package/lib/components/elements/keylink-to-content/index.js.map +1 -1
  66. package/lib/components/elements/keylink-to-navigation/index.js.map +1 -1
  67. package/lib/components/elements/robin-provider/index.js.map +1 -1
  68. package/lib/components/elements/sidebar/index.js +1 -1
  69. package/lib/components/elements/sidebar/index.js.map +1 -1
  70. package/lib/components/elements/sidebar/sidebar-drop/index.js +1 -1
  71. package/lib/components/elements/sidebar/sidebar-drop/index.js.map +1 -1
  72. package/lib/components/elements/sidebar/sidebar-link/index.js.map +1 -1
  73. package/lib/components/elements/sidebar/sidebar-menu/index.js +1 -1
  74. package/lib/components/elements/sidebar/sidebar-menu/index.js.map +1 -1
  75. package/lib/components/elements/sidebar/tools.d.ts.map +1 -1
  76. package/lib/components/elements/sidebar/tools.js +1 -1
  77. package/lib/components/elements/sidebar/tools.js.map +1 -1
  78. package/lib/components/ui/backdrop/index.js.map +1 -1
  79. package/lib/components/ui/block/index.js.map +1 -1
  80. package/lib/components/ui/blockquote/data.d.ts +0 -1
  81. package/lib/components/ui/blockquote/data.d.ts.map +1 -1
  82. package/lib/components/ui/blockquote/data.js +1 -1
  83. package/lib/components/ui/blockquote/data.js.map +1 -1
  84. package/lib/components/ui/blockquote/icons.js.map +1 -1
  85. package/lib/components/ui/blockquote/index.js.map +1 -1
  86. package/lib/components/ui/code-block/index.js +1 -1
  87. package/lib/components/ui/code-block/index.js.map +1 -1
  88. package/lib/components/ui/code-block/theme.js.map +1 -1
  89. package/lib/components/ui/code-span/index.js.map +1 -1
  90. package/lib/components/ui/container/index.js.map +1 -1
  91. package/lib/components/ui/content-link/index.d.ts.map +1 -1
  92. package/lib/components/ui/content-link/index.js.map +1 -1
  93. package/lib/components/ui/copy-button/index.js +1 -1
  94. package/lib/components/ui/copy-button/index.js.map +1 -1
  95. package/lib/components/ui/copy-text/index.js +1 -1
  96. package/lib/components/ui/copy-text/index.js.map +1 -1
  97. package/lib/components/ui/del/index.js.map +1 -1
  98. package/lib/components/ui/em/index.js.map +1 -1
  99. package/lib/components/ui/external-mark/index.js.map +1 -1
  100. package/lib/components/ui/git-logos/index.js.map +1 -1
  101. package/lib/components/ui/heading/index.js +1 -1
  102. package/lib/components/ui/heading/index.js.map +1 -1
  103. package/lib/components/ui/hr/index.js.map +1 -1
  104. package/lib/components/ui/img/index.js.map +1 -1
  105. package/lib/components/ui/list/list-item/index.js.map +1 -1
  106. package/lib/components/ui/list/ordered-list/index.js.map +1 -1
  107. package/lib/components/ui/list/unordered-list/index.js.map +1 -1
  108. package/lib/components/ui/modal/index.js.map +1 -1
  109. package/lib/components/ui/modal/use-modal.js +1 -1
  110. package/lib/components/ui/modal/use-modal.js.map +1 -1
  111. package/lib/components/ui/paragraph/index.js.map +1 -1
  112. package/lib/components/ui/strong/index.js.map +1 -1
  113. package/lib/components/ui/table/table/index.js.map +1 -1
  114. package/lib/components/ui/table/tbody/index.js.map +1 -1
  115. package/lib/components/ui/table/td/index.js.map +1 -1
  116. package/lib/components/ui/table/th/index.js.map +1 -1
  117. package/lib/components/ui/table/thead/index.js.map +1 -1
  118. package/lib/components/ui/table/tr/index.js.map +1 -1
  119. package/lib/components/ui/tabs/index.js +1 -1
  120. package/lib/components/ui/tabs/index.js.map +1 -1
  121. package/lib/components/ui/tabs/tabs-header/index.js +1 -1
  122. package/lib/components/ui/tabs/tabs-header/index.js.map +1 -1
  123. package/lib/components/ui/tabs/tabs-styles/index.js +1 -1
  124. package/lib/components/ui/tabs/tabs-styles/index.js.map +1 -1
  125. package/lib/components/ui/task-list/task-list-item/index.js.map +1 -1
  126. package/lib/components/ui/task-list/task-unordered-list/index.js.map +1 -1
  127. package/lib/components/ui/tooltip/index.js.map +1 -1
  128. package/lib/core/data/contents.js.map +1 -1
  129. package/lib/core/hooks/use-debouncer.d.ts.map +1 -1
  130. package/lib/core/hooks/use-debouncer.js +1 -1
  131. package/lib/core/hooks/use-debouncer.js.map +1 -1
  132. package/lib/core/hooks/use-system-type.js +1 -1
  133. package/lib/core/hooks/use-system-type.js.map +1 -1
  134. package/lib/core/providers/base.js +1 -1
  135. package/lib/core/providers/base.js.map +1 -1
  136. package/lib/core/providers/file-system.js +1 -1
  137. package/lib/core/providers/file-system.js.map +1 -1
  138. package/lib/core/providers/github.js +1 -1
  139. package/lib/core/providers/github.js.map +1 -1
  140. package/lib/core/types/content.d.ts +0 -1
  141. package/lib/core/types/content.d.ts.map +1 -1
  142. package/lib/core/utils/content-tools.d.ts.map +1 -1
  143. package/lib/core/utils/content-tools.js +1 -1
  144. package/lib/core/utils/content-tools.js.map +1 -1
  145. package/lib/core/utils/create-base-searcher.d.ts.map +1 -1
  146. package/lib/core/utils/create-base-searcher.js +1 -1
  147. package/lib/core/utils/create-base-searcher.js.map +1 -1
  148. package/lib/core/utils/detect-provider.d.ts.map +1 -1
  149. package/lib/core/utils/detect-provider.js.map +1 -1
  150. package/lib/core/utils/get-configuration.d.ts.map +1 -1
  151. package/lib/core/utils/get-configuration.js.map +1 -1
  152. package/lib/core/utils/get-metadata.d.ts.map +1 -1
  153. package/lib/core/utils/get-metadata.js +1 -1
  154. package/lib/core/utils/get-metadata.js.map +1 -1
  155. package/lib/core/utils/git-tools.d.ts.map +1 -1
  156. package/lib/core/utils/git-tools.js.map +1 -1
  157. package/lib/core/utils/initialize-robindoc.d.ts.map +1 -1
  158. package/lib/core/utils/initialize-robindoc.js +1 -1
  159. package/lib/core/utils/initialize-robindoc.js.map +1 -1
  160. package/lib/core/utils/load-content.d.ts.map +1 -1
  161. package/lib/core/utils/load-content.js.map +1 -1
  162. package/lib/core/utils/parse-structure.d.ts.map +1 -1
  163. package/lib/core/utils/parse-structure.js.map +1 -1
  164. package/lib/core/utils/path-tools.d.ts.map +1 -1
  165. package/lib/core/utils/path-tools.js +1 -1
  166. package/lib/core/utils/path-tools.js.map +1 -1
  167. package/lib/core/utils/tabs-tools.d.ts.map +1 -1
  168. package/lib/core/utils/tabs-tools.js +1 -1
  169. package/lib/core/utils/tabs-tools.js.map +1 -1
  170. package/lib/styles.css +2045 -2
  171. package/package.json +31 -29
  172. package/lib/styles.css.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/elements/article/index.tsx"],"sourcesContent":["import \"./article.scss\";\nimport React from \"react\";\n\nimport { type Components } from \"@src/core/types/content\";\nimport { type BaseProvider } from \"@src/core/providers/base\";\nimport { loadContent } from \"@src/core/utils/load-content\";\nimport { ContentsProvider } from \"@src/components/contexts/contents/provider\";\nimport { Contents, type ContentsProps } from \"@src/components/blocks/contents\";\nimport { Breadcrumbs, type BreadcrumbsProps } from \"@src/components/blocks/breadcrumbs\";\nimport { Pagination, type PaginationProps } from \"@src/components/blocks/pagination\";\nimport { parseMarkdown } from \"./utils\";\nimport { Document } from \"./document\";\nimport { LastModified } from \"@src/components/blocks/last-modified\";\n\nexport type ContentProps = {\n title: string;\n components?: Components;\n config?: {\n publicDirs?: string[];\n };\n provider?: BaseProvider;\n pathname: string;\n pages?: { clientPath: string; origPath: string }[];\n translations?: {\n /** Last modified on */\n lastModifiedOn?: string;\n };\n} & ({ content: string; uri?: undefined } | { uri: string; content?: undefined });\n\nexport type ArticleProps = Partial<PaginationProps> &\n Partial<BreadcrumbsProps> &\n Omit<ContentsProps, \"headings\"> &\n ContentProps;\n\nexport const Article: React.FC<ArticleProps> = async ({\n components,\n content,\n uri,\n config = {},\n provider,\n hideContents,\n editUri: editUriProp,\n pathname,\n title,\n breadcrumbs,\n prev,\n next,\n pages = [],\n translations,\n}) => {\n const {\n lastModifiedOn = \"Last modified on\",\n editOnService,\n onThisPage,\n next: nextTranslation,\n previous,\n } = translations || {};\n const { data, provider: targetProvider } =\n content || !uri ? { data: content, provider: null } : await loadContent(uri, provider);\n\n if (!data) {\n throw new Error(\"Robindoc: Please provide content or valid uri\");\n }\n\n const { headings, tokens } = parseMarkdown(data);\n const editUri = uri && targetProvider && (await targetProvider.getEditUri(uri));\n const lastModified = uri && targetProvider && (await targetProvider.getLastModifiedDate(uri));\n\n return (\n <ContentsProvider>\n {breadcrumbs && breadcrumbs.length > 0 && <Breadcrumbs breadcrumbs={breadcrumbs} title={title} />}\n <Contents\n editUri={editUriProp === null ? null : editUriProp || editUri}\n hideContents={hideContents}\n headings={headings}\n translations={{ editOnService, onThisPage }}\n />\n <div className=\"r-article\">\n <Document\n headings={headings}\n tokens={tokens}\n pages={pages}\n components={components}\n config={config}\n targetProvider={targetProvider}\n pathname={pathname}\n uri={uri}\n />\n {lastModified && <LastModified date={lastModified}>{lastModifiedOn}</LastModified>}\n </div>\n {(prev || next) && (\n <Pagination prev={prev} next={next} translations={{ next: nextTranslation, previous }} />\n )}\n </ContentsProvider>\n );\n};\n"],"names":["Article","async","components","content","uri","config","provider","hideContents","editUri","editUriProp","pathname","title","breadcrumbs","prev","next","pages","translations","lastModifiedOn","editOnService","onThisPage","nextTranslation","previous","data","targetProvider","loadContent","Error","headings","tokens","parseMarkdown","getEditUri","lastModified","getLastModifiedDate","React","ContentsProvider","length","createElement","Breadcrumbs","Contents","className","Document","LastModified","date","Pagination"],"mappings":"6eAkCa,MAAAA,EAAkCC,OAC3CC,aACAC,UACAC,MACAC,SAAS,CAAA,EACTC,WACAC,eACAC,QAASC,EACTC,WACAC,QACAC,cACAC,OACAC,OACAC,QAAQ,GACRC,mBAEA,MAAMC,eACFA,EAAiB,mBAAkBC,cACnCA,EAAaC,WACbA,EACAL,KAAMM,EAAeC,SACrBA,GACAL,GAAgB,IACdM,KAAEA,EAAMhB,SAAUiB,GACpBpB,IAAYC,EAAM,CAAEkB,KAAMnB,EAASG,SAAU,YAAekB,EAAYpB,EAAKE,GAEjF,IAAKgB,EACD,MAAM,IAAIG,MAAM,iDAGpB,MAAMC,SAAEA,EAAQC,OAAEA,GAAWC,EAAcN,GACrCd,EAAUJ,GAAOmB,SAAyBA,EAAeM,WAAWzB,GACpE0B,EAAe1B,GAAOmB,SAAyBA,EAAeQ,oBAAoB3B,GAExF,OACI4B,gBAACC,EAAgB,KACZrB,GAAeA,EAAYsB,OAAS,GAAKF,EAAAG,cAACC,EAAW,CAACxB,YAAaA,EAAaD,MAAOA,IACxFqB,EAAAG,cAACE,EAAQ,CACL7B,QAAyB,OAAhBC,EAAuB,KAAOA,GAAeD,EACtDD,aAAcA,EACdmB,SAAUA,EACVV,aAAc,CAAEE,gBAAeC,gBAEnCa,EAAKG,cAAA,MAAA,CAAAG,UAAU,aACXN,EAAAG,cAACI,EAAQ,CACLb,SAAUA,EACVC,OAAQA,EACRZ,MAAOA,EACPb,WAAYA,EACZG,OAAQA,EACRkB,eAAgBA,EAChBb,SAAUA,EACVN,IAAKA,IAER0B,GAAgBE,EAACG,cAAAK,EAAa,CAAAC,KAAMX,GAAeb,KAEtDJ,GAAQC,IACNkB,EAACG,cAAAO,EAAW,CAAA7B,KAAMA,EAAMC,KAAMA,EAAME,aAAc,CAAEF,KAAMM,EAAiBC,cAGrF"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/elements/article/index.tsx"],"sourcesContent":["import \"./article.scss\";\nimport React from \"react\";\n\nimport { type Components } from \"@src/core/types/content\";\nimport { type BaseProvider } from \"@src/core/providers/base\";\nimport { loadContent } from \"@src/core/utils/load-content\";\nimport { ContentsProvider } from \"@src/components/contexts/contents/provider\";\nimport { Contents, type ContentsProps } from \"@src/components/blocks/contents\";\nimport { Breadcrumbs, type BreadcrumbsProps } from \"@src/components/blocks/breadcrumbs\";\nimport { Pagination, type PaginationProps } from \"@src/components/blocks/pagination\";\nimport { parseMarkdown } from \"./utils\";\nimport { Document } from \"./document\";\nimport { LastModified } from \"@src/components/blocks/last-modified\";\n\nexport type ContentProps = {\n title: string;\n components?: Components;\n config?: {\n publicDirs?: string[];\n };\n provider?: BaseProvider;\n pathname: string;\n pages?: { clientPath: string; origPath: string }[];\n translations?: {\n /** Last modified on */\n lastModifiedOn?: string;\n };\n} & ({ content: string; uri?: undefined } | { uri: string; content?: undefined });\n\nexport type ArticleProps = Partial<PaginationProps> &\n Partial<BreadcrumbsProps> &\n Omit<ContentsProps, \"headings\"> &\n ContentProps;\n\nexport const Article: React.FC<ArticleProps> = async ({\n components,\n content,\n uri,\n config = {},\n provider,\n hideContents,\n editUri: editUriProp,\n pathname,\n title,\n breadcrumbs,\n prev,\n next,\n pages = [],\n translations,\n}) => {\n const {\n lastModifiedOn = \"Last modified on\",\n editOnService,\n onThisPage,\n next: nextTranslation,\n previous,\n } = translations || {};\n const { data, provider: targetProvider } =\n content || !uri ? { data: content, provider: null } : await loadContent(uri, provider);\n\n if (!data) {\n throw new Error(\"Robindoc: Please provide content or valid uri\");\n }\n\n const { headings, tokens } = parseMarkdown(data);\n const editUri = uri && targetProvider && (await targetProvider.getEditUri(uri));\n const lastModified = uri && targetProvider && (await targetProvider.getLastModifiedDate(uri));\n\n return (\n <ContentsProvider>\n {breadcrumbs && breadcrumbs.length > 0 && <Breadcrumbs breadcrumbs={breadcrumbs} title={title} />}\n <Contents\n editUri={editUriProp === null ? null : editUriProp || editUri}\n hideContents={hideContents}\n headings={headings}\n translations={{ editOnService, onThisPage }}\n />\n <div className=\"r-article\">\n <Document\n headings={headings}\n tokens={tokens}\n pages={pages}\n components={components}\n config={config}\n targetProvider={targetProvider}\n pathname={pathname}\n uri={uri}\n />\n {lastModified && <LastModified date={lastModified}>{lastModifiedOn}</LastModified>}\n </div>\n {(prev || next) && (\n <Pagination prev={prev} next={next} translations={{ next: nextTranslation, previous }} />\n )}\n </ContentsProvider>\n );\n};\n"],"names":["Article","async","components","content","uri","config","provider","hideContents","editUri","editUriProp","pathname","title","breadcrumbs","prev","next","pages","translations","lastModifiedOn","editOnService","onThisPage","nextTranslation","previous","data","targetProvider","loadContent","Error","headings","tokens","parseMarkdown","getEditUri","lastModified","getLastModifiedDate","React","ContentsProvider","length","createElement","Breadcrumbs","Contents","className","Document","LastModified","date","Pagination"],"mappings":"6eAkCO,MAAMA,EAAkCC,OAC3CC,aACAC,UACAC,MACAC,SAAS,CAAA,EACTC,WACAC,eACAC,QAASC,EACTC,WACAC,QACAC,cACAC,OACAC,OACAC,QAAQ,GACRC,mBAEA,MAAMC,eACFA,EAAiB,mBAAkBC,cACnCA,EAAaC,WACbA,EACAL,KAAMM,EAAeC,SACrBA,GACAL,GAAgB,CAAA,GACdM,KAAEA,EAAMhB,SAAUiB,GACpBpB,IAAYC,EAAM,CAAEkB,KAAMnB,EAASG,SAAU,YAAekB,EAAYpB,EAAKE,GAEjF,IAAKgB,EACD,MAAM,IAAIG,MAAM,iDAGpB,MAAMC,SAAEA,EAAQC,OAAEA,GAAWC,EAAcN,GACrCd,EAAUJ,GAAOmB,SAAyBA,EAAeM,WAAWzB,GACpE0B,EAAe1B,GAAOmB,SAAyBA,EAAeQ,oBAAoB3B,GAExF,OACI4B,gBAACC,EAAgB,KACZrB,GAAeA,EAAYsB,OAAS,GAAKF,EAAAG,cAACC,EAAW,CAACxB,YAAaA,EAAaD,MAAOA,IACxFqB,EAAAG,cAACE,EAAQ,CACL7B,QAAyB,OAAhBC,EAAuB,KAAOA,GAAeD,EACtDD,aAAcA,EACdmB,SAAUA,EACVV,aAAc,CAAEE,gBAAeC,gBAEnCa,EAAAG,cAAA,MAAA,CAAKG,UAAU,aACXN,EAAAG,cAACI,EAAQ,CACLb,SAAUA,EACVC,OAAQA,EACRZ,MAAOA,EACPb,WAAYA,EACZG,OAAQA,EACRkB,eAAgBA,EAChBb,SAAUA,EACVN,IAAKA,IAER0B,GAAgBE,EAAAG,cAACK,EAAY,CAACC,KAAMX,GAAeb,KAEtDJ,GAAQC,IACNkB,EAAAG,cAACO,EAAU,CAAC7B,KAAMA,EAAMC,KAAMA,EAAME,aAAc,CAAEF,KAAMM,EAAiBC"}
@@ -38,7 +38,7 @@ export declare const parseBlockqoute: (token: Tokens.Blockquote | Tokens.Generic
38
38
  } | {
39
39
  raw: string;
40
40
  type: string;
41
- tokens?: Token[] | undefined;
41
+ tokens?: Token[];
42
42
  };
43
43
  type: BlockquoteType;
44
44
  } | {
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/components/elements/article/utils.ts"],"names":[],"mappings":"AAEA,OAAO,EAAS,KAAK,MAAM,EAAE,KAAK,KAAK,EAAE,MAAM,QAAQ,CAAC;AAGxD,OAAO,EAAE,KAAK,cAAc,EAAE,4BAAsC;AAGpE,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,SAAS,CAAC;AAEzC,MAAM,MAAM,UAAU,GAAG;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,OAAO,CAAC;IAChB,KAAK,EAAE,KAAK,CAAC;CAChB,CAAC;AAEF,eAAO,MAAM,aAAa,YAAa,MAAM;;;CAmB5C,CAAC;AAEF,eAAO,MAAM,QAAQ,QAAS,MAAM,WAEnC,CAAC;AAEF,eAAO,MAAM,qBAAqB,SAAU,MAAM,YAEjD,CAAC;AAEF,eAAO,MAAM,aAAa,QAAS,MAAM;;;;;CAmBxC,CAAC;AAEF,eAAO,MAAM,cAAc,UAChB,KAAK,GAAG,KAAK,EAAE,aACX;IAAE,CAAC,IAAI,EAAE,MAAM,GAAG;QAAE,OAAO,EAAE,MAAM,SAAS,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,YAa/E,CAAC;AAEF,eAAO,MAAM,cAAc,SAAU,MAAM,YAAY,MAAM,UAAU,SAAS;;;CAiB/E,CAAC;AAEF,eAAO,MAAM,eAAe,UAAW,OAAO,UAAU,GAAG,OAAO,OAAO;;;;;;;;;;;;;;;CAyBxE,CAAC"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/components/elements/article/utils.ts"],"names":[],"mappings":"AAEA,OAAO,EAAS,KAAK,MAAM,EAAE,KAAK,KAAK,EAAE,MAAM,QAAQ,CAAC;AAGxD,OAAO,EAAE,KAAK,cAAc,EAAE,4BAAsC;AAGpE,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,SAAS,CAAC;AAEzC,MAAM,MAAM,UAAU,GAAG;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,OAAO,CAAC;IAChB,KAAK,EAAE,KAAK,CAAC;CAChB,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,SAAS,MAAM;;;CAmB5C,CAAC;AAEF,eAAO,MAAM,QAAQ,GAAI,KAAK,MAAM,WAEnC,CAAC;AAEF,eAAO,MAAM,qBAAqB,GAAI,MAAM,MAAM,YAEjD,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,KAAK,MAAM;;;;;CAmBxC,CAAC;AAEF,eAAO,MAAM,cAAc,GACvB,OAAO,KAAK,GAAG,KAAK,EAAE,EACtB,WAAW;IAAE,CAAC,IAAI,EAAE,MAAM,GAAG;QAAE,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,YAa/E,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,MAAM,MAAM,EAAE,UAAU,MAAM,EAAE,QAAQ,SAAS;;;CAiB/E,CAAC;AAEF,eAAO,MAAM,eAAe,GAAI,OAAO,MAAM,CAAC,UAAU,GAAG,MAAM,CAAC,OAAO;;;;;;;;;;;UAoBjC,cAAc;;;;CAKrD,CAAC"}
@@ -1,2 +1,2 @@
1
- import t from"github-slugger";import e from"gray-matter";import{lexer as r}from"marked";import{join as n,dirname as o}from"path";import{parseTokenText as s}from"../../../core/utils/content-tools.js";const i=n=>{const{content:o}=e(n),i=r(o.trim()),a=new t,c=i.reduce(((t,e)=>{if("heading"===e.type&&(2===e.depth||3===e.depth)){const r=s(e);t.push({title:r,id:a.slug(r),token:e,nested:3===e.depth})}return t}),[]);return{tokens:i,headings:c}},a=t=>t.toLowerCase().replace(/\W/g,"_").replace(/_+/g,"_"),c=t=>/^[A-Z][a-zA-Z0-9]+$/.test(t),g=t=>{let e={},r=t;const n=t.match(/[a-z]+=("[^"]+"|'[^']+'|[^ ]+)|[a-z]+/g);if(Array.isArray(n)){const[t,...o]=n;r=t,e=o.reduce(((t,e)=>{const[r,...n]=e.split("=");return t[r]=!n||(0===n.length||n.join("=").replace(/(^["']|['"]$)/g,"")),t}),{})}return{lang:r,configuration:e}},l=(t,e)=>{if(Array.isArray(t)||!Object.keys(e).length)return!1;if("code"===t.type){const{lang:r,configuration:n}=g(t.lang);if(e["string"==typeof n.tab?a(n.tab):r]||!n.switcher)return!0}return"space"!==t.type&&"code"!==t.type},p=(t,e,r)=>{let s=t;const i=/^(https?:\/\/|\/)/.test(t);if(r&&!i){const i=r.find((t=>t.clientPath===e));if(i){const e=n(o(i.origPath),t).replace(/\\/g,"/"),a=r.find((t=>t.origPath===e));a&&(s=a?.clientPath)}}return{href:s,external:i}},u=t=>{const e=t.raw.match(/^> \[!(NOTE|TIP|IMPORTANT|WARNING|CAUTION)\]\n/);if(e){const[r,n]=e,o={...t,raw:t.raw.substring(r.length)};if(o.tokens){const t={...o.tokens[0]};if(t.raw=t.raw.substring(n.length+4),t.text=t.text.substring(n.length+4),t.tokens[0]){const e={...t.tokens[0]};e.raw=e.raw.substring(n.length+4),e.text=e.text.substring(n.length+4),t.tokens[0]=e}o.tokens[0]=t}return{token:o,type:n.toLowerCase()}}return{token:t,type:null}};export{a as formatId,p as formatLinkHref,l as isNewCodeToken,u as parseBlockqoute,g as parseCodeLang,i as parseMarkdown,c as validateComponentName};
1
+ import t from"github-slugger";import e from"gray-matter";import{lexer as r}from"marked";import{join as n,dirname as o}from"path";import{parseTokenText as s}from"../../../core/utils/content-tools.js";const i=n=>{const{content:o}=e(n),i=r(o.trim()),a=new t,c=i.reduce((t,e)=>{if("heading"===e.type&&(2===e.depth||3===e.depth)){const r=s(e);t.push({title:r,id:a.slug(r),token:e,nested:3===e.depth})}return t},[]);return{tokens:i,headings:c}},a=t=>t.toLowerCase().replace(/\W/g,"_").replace(/_+/g,"_"),c=t=>/^[A-Z][a-zA-Z0-9]+$/.test(t),g=t=>{let e={},r=t;const n=t.match(/[a-z]+=("[^"]+"|'[^']+'|[^ ]+)|[a-z]+/g);if(Array.isArray(n)){const[t,...o]=n;r=t,e=o.reduce((t,e)=>{const[r,...n]=e.split("=");return t[r]=!n||(0===n.length||n.join("=").replace(/(^["']|['"]$)/g,"")),t},{})}return{lang:r,configuration:e}},l=(t,e)=>{if(Array.isArray(t)||!Object.keys(e).length)return!1;if("code"===t.type){const{lang:r,configuration:n}=g(t.lang);if(e["string"==typeof n.tab?a(n.tab):r]||!n.switcher)return!0}return"space"!==t.type&&"code"!==t.type},p=(t,e,r)=>{let s=t;const i=/^(https?:\/\/|\/)/.test(t);if(r&&!i){const i=r.find(t=>t.clientPath===e);if(i){const e=n(o(i.origPath),t).replace(/\\/g,"/"),a=r.find(t=>t.origPath===e);a&&(s=a?.clientPath)}}return{href:s,external:i}},u=t=>{const e=t.raw.match(/^> \[!(NOTE|TIP|IMPORTANT|WARNING|CAUTION)\]\n/);if(e){const[r,n]=e,o={...t,raw:t.raw.substring(r.length)};if(o.tokens){const t={...o.tokens[0]};if(t.raw=t.raw.substring(n.length+4),t.text=t.text.substring(n.length+4),t.tokens[0]){const e={...t.tokens[0]};e.raw=e.raw.substring(n.length+4),e.text=e.text.substring(n.length+4),t.tokens[0]=e}o.tokens[0]=t}return{token:o,type:n.toLowerCase()}}return{token:t,type:null}};export{a as formatId,p as formatLinkHref,l as isNewCodeToken,u as parseBlockqoute,g as parseCodeLang,i as parseMarkdown,c as validateComponentName};
2
2
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sources":["../../../../src/components/elements/article/utils.ts"],"sourcesContent":["import GithubSlugger from \"github-slugger\";\nimport matter from \"gray-matter\";\nimport { lexer, type Tokens, type Token } from \"marked\";\nimport { dirname, join } from \"path\";\n\nimport { type BlockquoteType } from \"@src/components/ui/blockquote\";\nimport { parseTokenText } from \"@src/core/utils/content-tools\";\n\nimport { type PagesType } from \"./types\";\n\nexport type AnchorData = {\n title: string;\n id: string;\n nested: boolean;\n token: Token;\n};\n\nexport const parseMarkdown = (content: string) => {\n const { content: matterContent } = matter(content);\n const tokens = lexer(matterContent.trim());\n\n const slugger = new GithubSlugger();\n const headings = tokens.reduce<AnchorData[]>((acc, token) => {\n if (token.type === \"heading\" && (token.depth === 2 || token.depth === 3)) {\n const title = parseTokenText(token);\n acc.push({\n title,\n id: slugger.slug(title),\n token,\n nested: token.depth === 3,\n });\n }\n return acc;\n }, []);\n\n return { tokens, headings };\n};\n\nexport const formatId = (raw: string) => {\n return raw.toLowerCase().replace(/\\W/g, \"_\").replace(/_+/g, \"_\");\n};\n\nexport const validateComponentName = (name: string) => {\n return /^[A-Z][a-zA-Z0-9]+$/.test(name);\n};\n\nexport const parseCodeLang = (raw: string) => {\n let configuration: { [key: string]: string | boolean } = {};\n let lang: string = raw;\n\n const match = raw.match(/[a-z]+=(\"[^\"]+\"|'[^']+'|[^ ]+)|[a-z]+/g);\n if (Array.isArray(match)) {\n const [language, ...modifiers] = match as string[];\n lang = language;\n configuration = modifiers.reduce<{ [key: string]: string | boolean }>((acc, cur) => {\n const [key, ...value] = cur.split(\"=\");\n if (value) {\n acc[key] = value.length === 0 ? true : value.join(\"=\").replace(/(^[\"']|['\"]$)/g, \"\");\n } else {\n acc[key] = true;\n }\n return acc;\n }, {});\n }\n return { lang, configuration };\n};\n\nexport const isNewCodeToken = (\n token: Token | Token[],\n codeQueue: { [lang: string]: { element: React.ReactNode; tabName: string } },\n) => {\n if (Array.isArray(token) || !Object.keys(codeQueue).length) return false;\n\n if (token.type === \"code\") {\n const { lang, configuration } = parseCodeLang(token.lang);\n const tabKey = typeof configuration.tab === \"string\" ? formatId(configuration.tab) : lang;\n if (codeQueue[tabKey] || !configuration.switcher) return true;\n }\n\n if (token.type !== \"space\" && token.type !== \"code\") return true;\n\n return false;\n};\n\nexport const formatLinkHref = (href: string, pathname: string, pages?: PagesType) => {\n let finalHref: string = href;\n const external = /^(https?:\\/\\/|\\/)/.test(href);\n\n if (pages && !external) {\n const currentPageData = pages.find((item) => item.clientPath === pathname);\n\n if (currentPageData) {\n const linkOrigPath = join(dirname(currentPageData.origPath), href).replace(/\\\\/g, \"/\");\n const linkData = pages.find((item) => item.origPath === linkOrigPath);\n\n if (linkData) {\n finalHref = linkData?.clientPath;\n }\n }\n }\n return { href: finalHref, external };\n};\n\nexport const parseBlockqoute = (token: Tokens.Blockquote | Tokens.Generic) => {\n const typeMatch = token.raw.match(/^> \\[!(NOTE|TIP|IMPORTANT|WARNING|CAUTION)\\]\\n/);\n if (typeMatch) {\n const [raw, type] = typeMatch;\n const newToken = { ...token, raw: token.raw.substring(raw.length) };\n if (newToken.tokens) {\n const firstToken = { ...newToken.tokens[0] } as Tokens.Paragraph;\n firstToken.raw = firstToken.raw.substring(type.length + 4);\n firstToken.text = firstToken.text.substring(type.length + 4);\n if (firstToken.tokens[0]) {\n const firstSubtoken = { ...firstToken.tokens[0] } as Tokens.Paragraph;\n firstSubtoken.raw = firstSubtoken.raw.substring(type.length + 4);\n firstSubtoken.text = firstSubtoken.text.substring(type.length + 4);\n firstToken.tokens[0] = firstSubtoken;\n }\n newToken.tokens[0] = firstToken;\n }\n\n return {\n token: newToken,\n type: type.toLowerCase() as BlockquoteType,\n };\n }\n\n return { token, type: null };\n};\n"],"names":["parseMarkdown","content","matterContent","matter","tokens","lexer","trim","slugger","GithubSlugger","headings","reduce","acc","token","type","depth","title","parseTokenText","push","id","slug","nested","formatId","raw","toLowerCase","replace","validateComponentName","name","test","parseCodeLang","configuration","lang","match","Array","isArray","language","modifiers","cur","key","value","split","length","join","isNewCodeToken","codeQueue","Object","keys","tab","switcher","formatLinkHref","href","pathname","pages","finalHref","external","currentPageData","find","item","clientPath","linkOrigPath","dirname","origPath","linkData","parseBlockqoute","typeMatch","newToken","substring","firstToken","text","firstSubtoken"],"mappings":"uMAiBa,MAAAA,EAAiBC,IAC1B,MAAQA,QAASC,GAAkBC,EAAOF,GACpCG,EAASC,EAAMH,EAAcI,QAE7BC,EAAU,IAAIC,EACdC,EAAWL,EAAOM,QAAqB,CAACC,EAAKC,KAC/C,GAAmB,YAAfA,EAAMC,OAAuC,IAAhBD,EAAME,OAA+B,IAAhBF,EAAME,OAAc,CACtE,MAAMC,EAAQC,EAAeJ,GAC7BD,EAAIM,KAAK,CACLF,QACAG,GAAIX,EAAQY,KAAKJ,GACjBH,QACAQ,OAAwB,IAAhBR,EAAME,OAErB,CACD,OAAOH,CAAG,GACX,IAEH,MAAO,CAAEP,SAAQK,WAAU,EAGlBY,EAAYC,GACdA,EAAIC,cAAcC,QAAQ,MAAO,KAAKA,QAAQ,MAAO,KAGnDC,EAAyBC,GAC3B,sBAAsBC,KAAKD,GAGzBE,EAAiBN,IAC1B,IAAIO,EAAqD,CAAA,EACrDC,EAAeR,EAEnB,MAAMS,EAAQT,EAAIS,MAAM,0CACxB,GAAIC,MAAMC,QAAQF,GAAQ,CACtB,MAAOG,KAAaC,GAAaJ,EACjCD,EAAOI,EACPL,EAAgBM,EAAUzB,QAA4C,CAACC,EAAKyB,KACxE,MAAOC,KAAQC,GAASF,EAAIG,MAAM,KAMlC,OAJI5B,EAAI0B,IADJC,IAC4B,IAAjBA,EAAME,QAAsBF,EAAMG,KAAK,KAAKjB,QAAQ,iBAAkB,KAI9Eb,CAAG,GACX,CAAE,EACR,CACD,MAAO,CAAEmB,OAAMD,gBAAe,EAGrBa,EAAiB,CAC1B9B,EACA+B,KAEA,GAAIX,MAAMC,QAAQrB,KAAWgC,OAAOC,KAAKF,GAAWH,OAAQ,OAAO,EAEnE,GAAmB,SAAf5B,EAAMC,KAAiB,CACvB,MAAMiB,KAAEA,EAAID,cAAEA,GAAkBD,EAAchB,EAAMkB,MAEpD,GAAIa,EADwC,iBAAtBd,EAAciB,IAAmBzB,EAASQ,EAAciB,KAAOhB,KAC3DD,EAAckB,SAAU,OAAO,CAC5D,CAED,MAAmB,UAAfnC,EAAMC,MAAmC,SAAfD,EAAMC,IAExB,EAGHmC,EAAiB,CAACC,EAAcC,EAAkBC,KAC3D,IAAIC,EAAoBH,EACxB,MAAMI,EAAW,oBAAoB1B,KAAKsB,GAE1C,GAAIE,IAAUE,EAAU,CACpB,MAAMC,EAAkBH,EAAMI,MAAMC,GAASA,EAAKC,aAAeP,IAEjE,GAAII,EAAiB,CACjB,MAAMI,EAAejB,EAAKkB,EAAQL,EAAgBM,UAAWX,GAAMzB,QAAQ,MAAO,KAC5EqC,EAAWV,EAAMI,MAAMC,GAASA,EAAKI,WAAaF,IAEpDG,IACAT,EAAYS,GAAUJ,WAE7B,CACJ,CACD,MAAO,CAAER,KAAMG,EAAWC,WAAU,EAG3BS,EAAmBlD,IAC5B,MAAMmD,EAAYnD,EAAMU,IAAIS,MAAM,kDAClC,GAAIgC,EAAW,CACX,MAAOzC,EAAKT,GAAQkD,EACdC,EAAW,IAAKpD,EAAOU,IAAKV,EAAMU,IAAI2C,UAAU3C,EAAIkB,SAC1D,GAAIwB,EAAS5D,OAAQ,CACjB,MAAM8D,EAAa,IAAKF,EAAS5D,OAAO,IAGxC,GAFA8D,EAAW5C,IAAM4C,EAAW5C,IAAI2C,UAAUpD,EAAK2B,OAAS,GACxD0B,EAAWC,KAAOD,EAAWC,KAAKF,UAAUpD,EAAK2B,OAAS,GACtD0B,EAAW9D,OAAO,GAAI,CACtB,MAAMgE,EAAgB,IAAKF,EAAW9D,OAAO,IAC7CgE,EAAc9C,IAAM8C,EAAc9C,IAAI2C,UAAUpD,EAAK2B,OAAS,GAC9D4B,EAAcD,KAAOC,EAAcD,KAAKF,UAAUpD,EAAK2B,OAAS,GAChE0B,EAAW9D,OAAO,GAAKgE,CAC1B,CACDJ,EAAS5D,OAAO,GAAK8D,CACxB,CAED,MAAO,CACHtD,MAAOoD,EACPnD,KAAMA,EAAKU,cAElB,CAED,MAAO,CAAEX,QAAOC,KAAM,KAAM"}
1
+ {"version":3,"file":"utils.js","sources":["../../../../src/components/elements/article/utils.ts"],"sourcesContent":["import GithubSlugger from \"github-slugger\";\nimport matter from \"gray-matter\";\nimport { lexer, type Tokens, type Token } from \"marked\";\nimport { dirname, join } from \"path\";\n\nimport { type BlockquoteType } from \"@src/components/ui/blockquote\";\nimport { parseTokenText } from \"@src/core/utils/content-tools\";\n\nimport { type PagesType } from \"./types\";\n\nexport type AnchorData = {\n title: string;\n id: string;\n nested: boolean;\n token: Token;\n};\n\nexport const parseMarkdown = (content: string) => {\n const { content: matterContent } = matter(content);\n const tokens = lexer(matterContent.trim());\n\n const slugger = new GithubSlugger();\n const headings = tokens.reduce<AnchorData[]>((acc, token) => {\n if (token.type === \"heading\" && (token.depth === 2 || token.depth === 3)) {\n const title = parseTokenText(token);\n acc.push({\n title,\n id: slugger.slug(title),\n token,\n nested: token.depth === 3,\n });\n }\n return acc;\n }, []);\n\n return { tokens, headings };\n};\n\nexport const formatId = (raw: string) => {\n return raw.toLowerCase().replace(/\\W/g, \"_\").replace(/_+/g, \"_\");\n};\n\nexport const validateComponentName = (name: string) => {\n return /^[A-Z][a-zA-Z0-9]+$/.test(name);\n};\n\nexport const parseCodeLang = (raw: string) => {\n let configuration: { [key: string]: string | boolean } = {};\n let lang: string = raw;\n\n const match = raw.match(/[a-z]+=(\"[^\"]+\"|'[^']+'|[^ ]+)|[a-z]+/g);\n if (Array.isArray(match)) {\n const [language, ...modifiers] = match as string[];\n lang = language;\n configuration = modifiers.reduce<{ [key: string]: string | boolean }>((acc, cur) => {\n const [key, ...value] = cur.split(\"=\");\n if (value) {\n acc[key] = value.length === 0 ? true : value.join(\"=\").replace(/(^[\"']|['\"]$)/g, \"\");\n } else {\n acc[key] = true;\n }\n return acc;\n }, {});\n }\n return { lang, configuration };\n};\n\nexport const isNewCodeToken = (\n token: Token | Token[],\n codeQueue: { [lang: string]: { element: React.ReactNode; tabName: string } },\n) => {\n if (Array.isArray(token) || !Object.keys(codeQueue).length) return false;\n\n if (token.type === \"code\") {\n const { lang, configuration } = parseCodeLang(token.lang);\n const tabKey = typeof configuration.tab === \"string\" ? formatId(configuration.tab) : lang;\n if (codeQueue[tabKey] || !configuration.switcher) return true;\n }\n\n if (token.type !== \"space\" && token.type !== \"code\") return true;\n\n return false;\n};\n\nexport const formatLinkHref = (href: string, pathname: string, pages?: PagesType) => {\n let finalHref: string = href;\n const external = /^(https?:\\/\\/|\\/)/.test(href);\n\n if (pages && !external) {\n const currentPageData = pages.find((item) => item.clientPath === pathname);\n\n if (currentPageData) {\n const linkOrigPath = join(dirname(currentPageData.origPath), href).replace(/\\\\/g, \"/\");\n const linkData = pages.find((item) => item.origPath === linkOrigPath);\n\n if (linkData) {\n finalHref = linkData?.clientPath;\n }\n }\n }\n return { href: finalHref, external };\n};\n\nexport const parseBlockqoute = (token: Tokens.Blockquote | Tokens.Generic) => {\n const typeMatch = token.raw.match(/^> \\[!(NOTE|TIP|IMPORTANT|WARNING|CAUTION)\\]\\n/);\n if (typeMatch) {\n const [raw, type] = typeMatch;\n const newToken = { ...token, raw: token.raw.substring(raw.length) };\n if (newToken.tokens) {\n const firstToken = { ...newToken.tokens[0] } as Tokens.Paragraph;\n firstToken.raw = firstToken.raw.substring(type.length + 4);\n firstToken.text = firstToken.text.substring(type.length + 4);\n if (firstToken.tokens[0]) {\n const firstSubtoken = { ...firstToken.tokens[0] } as Tokens.Paragraph;\n firstSubtoken.raw = firstSubtoken.raw.substring(type.length + 4);\n firstSubtoken.text = firstSubtoken.text.substring(type.length + 4);\n firstToken.tokens[0] = firstSubtoken;\n }\n newToken.tokens[0] = firstToken;\n }\n\n return {\n token: newToken,\n type: type.toLowerCase() as BlockquoteType,\n };\n }\n\n return { token, type: null };\n};\n"],"names":["parseMarkdown","content","matterContent","matter","tokens","lexer","trim","slugger","GithubSlugger","headings","reduce","acc","token","type","depth","title","parseTokenText","push","id","slug","nested","formatId","raw","toLowerCase","replace","validateComponentName","name","test","parseCodeLang","configuration","lang","match","Array","isArray","language","modifiers","cur","key","value","split","length","join","isNewCodeToken","codeQueue","Object","keys","tab","switcher","formatLinkHref","href","pathname","pages","finalHref","external","currentPageData","find","item","clientPath","linkOrigPath","dirname","origPath","linkData","parseBlockqoute","typeMatch","newToken","substring","firstToken","text","firstSubtoken"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/elements/footer/index.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { ThemeSwitcher } from \"@src/components/blocks/theme-switcher\";\nimport { Container } from \"@src/components/ui/container\";\n\nimport \"./footer.scss\";\n\nexport type FooterProps = {\n copyright: string;\n hidePoweredBy?: boolean;\n};\n\nexport const Footer: React.FC<FooterProps> = ({ copyright, hidePoweredBy }) => (\n <footer className=\"r-footer\">\n <Container>\n <div className=\"r-footer-row\">\n <div className=\"r-copyright\">{copyright}</div>\n <ThemeSwitcher />\n </div>\n {!hidePoweredBy && (\n <div className=\"r-footer-row r-footer-additional\">\n <div className=\"r-powered\">\n Powered by{\" \"}\n <a\n href=\"https://robindoc.com\"\n className=\"r-powered-link\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n ROBINDOC\n </a>\n </div>\n </div>\n )}\n </Container>\n </footer>\n);\n"],"names":["Footer","copyright","hidePoweredBy","React","createElement","className","Container","ThemeSwitcher","href","target","rel"],"mappings":"kJAYa,MAAAA,EAAgC,EAAGC,YAAWC,mBACvDC,EAAQC,cAAA,SAAA,CAAAC,UAAU,YACdF,EAAAC,cAACE,EAAS,KACNH,EAAKC,cAAA,MAAA,CAAAC,UAAU,gBACXF,EAAAC,cAAA,MAAA,CAAKC,UAAU,eAAeJ,GAC9BE,EAACC,cAAAG,UAEHL,GACEC,EAAKC,cAAA,MAAA,CAAAC,UAAU,oCACXF,EAAKC,cAAA,MAAA,CAAAC,UAAU,0BACA,IACXF,EACIC,cAAA,IAAA,CAAAI,KAAK,uBACLH,UAAU,iBACVI,OAAO,SACPC,IAAI,uBAGJ"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/elements/footer/index.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { ThemeSwitcher } from \"@src/components/blocks/theme-switcher\";\nimport { Container } from \"@src/components/ui/container\";\n\nimport \"./footer.scss\";\n\nexport type FooterProps = {\n copyright: string;\n hidePoweredBy?: boolean;\n};\n\nexport const Footer: React.FC<FooterProps> = ({ copyright, hidePoweredBy }) => (\n <footer className=\"r-footer\">\n <Container>\n <div className=\"r-footer-row\">\n <div className=\"r-copyright\">{copyright}</div>\n <ThemeSwitcher />\n </div>\n {!hidePoweredBy && (\n <div className=\"r-footer-row r-footer-additional\">\n <div className=\"r-powered\">\n Powered by{\" \"}\n <a\n href=\"https://robindoc.com\"\n className=\"r-powered-link\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n ROBINDOC\n </a>\n </div>\n </div>\n )}\n </Container>\n </footer>\n);\n"],"names":["Footer","copyright","hidePoweredBy","React","createElement","className","Container","ThemeSwitcher","href","target","rel"],"mappings":"kJAYO,MAAMA,EAAgC,EAAGC,YAAWC,mBACvDC,EAAAC,cAAA,SAAA,CAAQC,UAAU,YACdF,EAAAC,cAACE,EAAS,KACNH,EAAAC,cAAA,MAAA,CAAKC,UAAU,gBACXF,EAAAC,cAAA,MAAA,CAAKC,UAAU,eAAeJ,GAC9BE,EAAAC,cAACG,UAEHL,GACEC,EAAAC,cAAA,MAAA,CAAKC,UAAU,oCACXF,EAAAC,cAAA,MAAA,CAAKC,UAAU,0BACA,IACXF,EAAAC,cAAA,IAAA,CACII,KAAK,uBACLH,UAAU,iBACVI,OAAO,SACPC,IAAI,uBAAqB"}
@@ -1,2 +1,2 @@
1
- import e from"react";import{HeaderMenu as t}from"../../blocks/header-menu/index.js";import{Search as r}from"../../blocks/search/index.js";import{SectionDropdown as a}from"../../blocks/section-dropdown/index.js";import{HeaderSocial as l}from"../../blocks/header-social/index.js";import{Container as s}from"../../ui/container/index.js";import{NavLink as i}from"../../blocks/nav-link/index.js";const n=({logo:n,versions:o,locales:m,links:c=[],git:d,searcher:k,translations:h})=>{const{menu:f,...y}=h||{},p=o?.list.find((e=>e.key===o.target)),E=p&&p.key!==o?.default?`/${p.key}`:"",u=m?.list.find((e=>e.key===m.target)),g=u&&u.key!==m?.default?`/${u.key}`:"";return e.createElement("header",{className:"r-header"},e.createElement(s,{className:"r-header-body"},e.createElement("div",null,e.createElement(i,{href:"/",className:"r-header-logo"},n)),e.createElement(t,{translations:{menu:f}},e.createElement("nav",{className:"r-header-nav"},c.map((t=>e.createElement(i,{href:t.href,className:"r-header-link",targetClassName:"_target",key:t.title},t.title)))),e.createElement("div",{className:"r-header-actions"},e.createElement("div",{className:"r-header-sections"},o&&p&&e.createElement(a,{defaultOption:p.key,options:o.list.map((e=>({href:e.href||`${g}${e.key===o.default?"":`/${e.key}`}/`,key:e.key,title:e.title,shortTitle:e.shortTitle})))}),m&&u&&e.createElement(a,{defaultOption:u.key,options:m.list.map((e=>({href:e.href||`${e.key===m.default?"":`/${e.key}`}${E}/`,key:e.key,title:e.title,shortTitle:e.shortTitle})))})),k&&e.createElement(r,{searcher:k,translations:y}))),d&&e.createElement(l,{git:d})))};export{n as Header};
1
+ import e from"react";import{HeaderMenu as t}from"../../blocks/header-menu/index.js";import{Search as r}from"../../blocks/search/index.js";import{SectionDropdown as a}from"../../blocks/section-dropdown/index.js";import{HeaderSocial as l}from"../../blocks/header-social/index.js";import{Container as s}from"../../ui/container/index.js";import{NavLink as i}from"../../blocks/nav-link/index.js";const n=({logo:n,versions:o,locales:m,links:c=[],git:d,searcher:k,translations:h})=>{const{menu:f,...y}=h||{},p=o?.list.find(e=>e.key===o.target),E=p&&p.key!==o?.default?`/${p.key}`:"",u=m?.list.find(e=>e.key===m.target),g=u&&u.key!==m?.default?`/${u.key}`:"";return e.createElement("header",{className:"r-header"},e.createElement(s,{className:"r-header-body"},e.createElement("div",null,e.createElement(i,{href:"/",className:"r-header-logo"},n)),e.createElement(t,{translations:{menu:f}},e.createElement("nav",{className:"r-header-nav"},c.map(t=>e.createElement(i,{href:t.href,className:"r-header-link",targetClassName:"_target",key:t.title},t.title))),e.createElement("div",{className:"r-header-actions"},e.createElement("div",{className:"r-header-sections"},o&&p&&e.createElement(a,{defaultOption:p.key,options:o.list.map(e=>({href:e.href||`${g}${e.key===o.default?"":`/${e.key}`}/`,key:e.key,title:e.title,shortTitle:e.shortTitle}))}),m&&u&&e.createElement(a,{defaultOption:u.key,options:m.list.map(e=>({href:e.href||`${e.key===m.default?"":`/${e.key}`}${E}/`,key:e.key,title:e.title,shortTitle:e.shortTitle}))})),k&&e.createElement(r,{searcher:k,translations:y}))),d&&e.createElement(l,{git:d})))};export{n as Header};
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/elements/header/index.tsx"],"sourcesContent":["import \"./header.scss\";\nimport React from \"react\";\nimport { HeaderMenu, type HeaderMenuProps } from \"@src/components/blocks/header-menu\";\nimport { Search, type SearchProps } from \"@src/components/blocks/search\";\nimport { SectionDropdown } from \"@src/components/blocks/section-dropdown\";\nimport { HeaderSocial } from \"@src/components/blocks/header-social\";\nimport { Container } from \"@src/components/ui/container\";\nimport { NavLink } from \"@src/components/blocks/nav-link\";\n\ntype SectionOption = {\n key: string;\n href?: string;\n title: string;\n shortTitle?: string;\n};\n\ntype SectionType = {\n default?: string;\n target: string;\n list: SectionOption[];\n};\n\nexport type HeaderProps = {\n logo: React.ReactElement;\n links?: {\n title: string;\n href: string;\n }[];\n git?: string | { uri: string; logo: React.ElementType };\n versions?: SectionType;\n locales?: SectionType;\n} & HeaderMenuProps &\n SearchProps;\n\nexport const Header: React.FC<HeaderProps> = ({ logo, versions, locales, links = [], git, searcher, translations }) => {\n const { menu, ...searchTranslations } = translations || {};\n const targetVersion = versions?.list.find((version) => version.key === versions.target);\n const versionPrefix = !targetVersion || targetVersion.key === versions?.default ? \"\" : `/${targetVersion.key}`;\n const targetLocale = locales?.list.find((locale) => locale.key === locales.target);\n const localePrefix = !targetLocale || targetLocale.key === locales?.default ? \"\" : `/${targetLocale.key}`;\n\n return (\n <header className=\"r-header\">\n <Container className=\"r-header-body\">\n <div>\n <NavLink href=\"/\" className=\"r-header-logo\">\n {logo}\n </NavLink>\n </div>\n <HeaderMenu translations={{ menu }}>\n <nav className=\"r-header-nav\">\n {links.map((link) => (\n <NavLink\n href={link.href}\n className=\"r-header-link\"\n targetClassName=\"_target\"\n key={link.title}\n >\n {link.title}\n </NavLink>\n ))}\n </nav>\n <div className=\"r-header-actions\">\n <div className=\"r-header-sections\">\n {versions && targetVersion && (\n <SectionDropdown\n defaultOption={targetVersion.key}\n options={versions.list.map((version) => ({\n href:\n version.href ||\n `${localePrefix}${version.key === versions.default ? \"\" : `/${version.key}`}/`,\n key: version.key,\n title: version.title,\n shortTitle: version.shortTitle,\n }))}\n />\n )}\n {locales && targetLocale && (\n <SectionDropdown\n defaultOption={targetLocale.key}\n options={locales.list.map((locale) => ({\n href:\n locale.href ||\n `${locale.key === locales.default ? \"\" : `/${locale.key}`}${versionPrefix}/`,\n key: locale.key,\n title: locale.title,\n shortTitle: locale.shortTitle,\n }))}\n />\n )}\n </div>\n {searcher && <Search searcher={searcher} translations={searchTranslations} />}\n </div>\n </HeaderMenu>\n {git && <HeaderSocial git={git} />}\n </Container>\n </header>\n );\n};\n"],"names":["Header","logo","versions","locales","links","git","searcher","translations","menu","searchTranslations","targetVersion","list","find","version","key","target","versionPrefix","default","targetLocale","locale","localePrefix","React","createElement","className","Container","NavLink","href","HeaderMenu","map","link","targetClassName","title","SectionDropdown","defaultOption","options","shortTitle","Search","HeaderSocial"],"mappings":"6YAkCaA,EAAgC,EAAGC,OAAMC,WAAUC,UAASC,QAAQ,GAAIC,MAAKC,WAAUC,mBAChG,MAAMC,KAAEA,KAASC,GAAuBF,GAAgB,CAAA,EAClDG,EAAgBR,GAAUS,KAAKC,MAAMC,GAAYA,EAAQC,MAAQZ,EAASa,SAC1EC,EAAiBN,GAAiBA,EAAcI,MAAQZ,GAAUe,QAAe,IAAIP,EAAcI,MAAvB,GAC5EI,EAAef,GAASQ,KAAKC,MAAMO,GAAWA,EAAOL,MAAQX,EAAQY,SACrEK,EAAgBF,GAAgBA,EAAaJ,MAAQX,GAASc,QAAe,IAAIC,EAAaJ,MAAtB,GAE9E,OACIO,EAAAC,cAAA,SAAA,CAAQC,UAAU,YACdF,EAAAC,cAACE,EAAS,CAACD,UAAU,iBACjBF,EAAAC,cAAA,MAAA,KACID,EAAAC,cAACG,EAAO,CAACC,KAAK,IAAIH,UAAU,iBACvBtB,IAGToB,EAAAC,cAACK,EAAW,CAAApB,aAAc,CAAEC,SACxBa,EAAAC,cAAA,MAAA,CAAKC,UAAU,gBACVnB,EAAMwB,KAAKC,GACRR,EAAAC,cAACG,EACG,CAAAC,KAAMG,EAAKH,KACXH,UAAU,gBACVO,gBAAgB,UAChBhB,IAAKe,EAAKE,OAETF,EAAKE,UAIlBV,EAAKC,cAAA,MAAA,CAAAC,UAAU,oBACXF,EAAKC,cAAA,MAAA,CAAAC,UAAU,qBACVrB,GAAYQ,GACTW,EAAAC,cAACU,EAAe,CACZC,cAAevB,EAAcI,IAC7BoB,QAAShC,EAASS,KAAKiB,KAAKf,IAAa,CACrCa,KACIb,EAAQa,MACR,GAAGN,IAAeP,EAAQC,MAAQZ,EAASe,QAAU,GAAK,IAAIJ,EAAQC,SAC1EA,IAAKD,EAAQC,IACbiB,MAAOlB,EAAQkB,MACfI,WAAYtB,EAAQsB,iBAI/BhC,GAAWe,GACRG,EAAAC,cAACU,EAAe,CACZC,cAAef,EAAaJ,IAC5BoB,QAAS/B,EAAQQ,KAAKiB,KAAKT,IAAY,CACnCO,KACIP,EAAOO,MACP,GAAGP,EAAOL,MAAQX,EAAQc,QAAU,GAAK,IAAIE,EAAOL,QAAQE,KAChEF,IAAKK,EAAOL,IACZiB,MAAOZ,EAAOY,MACdI,WAAYhB,EAAOgB,kBAKlC7B,GAAYe,EAAAC,cAACc,EAAM,CAAC9B,SAAUA,EAAUC,aAAcE,MAG9DJ,GAAOgB,EAACC,cAAAe,EAAa,CAAAhC,IAAKA,KAGrC"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/elements/header/index.tsx"],"sourcesContent":["import \"./header.scss\";\nimport React from \"react\";\nimport { HeaderMenu, type HeaderMenuProps } from \"@src/components/blocks/header-menu\";\nimport { Search, type SearchProps } from \"@src/components/blocks/search\";\nimport { SectionDropdown } from \"@src/components/blocks/section-dropdown\";\nimport { HeaderSocial } from \"@src/components/blocks/header-social\";\nimport { Container } from \"@src/components/ui/container\";\nimport { NavLink } from \"@src/components/blocks/nav-link\";\n\ntype SectionOption = {\n key: string;\n href?: string;\n title: string;\n shortTitle?: string;\n};\n\ntype SectionType = {\n default?: string;\n target: string;\n list: SectionOption[];\n};\n\nexport type HeaderProps = {\n logo: React.ReactElement;\n links?: {\n title: string;\n href: string;\n }[];\n git?: string | { uri: string; logo: React.ElementType };\n versions?: SectionType;\n locales?: SectionType;\n} & HeaderMenuProps &\n SearchProps;\n\nexport const Header: React.FC<HeaderProps> = ({ logo, versions, locales, links = [], git, searcher, translations }) => {\n const { menu, ...searchTranslations } = translations || {};\n const targetVersion = versions?.list.find((version) => version.key === versions.target);\n const versionPrefix = !targetVersion || targetVersion.key === versions?.default ? \"\" : `/${targetVersion.key}`;\n const targetLocale = locales?.list.find((locale) => locale.key === locales.target);\n const localePrefix = !targetLocale || targetLocale.key === locales?.default ? \"\" : `/${targetLocale.key}`;\n\n return (\n <header className=\"r-header\">\n <Container className=\"r-header-body\">\n <div>\n <NavLink href=\"/\" className=\"r-header-logo\">\n {logo}\n </NavLink>\n </div>\n <HeaderMenu translations={{ menu }}>\n <nav className=\"r-header-nav\">\n {links.map((link) => (\n <NavLink\n href={link.href}\n className=\"r-header-link\"\n targetClassName=\"_target\"\n key={link.title}\n >\n {link.title}\n </NavLink>\n ))}\n </nav>\n <div className=\"r-header-actions\">\n <div className=\"r-header-sections\">\n {versions && targetVersion && (\n <SectionDropdown\n defaultOption={targetVersion.key}\n options={versions.list.map((version) => ({\n href:\n version.href ||\n `${localePrefix}${version.key === versions.default ? \"\" : `/${version.key}`}/`,\n key: version.key,\n title: version.title,\n shortTitle: version.shortTitle,\n }))}\n />\n )}\n {locales && targetLocale && (\n <SectionDropdown\n defaultOption={targetLocale.key}\n options={locales.list.map((locale) => ({\n href:\n locale.href ||\n `${locale.key === locales.default ? \"\" : `/${locale.key}`}${versionPrefix}/`,\n key: locale.key,\n title: locale.title,\n shortTitle: locale.shortTitle,\n }))}\n />\n )}\n </div>\n {searcher && <Search searcher={searcher} translations={searchTranslations} />}\n </div>\n </HeaderMenu>\n {git && <HeaderSocial git={git} />}\n </Container>\n </header>\n );\n};\n"],"names":["Header","logo","versions","locales","links","git","searcher","translations","menu","searchTranslations","targetVersion","list","find","version","key","target","versionPrefix","default","targetLocale","locale","localePrefix","React","createElement","className","Container","NavLink","href","HeaderMenu","map","link","targetClassName","title","SectionDropdown","defaultOption","options","shortTitle","Search","HeaderSocial"],"mappings":"6YAkCaA,EAAgC,EAAGC,OAAMC,WAAUC,UAASC,QAAQ,GAAIC,MAAKC,WAAUC,mBAChG,MAAMC,KAAEA,KAASC,GAAuBF,GAAgB,CAAA,EAClDG,EAAgBR,GAAUS,KAAKC,KAAMC,GAAYA,EAAQC,MAAQZ,EAASa,QAC1EC,EAAiBN,GAAiBA,EAAcI,MAAQZ,GAAUe,QAAe,IAAIP,EAAcI,MAAvB,GAC5EI,EAAef,GAASQ,KAAKC,KAAMO,GAAWA,EAAOL,MAAQX,EAAQY,QACrEK,EAAgBF,GAAgBA,EAAaJ,MAAQX,GAASc,QAAe,IAAIC,EAAaJ,MAAtB,GAE9E,OACIO,EAAAC,cAAA,SAAA,CAAQC,UAAU,YACdF,EAAAC,cAACE,EAAS,CAACD,UAAU,iBACjBF,EAAAC,cAAA,MAAA,KACID,EAAAC,cAACG,EAAO,CAACC,KAAK,IAAIH,UAAU,iBACvBtB,IAGToB,EAAAC,cAACK,EAAU,CAACpB,aAAc,CAAEC,SACxBa,EAAAC,cAAA,MAAA,CAAKC,UAAU,gBACVnB,EAAMwB,IAAKC,GACRR,EAAAC,cAACG,EAAO,CACJC,KAAMG,EAAKH,KACXH,UAAU,gBACVO,gBAAgB,UAChBhB,IAAKe,EAAKE,OAETF,EAAKE,SAIlBV,EAAAC,cAAA,MAAA,CAAKC,UAAU,oBACXF,EAAAC,cAAA,MAAA,CAAKC,UAAU,qBACVrB,GAAYQ,GACTW,EAAAC,cAACU,EAAe,CACZC,cAAevB,EAAcI,IAC7BoB,QAAShC,EAASS,KAAKiB,IAAKf,IAAO,CAC/Ba,KACIb,EAAQa,MACR,GAAGN,IAAeP,EAAQC,MAAQZ,EAASe,QAAU,GAAK,IAAIJ,EAAQC,SAC1EA,IAAKD,EAAQC,IACbiB,MAAOlB,EAAQkB,MACfI,WAAYtB,EAAQsB,gBAI/BhC,GAAWe,GACRG,EAAAC,cAACU,EAAe,CACZC,cAAef,EAAaJ,IAC5BoB,QAAS/B,EAAQQ,KAAKiB,IAAKT,IAAM,CAC7BO,KACIP,EAAOO,MACP,GAAGP,EAAOL,MAAQX,EAAQc,QAAU,GAAK,IAAIE,EAAOL,QAAQE,KAChEF,IAAKK,EAAOL,IACZiB,MAAOZ,EAAOY,MACdI,WAAYhB,EAAOgB,iBAKlC7B,GAAYe,EAAAC,cAACc,EAAM,CAAC9B,SAAUA,EAAUC,aAAcE,MAG9DJ,GAAOgB,EAAAC,cAACe,EAAY,CAAChC,IAAKA"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/elements/keylink-to-content/index.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { Keylink } from \"@src/components/ui/keylink\";\n\nimport \"./keylink-to-content.scss\";\n\nexport type KeylinkToContentProps = {\n translations?: {\n /** Skip to main content */\n skipToMainContent?: string;\n };\n};\n\nexport const KeylinkToContent: React.FC<KeylinkToContentProps> = ({ translations }) => {\n const { skipToMainContent = \"Skip to main content\" } = translations || {};\n\n return (\n <Keylink className=\"keylink-to-content\" toId=\"main-content\">\n {skipToMainContent}\n </Keylink>\n );\n};\n"],"names":["KeylinkToContent","translations","skipToMainContent","React","createElement","Keylink","className","toId"],"mappings":"+EAaaA,EAAoD,EAAGC,mBAChE,MAAMC,kBAAEA,EAAoB,wBAA2BD,GAAgB,CAAA,EAEvE,OACIE,EAAAC,cAACC,EAAO,CAACC,UAAU,qBAAqBC,KAAK,gBACxCL,EAEP"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/elements/keylink-to-content/index.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { Keylink } from \"@src/components/ui/keylink\";\n\nimport \"./keylink-to-content.scss\";\n\nexport type KeylinkToContentProps = {\n translations?: {\n /** Skip to main content */\n skipToMainContent?: string;\n };\n};\n\nexport const KeylinkToContent: React.FC<KeylinkToContentProps> = ({ translations }) => {\n const { skipToMainContent = \"Skip to main content\" } = translations || {};\n\n return (\n <Keylink className=\"keylink-to-content\" toId=\"main-content\">\n {skipToMainContent}\n </Keylink>\n );\n};\n"],"names":["KeylinkToContent","translations","skipToMainContent","React","createElement","Keylink","className","toId"],"mappings":"+EAaaA,EAAoD,EAAGC,mBAChE,MAAMC,kBAAEA,EAAoB,wBAA2BD,GAAgB,CAAA,EAEvE,OACIE,EAAAC,cAACC,EAAO,CAACC,UAAU,qBAAqBC,KAAK,gBACxCL"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/elements/keylink-to-navigation/index.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { Keylink } from \"@src/components/ui/keylink\";\n\nimport \"./keylink-to-navigation.scss\";\n\nexport type KeylinkToNavigationProps = {\n translations?: {\n /** Return to navigation */\n returnToNavigation?: string;\n };\n};\n\nexport const KeylinkToNavigation: React.FC<KeylinkToNavigationProps> = ({ translations }) => {\n const { returnToNavigation = \"Return to navigation\" } = translations || {};\n\n return (\n <Keylink className=\"keylink-to-navigation\" toId=\"navigation\">\n {returnToNavigation}\n </Keylink>\n );\n};\n"],"names":["KeylinkToNavigation","translations","returnToNavigation","React","createElement","Keylink","className","toId"],"mappings":"+EAaaA,EAA0D,EAAGC,mBACtE,MAAMC,mBAAEA,EAAqB,wBAA2BD,GAAgB,CAAA,EAExE,OACIE,EAAAC,cAACC,EAAO,CAACC,UAAU,wBAAwBC,KAAK,cAC3CL,EAEP"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/elements/keylink-to-navigation/index.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { Keylink } from \"@src/components/ui/keylink\";\n\nimport \"./keylink-to-navigation.scss\";\n\nexport type KeylinkToNavigationProps = {\n translations?: {\n /** Return to navigation */\n returnToNavigation?: string;\n };\n};\n\nexport const KeylinkToNavigation: React.FC<KeylinkToNavigationProps> = ({ translations }) => {\n const { returnToNavigation = \"Return to navigation\" } = translations || {};\n\n return (\n <Keylink className=\"keylink-to-navigation\" toId=\"navigation\">\n {returnToNavigation}\n </Keylink>\n );\n};\n"],"names":["KeylinkToNavigation","translations","returnToNavigation","React","createElement","Keylink","className","toId"],"mappings":"+EAaaA,EAA0D,EAAGC,mBACtE,MAAMC,mBAAEA,EAAqB,wBAA2BD,GAAgB,CAAA,EAExE,OACIE,EAAAC,cAACC,EAAO,CAACC,UAAU,wBAAwBC,KAAK,cAC3CL"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/elements/robin-provider/index.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { type Theme } from \"@src/core/types/theme\";\nimport { NavigateProvider } from \"@src/components/contexts/navigate/provider\";\nimport { ThemeStyles } from \"@src/components/blocks/theme-styles\";\nimport { ThemeDetector } from \"@src/components/blocks/theme-detector\";\nimport { NoJs } from \"@src/components/blocks/no-js\";\n\ninterface RobinProviderProps {\n theme?: Theme;\n}\n\nexport const RobinProvider: React.FC<React.PropsWithChildren<RobinProviderProps>> = ({ children, theme }) => (\n <>\n {theme && <ThemeStyles theme={theme} />}\n <ThemeDetector />\n <NavigateProvider>{children}</NavigateProvider>\n <NoJs />\n </>\n);\n"],"names":["RobinProvider","children","theme","React","createElement","Fragment","ThemeStyles","ThemeDetector","NavigateProvider","NoJs"],"mappings":"qRAYO,MAAMA,EAAuE,EAAGC,WAAUC,WAC7FC,EAAAC,cAAAD,EAAAE,SAAA,KACKH,GAASC,EAACC,cAAAE,GAAYJ,MAAOA,IAC9BC,EAAAC,cAACG,EAAgB,MACjBJ,EAACC,cAAAI,EAAkB,KAAAP,GACnBE,EAAAC,cAACK,EAAI"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/elements/robin-provider/index.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { type Theme } from \"@src/core/types/theme\";\nimport { NavigateProvider } from \"@src/components/contexts/navigate/provider\";\nimport { ThemeStyles } from \"@src/components/blocks/theme-styles\";\nimport { ThemeDetector } from \"@src/components/blocks/theme-detector\";\nimport { NoJs } from \"@src/components/blocks/no-js\";\n\ninterface RobinProviderProps {\n theme?: Theme;\n}\n\nexport const RobinProvider: React.FC<React.PropsWithChildren<RobinProviderProps>> = ({ children, theme }) => (\n <>\n {theme && <ThemeStyles theme={theme} />}\n <ThemeDetector />\n <NavigateProvider>{children}</NavigateProvider>\n <NoJs />\n </>\n);\n"],"names":["RobinProvider","children","theme","React","createElement","Fragment","ThemeStyles","ThemeDetector","NavigateProvider","NoJs"],"mappings":"qRAYO,MAAMA,EAAuE,EAAGC,WAAUC,WAC7FC,EAAAC,cAAAD,EAAAE,SAAA,KACKH,GAASC,EAAAC,cAACE,GAAYJ,MAAOA,IAC9BC,EAAAC,cAACG,EAAa,MACdJ,EAAAC,cAACI,EAAgB,KAAEP,GACnBE,EAAAC,cAACK,EAAI"}
@@ -1,2 +1,2 @@
1
- import e from"react";import t from"clsx";import{SidebarMenu as r}from"./sidebar-menu/index.js";import{SidebarDrop as a}from"./sidebar-drop/index.js";import{SidebarLink as l}from"./sidebar-link/index.js";import{isActiveItem as s,collectItems as i}from"./tools.js";const n=({branch:r,depth:m,translations:p})=>{const{expandTitle:d="Expand {title}"}=p||{};return"separator"===r.type?e.createElement("li",{className:"r-sidebar-li _separator"}):e.createElement("li",{className:t("r-sidebar-li","heading"===r.type&&"r-sidebar-heading",r.items&&r.items.length>0&&"_droppable")},s(r)?e.createElement(l,{branch:r}):e.createElement("p",{className:t("r-sidebar-p","heading"===r.type&&"r-sidebar-heading")},r.title),r.items&&r.items.length>0&&e.createElement(a,{childHrefs:i(r),defaultOpen:!1,id:r.href+r.title,label:d.replace("{title}",r.title)},r.items.map(((t,r)=>e.createElement(n,{branch:t,key:"separator"===t.type?`sep${r}`:t.href+t.title,depth:m>=4?4:m+1,translations:p})))))},m=({tree:t,translations:a})=>t?.length?e.createElement(e.Fragment,null,e.createElement("div",{className:"r-sidebar-top-mock"}),e.createElement(r,null,e.createElement("ul",{className:"r-sidebar-list"},t.map(((t,r)=>e.createElement(n,{branch:t,key:"separator"===t.type?`sep${r}`:t.href+t.title,depth:0,translations:a})))))):e.createElement("div",{className:"r-sidebar"});export{m as Sidebar};
1
+ import e from"react";import t from"clsx";import{SidebarMenu as r}from"./sidebar-menu/index.js";import{SidebarDrop as a}from"./sidebar-drop/index.js";import{SidebarLink as l}from"./sidebar-link/index.js";import{isActiveItem as s,collectItems as i}from"./tools.js";const n=({branch:r,depth:m,translations:p})=>{const{expandTitle:d="Expand {title}"}=p||{};return"separator"===r.type?e.createElement("li",{className:"r-sidebar-li _separator"}):e.createElement("li",{className:t("r-sidebar-li","heading"===r.type&&"r-sidebar-heading",r.items&&r.items.length>0&&"_droppable")},s(r)?e.createElement(l,{branch:r}):e.createElement("p",{className:t("r-sidebar-p","heading"===r.type&&"r-sidebar-heading")},r.title),r.items&&r.items.length>0&&e.createElement(a,{childHrefs:i(r),defaultOpen:!1,id:r.href+r.title,label:d.replace("{title}",r.title)},r.items.map((t,r)=>e.createElement(n,{branch:t,key:"separator"===t.type?`sep${r}`:t.href+t.title,depth:m>=4?4:m+1,translations:p}))))},m=({tree:t,translations:a})=>t?.length?e.createElement(e.Fragment,null,e.createElement("div",{className:"r-sidebar-top-mock"}),e.createElement(r,null,e.createElement("ul",{className:"r-sidebar-list"},t.map((t,r)=>e.createElement(n,{branch:t,key:"separator"===t.type?`sep${r}`:t.href+t.title,depth:0,translations:a}))))):e.createElement("div",{className:"r-sidebar"});export{m as Sidebar};
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/elements/sidebar/index.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\n\nimport { type TreeItem } from \"./types\";\nimport { SidebarMenu } from \"./sidebar-menu\";\nimport { SidebarDrop } from \"./sidebar-drop\";\nimport { SidebarLink } from \"./sidebar-link\";\nimport { collectItems, isActiveItem } from \"./tools\";\n\nimport \"./sidebar.scss\";\n\ntype LinkBranchProps = {\n branch: TreeItem;\n depth: number;\n translations?: {\n /** Expand {title} */\n expandTitle?: string;\n };\n};\n\nconst LinkBranch: React.FC<LinkBranchProps> = ({ branch, depth, translations }) => {\n const { expandTitle = \"Expand {title}\" } = translations || {};\n\n if (branch.type === \"separator\") {\n return <li className=\"r-sidebar-li _separator\" />;\n }\n\n return (\n <li\n className={clsx(\n \"r-sidebar-li\",\n branch.type === \"heading\" && \"r-sidebar-heading\",\n branch.items && branch.items.length > 0 && \"_droppable\",\n )}\n >\n {isActiveItem(branch) ? (\n <SidebarLink branch={branch} />\n ) : (\n <p className={clsx(\"r-sidebar-p\", branch.type === \"heading\" && \"r-sidebar-heading\")}>{branch.title}</p>\n )}\n {branch.items && branch.items.length > 0 && (\n <SidebarDrop\n childHrefs={collectItems(branch)}\n defaultOpen={false}\n id={branch.href + branch.title}\n label={expandTitle.replace(\"{title}\", branch.title)}\n >\n {branch.items.map((item, index) => (\n <LinkBranch\n branch={item}\n key={item.type === \"separator\" ? `sep${index}` : item.href + item.title}\n depth={depth >= 4 ? 4 : depth + 1}\n translations={translations}\n />\n ))}\n </SidebarDrop>\n )}\n </li>\n );\n};\n\nexport type SidebarProps = {\n tree?: TreeItem[] | null;\n translations?: LinkBranchProps[\"translations\"];\n};\n\nexport const Sidebar: React.FC<SidebarProps> = ({ tree, translations }) => {\n if (!tree?.length) return <div className=\"r-sidebar\" />;\n\n return (\n <>\n <div className=\"r-sidebar-top-mock\" />\n <SidebarMenu>\n <ul className=\"r-sidebar-list\">\n {tree.map((item, index) => (\n <LinkBranch\n branch={item}\n key={item.type === \"separator\" ? `sep${index}` : item.href + item.title}\n depth={0}\n translations={translations}\n />\n ))}\n </ul>\n </SidebarMenu>\n </>\n );\n};\n"],"names":["LinkBranch","branch","depth","translations","expandTitle","type","React","createElement","className","clsx","items","length","isActiveItem","SidebarLink","title","SidebarDrop","childHrefs","collectItems","defaultOpen","id","href","label","replace","map","item","index","key","Sidebar","tree","Fragment","SidebarMenu"],"mappings":"uQAoBA,MAAMA,EAAwC,EAAGC,SAAQC,QAAOC,mBAC5D,MAAMC,YAAEA,EAAc,kBAAqBD,GAAgB,CAAA,EAE3D,MAAoB,cAAhBF,EAAOI,KACAC,EAAIC,cAAA,KAAA,CAAAC,UAAU,4BAIrBF,EAAAC,cAAA,KAAA,CACIC,UAAWC,EACP,eACgB,YAAhBR,EAAOI,MAAsB,oBAC7BJ,EAAOS,OAAST,EAAOS,MAAMC,OAAS,GAAK,eAG9CC,EAAaX,GACVK,EAAAC,cAACM,EAAW,CAACZ,OAAQA,IAErBK,EAAGC,cAAA,IAAA,CAAAC,UAAWC,EAAK,cAA+B,YAAhBR,EAAOI,MAAsB,sBAAuBJ,EAAOa,OAEhGb,EAAOS,OAAST,EAAOS,MAAMC,OAAS,GACnCL,EAAAC,cAACQ,EAAW,CACRC,WAAYC,EAAahB,GACzBiB,aAAa,EACbC,GAAIlB,EAAOmB,KAAOnB,EAAOa,MACzBO,MAAOjB,EAAYkB,QAAQ,UAAWrB,EAAOa,QAE5Cb,EAAOS,MAAMa,KAAI,CAACC,EAAMC,IACrBnB,EAACC,cAAAP,EACG,CAAAC,OAAQuB,EACRE,IAAmB,cAAdF,EAAKnB,KAAuB,MAAMoB,IAAUD,EAAKJ,KAAOI,EAAKV,MAClEZ,MAAOA,GAAS,EAAI,EAAIA,EAAQ,EAChCC,aAAcA,OAMpC,EAQOwB,EAAkC,EAAGC,OAAMzB,kBAC/CyB,GAAMjB,OAGPL,EAAAC,cAAAD,EAAAuB,SAAA,KACIvB,EAAKC,cAAA,MAAA,CAAAC,UAAU,uBACfF,EAAAC,cAACuB,EAAW,KACRxB,EAAAC,cAAA,KAAA,CAAIC,UAAU,kBACToB,EAAKL,KAAI,CAACC,EAAMC,IACbnB,EAACC,cAAAP,EACG,CAAAC,OAAQuB,EACRE,IAAmB,cAAdF,EAAKnB,KAAuB,MAAMoB,IAAUD,EAAKJ,KAAOI,EAAKV,MAClEZ,MAAO,EACPC,aAAcA,SAZZG,EAAKC,cAAA,MAAA,CAAAC,UAAU"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/elements/sidebar/index.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\n\nimport { type TreeItem } from \"./types\";\nimport { SidebarMenu } from \"./sidebar-menu\";\nimport { SidebarDrop } from \"./sidebar-drop\";\nimport { SidebarLink } from \"./sidebar-link\";\nimport { collectItems, isActiveItem } from \"./tools\";\n\nimport \"./sidebar.scss\";\n\ntype LinkBranchProps = {\n branch: TreeItem;\n depth: number;\n translations?: {\n /** Expand {title} */\n expandTitle?: string;\n };\n};\n\nconst LinkBranch: React.FC<LinkBranchProps> = ({ branch, depth, translations }) => {\n const { expandTitle = \"Expand {title}\" } = translations || {};\n\n if (branch.type === \"separator\") {\n return <li className=\"r-sidebar-li _separator\" />;\n }\n\n return (\n <li\n className={clsx(\n \"r-sidebar-li\",\n branch.type === \"heading\" && \"r-sidebar-heading\",\n branch.items && branch.items.length > 0 && \"_droppable\",\n )}\n >\n {isActiveItem(branch) ? (\n <SidebarLink branch={branch} />\n ) : (\n <p className={clsx(\"r-sidebar-p\", branch.type === \"heading\" && \"r-sidebar-heading\")}>{branch.title}</p>\n )}\n {branch.items && branch.items.length > 0 && (\n <SidebarDrop\n childHrefs={collectItems(branch)}\n defaultOpen={false}\n id={branch.href + branch.title}\n label={expandTitle.replace(\"{title}\", branch.title)}\n >\n {branch.items.map((item, index) => (\n <LinkBranch\n branch={item}\n key={item.type === \"separator\" ? `sep${index}` : item.href + item.title}\n depth={depth >= 4 ? 4 : depth + 1}\n translations={translations}\n />\n ))}\n </SidebarDrop>\n )}\n </li>\n );\n};\n\nexport type SidebarProps = {\n tree?: TreeItem[] | null;\n translations?: LinkBranchProps[\"translations\"];\n};\n\nexport const Sidebar: React.FC<SidebarProps> = ({ tree, translations }) => {\n if (!tree?.length) return <div className=\"r-sidebar\" />;\n\n return (\n <>\n <div className=\"r-sidebar-top-mock\" />\n <SidebarMenu>\n <ul className=\"r-sidebar-list\">\n {tree.map((item, index) => (\n <LinkBranch\n branch={item}\n key={item.type === \"separator\" ? `sep${index}` : item.href + item.title}\n depth={0}\n translations={translations}\n />\n ))}\n </ul>\n </SidebarMenu>\n </>\n );\n};\n"],"names":["LinkBranch","branch","depth","translations","expandTitle","type","React","createElement","className","clsx","items","length","isActiveItem","SidebarLink","title","SidebarDrop","childHrefs","collectItems","defaultOpen","id","href","label","replace","map","item","index","key","Sidebar","tree","Fragment","SidebarMenu"],"mappings":"uQAoBA,MAAMA,EAAwC,EAAGC,SAAQC,QAAOC,mBAC5D,MAAMC,YAAEA,EAAc,kBAAqBD,GAAgB,CAAA,EAE3D,MAAoB,cAAhBF,EAAOI,KACAC,EAAAC,cAAA,KAAA,CAAIC,UAAU,4BAIrBF,EAAAC,cAAA,KAAA,CACIC,UAAWC,EACP,eACgB,YAAhBR,EAAOI,MAAsB,oBAC7BJ,EAAOS,OAAST,EAAOS,MAAMC,OAAS,GAAK,eAG9CC,EAAaX,GACVK,EAAAC,cAACM,EAAW,CAACZ,OAAQA,IAErBK,EAAAC,cAAA,IAAA,CAAGC,UAAWC,EAAK,cAA+B,YAAhBR,EAAOI,MAAsB,sBAAuBJ,EAAOa,OAEhGb,EAAOS,OAAST,EAAOS,MAAMC,OAAS,GACnCL,EAAAC,cAACQ,EAAW,CACRC,WAAYC,EAAahB,GACzBiB,aAAa,EACbC,GAAIlB,EAAOmB,KAAOnB,EAAOa,MACzBO,MAAOjB,EAAYkB,QAAQ,UAAWrB,EAAOa,QAE5Cb,EAAOS,MAAMa,IAAI,CAACC,EAAMC,IACrBnB,EAAAC,cAACP,EAAU,CACPC,OAAQuB,EACRE,IAAmB,cAAdF,EAAKnB,KAAuB,MAAMoB,IAAUD,EAAKJ,KAAOI,EAAKV,MAClEZ,MAAOA,GAAS,EAAI,EAAIA,EAAQ,EAChCC,aAAcA,QAc7BwB,EAAkC,EAAGC,OAAMzB,kBAC/CyB,GAAMjB,OAGPL,EAAAC,cAAAD,EAAAuB,SAAA,KACIvB,EAAAC,cAAA,MAAA,CAAKC,UAAU,uBACfF,EAAAC,cAACuB,EAAW,KACRxB,EAAAC,cAAA,KAAA,CAAIC,UAAU,kBACToB,EAAKL,IAAI,CAACC,EAAMC,IACbnB,EAAAC,cAACP,EAAU,CACPC,OAAQuB,EACRE,IAAmB,cAAdF,EAAKnB,KAAuB,MAAMoB,IAAUD,EAAKJ,KAAOI,EAAKV,MAClEZ,MAAO,EACPC,aAAcA,QAZZG,EAAAC,cAAA,MAAA,CAAKC,UAAU"}
@@ -1,3 +1,3 @@
1
1
  'use client';
2
- import e,{useState as r,useRef as t,useEffect as n}from"react";import{usePathname as o}from"next/navigation";const s=({childHrefs:s,label:a,children:i})=>{const l=o(),c=s.includes(l),[d,m]=r(c),u=t(null),p=t(null);return n((()=>{c&&!d&&m(!0),c&&p.current&&!p.current?.open&&(p.current.open=!0)}),[c]),n((()=>{p.current?.style.setProperty("--drop-height",u.current?.offsetHeight.toString()+"px")}),[]),e.createElement("details",{className:"r-sidebar-drop",open:d,ref:p},e.createElement("summary",{className:"r-sidebar-drop-btn","aria-label":a},e.createElement("svg",{className:"r-sidebar-drop-icon",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},e.createElement("path",{d:"m9 18 6-6-6-6"}))),e.createElement("ul",{className:"r-sidebar-list r-sidebar-sublist",ref:u},i))};export{s as SidebarDrop};
2
+ import e,{useState as r,useRef as t,useEffect as n}from"react";import{usePathname as o}from"next/navigation";const s=({childHrefs:s,label:a,children:i})=>{const l=o(),c=s.includes(l),[d,m]=r(c),u=t(null),p=t(null);return n(()=>{c&&!d&&m(!0),c&&p.current&&!p.current?.open&&(p.current.open=!0)},[c]),n(()=>{p.current?.style.setProperty("--drop-height",u.current?.offsetHeight.toString()+"px")},[]),e.createElement("details",{className:"r-sidebar-drop",open:d,ref:p},e.createElement("summary",{className:"r-sidebar-drop-btn","aria-label":a},e.createElement("svg",{className:"r-sidebar-drop-icon",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},e.createElement("path",{d:"m9 18 6-6-6-6"}))),e.createElement("ul",{className:"r-sidebar-list r-sidebar-sublist",ref:u},i))};export{s as SidebarDrop};
3
3
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../../src/components/elements/sidebar/sidebar-drop/index.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { useEffect, useRef, useState } from \"react\";\nimport { usePathname } from \"next/navigation\";\n\nexport interface SidebarDropProps {\n childHrefs: string[];\n defaultOpen?: boolean;\n label: string;\n id: string;\n}\n\nexport const SidebarDrop: React.FC<React.PropsWithChildren<SidebarDropProps>> = ({ childHrefs, label, children }) => {\n const pathname = usePathname();\n const openedByDefault = childHrefs.includes(pathname);\n const [opened, setOpened] = useState(openedByDefault);\n const dropdownRef = useRef<HTMLUListElement>(null);\n const detailsRef = useRef<HTMLDetailsElement>(null);\n\n useEffect(() => {\n if (openedByDefault && !opened) setOpened(true);\n if (openedByDefault && detailsRef.current && !detailsRef.current?.open) detailsRef.current.open = true;\n }, [openedByDefault]);\n\n useEffect(() => {\n detailsRef.current?.style.setProperty(\"--drop-height\", dropdownRef.current?.offsetHeight.toString() + \"px\");\n }, []);\n\n return (\n <details className=\"r-sidebar-drop\" open={opened} ref={detailsRef}>\n <summary className=\"r-sidebar-drop-btn\" aria-label={label}>\n <svg\n className=\"r-sidebar-drop-icon\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n </summary>\n <ul className=\"r-sidebar-list r-sidebar-sublist\" ref={dropdownRef}>\n {children}\n </ul>\n </details>\n );\n};\n"],"names":["SidebarDrop","childHrefs","label","children","pathname","usePathname","openedByDefault","includes","opened","setOpened","useState","dropdownRef","useRef","detailsRef","useEffect","current","open","style","setProperty","offsetHeight","toString","React","createElement","className","ref","width","height","viewBox","fill","stroke","strokeWidth","strokeLinecap","strokeLinejoin","d"],"mappings":";4FAYO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAMA,CAAmE,CAAA,CAAA,CAAGC,CAAYC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAOC,CAClG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAMC,EAAWC,CACXC,CAAAA,CAAAA,CAAAA,CAAAA,CAAkBL,CAAWM,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAASH,CACrCI,CAAAA,CAAAA,CAAAA,CAAAA,CAAQC,CAAaC,CAAAA,CAAAA,CAAAA,CAASJ,CAC/BK,CAAAA,CAAAA,CAAAA,CAAcC,CAAyB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CACvCC,CAAaD,CAAAA,CAAAA,CAA2B,MAW9C,CATAE,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAU,CACFR,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAoBE,CAAQC,CAAAA,CAAAA,CAAAA,CAAAA,CAAU,CACtCH,CAAAA,CAAAA,CAAAA,CAAAA,CAAmBO,CAAWE,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAYF,CAAWE,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAASC,CAAMH,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAWE,CAAQC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAO,CAAI,CAAA,CAAA,CAAA,CACvG,CAACV,CAAAA,CAAAA,CAAAA,CAEJQ,CAAU,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CACND,CAAWE,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAASE,CAAMC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAY,CAAiBP,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAYI,CAASI,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAaC,WAAa,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAC5G,CAGCC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAASC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAU,CAAiBP,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAMR,CAAQgB,CAAAA,CAAAA,CAAAA,CAAAA,CAAKX,CACnDQ,CAAAA,CAAAA,CAAAA,CAAAC,cAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAASC,CAAU,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAoB,CAAarB,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAChDmB,CAAAC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CACIC,CAAU,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CACVE,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CACNC,OAAO,CACPC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAQ,CACRC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAK,CACLC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAO,CACPC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAY,CACZC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAc,CACdC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAe,CAEfX,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAMW,CAAAA,CAAE,CAGhBZ,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAIC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAU,CAAmCC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAKb,CACjDR,CAAAA,CAAAA,CAAAA,CAAAA,CAGZ"}
1
+ {"version":3,"file":"index.js","sources":["../../../../../src/components/elements/sidebar/sidebar-drop/index.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { useEffect, useRef, useState } from \"react\";\nimport { usePathname } from \"next/navigation\";\n\nexport interface SidebarDropProps {\n childHrefs: string[];\n defaultOpen?: boolean;\n label: string;\n id: string;\n}\n\nexport const SidebarDrop: React.FC<React.PropsWithChildren<SidebarDropProps>> = ({ childHrefs, label, children }) => {\n const pathname = usePathname();\n const openedByDefault = childHrefs.includes(pathname);\n const [opened, setOpened] = useState(openedByDefault);\n const dropdownRef = useRef<HTMLUListElement>(null);\n const detailsRef = useRef<HTMLDetailsElement>(null);\n\n useEffect(() => {\n if (openedByDefault && !opened) setOpened(true);\n if (openedByDefault && detailsRef.current && !detailsRef.current?.open) detailsRef.current.open = true;\n }, [openedByDefault]);\n\n useEffect(() => {\n detailsRef.current?.style.setProperty(\"--drop-height\", dropdownRef.current?.offsetHeight.toString() + \"px\");\n }, []);\n\n return (\n <details className=\"r-sidebar-drop\" open={opened} ref={detailsRef}>\n <summary className=\"r-sidebar-drop-btn\" aria-label={label}>\n <svg\n className=\"r-sidebar-drop-icon\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n </summary>\n <ul className=\"r-sidebar-list r-sidebar-sublist\" ref={dropdownRef}>\n {children}\n </ul>\n </details>\n );\n};\n"],"names":["SidebarDrop","childHrefs","label","children","pathname","usePathname","openedByDefault","includes","opened","setOpened","useState","dropdownRef","useRef","detailsRef","useEffect","current","open","style","setProperty","offsetHeight","toString","React","createElement","className","ref","width","height","viewBox","fill","stroke","strokeWidth","strokeLinecap","strokeLinejoin","d"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../../src/components/elements/sidebar/sidebar-link/index.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { useRef } from \"react\";\nimport { usePathname } from \"next/navigation\";\nimport clsx from \"clsx\";\n\nimport { useReference } from \"@src/components/contexts/reference/use-reference\";\nimport { NavLink } from \"@src/components/blocks/nav-link\";\n\nimport { type TreeItem } from \"../types\";\nimport { checkIsTargetPathname, collectItems } from \"../tools\";\n\ntype SidebarLinkProps = {\n branch: Exclude<TreeItem, { type: \"separator\" }> & { href: string };\n};\n\nexport const SidebarLink: React.FC<SidebarLinkProps> = ({ branch }) => {\n const pathname = usePathname();\n const isActive = checkIsTargetPathname(branch.href, pathname);\n const isTarget = collectItems(branch).includes(pathname);\n const scrollTimeoutRef = useRef<NodeJS.Timeout | null>(null);\n const sidebar = useReference();\n\n return (\n <NavLink\n href={branch.href}\n className={clsx(\"r-sidebar-link\", isActive && \"_active\", isTarget && \"_target\")}\n ref={(node) => {\n if (isTarget && sidebar && sidebar.scrollHeight > window.innerHeight - 60) {\n scrollTimeoutRef.current = null;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (node as any)?.parentElement?.scrollIntoViewIfNeeded?.();\n }\n }}\n >\n {branch.title}\n </NavLink>\n );\n};\n"],"names":["SidebarLink","branch","pathname","usePathname","isActive","checkIsTargetPathname","href","isTarget","collectItems","includes","scrollTimeoutRef","useRef","sidebar","useReference","React","createElement","NavLink","className","clsx","ref","node","scrollHeight","window","innerHeight","current","parentElement","scrollIntoViewIfNeeded","title"],"mappings":";wTAgBaA,CAA0C,CAAA,CAAA,CAAGC,CACtD,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAMC,CAAWC,CAAAA,CAAAA,CAAAA,CAAAA,CACXC,CAAWC,CAAAA,CAAAA,CAAsBJ,EAAOK,CAAMJ,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAC9CK,CAAWC,CAAAA,CAAAA,CAAaP,CAAQQ,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAASP,CACzCQ,CAAAA,CAAAA,CAAAA,CAAmBC,EAA8B,CACjDC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAUC,CAEhB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CACIC,CAAAC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAACC,CAAO,CAAA,CACJV,KAAML,CAAOK,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CACbW,CAAWC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAK,CAAkBd,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAY,CAAWG,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAY,WACrEY,CAAMC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CACEb,CAAYK,CAAAA,CAAAA,CAAAA,CAAAA,CAAWA,CAAQS,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAeC,CAAOC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAc,KACnEb,CAAiBc,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAU,CAE1BJ,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAcK,CAAeC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAClC,CAGHzB,CAAAA,CAAAA,CAAAA,CAAO0B,MAEf"}
1
+ {"version":3,"file":"index.js","sources":["../../../../../src/components/elements/sidebar/sidebar-link/index.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { useRef } from \"react\";\nimport { usePathname } from \"next/navigation\";\nimport clsx from \"clsx\";\n\nimport { useReference } from \"@src/components/contexts/reference/use-reference\";\nimport { NavLink } from \"@src/components/blocks/nav-link\";\n\nimport { type TreeItem } from \"../types\";\nimport { checkIsTargetPathname, collectItems } from \"../tools\";\n\ntype SidebarLinkProps = {\n branch: Exclude<TreeItem, { type: \"separator\" }> & { href: string };\n};\n\nexport const SidebarLink: React.FC<SidebarLinkProps> = ({ branch }) => {\n const pathname = usePathname();\n const isActive = checkIsTargetPathname(branch.href, pathname);\n const isTarget = collectItems(branch).includes(pathname);\n const scrollTimeoutRef = useRef<NodeJS.Timeout | null>(null);\n const sidebar = useReference();\n\n return (\n <NavLink\n href={branch.href}\n className={clsx(\"r-sidebar-link\", isActive && \"_active\", isTarget && \"_target\")}\n ref={(node) => {\n if (isTarget && sidebar && sidebar.scrollHeight > window.innerHeight - 60) {\n scrollTimeoutRef.current = null;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (node as any)?.parentElement?.scrollIntoViewIfNeeded?.();\n }\n }}\n >\n {branch.title}\n </NavLink>\n );\n};\n"],"names":["SidebarLink","branch","pathname","usePathname","isActive","checkIsTargetPathname","href","isTarget","collectItems","includes","scrollTimeoutRef","useRef","sidebar","useReference","React","createElement","NavLink","className","clsx","ref","node","scrollHeight","window","innerHeight","current","parentElement","scrollIntoViewIfNeeded","title"],"mappings":";wTAgBaA,CAAAA,CAA0C,CAAA,CAAGC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CACtD,CAAA,CAAA,CAAA,CAAA,CAAA,CAAMC,CAAAA,CAAWC,CAAAA,CAAAA,CAAAA,CACXC,CAAAA,CAAWC,EAAsBJ,CAAAA,CAAOK,CAAAA,CAAAA,CAAAA,CAAAA,CAAMJ,CAAAA,CAAAA,CAC9CK,CAAAA,CAAWC,CAAAA,CAAaP,CAAAA,CAAAA,CAAQQ,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAASP,CAAAA,CAAAA,CACzCQ,EAAmBC,CAAAA,CAA8B,CAAA,CAAA,CAAA,CAAA,CAAA,CACjDC,CAAAA,CAAUC,CAAAA,CAAAA,CAAAA,CAEhB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CACIC,CAAAA,CAAAC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAACC,CAAAA,CAAO,CACJV,CAAAA,CAAAA,CAAAA,CAAAA,CAAML,CAAAA,CAAOK,CAAAA,CAAAA,CAAAA,CAAAA,CACbW,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAWC,CAAAA,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAkBd,CAAAA,CAAAA,CAAY,UAAWG,CAAAA,CAAAA,CAAY,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CACrEY,CAAAA,CAAAA,CAAAA,CAAMC,CAAAA,CAAAA,CAAAA,CACEb,CAAAA,CAAAA,CAAYK,CAAAA,CAAAA,CAAWA,CAAAA,CAAQS,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAeC,OAAOC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAc,CAAA,CAAA,CAAA,CAAA,CACnEb,CAAAA,CAAiBc,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAU,CAAA,CAAA,CAAA,CAAA,CAE1BJ,CAAAA,CAAAA,CAAcK,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAeC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAIrCzB,EAAO0B,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA"}
@@ -1,3 +1,3 @@
1
1
  'use client';
2
- import e,{useState as t,useRef as r,useEffect as n}from"react";import{useNavigate as a}from"../../../contexts/navigate/use-navigate.js";import{ReferenceProvider as o}from"../../../contexts/reference/provider.js";const s=({children:s,translations:i})=>{const{menu:c="Menu"}=i||{},{addListener:l,removeListener:d}=a(),[m,b]=t(!1),u=r(null),p=()=>{document.body.classList.remove("body-mobile-lock"),b(!1),d("closeSidebarMenu")};return n((()=>()=>{p()}),[]),e.createElement("div",{className:"r-sidebar"},e.createElement("input",{type:"checkbox",id:"sidebar-input",className:"r-sidebar-input",hidden:!0,onChange:()=>{m?p():(document.body.classList.add("body-mobile-lock"),b(!0),l("closeSidebarMenu",p))},checked:m}),e.createElement("label",{htmlFor:"sidebar-input",className:"r-sidebar-btn",role:"button",tabIndex:0},e.createElement("svg",{className:"r-sidebar-chevron",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},e.createElement("path",{d:"m9 18 6-6-6-6"})),e.createElement("span",null,c)),e.createElement("nav",{ref:u,className:"r-sidebar-nav",id:"navigation"},e.createElement(o,{reference:u},s)))};export{s as SidebarMenu};
2
+ import e,{useState as t,useRef as r,useEffect as n}from"react";import{useNavigate as a}from"../../../contexts/navigate/use-navigate.js";import{ReferenceProvider as o}from"../../../contexts/reference/provider.js";const s=({children:s,translations:i})=>{const{menu:c="Menu"}=i||{},{addListener:l,removeListener:d}=a(),[m,b]=t(!1),u=r(null),p=()=>{document.body.classList.remove("body-mobile-lock"),b(!1),d("closeSidebarMenu")};return n(()=>()=>{p()},[]),e.createElement("div",{className:"r-sidebar"},e.createElement("input",{type:"checkbox",id:"sidebar-input",className:"r-sidebar-input",hidden:!0,onChange:()=>{m?p():(document.body.classList.add("body-mobile-lock"),b(!0),l("closeSidebarMenu",p))},checked:m}),e.createElement("label",{htmlFor:"sidebar-input",className:"r-sidebar-btn",role:"button",tabIndex:0},e.createElement("svg",{className:"r-sidebar-chevron",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},e.createElement("path",{d:"m9 18 6-6-6-6"})),e.createElement("span",null,c)),e.createElement("nav",{ref:u,className:"r-sidebar-nav",id:"navigation"},e.createElement(o,{reference:u},s)))};export{s as SidebarMenu};
3
3
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../../src/components/elements/sidebar/sidebar-menu/index.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { useEffect, useRef, useState } from \"react\";\n\nimport { useNavigate } from \"@src/components/contexts/navigate/use-navigate\";\nimport { ReferenceProvider } from \"@src/components/contexts/reference/provider\";\n\nexport type SidebarMenuProps = React.PropsWithChildren<{\n translations?: {\n menu?: string;\n };\n}>;\n\nexport const SidebarMenu: React.FC<SidebarMenuProps> = ({ children, translations }) => {\n const { menu = \"Menu\" } = translations || {};\n const { addListener, removeListener } = useNavigate();\n const [opened, setOpened] = useState(false);\n const sidebarNavRef = useRef<HTMLElement | null>(null);\n\n const openHandler = () => {\n document.body.classList.add(\"body-mobile-lock\");\n setOpened(true);\n addListener(\"closeSidebarMenu\", closeHandler);\n };\n\n const closeHandler = () => {\n document.body.classList.remove(\"body-mobile-lock\");\n setOpened(false);\n removeListener(\"closeSidebarMenu\");\n };\n\n const toggleHandler = () => {\n if (opened) {\n closeHandler();\n } else {\n openHandler();\n }\n };\n\n useEffect(\n () => () => {\n closeHandler();\n },\n [],\n );\n\n return (\n <div className=\"r-sidebar\">\n <input\n type=\"checkbox\"\n id=\"sidebar-input\"\n className=\"r-sidebar-input\"\n hidden\n onChange={toggleHandler}\n checked={opened}\n />\n <label htmlFor=\"sidebar-input\" className=\"r-sidebar-btn\" role=\"button\" tabIndex={0}>\n <svg\n className=\"r-sidebar-chevron\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n <span>{menu}</span>\n </label>\n <nav ref={sidebarNavRef} className=\"r-sidebar-nav\" id=\"navigation\">\n <ReferenceProvider reference={sidebarNavRef}>{children}</ReferenceProvider>\n </nav>\n </div>\n );\n};\n"],"names":["SidebarMenu","children","translations","menu","addListener","removeListener","useNavigate","opened","setOpened","useState","sidebarNavRef","useRef","closeHandler","document","body","classList","remove","useEffect","React","createElement","className","type","id","hidden","onChange","add","checked","htmlFor","role","tabIndex","width","height","viewBox","fill","stroke","strokeWidth","strokeLinecap","strokeLinejoin","d","ref","ReferenceProvider","reference"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../../../../src/components/elements/sidebar/sidebar-menu/index.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { useEffect, useRef, useState } from \"react\";\n\nimport { useNavigate } from \"@src/components/contexts/navigate/use-navigate\";\nimport { ReferenceProvider } from \"@src/components/contexts/reference/provider\";\n\nexport type SidebarMenuProps = React.PropsWithChildren<{\n translations?: {\n menu?: string;\n };\n}>;\n\nexport const SidebarMenu: React.FC<SidebarMenuProps> = ({ children, translations }) => {\n const { menu = \"Menu\" } = translations || {};\n const { addListener, removeListener } = useNavigate();\n const [opened, setOpened] = useState(false);\n const sidebarNavRef = useRef<HTMLElement | null>(null);\n\n const openHandler = () => {\n document.body.classList.add(\"body-mobile-lock\");\n setOpened(true);\n addListener(\"closeSidebarMenu\", closeHandler);\n };\n\n const closeHandler = () => {\n document.body.classList.remove(\"body-mobile-lock\");\n setOpened(false);\n removeListener(\"closeSidebarMenu\");\n };\n\n const toggleHandler = () => {\n if (opened) {\n closeHandler();\n } else {\n openHandler();\n }\n };\n\n useEffect(\n () => () => {\n closeHandler();\n },\n [],\n );\n\n return (\n <div className=\"r-sidebar\">\n <input\n type=\"checkbox\"\n id=\"sidebar-input\"\n className=\"r-sidebar-input\"\n hidden\n onChange={toggleHandler}\n checked={opened}\n />\n <label htmlFor=\"sidebar-input\" className=\"r-sidebar-btn\" role=\"button\" tabIndex={0}>\n <svg\n className=\"r-sidebar-chevron\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n <span>{menu}</span>\n </label>\n <nav ref={sidebarNavRef} className=\"r-sidebar-nav\" id=\"navigation\">\n <ReferenceProvider reference={sidebarNavRef}>{children}</ReferenceProvider>\n </nav>\n </div>\n );\n};\n"],"names":["SidebarMenu","children","translations","menu","addListener","removeListener","useNavigate","opened","setOpened","useState","sidebarNavRef","useRef","closeHandler","document","body","classList","remove","useEffect","React","createElement","className","type","id","hidden","onChange","add","checked","htmlFor","role","tabIndex","width","height","viewBox","fill","stroke","strokeWidth","strokeLinecap","strokeLinejoin","d","ref","ReferenceProvider","reference"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"tools.d.ts","sourceRoot":"","sources":["../../../../src/components/elements/sidebar/tools.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,SAAS,CAAC;AAExC,eAAO,MAAM,YAAY,WAAY,QAAQ,aAY5C,CAAC;AAEF,eAAO,MAAM,YAAY,WAAY,QAAQ;UAAgC,MAAM;CAC5B,CAAC;AAExD,eAAO,MAAM,qBAAqB,cAAe,MAAM,aAAa,MAAM,YAIzE,CAAC"}
1
+ {"version":3,"file":"tools.d.ts","sourceRoot":"","sources":["../../../../src/components/elements/sidebar/tools.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,SAAS,CAAC;AAExC,eAAO,MAAM,YAAY,GAAI,QAAQ,QAAQ,aAY5C,CAAC;AAEF,eAAO,MAAM,YAAY,GAAI,QAAQ,QAAQ,KAAG,MAAM,IAAI,QAAQ,GAAG;IAAE,IAAI,EAAE,MAAM,CAAA;CAC5B,CAAC;AAExD,eAAO,MAAM,qBAAqB,GAAI,WAAW,MAAM,EAAE,WAAW,MAAM,YAIzE,CAAC"}
@@ -1,2 +1,2 @@
1
- const e=t=>{const r=[];return"separator"===t.type||(t.href&&r.push(t.href),t.items?.forEach((t=>{r.push(...e(t))}))),r},t=e=>Boolean("separator"!==e.type&&e.href),r=(e,t)=>"string"==typeof t&&"string"==typeof e&&t===new URL(e,"http://r").pathname?.replace(/\/$/,"");export{r as checkIsTargetPathname,e as collectItems,t as isActiveItem};
1
+ const e=t=>{const r=[];return"separator"===t.type||(t.href&&r.push(t.href),t.items?.forEach(t=>{r.push(...e(t))})),r},t=e=>Boolean("separator"!==e.type&&e.href),r=(e,t)=>"string"==typeof t&&"string"==typeof e&&t===new URL(e,"http://r").pathname?.replace(/\/$/,"");export{r as checkIsTargetPathname,e as collectItems,t as isActiveItem};
2
2
  //# sourceMappingURL=tools.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tools.js","sources":["../../../../src/components/elements/sidebar/tools.ts"],"sourcesContent":["import { type TreeItem } from \"./types\";\n\nexport const collectItems = (branch: TreeItem) => {\n const links: string[] = [];\n\n if (branch.type === \"separator\") return links;\n\n if (branch.href) links.push(branch.href);\n\n branch.items?.forEach((item) => {\n links.push(...collectItems(item));\n });\n\n return links;\n};\n\nexport const isActiveItem = (branch: TreeItem): branch is TreeItem & { href: string } =>\n Boolean(branch.type !== \"separator\" && branch.href);\n\nexport const checkIsTargetPathname = (itemHref?: string, pathname?: string) => {\n if (typeof pathname !== \"string\" || typeof itemHref !== \"string\") return false;\n\n return pathname === new URL(itemHref, \"http://r\").pathname?.replace(/\\/$/, \"\");\n};\n"],"names":["collectItems","branch","links","type","href","push","items","forEach","item","isActiveItem","Boolean","checkIsTargetPathname","itemHref","pathname","URL","replace"],"mappings":"AAEa,MAAAA,EAAgBC,IACzB,MAAMC,EAAkB,GAExB,MAAoB,cAAhBD,EAAOE,OAEPF,EAAOG,MAAMF,EAAMG,KAAKJ,EAAOG,MAEnCH,EAAOK,OAAOC,SAASC,IACnBN,EAAMG,QAAQL,EAAaQ,GAAM,KALGN,CAQ5B,EAGHO,EAAgBR,GACzBS,QAAwB,cAAhBT,EAAOE,MAAwBF,EAAOG,MAErCO,EAAwB,CAACC,EAAmBC,IAC7B,iBAAbA,GAA6C,iBAAbD,GAEpCC,IAAa,IAAIC,IAAIF,EAAU,YAAYC,UAAUE,QAAQ,MAAO"}
1
+ {"version":3,"file":"tools.js","sources":["../../../../src/components/elements/sidebar/tools.ts"],"sourcesContent":["import { type TreeItem } from \"./types\";\n\nexport const collectItems = (branch: TreeItem) => {\n const links: string[] = [];\n\n if (branch.type === \"separator\") return links;\n\n if (branch.href) links.push(branch.href);\n\n branch.items?.forEach((item) => {\n links.push(...collectItems(item));\n });\n\n return links;\n};\n\nexport const isActiveItem = (branch: TreeItem): branch is TreeItem & { href: string } =>\n Boolean(branch.type !== \"separator\" && branch.href);\n\nexport const checkIsTargetPathname = (itemHref?: string, pathname?: string) => {\n if (typeof pathname !== \"string\" || typeof itemHref !== \"string\") return false;\n\n return pathname === new URL(itemHref, \"http://r\").pathname?.replace(/\\/$/, \"\");\n};\n"],"names":["collectItems","branch","links","type","href","push","items","forEach","item","isActiveItem","Boolean","checkIsTargetPathname","itemHref","pathname","URL","replace"],"mappings":"AAEO,MAAMA,EAAgBC,IACzB,MAAMC,EAAkB,GAExB,MAAoB,cAAhBD,EAAOE,OAEPF,EAAOG,MAAMF,EAAMG,KAAKJ,EAAOG,MAEnCH,EAAOK,OAAOC,QAASC,IACnBN,EAAMG,QAAQL,EAAaQ,OALSN,GAW/BO,EAAgBR,GACzBS,QAAwB,cAAhBT,EAAOE,MAAwBF,EAAOG,MAErCO,EAAwB,CAACC,EAAmBC,IAC7B,iBAAbA,GAA6C,iBAAbD,GAEpCC,IAAa,IAAIC,IAAIF,EAAU,YAAYC,UAAUE,QAAQ,MAAO"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/ui/backdrop/index.tsx"],"sourcesContent":["\"use client\";\n\nimport React from \"react\";\nimport clsx from \"clsx\";\n\nimport \"./backdrop.scss\";\n\nexport interface BackdropProps {\n onClose(): void;\n open: boolean;\n}\n\nexport const Backdrop: React.FC<BackdropProps> = ({ open, onClose }) => {\n return <div onClick={onClose} className={clsx(\"r-backdrop\", open && \"_visible\")} />;\n};\n"],"names":["Backdrop","open","onClose","React","onClick","className","clsx"],"mappings":";yCAYa,MAAAA,CAAoC,CAAA,CAAA,CAAGC,OAAMC,CAC/CC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,sBAAKC,CAASF,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAASG,UAAWC,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAcL,GAAQ"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/ui/backdrop/index.tsx"],"sourcesContent":["\"use client\";\n\nimport React from \"react\";\nimport clsx from \"clsx\";\n\nimport \"./backdrop.scss\";\n\nexport interface BackdropProps {\n onClose(): void;\n open: boolean;\n}\n\nexport const Backdrop: React.FC<BackdropProps> = ({ open, onClose }) => {\n return <div onClick={onClose} className={clsx(\"r-backdrop\", open && \"_visible\")} />;\n};\n"],"names":["Backdrop","open","onClose","React","onClick","className","clsx"],"mappings":";yCAYO,MAAMA,CAAAA,CAAoC,CAAA,CAAGC,OAAMC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAC/CC,CAAAA,sBAAKC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAASF,CAAAA,CAASG,UAAWC,CAAAA,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAcL,GAAQ,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/ui/block/index.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\n\nimport \"./block.scss\";\n\ninterface BlockProps {\n className?: string;\n}\n\nexport const Block: React.FC<React.PropsWithChildren<BlockProps>> = ({ className, children }) => {\n return <div className={clsx(\"r-block\", className)}>{children}</div>;\n};\n"],"names":["Block","className","children","React","createElement","clsx"],"mappings":"yCASa,MAAAA,EAAuD,EAAGC,YAAWC,cACvEC,EAAKC,cAAA,MAAA,CAAAH,UAAWI,EAAK,UAAWJ,IAAaC"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/ui/block/index.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\n\nimport \"./block.scss\";\n\ninterface BlockProps {\n className?: string;\n}\n\nexport const Block: React.FC<React.PropsWithChildren<BlockProps>> = ({ className, children }) => {\n return <div className={clsx(\"r-block\", className)}>{children}</div>;\n};\n"],"names":["Block","className","children","React","createElement","clsx"],"mappings":"yCASO,MAAMA,EAAuD,EAAGC,YAAWC,cACvEC,EAAAC,cAAA,MAAA,CAAKH,UAAWI,EAAK,UAAWJ,IAAaC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  export declare const TYPES_DATA: {
3
2
  note: {
4
3
  title: string;
@@ -1 +1 @@
1
- {"version":3,"file":"data.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/blockquote/data.ts"],"names":[],"mappings":";AAEA,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;;;;;;;CAMtB,CAAC"}
1
+ {"version":3,"file":"data.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/blockquote/data.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;;;;;;;CAMtB,CAAC"}
@@ -1,2 +1,2 @@
1
- import{NoteIcon as t,TipIcon as i,ImportantIcon as n,WarningIcon as o,CautionIcon as c}from"./icons.js";const e={note:{title:"Note",icon:t},tip:{title:"Tip",icon:i},important:{title:"Important",icon:n},warning:{title:"Warning",icon:o},caution:{title:"Caution",icon:c}};export{e as TYPES_DATA};
1
+ import{CautionIcon as t,WarningIcon as i,ImportantIcon as n,TipIcon as o,NoteIcon as c}from"./icons.js";const e={note:{title:"Note",icon:c},tip:{title:"Tip",icon:o},important:{title:"Important",icon:n},warning:{title:"Warning",icon:i},caution:{title:"Caution",icon:t}};export{e as TYPES_DATA};
2
2
  //# sourceMappingURL=data.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"data.js","sources":["../../../../src/components/ui/blockquote/data.ts"],"sourcesContent":["import { CautionIcon, ImportantIcon, NoteIcon, TipIcon, WarningIcon } from \"./icons\";\n\nexport const TYPES_DATA = {\n note: { title: \"Note\", icon: NoteIcon },\n tip: { title: \"Tip\", icon: TipIcon },\n important: { title: \"Important\", icon: ImportantIcon },\n warning: { title: \"Warning\", icon: WarningIcon },\n caution: { title: \"Caution\", icon: CautionIcon },\n};\n"],"names":["TYPES_DATA","note","title","icon","NoteIcon","tip","TipIcon","important","ImportantIcon","warning","WarningIcon","caution","CautionIcon"],"mappings":"wGAEa,MAAAA,EAAa,CACtBC,KAAM,CAAEC,MAAO,OAAQC,KAAMC,GAC7BC,IAAK,CAAEH,MAAO,MAAOC,KAAMG,GAC3BC,UAAW,CAAEL,MAAO,YAAaC,KAAMK,GACvCC,QAAS,CAAEP,MAAO,UAAWC,KAAMO,GACnCC,QAAS,CAAET,MAAO,UAAWC,KAAMS"}
1
+ {"version":3,"file":"data.js","sources":["../../../../src/components/ui/blockquote/data.ts"],"sourcesContent":["import { CautionIcon, ImportantIcon, NoteIcon, TipIcon, WarningIcon } from \"./icons\";\n\nexport const TYPES_DATA = {\n note: { title: \"Note\", icon: NoteIcon },\n tip: { title: \"Tip\", icon: TipIcon },\n important: { title: \"Important\", icon: ImportantIcon },\n warning: { title: \"Warning\", icon: WarningIcon },\n caution: { title: \"Caution\", icon: CautionIcon },\n};\n"],"names":["TYPES_DATA","note","title","icon","NoteIcon","tip","TipIcon","important","ImportantIcon","warning","WarningIcon","caution","CautionIcon"],"mappings":"wGAEO,MAAMA,EAAa,CACtBC,KAAM,CAAEC,MAAO,OAAQC,KAAMC,GAC7BC,IAAK,CAAEH,MAAO,MAAOC,KAAMG,GAC3BC,UAAW,CAAEL,MAAO,YAAaC,KAAMK,GACvCC,QAAS,CAAEP,MAAO,UAAWC,KAAMO,GACnCC,QAAS,CAAET,MAAO,UAAWC,KAAMS"}
@@ -1 +1 @@
1
- {"version":3,"file":"icons.js","sources":["../../../../src/components/ui/blockquote/icons.tsx"],"sourcesContent":["import React from \"react\";\n\nexport const NoteIcon = () => (\n <>\n <path d=\"m18 5-2.414-2.414A2 2 0 0 0 14.172 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2\" />\n <path d=\"M21.378 12.626a1 1 0 0 0-3.004-3.004l-4.01 4.012a2 2 0 0 0-.506.854l-.837 2.87a.5.5 0 0 0 .62.62l2.87-.837a2 2 0 0 0 .854-.506z\" />\n <path d=\"M8 18h1\" />\n </>\n);\n\nexport const TipIcon = () => (\n <>\n <path d=\"M15 14c.2-1 .7-1.7 1.5-2.5 1-.9 1.5-2.2 1.5-3.5A6 6 0 0 0 6 8c0 1 .2 2.2 1.5 3.5.7.7 1.3 1.5 1.5 2.5\" />\n <path d=\"M9 18h6\" />\n <path d=\"M10 22h4\" />\n </>\n);\n\nexport const ImportantIcon = () => (\n <>\n <path d=\"M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z\" />\n <path d=\"M12 7v2\" />\n <path d=\"M12 13h.01\" />\n </>\n);\n\nexport const WarningIcon = () => (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"12\" x2=\"12\" y1=\"8\" y2=\"12\" />\n <line x1=\"12\" x2=\"12.01\" y1=\"16\" y2=\"16\" />\n </>\n);\n\nexport const CautionIcon = () => (\n <>\n <path d=\"m15 9-6 6\" />\n <path d=\"M2.586 16.726A2 2 0 0 1 2 15.312V8.688a2 2 0 0 1 .586-1.414l4.688-4.688A2 2 0 0 1 8.688 2h6.624a2 2 0 0 1 1.414.586l4.688 4.688A2 2 0 0 1 22 8.688v6.624a2 2 0 0 1-.586 1.414l-4.688 4.688a2 2 0 0 1-1.414.586H8.688a2 2 0 0 1-1.414-.586z\" />\n <path d=\"m9 9 6 6\" />\n </>\n);\n"],"names":["NoteIcon","React","createElement","Fragment","d","TipIcon","ImportantIcon","WarningIcon","cx","cy","r","x1","x2","y1","y2","CautionIcon"],"mappings":"qBAEa,MAAAA,EAAW,IACpBC,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAMC,cAAA,OAAA,CAAAE,EAAE,2FACRH,EAAMC,cAAA,OAAA,CAAAE,EAAE,oIACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,aAIHC,EAAU,IACnBJ,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAMC,cAAA,OAAA,CAAAE,EAAE,yGACRH,EAAMC,cAAA,OAAA,CAAAE,EAAE,YACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,cAIHE,EAAgB,IACzBL,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAMC,cAAA,OAAA,CAAAE,EAAE,kEACRH,EAAMC,cAAA,OAAA,CAAAE,EAAE,YACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,gBAIHG,EAAc,IACvBN,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAQC,cAAA,SAAA,CAAAM,GAAG,KAAKC,GAAG,KAAKC,EAAE,OAC1BT,EAAAC,cAAA,OAAA,CAAMS,GAAG,KAAKC,GAAG,KAAKC,GAAG,IAAIC,GAAG,OAChCb,EAAAC,cAAA,OAAA,CAAMS,GAAG,KAAKC,GAAG,QAAQC,GAAG,KAAKC,GAAG,QAI/BC,EAAc,IACvBd,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAMC,cAAA,OAAA,CAAAE,EAAE,cACRH,EAAMC,cAAA,OAAA,CAAAE,EAAE,+OACRH,EAAAC,cAAA,OAAA,CAAME,EAAE"}
1
+ {"version":3,"file":"icons.js","sources":["../../../../src/components/ui/blockquote/icons.tsx"],"sourcesContent":["import React from \"react\";\n\nexport const NoteIcon = () => (\n <>\n <path d=\"m18 5-2.414-2.414A2 2 0 0 0 14.172 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2\" />\n <path d=\"M21.378 12.626a1 1 0 0 0-3.004-3.004l-4.01 4.012a2 2 0 0 0-.506.854l-.837 2.87a.5.5 0 0 0 .62.62l2.87-.837a2 2 0 0 0 .854-.506z\" />\n <path d=\"M8 18h1\" />\n </>\n);\n\nexport const TipIcon = () => (\n <>\n <path d=\"M15 14c.2-1 .7-1.7 1.5-2.5 1-.9 1.5-2.2 1.5-3.5A6 6 0 0 0 6 8c0 1 .2 2.2 1.5 3.5.7.7 1.3 1.5 1.5 2.5\" />\n <path d=\"M9 18h6\" />\n <path d=\"M10 22h4\" />\n </>\n);\n\nexport const ImportantIcon = () => (\n <>\n <path d=\"M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z\" />\n <path d=\"M12 7v2\" />\n <path d=\"M12 13h.01\" />\n </>\n);\n\nexport const WarningIcon = () => (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"12\" x2=\"12\" y1=\"8\" y2=\"12\" />\n <line x1=\"12\" x2=\"12.01\" y1=\"16\" y2=\"16\" />\n </>\n);\n\nexport const CautionIcon = () => (\n <>\n <path d=\"m15 9-6 6\" />\n <path d=\"M2.586 16.726A2 2 0 0 1 2 15.312V8.688a2 2 0 0 1 .586-1.414l4.688-4.688A2 2 0 0 1 8.688 2h6.624a2 2 0 0 1 1.414.586l4.688 4.688A2 2 0 0 1 22 8.688v6.624a2 2 0 0 1-.586 1.414l-4.688 4.688a2 2 0 0 1-1.414.586H8.688a2 2 0 0 1-1.414-.586z\" />\n <path d=\"m9 9 6 6\" />\n </>\n);\n"],"names":["NoteIcon","React","createElement","Fragment","d","TipIcon","ImportantIcon","WarningIcon","cx","cy","r","x1","x2","y1","y2","CautionIcon"],"mappings":"qBAEO,MAAMA,EAAW,IACpBC,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAAC,cAAA,OAAA,CAAME,EAAE,2FACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,oIACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,aAIHC,EAAU,IACnBJ,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAAC,cAAA,OAAA,CAAME,EAAE,yGACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,YACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,cAIHE,EAAgB,IACzBL,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAAC,cAAA,OAAA,CAAME,EAAE,kEACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,YACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,gBAIHG,EAAc,IACvBN,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAAC,cAAA,SAAA,CAAQM,GAAG,KAAKC,GAAG,KAAKC,EAAE,OAC1BT,EAAAC,cAAA,OAAA,CAAMS,GAAG,KAAKC,GAAG,KAAKC,GAAG,IAAIC,GAAG,OAChCb,EAAAC,cAAA,OAAA,CAAMS,GAAG,KAAKC,GAAG,QAAQC,GAAG,KAAKC,GAAG,QAI/BC,EAAc,IACvBd,EAAAC,cAAAD,EAAAE,SAAA,KACIF,EAAAC,cAAA,OAAA,CAAME,EAAE,cACRH,EAAAC,cAAA,OAAA,CAAME,EAAE,+OACRH,EAAAC,cAAA,OAAA,CAAME,EAAE"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/ui/blockquote/index.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\n\nimport { TYPES_DATA } from \"./data\";\n\nimport \"./blockquote.scss\";\n\nexport type BlockquoteType = \"note\" | \"tip\" | \"important\" | \"warning\" | \"caution\";\n\ninterface BlockquoteProps {\n className?: string;\n type?: BlockquoteType | null;\n}\n\nexport const Blockquote: React.FC<React.PropsWithChildren<BlockquoteProps>> = ({ className, type, children }) => {\n const { icon: Icon, title } =\n type && type in TYPES_DATA ? TYPES_DATA[type] : ({} as { icon: undefined; title: undefined });\n\n return (\n <blockquote className={clsx(\"r-blockquote\", type && `r-blockquote-${type}`, className)}>\n {title && Icon && (\n <p className=\"r-blockquote-title\">\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className=\"r-blockquote-icon\"\n >\n <Icon />\n </svg>\n {title}\n </p>\n )}\n {children}\n </blockquote>\n );\n};\n"],"names":["Blockquote","className","type","children","icon","Icon","title","TYPES_DATA","React","createElement","clsx","width","height","viewBox","fill","stroke","strokeWidth","strokeLinecap","strokeLinejoin"],"mappings":"gFAcO,MAAMA,EAAiE,EAAGC,YAAWC,OAAMC,eAC9F,MAAQC,KAAMC,EAAIC,MAAEA,GAChBJ,GAAQA,KAAQK,EAAaA,EAAWL,GAAS,CAAA,EAErD,OACIM,EAAAC,cAAA,aAAA,CAAYR,UAAWS,EAAK,eAAgBR,GAAQ,gBAAgBA,IAAQD,IACvEK,GAASD,GACNG,EAAGC,cAAA,IAAA,CAAAR,UAAU,sBACTO,EAAAC,cAAA,MAAA,CACIE,MAAM,KACNC,OAAO,KACPC,QAAQ,YACRC,KAAK,OACLC,OAAO,eACPC,YAAY,IACZC,cAAc,QACdC,eAAe,QACfjB,UAAU,qBAEVO,EAACC,cAAAJ,SAEJC,GAGRH,EAEP"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/ui/blockquote/index.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\n\nimport { TYPES_DATA } from \"./data\";\n\nimport \"./blockquote.scss\";\n\nexport type BlockquoteType = \"note\" | \"tip\" | \"important\" | \"warning\" | \"caution\";\n\ninterface BlockquoteProps {\n className?: string;\n type?: BlockquoteType | null;\n}\n\nexport const Blockquote: React.FC<React.PropsWithChildren<BlockquoteProps>> = ({ className, type, children }) => {\n const { icon: Icon, title } =\n type && type in TYPES_DATA ? TYPES_DATA[type] : ({} as { icon: undefined; title: undefined });\n\n return (\n <blockquote className={clsx(\"r-blockquote\", type && `r-blockquote-${type}`, className)}>\n {title && Icon && (\n <p className=\"r-blockquote-title\">\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className=\"r-blockquote-icon\"\n >\n <Icon />\n </svg>\n {title}\n </p>\n )}\n {children}\n </blockquote>\n );\n};\n"],"names":["Blockquote","className","type","children","icon","Icon","title","TYPES_DATA","React","createElement","clsx","width","height","viewBox","fill","stroke","strokeWidth","strokeLinecap","strokeLinejoin"],"mappings":"gFAcO,MAAMA,EAAiE,EAAGC,YAAWC,OAAMC,eAC9F,MAAQC,KAAMC,EAAIC,MAAEA,GAChBJ,GAAQA,KAAQK,EAAaA,EAAWL,GAAS,CAAA,EAErD,OACIM,EAAAC,cAAA,aAAA,CAAYR,UAAWS,EAAK,eAAgBR,GAAQ,gBAAgBA,IAAQD,IACvEK,GAASD,GACNG,EAAAC,cAAA,IAAA,CAAGR,UAAU,sBACTO,EAAAC,cAAA,MAAA,CACIE,MAAM,KACNC,OAAO,KACPC,QAAQ,YACRC,KAAK,OACLC,OAAO,eACPC,YAAY,IACZC,cAAc,QACdC,eAAe,QACfjB,UAAU,qBAEVO,EAAAC,cAACJ,SAEJC,GAGRH"}
@@ -1,2 +1,2 @@
1
- import e,{cache as a}from"react";import{createHighlighter as t}from"shiki";import n from"clsx";import{githubDynamic as o}from"./theme.js";import{CodeSpan as r}from"../code-span/index.js";const c=(async()=>{const e=await t({langs:[],themes:[]});return await e.loadTheme(o),e})(),s=a((async e=>{const a=await c;return a.getLoadedLanguages().includes(e)||await a.loadLanguage(e),a})),i=async({code:a,lang:t,className:c,inline:i})=>{const m=await s(t);await m.loadTheme(o);const l=m.codeToHtml(a,{lang:t,theme:"github-dynamic",structure:"inline"});if(i)return e.createElement(r,{code:l});const d=i?"code":"pre";return e.createElement(d,{className:n(i?"r-code-span":"r-code-block",c),dangerouslySetInnerHTML:{__html:l}})};export{i as CodeBlock};
1
+ import e,{cache as a}from"react";import{createHighlighter as t}from"shiki";import n from"clsx";import{githubDynamic as o}from"./theme.js";import{CodeSpan as r}from"../code-span/index.js";const c=(async()=>{const e=await t({langs:[],themes:[]});return await e.loadTheme(o),e})(),s=a(async e=>{const a=await c;return a.getLoadedLanguages().includes(e)||await a.loadLanguage(e),a}),i=async({code:a,lang:t,className:c,inline:i})=>{const m=await s(t);await m.loadTheme(o);const l=m.codeToHtml(a,{lang:t,theme:"github-dynamic",structure:"inline"});if(i)return e.createElement(r,{code:l});const d=i?"code":"pre";return e.createElement(d,{className:n(i?"r-code-span":"r-code-block",c),dangerouslySetInnerHTML:{__html:l}})};export{i as CodeBlock};
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/ui/code-block/index.tsx"],"sourcesContent":["import React, { cache } from \"react\";\nimport { createHighlighter, type BuiltinLanguage } from \"shiki\";\nimport clsx from \"clsx\";\n\nimport { githubDynamic } from \"./theme\";\n\nimport \"./code-block.scss\";\nimport { CodeSpan } from \"../code-span\";\n\nexport interface CodeBlockProps {\n code: string;\n lang: BuiltinLanguage;\n className?: string;\n inline?: boolean;\n}\n\nconst initBaseHighlighter = async () => {\n const highlighter = await createHighlighter({ langs: [], themes: [] });\n await highlighter.loadTheme(githubDynamic);\n return highlighter;\n};\n\nconst highlighterPromise = initBaseHighlighter();\n\nconst getHighlighter = cache(async (language: BuiltinLanguage) => {\n const highlighter = await highlighterPromise;\n const loadedLanguages = highlighter.getLoadedLanguages();\n\n if (!loadedLanguages.includes(language)) {\n await highlighter.loadLanguage(language);\n }\n\n return highlighter;\n});\n\nexport const CodeBlock: React.FC<CodeBlockProps> = async ({ code, lang, className, inline }) => {\n const highlighter = await getHighlighter(lang);\n await highlighter.loadTheme(githubDynamic);\n\n const html = highlighter.codeToHtml(code, {\n lang,\n theme: \"github-dynamic\",\n structure: \"inline\",\n });\n\n if (inline) return <CodeSpan code={html} />;\n\n const Component = inline ? \"code\" : \"pre\";\n\n return (\n <Component\n className={clsx(inline ? \"r-code-span\" : \"r-code-block\", className)}\n dangerouslySetInnerHTML={{ __html: html }}\n />\n );\n};\n"],"names":["highlighterPromise","async","highlighter","createHighlighter","langs","themes","loadTheme","githubDynamic","initBaseHighlighter","getHighlighter","cache","language","getLoadedLanguages","includes","loadLanguage","CodeBlock","code","lang","className","inline","html","codeToHtml","theme","structure","React","CodeSpan","Component","createElement","clsx","dangerouslySetInnerHTML","__html"],"mappings":"2LAgBA,MAMMA,EANsBC,WACxB,MAAMC,QAAoBC,EAAkB,CAAEC,MAAO,GAAIC,OAAQ,KAEjE,aADMH,EAAYI,UAAUC,GACrBL,CAAW,EAGKM,GAErBC,EAAiBC,GAAMT,MAAOU,IAChC,MAAMT,QAAoBF,EAO1B,OANwBE,EAAYU,qBAEfC,SAASF,UACpBT,EAAYY,aAAaH,GAG5BT,CAAW,IAGTa,EAAsCd,OAASe,OAAMC,OAAMC,YAAWC,aAC/E,MAAMjB,QAAoBO,EAAeQ,SACnCf,EAAYI,UAAUC,GAE5B,MAAMa,EAAOlB,EAAYmB,WAAWL,EAAM,CACtCC,OACAK,MAAO,iBACPC,UAAW,WAGf,GAAIJ,EAAQ,OAAOK,gBAACC,EAAQ,CAACT,KAAMI,IAEnC,MAAMM,EAAYP,EAAS,OAAS,MAEpC,OACIK,EAAAG,cAACD,EAAS,CACNR,UAAWU,EAAKT,EAAS,cAAgB,eAAgBD,GACzDW,wBAAyB,CAAEC,OAAQV,IAEzC"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/ui/code-block/index.tsx"],"sourcesContent":["import React, { cache } from \"react\";\nimport { createHighlighter, type BuiltinLanguage } from \"shiki\";\nimport clsx from \"clsx\";\n\nimport { githubDynamic } from \"./theme\";\n\nimport \"./code-block.scss\";\nimport { CodeSpan } from \"../code-span\";\n\nexport interface CodeBlockProps {\n code: string;\n lang: BuiltinLanguage;\n className?: string;\n inline?: boolean;\n}\n\nconst initBaseHighlighter = async () => {\n const highlighter = await createHighlighter({ langs: [], themes: [] });\n await highlighter.loadTheme(githubDynamic);\n return highlighter;\n};\n\nconst highlighterPromise = initBaseHighlighter();\n\nconst getHighlighter = cache(async (language: BuiltinLanguage) => {\n const highlighter = await highlighterPromise;\n const loadedLanguages = highlighter.getLoadedLanguages();\n\n if (!loadedLanguages.includes(language)) {\n await highlighter.loadLanguage(language);\n }\n\n return highlighter;\n});\n\nexport const CodeBlock: React.FC<CodeBlockProps> = async ({ code, lang, className, inline }) => {\n const highlighter = await getHighlighter(lang);\n await highlighter.loadTheme(githubDynamic);\n\n const html = highlighter.codeToHtml(code, {\n lang,\n theme: \"github-dynamic\",\n structure: \"inline\",\n });\n\n if (inline) return <CodeSpan code={html} />;\n\n const Component = inline ? \"code\" : \"pre\";\n\n return (\n <Component\n className={clsx(inline ? \"r-code-span\" : \"r-code-block\", className)}\n dangerouslySetInnerHTML={{ __html: html }}\n />\n );\n};\n"],"names":["highlighterPromise","async","highlighter","createHighlighter","langs","themes","loadTheme","githubDynamic","initBaseHighlighter","getHighlighter","cache","language","getLoadedLanguages","includes","loadLanguage","CodeBlock","code","lang","className","inline","html","codeToHtml","theme","structure","React","CodeSpan","Component","createElement","clsx","dangerouslySetInnerHTML","__html"],"mappings":"2LAgBA,MAMMA,EANsBC,WACxB,MAAMC,QAAoBC,EAAkB,CAAEC,MAAO,GAAIC,OAAQ,KAEjE,aADMH,EAAYI,UAAUC,GACrBL,GAGgBM,GAErBC,EAAiBC,EAAMT,MAAOU,IAChC,MAAMT,QAAoBF,EAO1B,OANwBE,EAAYU,qBAEfC,SAASF,UACpBT,EAAYY,aAAaH,GAG5BT,IAGEa,EAAsCd,OAASe,OAAMC,OAAMC,YAAWC,aAC/E,MAAMjB,QAAoBO,EAAeQ,SACnCf,EAAYI,UAAUC,GAE5B,MAAMa,EAAOlB,EAAYmB,WAAWL,EAAM,CACtCC,OACAK,MAAO,iBACPC,UAAW,WAGf,GAAIJ,EAAQ,OAAOK,gBAACC,EAAQ,CAACT,KAAMI,IAEnC,MAAMM,EAAYP,EAAS,OAAS,MAEpC,OACIK,EAAAG,cAACD,EAAS,CACNR,UAAWU,EAAKT,EAAS,cAAgB,eAAgBD,GACzDW,wBAAyB,CAAEC,OAAQV"}