@semiont/cli 0.4.12 → 0.4.14

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 (153) hide show
  1. package/dist/cli.mjs +518 -67
  2. package/dist/dashboard/dashboard.css +1 -1
  3. package/dist/dashboard/dashboard.css.map +2 -2
  4. package/dist/frontend/dist/assets/CookiePreferences-Cbur0STI.js +2 -0
  5. package/dist/frontend/dist/assets/CookiePreferences-Cbur0STI.js.map +1 -0
  6. package/dist/frontend/dist/assets/{PdfAnnotationCanvas.client-CW6SKH2U-CjRY6TID.js → PdfAnnotationCanvas.client-CW6SKH2U-DIkAGn7X.js} +2 -2
  7. package/dist/frontend/dist/assets/{PdfAnnotationCanvas.client-CW6SKH2U-CjRY6TID.js.map → PdfAnnotationCanvas.client-CW6SKH2U-DIkAGn7X.js.map} +1 -1
  8. package/dist/frontend/dist/assets/ToolbarPanels-rN1MIRTV.js +2 -0
  9. package/dist/frontend/dist/assets/ToolbarPanels-rN1MIRTV.js.map +1 -0
  10. package/dist/frontend/dist/assets/XMarkIcon-6m9KVFaj.js +2 -0
  11. package/dist/frontend/dist/assets/XMarkIcon-6m9KVFaj.js.map +1 -0
  12. package/dist/frontend/dist/assets/client-BPbsU2tc.js +2 -0
  13. package/dist/frontend/dist/assets/{client-DZ-DNAU-.js.map → client-BPbsU2tc.js.map} +1 -1
  14. package/dist/frontend/dist/assets/client-BiL3eI7d.js +2 -0
  15. package/dist/frontend/dist/assets/{client-BbPyO59A.js.map → client-BiL3eI7d.js.map} +1 -1
  16. package/dist/frontend/dist/assets/client-BnL1es01.js +2 -0
  17. package/dist/frontend/dist/assets/{client-BsHptwGn.js.map → client-BnL1es01.js.map} +1 -1
  18. package/dist/frontend/dist/assets/client-DrQUcCJy.js +2 -0
  19. package/dist/frontend/dist/assets/{client-COY1ucYF.js.map → client-DrQUcCJy.js.map} +1 -1
  20. package/dist/frontend/dist/assets/en-IUV4ZXKH-BY1RKeLS.js +135 -0
  21. package/dist/frontend/dist/assets/en-IUV4ZXKH-BY1RKeLS.js.map +1 -0
  22. package/dist/frontend/dist/assets/{index-CwQxZp6g.css → index-CNb3PHS7.css} +1 -1
  23. package/dist/frontend/dist/assets/{index-DKq_l4UW.js → index-DA31r_0s.js} +3 -3
  24. package/dist/frontend/dist/assets/{index-DKq_l4UW.js.map → index-DA31r_0s.js.map} +1 -1
  25. package/dist/frontend/dist/assets/layout-B8IinUdt.js +2 -0
  26. package/dist/frontend/dist/assets/layout-B8IinUdt.js.map +1 -0
  27. package/dist/frontend/dist/assets/layout-BjpW078f.js +2 -0
  28. package/dist/frontend/dist/assets/layout-BjpW078f.js.map +1 -0
  29. package/dist/frontend/dist/assets/{layout-6uvM-QPR.js → layout-CDIjxs5a.js} +4 -4
  30. package/dist/frontend/dist/assets/layout-CDIjxs5a.js.map +1 -0
  31. package/dist/frontend/dist/assets/layout-DKm9XdRr.js +2 -0
  32. package/dist/frontend/dist/assets/{layout-D5Pjl6Q-.js.map → layout-DKm9XdRr.js.map} +1 -1
  33. package/dist/frontend/dist/assets/{not-found-CudKZDad.js → not-found-CwWw1pZc.js} +2 -2
  34. package/dist/frontend/dist/assets/{not-found-CudKZDad.js.map → not-found-CwWw1pZc.js.map} +1 -1
  35. package/dist/frontend/dist/assets/{page-Bz2r7ufy.js → page-1BwlyTUj.js} +2 -2
  36. package/dist/frontend/dist/assets/{page-Bz2r7ufy.js.map → page-1BwlyTUj.js.map} +1 -1
  37. package/dist/frontend/dist/assets/page-BQ00VxR5.js +2 -0
  38. package/dist/frontend/dist/assets/page-BQ00VxR5.js.map +1 -0
  39. package/dist/frontend/dist/assets/page-BmHLf-7O.js +2 -0
  40. package/dist/frontend/dist/assets/{page-ESjXBvXd.js.map → page-BmHLf-7O.js.map} +1 -1
  41. package/dist/frontend/dist/assets/page-C5bIvv1V.js +2 -0
  42. package/dist/frontend/dist/assets/{page-CJFp0ZpS.js.map → page-C5bIvv1V.js.map} +1 -1
  43. package/dist/frontend/dist/assets/{page-4gaXuuoi.js → page-CelRTchO.js} +3 -3
  44. package/dist/frontend/dist/assets/{page-4gaXuuoi.js.map → page-CelRTchO.js.map} +1 -1
  45. package/dist/frontend/dist/assets/page-Cf9cnqhC.js +2 -0
  46. package/dist/frontend/dist/assets/{page-uukho-t7.js.map → page-Cf9cnqhC.js.map} +1 -1
  47. package/dist/frontend/dist/assets/page-CslYhbgz.js +2 -0
  48. package/dist/frontend/dist/assets/{page-DK5bpgp9.js.map → page-CslYhbgz.js.map} +1 -1
  49. package/dist/frontend/dist/assets/page-DEjlNEY0.js +2 -0
  50. package/dist/frontend/dist/assets/{page-DIv5j5nE.js.map → page-DEjlNEY0.js.map} +1 -1
  51. package/dist/frontend/dist/assets/page-DLtwpo78.js +2 -0
  52. package/dist/frontend/dist/assets/{page-CGEmB0mm.js.map → page-DLtwpo78.js.map} +1 -1
  53. package/dist/frontend/dist/assets/{page-CE8hOJlL.js → page-D_nHe9FT.js} +2 -2
  54. package/dist/frontend/dist/assets/{page-CE8hOJlL.js.map → page-D_nHe9FT.js.map} +1 -1
  55. package/dist/frontend/dist/assets/page-Deep7E5d.js +2 -0
  56. package/dist/frontend/dist/assets/{page-DVRMfAkS.js.map → page-Deep7E5d.js.map} +1 -1
  57. package/dist/frontend/dist/assets/{page-C44nBk5U.js → page-Dv386AZD.js} +3 -3
  58. package/dist/frontend/dist/assets/{page-C44nBk5U.js.map → page-Dv386AZD.js.map} +1 -1
  59. package/dist/frontend/dist/assets/page-E99MPOn5.js +8 -0
  60. package/dist/frontend/dist/assets/{page-tb55k9Ji.js.map → page-E99MPOn5.js.map} +1 -1
  61. package/dist/frontend/dist/assets/page-KtkB4tEv.js +2 -0
  62. package/dist/frontend/dist/assets/{page-vzoIwpsS.js.map → page-KtkB4tEv.js.map} +1 -1
  63. package/dist/frontend/dist/assets/page-ZBwMTeR-.js +2 -0
  64. package/dist/frontend/dist/assets/page-ZBwMTeR-.js.map +1 -0
  65. package/dist/frontend/dist/assets/page-Zq6ARIvg.js +2 -0
  66. package/dist/frontend/dist/assets/{page-DjkPUxlb.js.map → page-Zq6ARIvg.js.map} +1 -1
  67. package/dist/frontend/dist/assets/page-iSL5E639.js +2 -0
  68. package/dist/frontend/dist/assets/page-iSL5E639.js.map +1 -0
  69. package/dist/frontend/dist/assets/page-xdXYx3nl.js +2 -0
  70. package/dist/frontend/dist/assets/{page-B9hPrBrN.js.map → page-xdXYx3nl.js.map} +1 -1
  71. package/dist/frontend/dist/assets/{privacy-W9SxWfL5.js → privacy-DO1oxJpM.js} +2 -2
  72. package/dist/frontend/dist/assets/{privacy-W9SxWfL5.js.map → privacy-DO1oxJpM.js.map} +1 -1
  73. package/dist/frontend/dist/assets/routing-DMdXWYXo.js +2 -0
  74. package/dist/frontend/dist/assets/{routing-BLuuVVPN.js.map → routing-DMdXWYXo.js.map} +1 -1
  75. package/dist/frontend/dist/assets/{routing-6lnx-g5H.js → routing-tJ_HbFRP.js} +2 -2
  76. package/dist/frontend/dist/assets/{routing-6lnx-g5H.js.map → routing-tJ_HbFRP.js.map} +1 -1
  77. package/dist/frontend/dist/assets/useAuth-yUx5lBP5.js +2 -0
  78. package/dist/frontend/dist/assets/useAuth-yUx5lBP5.js.map +1 -0
  79. package/dist/frontend/dist/index.html +2 -2
  80. package/dist/frontend/dist/messages/ar.json +29 -7
  81. package/dist/frontend/dist/messages/bn.json +29 -7
  82. package/dist/frontend/dist/messages/cs.json +29 -7
  83. package/dist/frontend/dist/messages/da.json +29 -7
  84. package/dist/frontend/dist/messages/de.json +29 -7
  85. package/dist/frontend/dist/messages/el.json +29 -7
  86. package/dist/frontend/dist/messages/en.json +29 -7
  87. package/dist/frontend/dist/messages/es.json +29 -7
  88. package/dist/frontend/dist/messages/fa.json +29 -7
  89. package/dist/frontend/dist/messages/fi.json +29 -7
  90. package/dist/frontend/dist/messages/fr.json +29 -7
  91. package/dist/frontend/dist/messages/he.json +29 -7
  92. package/dist/frontend/dist/messages/hi.json +29 -7
  93. package/dist/frontend/dist/messages/id.json +29 -7
  94. package/dist/frontend/dist/messages/it.json +29 -7
  95. package/dist/frontend/dist/messages/ja.json +29 -7
  96. package/dist/frontend/dist/messages/ko.json +29 -7
  97. package/dist/frontend/dist/messages/ms.json +29 -7
  98. package/dist/frontend/dist/messages/nl.json +29 -7
  99. package/dist/frontend/dist/messages/no.json +29 -7
  100. package/dist/frontend/dist/messages/pl.json +29 -7
  101. package/dist/frontend/dist/messages/pt.json +29 -7
  102. package/dist/frontend/dist/messages/ro.json +29 -7
  103. package/dist/frontend/dist/messages/sv.json +29 -7
  104. package/dist/frontend/dist/messages/th.json +29 -7
  105. package/dist/frontend/dist/messages/tr.json +29 -7
  106. package/dist/frontend/dist/messages/uk.json +29 -7
  107. package/dist/frontend/dist/messages/vi.json +29 -7
  108. package/dist/frontend/dist/messages/zh.json +29 -7
  109. package/dist/frontend/package.json +1 -1
  110. package/package.json +8 -8
  111. package/dist/frontend/dist/assets/AuthContext-CUx-cP7W.js +0 -2
  112. package/dist/frontend/dist/assets/AuthContext-CUx-cP7W.js.map +0 -1
  113. package/dist/frontend/dist/assets/CookiePreferences-BuRvkBwM.js +0 -2
  114. package/dist/frontend/dist/assets/CookiePreferences-BuRvkBwM.js.map +0 -1
  115. package/dist/frontend/dist/assets/KnowledgeBaseContext-CgnF8K-_.js +0 -2
  116. package/dist/frontend/dist/assets/KnowledgeBaseContext-CgnF8K-_.js.map +0 -1
  117. package/dist/frontend/dist/assets/PlusIcon-qGFPUzg0.js +0 -2
  118. package/dist/frontend/dist/assets/PlusIcon-qGFPUzg0.js.map +0 -1
  119. package/dist/frontend/dist/assets/ToolbarPanels-Drd8QG61.js +0 -2
  120. package/dist/frontend/dist/assets/ToolbarPanels-Drd8QG61.js.map +0 -1
  121. package/dist/frontend/dist/assets/client-BbPyO59A.js +0 -2
  122. package/dist/frontend/dist/assets/client-BsHptwGn.js +0 -2
  123. package/dist/frontend/dist/assets/client-COY1ucYF.js +0 -2
  124. package/dist/frontend/dist/assets/client-DZ-DNAU-.js +0 -2
  125. package/dist/frontend/dist/assets/en-IUV4ZXKH-eHunUM2g.js +0 -135
  126. package/dist/frontend/dist/assets/en-IUV4ZXKH-eHunUM2g.js.map +0 -1
  127. package/dist/frontend/dist/assets/layout-6uvM-QPR.js.map +0 -1
  128. package/dist/frontend/dist/assets/layout-CvaTeY53.js +0 -2
  129. package/dist/frontend/dist/assets/layout-CvaTeY53.js.map +0 -1
  130. package/dist/frontend/dist/assets/layout-D5Pjl6Q-.js +0 -2
  131. package/dist/frontend/dist/assets/layout-QZ56PNLk.js +0 -2
  132. package/dist/frontend/dist/assets/layout-QZ56PNLk.js.map +0 -1
  133. package/dist/frontend/dist/assets/page-B9hPrBrN.js +0 -2
  134. package/dist/frontend/dist/assets/page-BH5HMa4o.js +0 -2
  135. package/dist/frontend/dist/assets/page-BH5HMa4o.js.map +0 -1
  136. package/dist/frontend/dist/assets/page-CGEmB0mm.js +0 -2
  137. package/dist/frontend/dist/assets/page-CJFp0ZpS.js +0 -2
  138. package/dist/frontend/dist/assets/page-D1Di1cx-.js +0 -2
  139. package/dist/frontend/dist/assets/page-D1Di1cx-.js.map +0 -1
  140. package/dist/frontend/dist/assets/page-DIv5j5nE.js +0 -2
  141. package/dist/frontend/dist/assets/page-DK5bpgp9.js +0 -2
  142. package/dist/frontend/dist/assets/page-DVRMfAkS.js +0 -2
  143. package/dist/frontend/dist/assets/page-DjkPUxlb.js +0 -2
  144. package/dist/frontend/dist/assets/page-ESjXBvXd.js +0 -2
  145. package/dist/frontend/dist/assets/page-lbZaKDJf.js +0 -2
  146. package/dist/frontend/dist/assets/page-lbZaKDJf.js.map +0 -1
  147. package/dist/frontend/dist/assets/page-tb55k9Ji.js +0 -8
  148. package/dist/frontend/dist/assets/page-uukho-t7.js +0 -2
  149. package/dist/frontend/dist/assets/page-vzoIwpsS.js +0 -2
  150. package/dist/frontend/dist/assets/routing-BLuuVVPN.js +0 -2
  151. package/dist/frontend/dist/assets/useAuth-CAJolYxw.js +0 -2
  152. package/dist/frontend/dist/assets/useAuth-CAJolYxw.js.map +0 -1
  153. package/dist/templates/docker-compose.yml +0 -53
@@ -1,4 +1,4 @@
1
- import{j as e}from"./query-ATBhtd3K.js";import{r as m}from"./vendor-EnoIVk-c.js";import{P as u}from"./en-IUV4ZXKH-eHunUM2g.js";import{C as T}from"./CookiePreferences-BuRvkBwM.js";import{K as f}from"./privacy-W9SxWfL5.js";import{r as g,L as k}from"./routing-6lnx-g5H.js";import{u as c}from"./i18n-BYxb14hm.js";import"./index-DKq_l4UW.js";import"./routing-BLuuVVPN.js";function b(){const{t:r}=c(),s=(t,i)=>r(`Privacy.${t}`,i),{t:l}=c(),o=(t,i)=>l(`Footer.${t}`,i),{t:a}=c(),d=(t,i)=>a(`Navigation.${t}`,i),{t:h}=c(),x=(t,i)=>h(`Home.${t}`,i),n=m.useContext(f);return e.jsx(u,{Link:k,routes:g,t:o,tNav:d,tHome:x,CookiePreferences:T,...(n==null?void 0:n.openKeyboardHelp)&&{onOpenKeyboardHelp:n.openKeyboardHelp},className:"semiont-static-page",children:e.jsx("div",{className:"semiont-static-container",children:e.jsxs("div",{className:"semiont-static-content",children:[e.jsx("header",{className:"semiont-static-header",children:e.jsx("h1",{className:"semiont-static-title",children:s("pageTitle")})}),e.jsxs("article",{className:"semiont-static-article",children:[e.jsxs("section",{children:[e.jsx("h2",{children:s("introTitle")}),s("intro").split(`
1
+ import{j as e}from"./query-ATBhtd3K.js";import{r as m}from"./vendor-EnoIVk-c.js";import{P as u}from"./en-IUV4ZXKH-BY1RKeLS.js";import{C as T}from"./CookiePreferences-Cbur0STI.js";import{K as f}from"./privacy-DO1oxJpM.js";import{r as g,L as k}from"./routing-tJ_HbFRP.js";import{u as c}from"./i18n-BYxb14hm.js";import"./index-DA31r_0s.js";import"./XMarkIcon-6m9KVFaj.js";import"./routing-DMdXWYXo.js";function I(){const{t:r}=c(),s=(t,i)=>r(`Privacy.${t}`,i),{t:o}=c(),l=(t,i)=>o(`Footer.${t}`,i),{t:a}=c(),d=(t,i)=>a(`Navigation.${t}`,i),{t:h}=c(),x=(t,i)=>h(`Home.${t}`,i),n=m.useContext(f);return e.jsx(u,{Link:k,routes:g,t:l,tNav:d,tHome:x,CookiePreferences:T,...(n==null?void 0:n.openKeyboardHelp)&&{onOpenKeyboardHelp:n.openKeyboardHelp},className:"semiont-static-page",children:e.jsx("div",{className:"semiont-static-container",children:e.jsxs("div",{className:"semiont-static-content",children:[e.jsx("header",{className:"semiont-static-header",children:e.jsx("h1",{className:"semiont-static-title",children:s("pageTitle")})}),e.jsxs("article",{className:"semiont-static-article",children:[e.jsxs("section",{children:[e.jsx("h2",{children:s("introTitle")}),s("intro").split(`
2
2
 
3
3
  `).map((t,i)=>e.jsx("p",{children:t},i))]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("infoCollectTitle")}),e.jsx("h3",{children:s("personalInfoTitle")}),e.jsx("ul",{children:s("personalInfo").split(`
4
4
  `).map((t,i)=>e.jsx("li",{children:t},i))}),e.jsx("h3",{children:s("autoCollectTitle")}),e.jsx("ul",{children:s("autoCollect").split(`
@@ -16,5 +16,5 @@ import{j as e}from"./query-ATBhtd3K.js";import{r as m}from"./vendor-EnoIVk-c.js"
16
16
  `).map((t,i)=>e.jsx("li",{children:t},i))})]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("dataSecurityTitle")}),s("dataSecurity").split(`
17
17
 
18
18
  `).map((t,i)=>i===0?e.jsx("p",{children:t},i):e.jsx("ul",{children:t.split(`
19
- `).map((j,p)=>e.jsx("li",{children:j},p))},i))]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("dataRetentionTitle")}),e.jsx("p",{children:s("dataRetention")})]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("internationalTransfersTitle")}),e.jsx("p",{children:s("internationalTransfers")})]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("contactTitle")}),e.jsx("p",{children:s("contactIntro")}),e.jsx("div",{className:"semiont-static-info-box",children:e.jsxs("p",{children:[e.jsx("strong",{children:s("contactEmail")})," privacy@semiont.com",e.jsx("br",{}),e.jsx("strong",{children:s("contactAddress")})," [Your Company Address]"]})})]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("updatesTitle")}),e.jsx("p",{children:s("updates")}),e.jsx("footer",{className:"semiont-static-footer",children:e.jsx("p",{children:e.jsx("strong",{children:s("lastUpdated",{date:new Date().toLocaleDateString()})})})})]})]})]})})})}export{b as default};
20
- //# sourceMappingURL=page-C44nBk5U.js.map
19
+ `).map((j,p)=>e.jsx("li",{children:j},p))},i))]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("dataRetentionTitle")}),e.jsx("p",{children:s("dataRetention")})]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("internationalTransfersTitle")}),e.jsx("p",{children:s("internationalTransfers")})]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("contactTitle")}),e.jsx("p",{children:s("contactIntro")}),e.jsx("div",{className:"semiont-static-info-box",children:e.jsxs("p",{children:[e.jsx("strong",{children:s("contactEmail")})," privacy@semiont.com",e.jsx("br",{}),e.jsx("strong",{children:s("contactAddress")})," [Your Company Address]"]})})]}),e.jsxs("section",{children:[e.jsx("h2",{children:s("updatesTitle")}),e.jsx("p",{children:s("updates")}),e.jsx("footer",{className:"semiont-static-footer",children:e.jsx("p",{children:e.jsx("strong",{children:s("lastUpdated",{date:new Date().toLocaleDateString()})})})})]})]})]})})})}export{I as default};
20
+ //# sourceMappingURL=page-Dv386AZD.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"page-C44nBk5U.js","sources":["../../src/app/[locale]/privacy/page.tsx"],"sourcesContent":["import React, { useContext } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { PageLayout } from '@semiont/react-ui';\nimport { CookiePreferences } from '@/components/CookiePreferences';\nimport { KeyboardShortcutsContext } from '@/contexts/KeyboardShortcutsContext';\nimport { Link as RoutingLink, routes } from '@/lib/routing';\n\nexport default function PrivacyPolicyPage() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`Privacy.${k}`, p as any) as string;\n const { t: _tFooter } = useTranslation();\n const tFooter = (k: string, p?: Record<string, unknown>) => _tFooter(`Footer.${k}`, p as any) as string;\n const { t: _tNav } = useTranslation();\n const tNav = (k: string, p?: Record<string, unknown>) => _tNav(`Navigation.${k}`, p as any) as string;\n const { t: _tHome } = useTranslation();\n const tHome = (k: string, p?: Record<string, unknown>) => _tHome(`Home.${k}`, p as any) as string;\n const keyboardContext = useContext(KeyboardShortcutsContext);\n\n return (\n <PageLayout\n Link={RoutingLink}\n routes={routes}\n t={tFooter}\n tNav={tNav}\n tHome={tHome}\n CookiePreferences={CookiePreferences}\n {...(keyboardContext?.openKeyboardHelp && { onOpenKeyboardHelp: keyboardContext.openKeyboardHelp })}\n className=\"semiont-static-page\"\n >\n <div className=\"semiont-static-container\">\n <div className=\"semiont-static-content\">\n <header className=\"semiont-static-header\">\n <h1 className=\"semiont-static-title\">{t('pageTitle')}</h1>\n </header>\n\n <article className=\"semiont-static-article\">\n <section>\n <h2>{t('introTitle')}</h2>\n {t('intro').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </section>\n\n <section>\n <h2>{t('infoCollectTitle')}</h2>\n\n <h3>{t('personalInfoTitle')}</h3>\n <ul>\n {t('personalInfo').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n\n <h3>{t('autoCollectTitle')}</h3>\n <ul>\n {t('autoCollect').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n </section>\n\n <section>\n <h2>{t('howWeUseTitle')}</h2>\n <ul>\n {t('howWeUse').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n </section>\n\n <section>\n <h2>{t('cookiePolicyTitle')}</h2>\n <p>\n {t('cookiePolicyIntro')}\n </p>\n\n <h3>{t('cookieCategoriesTitle')}</h3>\n\n <div className=\"semiont-static-cookie-grid\">\n <div className=\"semiont-static-cookie-card\">\n <h4>{t('necessaryCookiesTitle')}</h4>\n {t('necessaryCookies').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </div>\n\n <div className=\"semiont-static-cookie-card\">\n <h4>{t('analyticsCookiesTitle')}</h4>\n {t('analyticsCookies').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </div>\n\n <div className=\"semiont-static-cookie-card\">\n <h4>{t('marketingCookiesTitle')}</h4>\n {t('marketingCookies').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </div>\n\n <div className=\"semiont-static-cookie-card\">\n <h4>{t('preferenceCookiesTitle')}</h4>\n {t('preferenceCookies').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </div>\n </div>\n </section>\n\n <section>\n <h2>{t('yourRightsTitle')}</h2>\n\n <h3>{t('gdprRightsTitle')}</h3>\n <ul>\n {t('gdprRights').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n\n <h3>{t('ccpaRightsTitle')}</h3>\n <ul>\n {t('ccpaRights').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n </section>\n\n <section>\n <h2>{t('dataSecurityTitle')}</h2>\n {t('dataSecurity').split('\\n\\n').map((block, i) => {\n if (i === 0) {\n return (\n <p key={i}>\n {block}\n </p>\n );\n }\n return (\n <ul key={i}>\n {block.split('\\n').map((item, j) => (\n <li key={j}>{item}</li>\n ))}\n </ul>\n );\n })}\n </section>\n\n <section>\n <h2>{t('dataRetentionTitle')}</h2>\n <p>\n {t('dataRetention')}\n </p>\n </section>\n\n <section>\n <h2>{t('internationalTransfersTitle')}</h2>\n <p>\n {t('internationalTransfers')}\n </p>\n </section>\n\n <section>\n <h2>{t('contactTitle')}</h2>\n <p>\n {t('contactIntro')}\n </p>\n <div className=\"semiont-static-info-box\">\n <p>\n <strong>{t('contactEmail')}</strong> privacy@semiont.com<br />\n <strong>{t('contactAddress')}</strong> [Your Company Address]\n </p>\n </div>\n </section>\n\n <section>\n <h2>{t('updatesTitle')}</h2>\n <p>\n {t('updates')}\n </p>\n <footer className=\"semiont-static-footer\">\n <p>\n <strong>{t('lastUpdated', { date: new Date().toLocaleDateString() })}</strong>\n </p>\n </footer>\n </section>\n </article>\n </div>\n </div>\n </PageLayout>\n );\n}"],"names":["PrivacyPolicyPage","_t","useTranslation","t","k","p","_tFooter","tFooter","_tNav","tNav","_tHome","tHome","keyboardContext","useContext","KeyboardShortcutsContext","jsx","PageLayout","RoutingLink","routes","CookiePreferences","jsxs","para","item","block","j"],"mappings":"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"}
1
+ {"version":3,"file":"page-Dv386AZD.js","sources":["../../src/app/[locale]/privacy/page.tsx"],"sourcesContent":["import React, { useContext } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { PageLayout } from '@semiont/react-ui';\nimport { CookiePreferences } from '@/components/CookiePreferences';\nimport { KeyboardShortcutsContext } from '@/contexts/KeyboardShortcutsContext';\nimport { Link as RoutingLink, routes } from '@/lib/routing';\n\nexport default function PrivacyPolicyPage() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`Privacy.${k}`, p as any) as string;\n const { t: _tFooter } = useTranslation();\n const tFooter = (k: string, p?: Record<string, unknown>) => _tFooter(`Footer.${k}`, p as any) as string;\n const { t: _tNav } = useTranslation();\n const tNav = (k: string, p?: Record<string, unknown>) => _tNav(`Navigation.${k}`, p as any) as string;\n const { t: _tHome } = useTranslation();\n const tHome = (k: string, p?: Record<string, unknown>) => _tHome(`Home.${k}`, p as any) as string;\n const keyboardContext = useContext(KeyboardShortcutsContext);\n\n return (\n <PageLayout\n Link={RoutingLink}\n routes={routes}\n t={tFooter}\n tNav={tNav}\n tHome={tHome}\n CookiePreferences={CookiePreferences}\n {...(keyboardContext?.openKeyboardHelp && { onOpenKeyboardHelp: keyboardContext.openKeyboardHelp })}\n className=\"semiont-static-page\"\n >\n <div className=\"semiont-static-container\">\n <div className=\"semiont-static-content\">\n <header className=\"semiont-static-header\">\n <h1 className=\"semiont-static-title\">{t('pageTitle')}</h1>\n </header>\n\n <article className=\"semiont-static-article\">\n <section>\n <h2>{t('introTitle')}</h2>\n {t('intro').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </section>\n\n <section>\n <h2>{t('infoCollectTitle')}</h2>\n\n <h3>{t('personalInfoTitle')}</h3>\n <ul>\n {t('personalInfo').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n\n <h3>{t('autoCollectTitle')}</h3>\n <ul>\n {t('autoCollect').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n </section>\n\n <section>\n <h2>{t('howWeUseTitle')}</h2>\n <ul>\n {t('howWeUse').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n </section>\n\n <section>\n <h2>{t('cookiePolicyTitle')}</h2>\n <p>\n {t('cookiePolicyIntro')}\n </p>\n\n <h3>{t('cookieCategoriesTitle')}</h3>\n\n <div className=\"semiont-static-cookie-grid\">\n <div className=\"semiont-static-cookie-card\">\n <h4>{t('necessaryCookiesTitle')}</h4>\n {t('necessaryCookies').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </div>\n\n <div className=\"semiont-static-cookie-card\">\n <h4>{t('analyticsCookiesTitle')}</h4>\n {t('analyticsCookies').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </div>\n\n <div className=\"semiont-static-cookie-card\">\n <h4>{t('marketingCookiesTitle')}</h4>\n {t('marketingCookies').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </div>\n\n <div className=\"semiont-static-cookie-card\">\n <h4>{t('preferenceCookiesTitle')}</h4>\n {t('preferenceCookies').split('\\n\\n').map((para, i) => (\n <p key={i}>\n {para}\n </p>\n ))}\n </div>\n </div>\n </section>\n\n <section>\n <h2>{t('yourRightsTitle')}</h2>\n\n <h3>{t('gdprRightsTitle')}</h3>\n <ul>\n {t('gdprRights').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n\n <h3>{t('ccpaRightsTitle')}</h3>\n <ul>\n {t('ccpaRights').split('\\n').map((item, i) => (\n <li key={i}>{item}</li>\n ))}\n </ul>\n </section>\n\n <section>\n <h2>{t('dataSecurityTitle')}</h2>\n {t('dataSecurity').split('\\n\\n').map((block, i) => {\n if (i === 0) {\n return (\n <p key={i}>\n {block}\n </p>\n );\n }\n return (\n <ul key={i}>\n {block.split('\\n').map((item, j) => (\n <li key={j}>{item}</li>\n ))}\n </ul>\n );\n })}\n </section>\n\n <section>\n <h2>{t('dataRetentionTitle')}</h2>\n <p>\n {t('dataRetention')}\n </p>\n </section>\n\n <section>\n <h2>{t('internationalTransfersTitle')}</h2>\n <p>\n {t('internationalTransfers')}\n </p>\n </section>\n\n <section>\n <h2>{t('contactTitle')}</h2>\n <p>\n {t('contactIntro')}\n </p>\n <div className=\"semiont-static-info-box\">\n <p>\n <strong>{t('contactEmail')}</strong> privacy@semiont.com<br />\n <strong>{t('contactAddress')}</strong> [Your Company Address]\n </p>\n </div>\n </section>\n\n <section>\n <h2>{t('updatesTitle')}</h2>\n <p>\n {t('updates')}\n </p>\n <footer className=\"semiont-static-footer\">\n <p>\n <strong>{t('lastUpdated', { date: new Date().toLocaleDateString() })}</strong>\n </p>\n </footer>\n </section>\n </article>\n </div>\n </div>\n </PageLayout>\n );\n}"],"names":["PrivacyPolicyPage","_t","useTranslation","t","k","p","_tFooter","tFooter","_tNav","tNav","_tHome","tHome","keyboardContext","useContext","KeyboardShortcutsContext","jsx","PageLayout","RoutingLink","routes","CookiePreferences","jsxs","para","item","block","j"],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import{j as s}from"./query-ATBhtd3K.js";import{r as u}from"./vendor-EnoIVk-c.js";import{P as j,b as c}from"./en-IUV4ZXKH-BY1RKeLS.js";import{C as b}from"./CookiePreferences-Cbur0STI.js";import{K as N}from"./privacy-DO1oxJpM.js";import{r as f,L as g}from"./routing-tJ_HbFRP.js";import{L as o}from"./routing-DMdXWYXo.js";import{u as n}from"./i18n-BYxb14hm.js";import"./index-DA31r_0s.js";import"./XMarkIcon-6m9KVFaj.js";function _(){const{t:r}=n(),e=(t,i)=>r(`About.${t}`,i),{t:l}=n(),m=(t,i)=>l(`Footer.${t}`,i),{t:d}=n(),h=(t,i)=>d(`Navigation.${t}`,i),{t:p}=n(),x=(t,i)=>p(`Home.${t}`,i),a=u.useContext(N);return s.jsx(j,{Link:g,routes:f,t:m,tNav:h,tHome:x,showAuthLinks:!1,CookiePreferences:b,...(a==null?void 0:a.openKeyboardHelp)&&{onOpenKeyboardHelp:a.openKeyboardHelp},className:"semiont-static-page",children:s.jsx("div",{className:"semiont-static-container",children:s.jsxs("div",{className:"semiont-static-content",children:[s.jsxs("header",{className:"semiont-static-header",children:[s.jsx("h1",{className:"semiont-static-title",children:e("pageTitle")}),s.jsx("p",{className:"semiont-static-subtitle",children:e("tagline")})]}),s.jsxs("div",{className:"semiont-static-action-buttons",children:[s.jsx(o,{to:"/auth/signup",className:c.primary.base,children:e("signUp")}),s.jsx(o,{to:"/auth/connect?callbackUrl=/know",className:c.primary.base,children:e("signIn")})]}),s.jsxs("article",{className:"semiont-static-article",children:[s.jsxs("section",{children:[s.jsx("h2",{children:e("missionTitle")}),s.jsx("p",{children:e("mission")})]}),s.jsxs("section",{children:[s.jsx("h2",{children:e("coreFeaturesTitle")}),s.jsxs("div",{className:"semiont-static-feature-grid",children:[s.jsxs("div",{className:"semiont-static-feature-card",children:[s.jsx("span",{className:"semiont-static-feature-icon",children:"📊"}),s.jsx("h3",{children:e("semanticContentTitle")}),s.jsx("p",{className:"semiont-static-feature-subtitle",children:e("semanticContentSubtitle")}),e("semanticContent").split(`
2
+
3
+ `).map((t,i)=>s.jsx("p",{children:t},i)),s.jsx("span",{className:"semiont-static-badge semiont-static-badge-planned",children:e("planned")})]}),s.jsxs("div",{className:"semiont-static-feature-card",children:[s.jsx("span",{className:"semiont-static-feature-icon",children:"🤝"}),s.jsx("h3",{children:e("collaborationTitle")}),s.jsx("p",{className:"semiont-static-feature-subtitle",children:e("collaborationSubtitle")}),e("collaboration").split(`
4
+
5
+ `).map((t,i)=>s.jsx("p",{children:t},i)),s.jsx("span",{className:"semiont-static-badge semiont-static-badge-planned",children:e("planned")})]}),s.jsxs("div",{className:"semiont-static-feature-card",children:[s.jsx("span",{className:"semiont-static-feature-icon",children:"🔐"}),s.jsx("h3",{children:e("rbacTitle")}),s.jsx("p",{className:"semiont-static-feature-subtitle",children:e("rbacSubtitle")}),e("rbac").split(`
6
+
7
+ `).map((t,i)=>s.jsx("p",{children:t},i)),s.jsx("span",{className:"semiont-static-badge semiont-static-badge-planned",children:e("planned")})]})]})]}),s.jsxs("section",{className:"semiont-static-highlight",children:[s.jsx("h2",{children:e("openSourceTitle")}),s.jsx("p",{children:e("openSource")}),s.jsx("div",{className:"semiont-static-action-buttons",children:s.jsx("a",{href:"https://github.com/The-AI-Alliance/semiont",target:"_blank",rel:"noopener noreferrer",className:c.secondary.base,children:e("viewOnGitHub")})})]}),s.jsxs("section",{children:[s.jsx("h2",{children:e("futureVisionTitle")}),s.jsx("p",{children:e("futureVision")})]})]})]})})})}export{_ as default};
8
+ //# sourceMappingURL=page-E99MPOn5.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"page-tb55k9Ji.js","sources":["../../src/app/[locale]/about/page.tsx"],"sourcesContent":["import React, { useContext } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { PageLayout, buttonStyles } from '@semiont/react-ui';\nimport { CookiePreferences } from '@/components/CookiePreferences';\nimport { KeyboardShortcutsContext } from '@/contexts/KeyboardShortcutsContext';\nimport { Link as RoutingLink, routes } from '@/lib/routing';\nimport { Link } from '@/i18n/routing';\n\nexport default function AboutPage() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`About.${k}`, p as any) as string;\n const { t: _tFooter } = useTranslation();\n const tFooter = (k: string, p?: Record<string, unknown>) => _tFooter(`Footer.${k}`, p as any) as string;\n const { t: _tNav } = useTranslation();\n const tNav = (k: string, p?: Record<string, unknown>) => _tNav(`Navigation.${k}`, p as any) as string;\n const { t: _tHome } = useTranslation();\n const tHome = (k: string, p?: Record<string, unknown>) => _tHome(`Home.${k}`, p as any) as string;\n const keyboardContext = useContext(KeyboardShortcutsContext);\n\n return (\n <PageLayout\n Link={RoutingLink}\n routes={routes}\n t={tFooter}\n tNav={tNav}\n tHome={tHome}\n showAuthLinks={false}\n CookiePreferences={CookiePreferences}\n {...(keyboardContext?.openKeyboardHelp && { onOpenKeyboardHelp: keyboardContext.openKeyboardHelp })}\n className=\"semiont-static-page\"\n >\n <div className=\"semiont-static-container\">\n <div className=\"semiont-static-content\">\n {/* Header */}\n <header className=\"semiont-static-header\">\n <h1 className=\"semiont-static-title\">\n {t('pageTitle')}\n </h1>\n <p className=\"semiont-static-subtitle\">\n {t('tagline')}\n </p>\n </header>\n\n {/* Action Buttons */}\n <div className=\"semiont-static-action-buttons\">\n <Link\n to=\"/auth/signup\"\n className={buttonStyles.primary.base}\n >\n {t('signUp')}\n </Link>\n <Link\n to=\"/auth/connect?callbackUrl=/know\"\n className={buttonStyles.primary.base}\n >\n {t('signIn')}\n </Link>\n </div>\n\n <article className=\"semiont-static-article\">\n {/* Mission Section */}\n <section>\n <h2>{t('missionTitle')}</h2>\n <p>\n {t('mission')}\n </p>\n </section>\n\n {/* Features Section */}\n <section>\n <h2>{t('coreFeaturesTitle')}</h2>\n\n <div className=\"semiont-static-feature-grid\">\n {/* Semantic Content */}\n <div className=\"semiont-static-feature-card\">\n <span className=\"semiont-static-feature-icon\">📊</span>\n <h3>{t('semanticContentTitle')}</h3>\n <p className=\"semiont-static-feature-subtitle\">\n {t('semanticContentSubtitle')}\n </p>\n {t('semanticContent').split('\\n\\n').map((para, i) => (\n <p key={i}>{para}</p>\n ))}\n <span className=\"semiont-static-badge semiont-static-badge-planned\">\n {t('planned')}\n </span>\n </div>\n\n {/* Real-time Collaboration */}\n <div className=\"semiont-static-feature-card\">\n <span className=\"semiont-static-feature-icon\">🤝</span>\n <h3>{t('collaborationTitle')}</h3>\n <p className=\"semiont-static-feature-subtitle\">\n {t('collaborationSubtitle')}\n </p>\n {t('collaboration').split('\\n\\n').map((para, i) => (\n <p key={i}>{para}</p>\n ))}\n <span className=\"semiont-static-badge semiont-static-badge-planned\">\n {t('planned')}\n </span>\n </div>\n\n {/* Advanced RBAC */}\n <div className=\"semiont-static-feature-card\">\n <span className=\"semiont-static-feature-icon\">🔐</span>\n <h3>{t('rbacTitle')}</h3>\n <p className=\"semiont-static-feature-subtitle\">\n {t('rbacSubtitle')}\n </p>\n {t('rbac').split('\\n\\n').map((para, i) => (\n <p key={i}>{para}</p>\n ))}\n <span className=\"semiont-static-badge semiont-static-badge-planned\">\n {t('planned')}\n </span>\n </div>\n </div>\n </section>\n\n {/* Open Source Section */}\n <section className=\"semiont-static-highlight\">\n <h2>{t('openSourceTitle')}</h2>\n <p>\n {t('openSource')}\n </p>\n <div className=\"semiont-static-action-buttons\">\n <a\n href=\"https://github.com/The-AI-Alliance/semiont\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className={buttonStyles.secondary.base}\n >\n {t('viewOnGitHub')}\n </a>\n </div>\n </section>\n\n {/* Future Vision */}\n <section>\n <h2>{t('futureVisionTitle')}</h2>\n <p>\n {t('futureVision')}\n </p>\n </section>\n </article>\n </div>\n </div>\n </PageLayout>\n );\n}"],"names":["AboutPage","_t","useTranslation","t","k","p","_tFooter","tFooter","_tNav","tNav","_tHome","tHome","keyboardContext","useContext","KeyboardShortcutsContext","jsx","PageLayout","RoutingLink","routes","CookiePreferences","jsxs","Link","buttonStyles","para"],"mappings":"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"}
1
+ {"version":3,"file":"page-E99MPOn5.js","sources":["../../src/app/[locale]/about/page.tsx"],"sourcesContent":["import React, { useContext } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { PageLayout, buttonStyles } from '@semiont/react-ui';\nimport { CookiePreferences } from '@/components/CookiePreferences';\nimport { KeyboardShortcutsContext } from '@/contexts/KeyboardShortcutsContext';\nimport { Link as RoutingLink, routes } from '@/lib/routing';\nimport { Link } from '@/i18n/routing';\n\nexport default function AboutPage() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`About.${k}`, p as any) as string;\n const { t: _tFooter } = useTranslation();\n const tFooter = (k: string, p?: Record<string, unknown>) => _tFooter(`Footer.${k}`, p as any) as string;\n const { t: _tNav } = useTranslation();\n const tNav = (k: string, p?: Record<string, unknown>) => _tNav(`Navigation.${k}`, p as any) as string;\n const { t: _tHome } = useTranslation();\n const tHome = (k: string, p?: Record<string, unknown>) => _tHome(`Home.${k}`, p as any) as string;\n const keyboardContext = useContext(KeyboardShortcutsContext);\n\n return (\n <PageLayout\n Link={RoutingLink}\n routes={routes}\n t={tFooter}\n tNav={tNav}\n tHome={tHome}\n showAuthLinks={false}\n CookiePreferences={CookiePreferences}\n {...(keyboardContext?.openKeyboardHelp && { onOpenKeyboardHelp: keyboardContext.openKeyboardHelp })}\n className=\"semiont-static-page\"\n >\n <div className=\"semiont-static-container\">\n <div className=\"semiont-static-content\">\n {/* Header */}\n <header className=\"semiont-static-header\">\n <h1 className=\"semiont-static-title\">\n {t('pageTitle')}\n </h1>\n <p className=\"semiont-static-subtitle\">\n {t('tagline')}\n </p>\n </header>\n\n {/* Action Buttons */}\n <div className=\"semiont-static-action-buttons\">\n <Link\n to=\"/auth/signup\"\n className={buttonStyles.primary.base}\n >\n {t('signUp')}\n </Link>\n <Link\n to=\"/auth/connect?callbackUrl=/know\"\n className={buttonStyles.primary.base}\n >\n {t('signIn')}\n </Link>\n </div>\n\n <article className=\"semiont-static-article\">\n {/* Mission Section */}\n <section>\n <h2>{t('missionTitle')}</h2>\n <p>\n {t('mission')}\n </p>\n </section>\n\n {/* Features Section */}\n <section>\n <h2>{t('coreFeaturesTitle')}</h2>\n\n <div className=\"semiont-static-feature-grid\">\n {/* Semantic Content */}\n <div className=\"semiont-static-feature-card\">\n <span className=\"semiont-static-feature-icon\">📊</span>\n <h3>{t('semanticContentTitle')}</h3>\n <p className=\"semiont-static-feature-subtitle\">\n {t('semanticContentSubtitle')}\n </p>\n {t('semanticContent').split('\\n\\n').map((para, i) => (\n <p key={i}>{para}</p>\n ))}\n <span className=\"semiont-static-badge semiont-static-badge-planned\">\n {t('planned')}\n </span>\n </div>\n\n {/* Real-time Collaboration */}\n <div className=\"semiont-static-feature-card\">\n <span className=\"semiont-static-feature-icon\">🤝</span>\n <h3>{t('collaborationTitle')}</h3>\n <p className=\"semiont-static-feature-subtitle\">\n {t('collaborationSubtitle')}\n </p>\n {t('collaboration').split('\\n\\n').map((para, i) => (\n <p key={i}>{para}</p>\n ))}\n <span className=\"semiont-static-badge semiont-static-badge-planned\">\n {t('planned')}\n </span>\n </div>\n\n {/* Advanced RBAC */}\n <div className=\"semiont-static-feature-card\">\n <span className=\"semiont-static-feature-icon\">🔐</span>\n <h3>{t('rbacTitle')}</h3>\n <p className=\"semiont-static-feature-subtitle\">\n {t('rbacSubtitle')}\n </p>\n {t('rbac').split('\\n\\n').map((para, i) => (\n <p key={i}>{para}</p>\n ))}\n <span className=\"semiont-static-badge semiont-static-badge-planned\">\n {t('planned')}\n </span>\n </div>\n </div>\n </section>\n\n {/* Open Source Section */}\n <section className=\"semiont-static-highlight\">\n <h2>{t('openSourceTitle')}</h2>\n <p>\n {t('openSource')}\n </p>\n <div className=\"semiont-static-action-buttons\">\n <a\n href=\"https://github.com/The-AI-Alliance/semiont\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className={buttonStyles.secondary.base}\n >\n {t('viewOnGitHub')}\n </a>\n </div>\n </section>\n\n {/* Future Vision */}\n <section>\n <h2>{t('futureVisionTitle')}</h2>\n <p>\n {t('futureVision')}\n </p>\n </section>\n </article>\n </div>\n </div>\n </PageLayout>\n );\n}"],"names":["AboutPage","_t","useTranslation","t","k","p","_tFooter","tFooter","_tNav","tNav","_tHome","tHome","keyboardContext","useContext","KeyboardShortcutsContext","jsx","PageLayout","RoutingLink","routes","CookiePreferences","jsxs","Link","buttonStyles","para"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{u as j,j as r}from"./query-ATBhtd3K.js";import{r as s}from"./vendor-EnoIVk-c.js";import{d as v,e as w,f as A,g as C,i as L,E as k,T as I}from"./en-IUV4ZXKH-BY1RKeLS.js";import{T as D}from"./ToolbarPanels-rN1MIRTV.js";import{u as M}from"./i18n-BYxb14hm.js";import"./index-DA31r_0s.js";import"./useAuth-yUx5lBP5.js";import"./routing-DMdXWYXo.js";import"./XMarkIcon-6m9KVFaj.js";function $(){const{t:m}=M(),e=(t,N)=>m(`ModerateEntityTags.${t}`,N),[a,i]=s.useState(""),[p,o]=s.useState(""),T=j(),{activePanel:y}=v(),{theme:h,setTheme:c}=w(),{showLineNumbers:f,toggleLineNumbers:d}=A(),E=s.useCallback(({theme:t})=>{c(t)},[c]),b=s.useCallback(()=>{d()},[d]);C({"settings:theme-changed":E,"settings:line-numbers-toggled":b});const l=L(),{data:n,isLoading:u}=l.list.useQuery({refetchInterval:3e4,refetchIntervalInBackground:!0}),x=(n==null?void 0:n.entityTypes)||[],g=l.add.useMutation(),P=async()=>{if(a.trim()){o("");try{await g.mutateAsync(a.trim()),T.invalidateQueries({queryKey:["/api/entity-types"]}),i("")}catch(t){o(t instanceof Error?t.message:e("errorFailedToAdd"))}}};return u?r.jsx("div",{className:"flex items-center justify-center py-20",children:r.jsx("p",{className:"text-gray-600 dark:text-gray-300",children:e("loading")})}):r.jsx(k,{entityTypes:x,isLoading:u,error:p,newTag:a,onNewTagChange:i,onAddTag:P,isAddingTag:g.isPending,theme:h,showLineNumbers:f,activePanel:y,translations:{pageTitle:e("pageTitle"),pageDescription:e("pageDescription"),sectionTitle:e("sectionTitle"),sectionDescription:e("sectionDescription"),inputPlaceholder:e("inputPlaceholder"),addTag:e("addTag"),adding:e("adding")},ToolbarPanels:D,Toolbar:I})}export{$ as default};
2
+ //# sourceMappingURL=page-KtkB4tEv.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"page-vzoIwpsS.js","sources":["../../src/app/[locale]/moderate/entity-tags/page.tsx"],"sourcesContent":["/**\n * Entity Tags Page - Thin Next.js wrapper\n *\n * This page handles Next.js-specific concerns (translations, API calls)\n * and delegates rendering to the pure React EntityTagsPage component.\n */\n\nimport { useState, useCallback } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { useEntityTypes, Toolbar } from '@semiont/react-ui';\nimport { useQueryClient } from '@tanstack/react-query';\nimport { ToolbarPanels } from '@/components/toolbar/ToolbarPanels';\nimport { useTheme, usePanelBrowse, useLineNumbers, useEventSubscriptions } from '@semiont/react-ui';\nimport { EntityTagsPage } from '@semiont/react-ui';\n\n// Authentication is handled by middleware (proxy.ts)\n// Only authenticated moderators/admins can reach this page\n\nexport default function EntityTagsPageWrapper() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`ModerateEntityTags.${k}`, p as any) as string;\n const [newTag, setNewTag] = useState('');\n const [error, setError] = useState('');\n const queryClient = useQueryClient();\n\n // Toolbar and settings state\n const { activePanel } = usePanelBrowse();\n const { theme, setTheme } = useTheme();\n const { showLineNumbers, toggleLineNumbers } = useLineNumbers();\n\n const handleThemeChanged = useCallback(({ theme }: { theme: 'light' | 'dark' | 'system' }) => {\n setTheme(theme);\n }, [setTheme]);\n\n const handleLineNumbersToggled = useCallback(() => {\n toggleLineNumbers();\n }, [toggleLineNumbers]);\n\n useEventSubscriptions({\n 'settings:theme-changed': handleThemeChanged,\n 'settings:line-numbers-toggled': handleLineNumbersToggled,\n });\n\n // API hooks\n const entityTypesAPI = useEntityTypes();\n\n // Query entity types with auto-refetch for cross-browser updates\n const { data: entityTypesData, isLoading } = entityTypesAPI.list.useQuery({\n refetchInterval: 30000,\n refetchIntervalInBackground: true,\n });\n const entityTypes = entityTypesData?.entityTypes || [];\n\n // Mutation for creating new entity type\n const createEntityTypeMutation = entityTypesAPI.add.useMutation();\n\n const handleAddTag = async () => {\n if (!newTag.trim()) return;\n\n setError('');\n\n try {\n await createEntityTypeMutation.mutateAsync(newTag.trim());\n queryClient.invalidateQueries({ queryKey: ['/api/entity-types'] });\n setNewTag('');\n } catch (err) {\n setError(err instanceof Error ? err.message : t('errorFailedToAdd'));\n }\n };\n\n if (isLoading) {\n return (\n <div className=\"flex items-center justify-center py-20\">\n <p className=\"text-gray-600 dark:text-gray-300\">{t('loading')}</p>\n </div>\n );\n }\n\n return (\n <EntityTagsPage\n entityTypes={entityTypes as string[]}\n isLoading={isLoading}\n error={error}\n newTag={newTag}\n onNewTagChange={setNewTag}\n onAddTag={handleAddTag}\n isAddingTag={createEntityTypeMutation.isPending}\n theme={theme}\n showLineNumbers={showLineNumbers}\n activePanel={activePanel}\n translations={{\n pageTitle: t('pageTitle'),\n pageDescription: t('pageDescription'),\n sectionTitle: t('sectionTitle'),\n sectionDescription: t('sectionDescription'),\n inputPlaceholder: t('inputPlaceholder'),\n addTag: t('addTag'),\n adding: t('adding'),\n }}\n ToolbarPanels={ToolbarPanels}\n Toolbar={Toolbar}\n />\n );\n}\n"],"names":["EntityTagsPageWrapper","_t","useTranslation","t","k","p","newTag","setNewTag","useState","error","setError","queryClient","useQueryClient","activePanel","usePanelBrowse","theme","setTheme","useTheme","showLineNumbers","toggleLineNumbers","useLineNumbers","handleThemeChanged","useCallback","handleLineNumbersToggled","useEventSubscriptions","entityTypesAPI","useEntityTypes","entityTypesData","isLoading","entityTypes","createEntityTypeMutation","handleAddTag","err","jsx","EntityTagsPage","ToolbarPanels","Toolbar"],"mappings":"2cAkBA,SAAwBA,GAAwB,CAC9C,KAAM,CAAE,EAAGC,CAAA,EAAOC,EAAA,EACZC,EAAI,CAACC,EAAWC,IAAgCJ,EAAG,sBAAsBG,CAAC,GAAIC,CAAQ,EACtF,CAACC,EAAQC,CAAS,EAAIC,EAAAA,SAAS,EAAE,EACjC,CAACC,EAAOC,CAAQ,EAAIF,EAAAA,SAAS,EAAE,EAC/BG,EAAcC,EAAA,EAGd,CAAE,YAAAC,CAAA,EAAgBC,EAAA,EAClB,CAAE,MAAAC,EAAO,SAAAC,CAAA,EAAaC,EAAA,EACtB,CAAE,gBAAAC,EAAiB,kBAAAC,CAAA,EAAsBC,EAAA,EAEzCC,EAAqBC,EAAAA,YAAY,CAAC,CAAE,MAAAP,KAAoD,CAC5FC,EAASD,CAAK,CAChB,EAAG,CAACC,CAAQ,CAAC,EAEPO,EAA2BD,EAAAA,YAAY,IAAM,CACjDH,EAAA,CACF,EAAG,CAACA,CAAiB,CAAC,EAEtBK,EAAsB,CACpB,yBAA0BH,EAC1B,gCAAiCE,CAAA,CAClC,EAGD,MAAME,EAAiBC,EAAA,EAGjB,CAAE,KAAMC,EAAiB,UAAAC,GAAcH,EAAe,KAAK,SAAS,CACxE,gBAAiB,IACjB,4BAA6B,EAAA,CAC9B,EACKI,GAAcF,GAAA,YAAAA,EAAiB,cAAe,CAAA,EAG9CG,EAA2BL,EAAe,IAAI,YAAA,EAE9CM,EAAe,SAAY,CAC/B,GAAKzB,EAAO,OAEZ,CAAAI,EAAS,EAAE,EAEX,GAAI,CACF,MAAMoB,EAAyB,YAAYxB,EAAO,KAAA,CAAM,EACxDK,EAAY,kBAAkB,CAAE,SAAU,CAAC,mBAAmB,EAAG,EACjEJ,EAAU,EAAE,CACd,OAASyB,EAAK,CACZtB,EAASsB,aAAe,MAAQA,EAAI,QAAU7B,EAAE,kBAAkB,CAAC,CACrE,EACF,EAEA,OAAIyB,EAEAK,EAAAA,IAAC,MAAA,CAAI,UAAU,yCACb,SAAAA,MAAC,IAAA,CAAE,UAAU,mCAAoC,SAAA9B,EAAE,SAAS,CAAA,CAAE,EAChE,EAKF8B,EAAAA,IAACC,EAAA,CACC,YAAAL,EACA,UAAAD,EACA,MAAAnB,EACA,OAAAH,EACA,eAAgBC,EAChB,SAAUwB,EACV,YAAaD,EAAyB,UACtC,MAAAf,EACA,gBAAAG,EACA,YAAAL,EACA,aAAc,CACZ,UAAWV,EAAE,WAAW,EACxB,gBAAiBA,EAAE,iBAAiB,EACpC,aAAcA,EAAE,cAAc,EAC9B,mBAAoBA,EAAE,oBAAoB,EAC1C,iBAAkBA,EAAE,kBAAkB,EACtC,OAAQA,EAAE,QAAQ,EAClB,OAAQA,EAAE,QAAQ,CAAA,EAEpB,cAAAgC,EACA,QAAAC,CAAA,CAAA,CAGN"}
1
+ {"version":3,"file":"page-KtkB4tEv.js","sources":["../../src/app/[locale]/moderate/entity-tags/page.tsx"],"sourcesContent":["/**\n * Entity Tags Page - Thin Next.js wrapper\n *\n * This page handles Next.js-specific concerns (translations, API calls)\n * and delegates rendering to the pure React EntityTagsPage component.\n */\n\nimport { useState, useCallback } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { useEntityTypes, Toolbar } from '@semiont/react-ui';\nimport { useQueryClient } from '@tanstack/react-query';\nimport { ToolbarPanels } from '@/components/toolbar/ToolbarPanels';\nimport { useTheme, usePanelBrowse, useLineNumbers, useEventSubscriptions } from '@semiont/react-ui';\nimport { EntityTagsPage } from '@semiont/react-ui';\n\n// Authentication is handled by middleware (proxy.ts)\n// Only authenticated moderators/admins can reach this page\n\nexport default function EntityTagsPageWrapper() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`ModerateEntityTags.${k}`, p as any) as string;\n const [newTag, setNewTag] = useState('');\n const [error, setError] = useState('');\n const queryClient = useQueryClient();\n\n // Toolbar and settings state\n const { activePanel } = usePanelBrowse();\n const { theme, setTheme } = useTheme();\n const { showLineNumbers, toggleLineNumbers } = useLineNumbers();\n\n const handleThemeChanged = useCallback(({ theme }: { theme: 'light' | 'dark' | 'system' }) => {\n setTheme(theme);\n }, [setTheme]);\n\n const handleLineNumbersToggled = useCallback(() => {\n toggleLineNumbers();\n }, [toggleLineNumbers]);\n\n useEventSubscriptions({\n 'settings:theme-changed': handleThemeChanged,\n 'settings:line-numbers-toggled': handleLineNumbersToggled,\n });\n\n // API hooks\n const entityTypesAPI = useEntityTypes();\n\n // Query entity types with auto-refetch for cross-browser updates\n const { data: entityTypesData, isLoading } = entityTypesAPI.list.useQuery({\n refetchInterval: 30000,\n refetchIntervalInBackground: true,\n });\n const entityTypes = entityTypesData?.entityTypes || [];\n\n // Mutation for creating new entity type\n const createEntityTypeMutation = entityTypesAPI.add.useMutation();\n\n const handleAddTag = async () => {\n if (!newTag.trim()) return;\n\n setError('');\n\n try {\n await createEntityTypeMutation.mutateAsync(newTag.trim());\n queryClient.invalidateQueries({ queryKey: ['/api/entity-types'] });\n setNewTag('');\n } catch (err) {\n setError(err instanceof Error ? err.message : t('errorFailedToAdd'));\n }\n };\n\n if (isLoading) {\n return (\n <div className=\"flex items-center justify-center py-20\">\n <p className=\"text-gray-600 dark:text-gray-300\">{t('loading')}</p>\n </div>\n );\n }\n\n return (\n <EntityTagsPage\n entityTypes={entityTypes as string[]}\n isLoading={isLoading}\n error={error}\n newTag={newTag}\n onNewTagChange={setNewTag}\n onAddTag={handleAddTag}\n isAddingTag={createEntityTypeMutation.isPending}\n theme={theme}\n showLineNumbers={showLineNumbers}\n activePanel={activePanel}\n translations={{\n pageTitle: t('pageTitle'),\n pageDescription: t('pageDescription'),\n sectionTitle: t('sectionTitle'),\n sectionDescription: t('sectionDescription'),\n inputPlaceholder: t('inputPlaceholder'),\n addTag: t('addTag'),\n adding: t('adding'),\n }}\n ToolbarPanels={ToolbarPanels}\n Toolbar={Toolbar}\n />\n );\n}\n"],"names":["EntityTagsPageWrapper","_t","useTranslation","t","k","p","newTag","setNewTag","useState","error","setError","queryClient","useQueryClient","activePanel","usePanelBrowse","theme","setTheme","useTheme","showLineNumbers","toggleLineNumbers","useLineNumbers","handleThemeChanged","useCallback","handleLineNumbersToggled","useEventSubscriptions","entityTypesAPI","useEntityTypes","entityTypesData","isLoading","entityTypes","createEntityTypeMutation","handleAddTag","err","jsx","EntityTagsPage","ToolbarPanels","Toolbar"],"mappings":"+XAkBA,SAAwBA,GAAwB,CAC9C,KAAM,CAAE,EAAGC,CAAA,EAAOC,EAAA,EACZC,EAAI,CAACC,EAAWC,IAAgCJ,EAAG,sBAAsBG,CAAC,GAAIC,CAAQ,EACtF,CAACC,EAAQC,CAAS,EAAIC,EAAAA,SAAS,EAAE,EACjC,CAACC,EAAOC,CAAQ,EAAIF,EAAAA,SAAS,EAAE,EAC/BG,EAAcC,EAAA,EAGd,CAAE,YAAAC,CAAA,EAAgBC,EAAA,EAClB,CAAE,MAAAC,EAAO,SAAAC,CAAA,EAAaC,EAAA,EACtB,CAAE,gBAAAC,EAAiB,kBAAAC,CAAA,EAAsBC,EAAA,EAEzCC,EAAqBC,EAAAA,YAAY,CAAC,CAAE,MAAAP,KAAoD,CAC5FC,EAASD,CAAK,CAChB,EAAG,CAACC,CAAQ,CAAC,EAEPO,EAA2BD,EAAAA,YAAY,IAAM,CACjDH,EAAA,CACF,EAAG,CAACA,CAAiB,CAAC,EAEtBK,EAAsB,CACpB,yBAA0BH,EAC1B,gCAAiCE,CAAA,CAClC,EAGD,MAAME,EAAiBC,EAAA,EAGjB,CAAE,KAAMC,EAAiB,UAAAC,GAAcH,EAAe,KAAK,SAAS,CACxE,gBAAiB,IACjB,4BAA6B,EAAA,CAC9B,EACKI,GAAcF,GAAA,YAAAA,EAAiB,cAAe,CAAA,EAG9CG,EAA2BL,EAAe,IAAI,YAAA,EAE9CM,EAAe,SAAY,CAC/B,GAAKzB,EAAO,OAEZ,CAAAI,EAAS,EAAE,EAEX,GAAI,CACF,MAAMoB,EAAyB,YAAYxB,EAAO,KAAA,CAAM,EACxDK,EAAY,kBAAkB,CAAE,SAAU,CAAC,mBAAmB,EAAG,EACjEJ,EAAU,EAAE,CACd,OAASyB,EAAK,CACZtB,EAASsB,aAAe,MAAQA,EAAI,QAAU7B,EAAE,kBAAkB,CAAC,CACrE,EACF,EAEA,OAAIyB,EAEAK,EAAAA,IAAC,MAAA,CAAI,UAAU,yCACb,SAAAA,MAAC,IAAA,CAAE,UAAU,mCAAoC,SAAA9B,EAAE,SAAS,CAAA,CAAE,EAChE,EAKF8B,EAAAA,IAACC,EAAA,CACC,YAAAL,EACA,UAAAD,EACA,MAAAnB,EACA,OAAAH,EACA,eAAgBC,EAChB,SAAUwB,EACV,YAAaD,EAAyB,UACtC,MAAAf,EACA,gBAAAG,EACA,YAAAL,EACA,aAAc,CACZ,UAAWV,EAAE,WAAW,EACxB,gBAAiBA,EAAE,iBAAiB,EACpC,aAAcA,EAAE,cAAc,EAC9B,mBAAoBA,EAAE,oBAAoB,EAC1C,iBAAkBA,EAAE,kBAAkB,EACtC,OAAQA,EAAE,QAAQ,EAClB,OAAQA,EAAE,QAAQ,CAAA,EAEpB,cAAAgC,EACA,QAAAC,CAAA,CAAA,CAGN"}
@@ -0,0 +1,2 @@
1
+ import{j as t}from"./query-ATBhtd3K.js";import{r as n}from"./vendor-EnoIVk-c.js";import{S as u,b as a}from"./en-IUV4ZXKH-BY1RKeLS.js";import{u as c}from"./routing-DMdXWYXo.js";import{u as l}from"./i18n-BYxb14hm.js";import"./index-DA31r_0s.js";const f=5e3;function b(){const{t:s}=l(),r=m=>s(`Home.${m}`),i=c(),e=n.useRef(null),o=()=>{e.current&&clearTimeout(e.current),i.push("/know/discover")};return n.useEffect(()=>(e.current=setTimeout(o,f),()=>{e.current&&clearTimeout(e.current)}),[]),t.jsxs("main",{role:"main",style:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",minHeight:"100vh",gap:"2rem"},children:[t.jsx(u,{t:r,size:"xl",animated:!0}),t.jsx("button",{onClick:o,className:a.primary.base,children:r("begin")})]})}export{b as default};
2
+ //# sourceMappingURL=page-ZBwMTeR-.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"page-ZBwMTeR-.js","sources":["../../src/app/[locale]/page.tsx"],"sourcesContent":["import { useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { SemiontBranding, buttonStyles } from '@semiont/react-ui';\nimport { useRouter } from '@/i18n/routing';\n\nconst AUTO_TRANSITION_MS = 5000;\n\nexport default function Home() {\n const { t: _t } = useTranslation();\n const t = (k: string) => _t(`Home.${k}`) as string;\n const router = useRouter();\n const timerRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n const goToWorkspace = () => {\n if (timerRef.current) clearTimeout(timerRef.current);\n router.push('/know/discover');\n };\n\n useEffect(() => {\n timerRef.current = setTimeout(goToWorkspace, AUTO_TRANSITION_MS);\n return () => { if (timerRef.current) clearTimeout(timerRef.current); };\n }, []);\n\n return (\n <main\n role=\"main\"\n style={{\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n minHeight: '100vh',\n gap: '2rem',\n }}\n >\n <SemiontBranding t={t} size=\"xl\" animated={true} />\n <button onClick={goToWorkspace} className={buttonStyles.primary.base}>\n {t('begin')}\n </button>\n </main>\n );\n}\n"],"names":["AUTO_TRANSITION_MS","Home","_t","useTranslation","t","k","router","useRouter","timerRef","useRef","goToWorkspace","useEffect","jsxs","jsx","SemiontBranding","buttonStyles"],"mappings":"mPAKA,MAAMA,EAAqB,IAE3B,SAAwBC,GAAO,CAC7B,KAAM,CAAE,EAAGC,CAAA,EAAOC,EAAA,EACZC,EAAKC,GAAcH,EAAG,QAAQG,CAAC,EAAE,EACjCC,EAASC,EAAA,EACTC,EAAWC,EAAAA,OAA6C,IAAI,EAE5DC,EAAgB,IAAM,CACtBF,EAAS,SAAS,aAAaA,EAAS,OAAO,EACnDF,EAAO,KAAK,gBAAgB,CAC9B,EAEAK,OAAAA,EAAAA,UAAU,KACRH,EAAS,QAAU,WAAWE,EAAeV,CAAkB,EACxD,IAAM,CAAMQ,EAAS,SAAS,aAAaA,EAAS,OAAO,CAAG,GACpE,CAAA,CAAE,EAGHI,EAAAA,KAAC,OAAA,CACC,KAAK,OACL,MAAO,CACL,QAAS,OACT,cAAe,SACf,WAAY,SACZ,eAAgB,SAChB,UAAW,QACX,IAAK,MAAA,EAGP,SAAA,CAAAC,EAAAA,IAACC,EAAA,CAAgB,EAAAV,EAAM,KAAK,KAAK,SAAU,GAAM,EACjDS,EAAAA,IAAC,SAAA,CAAO,QAASH,EAAe,UAAWK,EAAa,QAAQ,KAC7D,SAAAX,EAAE,OAAO,CAAA,CACZ,CAAA,CAAA,CAAA,CAGN"}
@@ -0,0 +1,2 @@
1
+ import{j as r}from"./query-ATBhtd3K.js";import{u as f,r as h}from"./vendor-EnoIVk-c.js";import{u as U,L as d}from"./routing-DMdXWYXo.js";import{P as k,a as H}from"./en-IUV4ZXKH-BY1RKeLS.js";import{C as b}from"./CookiePreferences-Cbur0STI.js";import{K as x}from"./privacy-DO1oxJpM.js";import{r as y,L as A}from"./routing-tJ_HbFRP.js";import{u as L}from"./i18n-BYxb14hm.js";import"./index-DA31r_0s.js";import"./XMarkIcon-6m9KVFaj.js";function S(){const{t:n}=L(),o=(t,e)=>n(`AuthSignUp.${t}`,e),i=(t,e)=>n(`Footer.${t}`,e),c=(t,e)=>n(`Navigation.${t}`,e),s=(t,e)=>n(`Home.${t}`,e),[p]=f(),m=U(),a=h.useContext(x),l=p.get("callbackUrl")??"/auth/welcome",u=async()=>{m.push(`/auth/connect?callbackUrl=${encodeURIComponent(l)}`)},g={pageTitle:o("pageTitle"),signUpPrompt:o("signUpPrompt"),signUpWithGoogle:o("signUpWithGoogle"),creatingAccount:o("creatingAccount"),approvedDomainsInfo:o("approvedDomainsInfo"),termsAgreement:o("termsAgreement"),alreadyHaveAccount:o("alreadyHaveAccount"),tagline:s("tagline"),backToHome:o("backToHome")};return r.jsx(k,{Link:A,routes:y,t:i,tNav:c,tHome:s,CookiePreferences:b,...(a==null?void 0:a.openKeyboardHelp)&&{onOpenKeyboardHelp:a.openKeyboardHelp},className:"semiont-page-layout--auth",showAuthLinks:!1,children:r.jsx(H,{onSignUp:u,Link:d,translations:g})})}function R(){return r.jsx(S,{})}export{R as default};
2
+ //# sourceMappingURL=page-Zq6ARIvg.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"page-DjkPUxlb.js","sources":["../../src/app/[locale]/auth/signup/page.tsx"],"sourcesContent":["import { useContext } from 'react';\nimport { useSearchParams } from 'react-router-dom';\nimport { useTranslation } from 'react-i18next';\nimport { useRouter } from '@/i18n/routing';\nimport { PageLayout, SignUpForm } from '@semiont/react-ui';\nimport { CookiePreferences } from '@/components/CookiePreferences';\nimport { KeyboardShortcutsContext } from '@/contexts/KeyboardShortcutsContext';\nimport { Link as RoutingLink, routes } from '@/lib/routing';\nimport { Link } from '@/i18n/routing';\n\nfunction SignUpContent() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`AuthSignUp.${k}`, p as any) as string;\n const tFooter = (k: string, p?: Record<string, unknown>) => _t(`Footer.${k}`, p as any) as string;\n const tNav = (k: string, p?: Record<string, unknown>) => _t(`Navigation.${k}`, p as any) as string;\n const tHome = (k: string, p?: Record<string, unknown>) => _t(`Home.${k}`, p as any) as string;\n const [searchParams] = useSearchParams();\n const router = useRouter();\n const keyboardContext = useContext(KeyboardShortcutsContext);\n\n const callbackUrl = searchParams.get('callbackUrl') ?? '/auth/welcome';\n\n const handleSignUp = async () => {\n router.push(`/auth/connect?callbackUrl=${encodeURIComponent(callbackUrl)}`);\n };\n\n const translations = {\n pageTitle: t('pageTitle'),\n signUpPrompt: t('signUpPrompt'),\n signUpWithGoogle: t('signUpWithGoogle'),\n creatingAccount: t('creatingAccount'),\n approvedDomainsInfo: t('approvedDomainsInfo'),\n termsAgreement: t('termsAgreement'),\n alreadyHaveAccount: t('alreadyHaveAccount'),\n tagline: tHome('tagline'),\n backToHome: t('backToHome'),\n };\n\n return (\n <PageLayout\n Link={RoutingLink}\n routes={routes}\n t={tFooter}\n tNav={tNav}\n tHome={tHome}\n CookiePreferences={CookiePreferences}\n {...(keyboardContext?.openKeyboardHelp && { onOpenKeyboardHelp: keyboardContext.openKeyboardHelp })}\n className=\"semiont-page-layout--auth\"\n showAuthLinks={false}\n >\n <SignUpForm onSignUp={handleSignUp} Link={Link} translations={translations} />\n </PageLayout>\n );\n}\n\nexport default function SignUp() {\n return <SignUpContent />;\n}\n"],"names":["SignUpContent","_t","useTranslation","t","k","p","tFooter","tNav","tHome","searchParams","useSearchParams","router","useRouter","keyboardContext","useContext","KeyboardShortcutsContext","callbackUrl","handleSignUp","translations","jsx","PageLayout","RoutingLink","routes","CookiePreferences","SignUpForm","Link","SignUp"],"mappings":"gZAUA,SAASA,GAAgB,CACvB,KAAM,CAAE,EAAGC,CAAA,EAAOC,EAAA,EACZC,EAAI,CAACC,EAAWC,IAAgCJ,EAAG,cAAcG,CAAC,GAAIC,CAAQ,EAC9EC,EAAU,CAACF,EAAWC,IAAgCJ,EAAG,UAAUG,CAAC,GAAIC,CAAQ,EAChFE,EAAO,CAACH,EAAWC,IAAgCJ,EAAG,cAAcG,CAAC,GAAIC,CAAQ,EACjFG,EAAQ,CAACJ,EAAWC,IAAgCJ,EAAG,QAAQG,CAAC,GAAIC,CAAQ,EAC5E,CAACI,CAAY,EAAIC,EAAA,EACjBC,EAASC,EAAA,EACTC,EAAkBC,EAAAA,WAAWC,CAAwB,EAErDC,EAAcP,EAAa,IAAI,aAAa,GAAK,gBAEjDQ,EAAe,SAAY,CAC/BN,EAAO,KAAK,6BAA6B,mBAAmBK,CAAW,CAAC,EAAE,CAC5E,EAEME,EAAe,CACnB,UAAWf,EAAE,WAAW,EACxB,aAAcA,EAAE,cAAc,EAC9B,iBAAkBA,EAAE,kBAAkB,EACtC,gBAAiBA,EAAE,iBAAiB,EACpC,oBAAqBA,EAAE,qBAAqB,EAC5C,eAAgBA,EAAE,gBAAgB,EAClC,mBAAoBA,EAAE,oBAAoB,EAC1C,QAASK,EAAM,SAAS,EACxB,WAAYL,EAAE,YAAY,CAAA,EAG5B,OACEgB,EAAAA,IAACC,EAAA,CACC,KAAMC,EACN,OAAAC,EACA,EAAGhB,EACH,KAAAC,EACA,MAAAC,EACA,kBAAAe,EACC,IAAIV,GAAA,YAAAA,EAAiB,mBAAoB,CAAE,mBAAoBA,EAAgB,gBAAA,EAChF,UAAU,4BACV,cAAe,GAEf,SAAAM,EAAAA,IAACK,EAAA,CAAW,SAAUP,EAAA,KAAcQ,EAAY,aAAAP,CAAA,CAA4B,CAAA,CAAA,CAGlF,CAEA,SAAwBQ,GAAS,CAC/B,aAAQ1B,EAAA,EAAc,CACxB"}
1
+ {"version":3,"file":"page-Zq6ARIvg.js","sources":["../../src/app/[locale]/auth/signup/page.tsx"],"sourcesContent":["import { useContext } from 'react';\nimport { useSearchParams } from 'react-router-dom';\nimport { useTranslation } from 'react-i18next';\nimport { useRouter } from '@/i18n/routing';\nimport { PageLayout, SignUpForm } from '@semiont/react-ui';\nimport { CookiePreferences } from '@/components/CookiePreferences';\nimport { KeyboardShortcutsContext } from '@/contexts/KeyboardShortcutsContext';\nimport { Link as RoutingLink, routes } from '@/lib/routing';\nimport { Link } from '@/i18n/routing';\n\nfunction SignUpContent() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`AuthSignUp.${k}`, p as any) as string;\n const tFooter = (k: string, p?: Record<string, unknown>) => _t(`Footer.${k}`, p as any) as string;\n const tNav = (k: string, p?: Record<string, unknown>) => _t(`Navigation.${k}`, p as any) as string;\n const tHome = (k: string, p?: Record<string, unknown>) => _t(`Home.${k}`, p as any) as string;\n const [searchParams] = useSearchParams();\n const router = useRouter();\n const keyboardContext = useContext(KeyboardShortcutsContext);\n\n const callbackUrl = searchParams.get('callbackUrl') ?? '/auth/welcome';\n\n const handleSignUp = async () => {\n router.push(`/auth/connect?callbackUrl=${encodeURIComponent(callbackUrl)}`);\n };\n\n const translations = {\n pageTitle: t('pageTitle'),\n signUpPrompt: t('signUpPrompt'),\n signUpWithGoogle: t('signUpWithGoogle'),\n creatingAccount: t('creatingAccount'),\n approvedDomainsInfo: t('approvedDomainsInfo'),\n termsAgreement: t('termsAgreement'),\n alreadyHaveAccount: t('alreadyHaveAccount'),\n tagline: tHome('tagline'),\n backToHome: t('backToHome'),\n };\n\n return (\n <PageLayout\n Link={RoutingLink}\n routes={routes}\n t={tFooter}\n tNav={tNav}\n tHome={tHome}\n CookiePreferences={CookiePreferences}\n {...(keyboardContext?.openKeyboardHelp && { onOpenKeyboardHelp: keyboardContext.openKeyboardHelp })}\n className=\"semiont-page-layout--auth\"\n showAuthLinks={false}\n >\n <SignUpForm onSignUp={handleSignUp} Link={Link} translations={translations} />\n </PageLayout>\n );\n}\n\nexport default function SignUp() {\n return <SignUpContent />;\n}\n"],"names":["SignUpContent","_t","useTranslation","t","k","p","tFooter","tNav","tHome","searchParams","useSearchParams","router","useRouter","keyboardContext","useContext","KeyboardShortcutsContext","callbackUrl","handleSignUp","translations","jsx","PageLayout","RoutingLink","routes","CookiePreferences","SignUpForm","Link","SignUp"],"mappings":"gbAUA,SAASA,GAAgB,CACvB,KAAM,CAAE,EAAGC,CAAA,EAAOC,EAAA,EACZC,EAAI,CAACC,EAAWC,IAAgCJ,EAAG,cAAcG,CAAC,GAAIC,CAAQ,EAC9EC,EAAU,CAACF,EAAWC,IAAgCJ,EAAG,UAAUG,CAAC,GAAIC,CAAQ,EAChFE,EAAO,CAACH,EAAWC,IAAgCJ,EAAG,cAAcG,CAAC,GAAIC,CAAQ,EACjFG,EAAQ,CAACJ,EAAWC,IAAgCJ,EAAG,QAAQG,CAAC,GAAIC,CAAQ,EAC5E,CAACI,CAAY,EAAIC,EAAA,EACjBC,EAASC,EAAA,EACTC,EAAkBC,EAAAA,WAAWC,CAAwB,EAErDC,EAAcP,EAAa,IAAI,aAAa,GAAK,gBAEjDQ,EAAe,SAAY,CAC/BN,EAAO,KAAK,6BAA6B,mBAAmBK,CAAW,CAAC,EAAE,CAC5E,EAEME,EAAe,CACnB,UAAWf,EAAE,WAAW,EACxB,aAAcA,EAAE,cAAc,EAC9B,iBAAkBA,EAAE,kBAAkB,EACtC,gBAAiBA,EAAE,iBAAiB,EACpC,oBAAqBA,EAAE,qBAAqB,EAC5C,eAAgBA,EAAE,gBAAgB,EAClC,mBAAoBA,EAAE,oBAAoB,EAC1C,QAASK,EAAM,SAAS,EACxB,WAAYL,EAAE,YAAY,CAAA,EAG5B,OACEgB,EAAAA,IAACC,EAAA,CACC,KAAMC,EACN,OAAAC,EACA,EAAGhB,EACH,KAAAC,EACA,MAAAC,EACA,kBAAAe,EACC,IAAIV,GAAA,YAAAA,EAAiB,mBAAoB,CAAE,mBAAoBA,EAAgB,gBAAA,EAChF,UAAU,4BACV,cAAe,GAEf,SAAAM,EAAAA,IAACK,EAAA,CAAW,SAAUP,EAAA,KAAcQ,EAAY,aAAAP,CAAA,CAA4B,CAAA,CAAA,CAGlF,CAEA,SAAwBQ,GAAS,CAC/B,aAAQ1B,EAAA,EAAc,CACxB"}
@@ -0,0 +1,2 @@
1
+ import{r as o}from"./vendor-EnoIVk-c.js";import{u as t}from"./routing-DMdXWYXo.js";import"./query-ATBhtd3K.js";import"./index-DA31r_0s.js";import"./i18n-BYxb14hm.js";function a(){const r=t();return o.useEffect(()=>{r.replace("/know/discover")},[r]),null}export{a as default};
2
+ //# sourceMappingURL=page-iSL5E639.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"page-iSL5E639.js","sources":["../../src/app/[locale]/auth/connect/page.tsx"],"sourcesContent":["import { useEffect } from 'react';\nimport { useRouter } from '@/i18n/routing';\n\n/**\n * Legacy connect page — redirects to /know/discover.\n * Authentication is now handled inline in the Knowledge Base Panel.\n */\nexport default function ConnectPage() {\n const router = useRouter();\n\n useEffect(() => {\n router.replace('/know/discover');\n }, [router]);\n\n return null;\n}\n"],"names":["ConnectPage","router","useRouter","useEffect"],"mappings":"sKAOA,SAAwBA,GAAc,CACpC,MAAMC,EAASC,EAAA,EAEfC,OAAAA,EAAAA,UAAU,IAAM,CACdF,EAAO,QAAQ,gBAAgB,CACjC,EAAG,CAACA,CAAM,CAAC,EAEJ,IACT"}
@@ -0,0 +1,2 @@
1
+ import{j as u}from"./query-ATBhtd3K.js";import{r as n}from"./vendor-EnoIVk-c.js";import{d as g,e as T,f as d,g as h,B as b,T as f}from"./en-IUV4ZXKH-BY1RKeLS.js";import{T as D}from"./ToolbarPanels-rN1MIRTV.js";import{u as x}from"./i18n-BYxb14hm.js";import"./index-DA31r_0s.js";import"./useAuth-yUx5lBP5.js";import"./routing-DMdXWYXo.js";import"./XMarkIcon-6m9KVFaj.js";function k(){const{t:a}=x(),e=(t,p)=>a(`ModerateRecent.${t}`,p),{activePanel:i}=g(),{theme:r,setTheme:s}=T(),{showLineNumbers:c,toggleLineNumbers:o}=d(),m=n.useCallback(({theme:t})=>{s(t)},[s]),l=n.useCallback(()=>{o()},[o]);return h({"settings:theme-changed":m,"settings:line-numbers-toggled":l}),u.jsx(b,{hasDocuments:!1,isLoading:!1,theme:r,showLineNumbers:c,activePanel:i,translations:{pageTitle:e("pageTitle"),pageDescription:e("pageDescription"),sectionTitle:e("sectionTitle"),sectionDescription:e("sectionDescription"),noDocuments:e("noDocuments"),activityWillAppear:e("activityWillAppear"),loading:e("loading")},ToolbarPanels:D,Toolbar:f})}export{k as default};
2
+ //# sourceMappingURL=page-xdXYx3nl.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"page-B9hPrBrN.js","sources":["../../src/app/[locale]/moderate/recent/page.tsx"],"sourcesContent":["import { useCallback } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { Toolbar } from '@semiont/react-ui';\nimport { ToolbarPanels } from '@/components/toolbar/ToolbarPanels';\nimport { useTheme, usePanelBrowse, useLineNumbers, useEventSubscriptions } from '@semiont/react-ui';\nimport { RecentDocumentsPage } from '@semiont/react-ui';\n\n// Authentication is handled by middleware (proxy.ts)\n// Only authenticated moderators/admins can reach this page\n\nexport default function RecentDocumentsPageWrapper() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`ModerateRecent.${k}`, p as any) as string;\n\n // Toolbar and settings state\n const { activePanel } = usePanelBrowse();\n const { theme, setTheme } = useTheme();\n const { showLineNumbers, toggleLineNumbers } = useLineNumbers();\n\n const handleThemeChanged = useCallback(({ theme }: { theme: 'light' | 'dark' | 'system' }) => {\n setTheme(theme);\n }, [setTheme]);\n\n const handleLineNumbersToggled = useCallback(() => {\n toggleLineNumbers();\n }, [toggleLineNumbers]);\n\n useEventSubscriptions({\n 'settings:theme-changed': handleThemeChanged,\n 'settings:line-numbers-toggled': handleLineNumbersToggled,\n });\n\n return (\n <RecentDocumentsPage\n hasDocuments={false}\n isLoading={false}\n theme={theme}\n showLineNumbers={showLineNumbers}\n activePanel={activePanel}\n translations={{\n pageTitle: t('pageTitle'),\n pageDescription: t('pageDescription'),\n sectionTitle: t('sectionTitle'),\n sectionDescription: t('sectionDescription'),\n noDocuments: t('noDocuments'),\n activityWillAppear: t('activityWillAppear'),\n loading: t('loading'),\n }}\n ToolbarPanels={ToolbarPanels}\n Toolbar={Toolbar}\n />\n );\n}\n"],"names":["RecentDocumentsPageWrapper","_t","useTranslation","t","k","activePanel","usePanelBrowse","theme","setTheme","useTheme","showLineNumbers","toggleLineNumbers","useLineNumbers","handleThemeChanged","useCallback","handleLineNumbersToggled","useEventSubscriptions","jsx","RecentDocumentsPage","ToolbarPanels","Toolbar"],"mappings":"6bAUA,SAAwBA,GAA6B,CACnD,KAAM,CAAE,EAAGC,CAAA,EAAOC,EAAA,EACZC,EAAI,CAACC,EAAW,IAAgCH,EAAG,kBAAkBG,CAAC,GAAI,CAAQ,EAGlF,CAAE,YAAAC,CAAA,EAAgBC,EAAA,EAClB,CAAE,MAAAC,EAAO,SAAAC,CAAA,EAAaC,EAAA,EACtB,CAAE,gBAAAC,EAAiB,kBAAAC,CAAA,EAAsBC,EAAA,EAEzCC,EAAqBC,EAAAA,YAAY,CAAC,CAAE,MAAAP,KAAoD,CAC5FC,EAASD,CAAK,CAChB,EAAG,CAACC,CAAQ,CAAC,EAEPO,EAA2BD,EAAAA,YAAY,IAAM,CACjDH,EAAA,CACF,EAAG,CAACA,CAAiB,CAAC,EAEtB,OAAAK,EAAsB,CACpB,yBAA0BH,EAC1B,gCAAiCE,CAAA,CAClC,EAGCE,EAAAA,IAACC,EAAA,CACC,aAAc,GACd,UAAW,GACX,MAAAX,EACA,gBAAAG,EACA,YAAAL,EACA,aAAc,CACZ,UAAWF,EAAE,WAAW,EACxB,gBAAiBA,EAAE,iBAAiB,EACpC,aAAcA,EAAE,cAAc,EAC9B,mBAAoBA,EAAE,oBAAoB,EAC1C,YAAaA,EAAE,aAAa,EAC5B,mBAAoBA,EAAE,oBAAoB,EAC1C,QAASA,EAAE,SAAS,CAAA,EAEtB,cAAAgB,EACA,QAAAC,CAAA,CAAA,CAGN"}
1
+ {"version":3,"file":"page-xdXYx3nl.js","sources":["../../src/app/[locale]/moderate/recent/page.tsx"],"sourcesContent":["import { useCallback } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { Toolbar } from '@semiont/react-ui';\nimport { ToolbarPanels } from '@/components/toolbar/ToolbarPanels';\nimport { useTheme, usePanelBrowse, useLineNumbers, useEventSubscriptions } from '@semiont/react-ui';\nimport { RecentDocumentsPage } from '@semiont/react-ui';\n\n// Authentication is handled by middleware (proxy.ts)\n// Only authenticated moderators/admins can reach this page\n\nexport default function RecentDocumentsPageWrapper() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`ModerateRecent.${k}`, p as any) as string;\n\n // Toolbar and settings state\n const { activePanel } = usePanelBrowse();\n const { theme, setTheme } = useTheme();\n const { showLineNumbers, toggleLineNumbers } = useLineNumbers();\n\n const handleThemeChanged = useCallback(({ theme }: { theme: 'light' | 'dark' | 'system' }) => {\n setTheme(theme);\n }, [setTheme]);\n\n const handleLineNumbersToggled = useCallback(() => {\n toggleLineNumbers();\n }, [toggleLineNumbers]);\n\n useEventSubscriptions({\n 'settings:theme-changed': handleThemeChanged,\n 'settings:line-numbers-toggled': handleLineNumbersToggled,\n });\n\n return (\n <RecentDocumentsPage\n hasDocuments={false}\n isLoading={false}\n theme={theme}\n showLineNumbers={showLineNumbers}\n activePanel={activePanel}\n translations={{\n pageTitle: t('pageTitle'),\n pageDescription: t('pageDescription'),\n sectionTitle: t('sectionTitle'),\n sectionDescription: t('sectionDescription'),\n noDocuments: t('noDocuments'),\n activityWillAppear: t('activityWillAppear'),\n loading: t('loading'),\n }}\n ToolbarPanels={ToolbarPanels}\n Toolbar={Toolbar}\n />\n );\n}\n"],"names":["RecentDocumentsPageWrapper","_t","useTranslation","t","k","activePanel","usePanelBrowse","theme","setTheme","useTheme","showLineNumbers","toggleLineNumbers","useLineNumbers","handleThemeChanged","useCallback","handleLineNumbersToggled","useEventSubscriptions","jsx","RecentDocumentsPage","ToolbarPanels","Toolbar"],"mappings":"iXAUA,SAAwBA,GAA6B,CACnD,KAAM,CAAE,EAAGC,CAAA,EAAOC,EAAA,EACZC,EAAI,CAACC,EAAW,IAAgCH,EAAG,kBAAkBG,CAAC,GAAI,CAAQ,EAGlF,CAAE,YAAAC,CAAA,EAAgBC,EAAA,EAClB,CAAE,MAAAC,EAAO,SAAAC,CAAA,EAAaC,EAAA,EACtB,CAAE,gBAAAC,EAAiB,kBAAAC,CAAA,EAAsBC,EAAA,EAEzCC,EAAqBC,EAAAA,YAAY,CAAC,CAAE,MAAAP,KAAoD,CAC5FC,EAASD,CAAK,CAChB,EAAG,CAACC,CAAQ,CAAC,EAEPO,EAA2BD,EAAAA,YAAY,IAAM,CACjDH,EAAA,CACF,EAAG,CAACA,CAAiB,CAAC,EAEtB,OAAAK,EAAsB,CACpB,yBAA0BH,EAC1B,gCAAiCE,CAAA,CAClC,EAGCE,EAAAA,IAACC,EAAA,CACC,aAAc,GACd,UAAW,GACX,MAAAX,EACA,gBAAAG,EACA,YAAAL,EACA,aAAc,CACZ,UAAWF,EAAE,WAAW,EACxB,gBAAiBA,EAAE,iBAAiB,EACpC,aAAcA,EAAE,cAAc,EAC9B,mBAAoBA,EAAE,oBAAoB,EAC1C,YAAaA,EAAE,aAAa,EAC5B,mBAAoBA,EAAE,oBAAoB,EAC1C,QAASA,EAAE,SAAS,CAAA,EAEtB,cAAAgB,EACA,QAAAC,CAAA,CAAA,CAGN"}
@@ -1,2 +1,2 @@
1
- import{j as l}from"./query-ATBhtd3K.js";import{r as c}from"./vendor-EnoIVk-c.js";import{a as m}from"./routing-BLuuVVPN.js";import{ag as C,ah as S,ai as b,aj as O}from"./en-IUV4ZXKH-eHunUM2g.js";import{u as v}from"./i18n-BYxb14hm.js";function E({isOpen:e,onClose:t}){const o=m(),{t:n}=v(),s=(r,a)=>n(`Search.${r}`,a),i=(r,a)=>{r==="resource"?o.push(`/know/resource/${encodeURIComponent(a)}`):o.push(`/know/entity/${a}`)};return l.jsx(C,{isOpen:e,onClose:t,onNavigate:i,translations:{placeholder:s("placeholder"),searching:s("searching"),noResults:s("noResults"),startTyping:s("startTyping"),navigate:s("navigate"),select:s("select"),close:s("close"),enter:s("enter"),esc:s("esc")}})}const T=c.createContext(null);function U({children:e}){const t=m(),[o,n]=c.useState(!1),[s,i]=c.useState(!1),[r,a]=c.useState([]),u=c.useCallback(()=>{n(!0)},[]),f=c.useCallback(()=>{i(!0)},[]),h=c.useCallback(()=>{n(!1),i(!1),r.forEach(w=>w()),a([])},[r]);S([{key:"k",ctrlOrCmd:!0,handler:()=>{u()},description:"Open global search"},{key:"n",ctrlOrCmd:!0,handler:()=>{t.push("/know/compose")},description:"Create new resource"},{key:"/",handler:()=>{u()},description:"Open global search (alternative)"},{key:"?",shift:!0,handler:()=>{f()},description:"Show keyboard shortcuts help"}]),b("Escape",h,300);const k={openGlobalSearch:u,openKeyboardHelp:f,closeAllOverlays:h};return l.jsxs(T.Provider,{value:k,children:[e,o&&l.jsx(E,{isOpen:o,onClose:()=>n(!1)}),s&&l.jsx(O,{isOpen:s,onClose:()=>i(!1)})]})}const x=[{id:"necessary",name:"Strictly Necessary",description:"These cookies are essential for the website to function properly. They enable core functionality such as security, network management, and accessibility.",required:!0,cookies:["semiont-token","consent-preferences"]},{id:"analytics",name:"Analytics",description:"These cookies help us understand how visitors interact with our website by collecting and reporting information anonymously.",required:!1,cookies:["_ga","_ga_*","_gid","_gat","lighthouse-*"]},{id:"marketing",name:"Marketing",description:"These cookies are used to track visitors across websites to display relevant advertisements and measure campaign effectiveness.",required:!1,cookies:["_fbp","_fbc","fr","ads-*"]},{id:"preferences",name:"Preferences",description:"These cookies remember your choices and preferences to provide a more personalized experience.",required:!1,cookies:["theme-preference","language-preference","ui-settings"]}],p="1.0",g="semiont-cookie-consent",_={necessary:!0,analytics:!1,marketing:!1,preferences:!1,timestamp:new Date().toISOString(),version:p},A=e=>{typeof window>"u"||x.forEach(t=>{if(t.required)return;e[t.id]||t.cookies.forEach(n=>{if(n.includes("*")){const s=n.replace("*","");document.cookie.split(";").forEach(i=>{var a;const r=(a=i.split("=")[0])==null?void 0:a.trim();r&&r.startsWith(s)&&d(r)})}else d(n)})})},d=e=>{document.cookie=`${e}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/`,document.cookie=`${e}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain=${window.location.hostname}`;const t=window.location.hostname.split(".").slice(-2).join(".");document.cookie=`${e}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain=.${t}`},I=()=>{if(typeof window>"u")return null;try{const e=localStorage.getItem(g);if(!e)return null;const t=JSON.parse(e);return t.version!==p?null:t}catch(e){return console.warn("Failed to parse cookie consent:",e),null}},j=e=>{if(typeof window>"u")return;const t={..._,...e,necessary:!0,timestamp:new Date().toISOString(),version:p};try{localStorage.setItem(g,JSON.stringify(t)),A(t),window.dispatchEvent(new CustomEvent("cookieConsentChanged",{detail:t}))}catch(o){console.error("Failed to save cookie consent:",o)}},D=()=>{const e=I();if(!e)return!1;const t=new Date(e.timestamp),o=new Date;return o.setMonth(o.getMonth()-13),t>o},G=()=>typeof window>"u"?!1:!D(),y=async()=>{try{const e=Intl.DateTimeFormat().resolvedOptions().timeZone;return e.includes("Europe/")?"EU":e.includes("America/Los_Angeles")||e.includes("America/Vancouver")?"CA":e.includes("America/")?"US":"OTHER"}catch{return"OTHER"}},H=async()=>await y()==="CA",P=async()=>await y()==="EU",q=()=>{if(typeof window>"u")return{};const e={};document.cookie.split(";").forEach(t=>{const[o,n]=t.trim().split("=");o&&n&&(e[`cookie_${o}`]=decodeURIComponent(n))});for(let t=0;t<localStorage.length;t++){const o=localStorage.key(t);o&&(e[`localStorage_${o}`]=localStorage.getItem(o)||"")}for(let t=0;t<sessionStorage.length;t++){const o=sessionStorage.key(t);o&&(e[`sessionStorage_${o}`]=sessionStorage.getItem(o)||"")}return e},J=()=>{typeof window>"u"||(localStorage.clear(),sessionStorage.clear(),document.cookie.split(";").forEach(e=>{var o;const t=(o=e.split("=")[0])==null?void 0:o.trim();t&&d(t)}),window.location.reload())};export{x as C,T as K,U as a,G as b,H as c,J as d,q as e,I as g,P as i,j as s};
2
- //# sourceMappingURL=privacy-W9SxWfL5.js.map
1
+ import{j as l}from"./query-ATBhtd3K.js";import{r as c}from"./vendor-EnoIVk-c.js";import{u as m}from"./routing-DMdXWYXo.js";import{a7 as C,a8 as S,a9 as b,aa as O}from"./en-IUV4ZXKH-BY1RKeLS.js";import{u as v}from"./i18n-BYxb14hm.js";function E({isOpen:e,onClose:t}){const o=m(),{t:n}=v(),s=(r,a)=>n(`Search.${r}`,a),i=(r,a)=>{r==="resource"?o.push(`/know/resource/${encodeURIComponent(a)}`):o.push(`/know/entity/${a}`)};return l.jsx(C,{isOpen:e,onClose:t,onNavigate:i,translations:{placeholder:s("placeholder"),searching:s("searching"),noResults:s("noResults"),startTyping:s("startTyping"),navigate:s("navigate"),select:s("select"),close:s("close"),enter:s("enter"),esc:s("esc")}})}const T=c.createContext(null);function U({children:e}){const t=m(),[o,n]=c.useState(!1),[s,i]=c.useState(!1),[r,a]=c.useState([]),u=c.useCallback(()=>{n(!0)},[]),f=c.useCallback(()=>{i(!0)},[]),h=c.useCallback(()=>{n(!1),i(!1),r.forEach(w=>w()),a([])},[r]);S([{key:"k",ctrlOrCmd:!0,handler:()=>{u()},description:"Open global search"},{key:"n",ctrlOrCmd:!0,handler:()=>{t.push("/know/compose")},description:"Create new resource"},{key:"/",handler:()=>{u()},description:"Open global search (alternative)"},{key:"?",shift:!0,handler:()=>{f()},description:"Show keyboard shortcuts help"}]),b("Escape",h,300);const k={openGlobalSearch:u,openKeyboardHelp:f,closeAllOverlays:h};return l.jsxs(T.Provider,{value:k,children:[e,o&&l.jsx(E,{isOpen:o,onClose:()=>n(!1)}),s&&l.jsx(O,{isOpen:s,onClose:()=>i(!1)})]})}const x=[{id:"necessary",name:"Strictly Necessary",description:"These cookies are essential for the website to function properly. They enable core functionality such as security, network management, and accessibility.",required:!0,cookies:["semiont-token","consent-preferences"]},{id:"analytics",name:"Analytics",description:"These cookies help us understand how visitors interact with our website by collecting and reporting information anonymously.",required:!1,cookies:["_ga","_ga_*","_gid","_gat","lighthouse-*"]},{id:"marketing",name:"Marketing",description:"These cookies are used to track visitors across websites to display relevant advertisements and measure campaign effectiveness.",required:!1,cookies:["_fbp","_fbc","fr","ads-*"]},{id:"preferences",name:"Preferences",description:"These cookies remember your choices and preferences to provide a more personalized experience.",required:!1,cookies:["theme-preference","language-preference","ui-settings"]}],p="1.0",g="semiont-cookie-consent",_={necessary:!0,analytics:!1,marketing:!1,preferences:!1,timestamp:new Date().toISOString(),version:p},A=e=>{typeof window>"u"||x.forEach(t=>{if(t.required)return;e[t.id]||t.cookies.forEach(n=>{if(n.includes("*")){const s=n.replace("*","");document.cookie.split(";").forEach(i=>{var a;const r=(a=i.split("=")[0])==null?void 0:a.trim();r&&r.startsWith(s)&&d(r)})}else d(n)})})},d=e=>{document.cookie=`${e}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/`,document.cookie=`${e}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain=${window.location.hostname}`;const t=window.location.hostname.split(".").slice(-2).join(".");document.cookie=`${e}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain=.${t}`},I=()=>{if(typeof window>"u")return null;try{const e=localStorage.getItem(g);if(!e)return null;const t=JSON.parse(e);return t.version!==p?null:t}catch(e){return console.warn("Failed to parse cookie consent:",e),null}},j=e=>{if(typeof window>"u")return;const t={..._,...e,necessary:!0,timestamp:new Date().toISOString(),version:p};try{localStorage.setItem(g,JSON.stringify(t)),A(t),window.dispatchEvent(new CustomEvent("cookieConsentChanged",{detail:t}))}catch(o){console.error("Failed to save cookie consent:",o)}},D=()=>{const e=I();if(!e)return!1;const t=new Date(e.timestamp),o=new Date;return o.setMonth(o.getMonth()-13),t>o},G=()=>typeof window>"u"?!1:!D(),y=async()=>{try{const e=Intl.DateTimeFormat().resolvedOptions().timeZone;return e.includes("Europe/")?"EU":e.includes("America/Los_Angeles")||e.includes("America/Vancouver")?"CA":e.includes("America/")?"US":"OTHER"}catch{return"OTHER"}},H=async()=>await y()==="CA",P=async()=>await y()==="EU",q=()=>{if(typeof window>"u")return{};const e={};document.cookie.split(";").forEach(t=>{const[o,n]=t.trim().split("=");o&&n&&(e[`cookie_${o}`]=decodeURIComponent(n))});for(let t=0;t<localStorage.length;t++){const o=localStorage.key(t);o&&(e[`localStorage_${o}`]=localStorage.getItem(o)||"")}for(let t=0;t<sessionStorage.length;t++){const o=sessionStorage.key(t);o&&(e[`sessionStorage_${o}`]=sessionStorage.getItem(o)||"")}return e},J=()=>{typeof window>"u"||(localStorage.clear(),sessionStorage.clear(),document.cookie.split(";").forEach(e=>{var o;const t=(o=e.split("=")[0])==null?void 0:o.trim();t&&d(t)}),window.location.reload())};export{x as C,T as K,U as a,G as b,H as c,J as d,q as e,I as g,P as i,j as s};
2
+ //# sourceMappingURL=privacy-DO1oxJpM.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"privacy-W9SxWfL5.js","sources":["../../src/components/modals/GlobalSearchModal.tsx","../../src/contexts/KeyboardShortcutsContext.tsx","../../src/lib/cookies/constants.ts","../../src/lib/cookies/cleanup.ts","../../src/lib/cookies/consent.ts","../../src/lib/cookies/privacy.ts"],"sourcesContent":["import React from 'react';\nimport { useRouter } from '@/i18n/routing';\nimport { SearchModal } from '@semiont/react-ui';\nimport { useTranslation } from 'react-i18next';\n\ninterface GlobalSearchModalProps {\n isOpen: boolean;\n onClose: () => void;\n}\n\nexport function GlobalSearchModal({ isOpen, onClose }: GlobalSearchModalProps) {\n const router = useRouter();\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`Search.${k}`, p as any) as string;\n\n const handleNavigate = (type: 'resource' | 'entity', id: string) => {\n if (type === 'resource') {\n router.push(`/know/resource/${encodeURIComponent(id)}`);\n } else {\n router.push(`/know/entity/${id}`);\n }\n };\n\n return (\n <SearchModal\n isOpen={isOpen}\n onClose={onClose}\n onNavigate={handleNavigate}\n translations={{\n placeholder: t('placeholder'),\n searching: t('searching'),\n noResults: t('noResults'),\n startTyping: t('startTyping'),\n navigate: t('navigate'),\n select: t('select'),\n close: t('close'),\n enter: t('enter'),\n esc: t('esc'),\n }}\n />\n );\n}","import React, { createContext, useContext, useState, useCallback } from 'react';\nimport { useRouter } from '@/i18n/routing';\nimport { useKeyboardShortcuts, useDoubleKeyPress, KeyboardShortcutsHelpModal } from '@semiont/react-ui';\nimport { GlobalSearchModal } from '../components/modals/GlobalSearchModal';\n\ninterface KeyboardShortcutsContextType {\n openGlobalSearch: () => void;\n openKeyboardHelp: () => void;\n closeAllOverlays: () => void;\n}\n\nexport const KeyboardShortcutsContext = createContext<KeyboardShortcutsContextType | null>(null);\n\nexport function useKeyboardShortcutsContext() {\n const context = useContext(KeyboardShortcutsContext);\n if (!context) {\n throw new Error('useKeyboardShortcutsContext must be used within KeyboardShortcutsProvider');\n }\n return context;\n}\n\ninterface KeyboardShortcutsProviderProps {\n children: React.ReactNode;\n}\n\nexport function KeyboardShortcutsProvider({ children }: KeyboardShortcutsProviderProps) {\n const router = useRouter();\n const [isSearchOpen, setIsSearchOpen] = useState(false);\n const [isHelpOpen, setIsHelpOpen] = useState(false);\n const [overlayCloseCallbacks, setOverlayCloseCallbacks] = useState<(() => void)[]>([]);\n\n // Open global search\n const openGlobalSearch = useCallback(() => {\n setIsSearchOpen(true);\n }, []);\n\n // Open keyboard help\n const openKeyboardHelp = useCallback(() => {\n setIsHelpOpen(true);\n }, []);\n\n // Close all overlays\n const closeAllOverlays = useCallback(() => {\n // Close all modals\n setIsSearchOpen(false);\n setIsHelpOpen(false);\n\n // Call all registered overlay close callbacks\n overlayCloseCallbacks.forEach(callback => callback());\n\n // Clear the callbacks\n setOverlayCloseCallbacks([]);\n }, [overlayCloseCallbacks]);\n\n // Register global keyboard shortcuts\n useKeyboardShortcuts([\n {\n key: 'k',\n ctrlOrCmd: true,\n handler: () => {\n openGlobalSearch();\n },\n description: 'Open global search'\n },\n {\n key: 'n',\n ctrlOrCmd: true,\n handler: () => {\n // Navigate to compose page to create new resource\n router.push('/know/compose');\n },\n description: 'Create new resource'\n },\n {\n key: '/',\n handler: () => {\n // Alternative search trigger (like GitHub)\n openGlobalSearch();\n },\n description: 'Open global search (alternative)'\n },\n {\n key: '?',\n shift: true,\n handler: () => {\n // Open keyboard shortcuts help\n openKeyboardHelp();\n },\n description: 'Show keyboard shortcuts help'\n }\n ]);\n\n // Double Escape to close all overlays\n useDoubleKeyPress('Escape', closeAllOverlays, 300);\n\n const contextValue: KeyboardShortcutsContextType = {\n openGlobalSearch,\n openKeyboardHelp,\n closeAllOverlays\n };\n\n return (\n <KeyboardShortcutsContext.Provider value={contextValue}>\n {children}\n {isSearchOpen && (\n <GlobalSearchModal\n isOpen={isSearchOpen}\n onClose={() => setIsSearchOpen(false)}\n />\n )}\n {isHelpOpen && (\n <KeyboardShortcutsHelpModal\n isOpen={isHelpOpen}\n onClose={() => setIsHelpOpen(false)}\n />\n )}\n </KeyboardShortcutsContext.Provider>\n );\n}","import type { CookieCategory, CookieConsent } from './types';\n\n// Cookie categories with descriptions\nexport const COOKIE_CATEGORIES: CookieCategory[] = [\n {\n id: 'necessary',\n name: 'Strictly Necessary',\n description: 'These cookies are essential for the website to function properly. They enable core functionality such as security, network management, and accessibility.',\n required: true,\n cookies: ['semiont-token', 'consent-preferences']\n },\n {\n id: 'analytics',\n name: 'Analytics',\n description: 'These cookies help us understand how visitors interact with our website by collecting and reporting information anonymously.',\n required: false,\n cookies: ['_ga', '_ga_*', '_gid', '_gat', 'lighthouse-*']\n },\n {\n id: 'marketing',\n name: 'Marketing',\n description: 'These cookies are used to track visitors across websites to display relevant advertisements and measure campaign effectiveness.',\n required: false,\n cookies: ['_fbp', '_fbc', 'fr', 'ads-*']\n },\n {\n id: 'preferences',\n name: 'Preferences',\n description: 'These cookies remember your choices and preferences to provide a more personalized experience.',\n required: false,\n cookies: ['theme-preference', 'language-preference', 'ui-settings']\n }\n];\n\n// Current consent version (increment when privacy policy changes)\nexport const CONSENT_VERSION = '1.0';\n\n// Cookie names\nexport const CONSENT_COOKIE_NAME = 'semiont-cookie-consent';\nexport const PREFERENCES_COOKIE_NAME = 'semiont-cookie-preferences';\n\n// Default consent state\nexport const DEFAULT_CONSENT: CookieConsent = {\n necessary: true, // Always true, required for functionality\n analytics: false,\n marketing: false,\n preferences: false,\n timestamp: new Date().toISOString(),\n version: CONSENT_VERSION\n};\n","import type { CookieConsent } from './types';\nimport { COOKIE_CATEGORIES } from './constants';\n\n// Clean up cookies based on consent\nexport const cleanupCookies = (consent: CookieConsent): void => {\n if (typeof window === 'undefined') return;\n\n COOKIE_CATEGORIES.forEach(category => {\n if (category.required) return; // Never clean up required cookies\n\n const hasConsent = consent[category.id];\n if (!hasConsent) {\n // Remove cookies for this category\n category.cookies.forEach(cookieName => {\n if (cookieName.includes('*')) {\n // Handle wildcard cookies\n const prefix = cookieName.replace('*', '');\n document.cookie.split(';').forEach(cookie => {\n const name = cookie.split('=')[0]?.trim();\n if (name && name.startsWith(prefix)) {\n deleteCookie(name);\n }\n });\n } else {\n deleteCookie(cookieName);\n }\n });\n }\n });\n};\n\n// Delete a specific cookie\nexport const deleteCookie = (name: string): void => {\n // Delete for current domain\n document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/`;\n // Delete for parent domain\n document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain=${window.location.hostname}`;\n // Delete for root domain\n const rootDomain = window.location.hostname.split('.').slice(-2).join('.');\n document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain=.${rootDomain}`;\n};\n","import type { CookieConsent } from './types';\nimport { CONSENT_COOKIE_NAME, CONSENT_VERSION, DEFAULT_CONSENT } from './constants';\nimport { cleanupCookies } from './cleanup';\n\nexport const getCookieConsent = (): CookieConsent | null => {\n if (typeof window === 'undefined') return null;\n\n try {\n const consent = localStorage.getItem(CONSENT_COOKIE_NAME);\n if (!consent) return null;\n\n const parsed = JSON.parse(consent) as CookieConsent;\n\n // Check if consent is for current version\n if (parsed.version !== CONSENT_VERSION) {\n return null; // Force re-consent for new version\n }\n\n return parsed;\n } catch (error) {\n console.warn('Failed to parse cookie consent:', error);\n return null;\n }\n};\n\nexport const setCookieConsent = (consent: Partial<CookieConsent>): void => {\n if (typeof window === 'undefined') return;\n\n const fullConsent: CookieConsent = {\n ...DEFAULT_CONSENT,\n ...consent,\n necessary: true, // Always true\n timestamp: new Date().toISOString(),\n version: CONSENT_VERSION\n };\n\n try {\n localStorage.setItem(CONSENT_COOKIE_NAME, JSON.stringify(fullConsent));\n\n // Clean up cookies based on consent\n cleanupCookies(fullConsent);\n\n // Dispatch custom event for components to react to consent changes\n window.dispatchEvent(new CustomEvent('cookieConsentChanged', {\n detail: fullConsent\n }));\n } catch (error) {\n console.error('Failed to save cookie consent:', error);\n }\n};\n\nexport const hasValidConsent = (): boolean => {\n const consent = getCookieConsent();\n if (!consent) return false;\n\n // Check if consent is less than 13 months old (GDPR requirement)\n const consentDate = new Date(consent.timestamp);\n const thirteenMonthsAgo = new Date();\n thirteenMonthsAgo.setMonth(thirteenMonthsAgo.getMonth() - 13);\n\n return consentDate > thirteenMonthsAgo;\n};\n\nexport const shouldShowBanner = (): boolean => {\n if (typeof window === 'undefined') return false;\n return !hasValidConsent();\n};\n","import { deleteCookie } from './cleanup';\n\n// Get user's location for CCPA vs GDPR detection (simplified)\nexport const getUserLocation = async (): Promise<'EU' | 'CA' | 'US' | 'OTHER'> => {\n try {\n // In a real implementation, you'd use a geolocation service\n // For now, we'll detect based on timezone as a rough approximation\n const timezone = Intl.DateTimeFormat().resolvedOptions().timeZone;\n\n if (timezone.includes('Europe/')) return 'EU';\n if (timezone.includes('America/Los_Angeles') || timezone.includes('America/Vancouver')) return 'CA';\n if (timezone.includes('America/')) return 'US';\n\n return 'OTHER';\n } catch {\n return 'OTHER';\n }\n};\n\n// Check if CCPA applies (California residents)\nexport const isCCPAApplicable = async (): Promise<boolean> => {\n const location = await getUserLocation();\n return location === 'CA';\n};\n\n// Check if GDPR applies (EU residents)\nexport const isGDPRApplicable = async (): Promise<boolean> => {\n const location = await getUserLocation();\n return location === 'EU';\n};\n\n// Export all cookies currently set\nexport const exportUserData = (): Record<string, string> => {\n if (typeof window === 'undefined') return {};\n\n const data: Record<string, string> = {};\n\n // Get all cookies\n document.cookie.split(';').forEach(cookie => {\n const [name, value] = cookie.trim().split('=');\n if (name && value) {\n data[`cookie_${name}`] = decodeURIComponent(value);\n }\n });\n\n // Get localStorage data\n for (let i = 0; i < localStorage.length; i++) {\n const key = localStorage.key(i);\n if (key) {\n data[`localStorage_${key}`] = localStorage.getItem(key) || '';\n }\n }\n\n // Get sessionStorage data\n for (let i = 0; i < sessionStorage.length; i++) {\n const key = sessionStorage.key(i);\n if (key) {\n data[`sessionStorage_${key}`] = sessionStorage.getItem(key) || '';\n }\n }\n\n return data;\n};\n\n// Delete all user data (GDPR right to be forgotten)\nexport const deleteAllUserData = (): void => {\n if (typeof window === 'undefined') return;\n\n // Clear all localStorage\n localStorage.clear();\n\n // Clear all sessionStorage\n sessionStorage.clear();\n\n // Delete all cookies\n document.cookie.split(';').forEach(cookie => {\n const name = cookie.split('=')[0]?.trim();\n if (name) {\n deleteCookie(name);\n }\n });\n\n // Reload page to ensure clean state\n window.location.reload();\n};\n"],"names":["GlobalSearchModal","isOpen","onClose","router","useRouter","_t","useTranslation","t","k","p","handleNavigate","type","id","jsx","SearchModal","KeyboardShortcutsContext","createContext","KeyboardShortcutsProvider","children","isSearchOpen","setIsSearchOpen","useState","isHelpOpen","setIsHelpOpen","overlayCloseCallbacks","setOverlayCloseCallbacks","openGlobalSearch","useCallback","openKeyboardHelp","closeAllOverlays","callback","useKeyboardShortcuts","useDoubleKeyPress","contextValue","jsxs","KeyboardShortcutsHelpModal","COOKIE_CATEGORIES","CONSENT_VERSION","CONSENT_COOKIE_NAME","DEFAULT_CONSENT","cleanupCookies","consent","category","cookieName","prefix","cookie","name","_a","deleteCookie","rootDomain","getCookieConsent","parsed","error","setCookieConsent","fullConsent","hasValidConsent","consentDate","thirteenMonthsAgo","shouldShowBanner","getUserLocation","timezone","isCCPAApplicable","isGDPRApplicable","exportUserData","data","value","i","key","deleteAllUserData"],"mappings":"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"}
1
+ {"version":3,"file":"privacy-DO1oxJpM.js","sources":["../../src/components/modals/GlobalSearchModal.tsx","../../src/contexts/KeyboardShortcutsContext.tsx","../../src/lib/cookies/constants.ts","../../src/lib/cookies/cleanup.ts","../../src/lib/cookies/consent.ts","../../src/lib/cookies/privacy.ts"],"sourcesContent":["import React from 'react';\nimport { useRouter } from '@/i18n/routing';\nimport { SearchModal } from '@semiont/react-ui';\nimport { useTranslation } from 'react-i18next';\n\ninterface GlobalSearchModalProps {\n isOpen: boolean;\n onClose: () => void;\n}\n\nexport function GlobalSearchModal({ isOpen, onClose }: GlobalSearchModalProps) {\n const router = useRouter();\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`Search.${k}`, p as any) as string;\n\n const handleNavigate = (type: 'resource' | 'entity', id: string) => {\n if (type === 'resource') {\n router.push(`/know/resource/${encodeURIComponent(id)}`);\n } else {\n router.push(`/know/entity/${id}`);\n }\n };\n\n return (\n <SearchModal\n isOpen={isOpen}\n onClose={onClose}\n onNavigate={handleNavigate}\n translations={{\n placeholder: t('placeholder'),\n searching: t('searching'),\n noResults: t('noResults'),\n startTyping: t('startTyping'),\n navigate: t('navigate'),\n select: t('select'),\n close: t('close'),\n enter: t('enter'),\n esc: t('esc'),\n }}\n />\n );\n}","import React, { createContext, useContext, useState, useCallback } from 'react';\nimport { useRouter } from '@/i18n/routing';\nimport { useKeyboardShortcuts, useDoubleKeyPress, KeyboardShortcutsHelpModal } from '@semiont/react-ui';\nimport { GlobalSearchModal } from '../components/modals/GlobalSearchModal';\n\ninterface KeyboardShortcutsContextType {\n openGlobalSearch: () => void;\n openKeyboardHelp: () => void;\n closeAllOverlays: () => void;\n}\n\nexport const KeyboardShortcutsContext = createContext<KeyboardShortcutsContextType | null>(null);\n\nexport function useKeyboardShortcutsContext() {\n const context = useContext(KeyboardShortcutsContext);\n if (!context) {\n throw new Error('useKeyboardShortcutsContext must be used within KeyboardShortcutsProvider');\n }\n return context;\n}\n\ninterface KeyboardShortcutsProviderProps {\n children: React.ReactNode;\n}\n\nexport function KeyboardShortcutsProvider({ children }: KeyboardShortcutsProviderProps) {\n const router = useRouter();\n const [isSearchOpen, setIsSearchOpen] = useState(false);\n const [isHelpOpen, setIsHelpOpen] = useState(false);\n const [overlayCloseCallbacks, setOverlayCloseCallbacks] = useState<(() => void)[]>([]);\n\n // Open global search\n const openGlobalSearch = useCallback(() => {\n setIsSearchOpen(true);\n }, []);\n\n // Open keyboard help\n const openKeyboardHelp = useCallback(() => {\n setIsHelpOpen(true);\n }, []);\n\n // Close all overlays\n const closeAllOverlays = useCallback(() => {\n // Close all modals\n setIsSearchOpen(false);\n setIsHelpOpen(false);\n\n // Call all registered overlay close callbacks\n overlayCloseCallbacks.forEach(callback => callback());\n\n // Clear the callbacks\n setOverlayCloseCallbacks([]);\n }, [overlayCloseCallbacks]);\n\n // Register global keyboard shortcuts\n useKeyboardShortcuts([\n {\n key: 'k',\n ctrlOrCmd: true,\n handler: () => {\n openGlobalSearch();\n },\n description: 'Open global search'\n },\n {\n key: 'n',\n ctrlOrCmd: true,\n handler: () => {\n // Navigate to compose page to create new resource\n router.push('/know/compose');\n },\n description: 'Create new resource'\n },\n {\n key: '/',\n handler: () => {\n // Alternative search trigger (like GitHub)\n openGlobalSearch();\n },\n description: 'Open global search (alternative)'\n },\n {\n key: '?',\n shift: true,\n handler: () => {\n // Open keyboard shortcuts help\n openKeyboardHelp();\n },\n description: 'Show keyboard shortcuts help'\n }\n ]);\n\n // Double Escape to close all overlays\n useDoubleKeyPress('Escape', closeAllOverlays, 300);\n\n const contextValue: KeyboardShortcutsContextType = {\n openGlobalSearch,\n openKeyboardHelp,\n closeAllOverlays\n };\n\n return (\n <KeyboardShortcutsContext.Provider value={contextValue}>\n {children}\n {isSearchOpen && (\n <GlobalSearchModal\n isOpen={isSearchOpen}\n onClose={() => setIsSearchOpen(false)}\n />\n )}\n {isHelpOpen && (\n <KeyboardShortcutsHelpModal\n isOpen={isHelpOpen}\n onClose={() => setIsHelpOpen(false)}\n />\n )}\n </KeyboardShortcutsContext.Provider>\n );\n}","import type { CookieCategory, CookieConsent } from './types';\n\n// Cookie categories with descriptions\nexport const COOKIE_CATEGORIES: CookieCategory[] = [\n {\n id: 'necessary',\n name: 'Strictly Necessary',\n description: 'These cookies are essential for the website to function properly. They enable core functionality such as security, network management, and accessibility.',\n required: true,\n cookies: ['semiont-token', 'consent-preferences']\n },\n {\n id: 'analytics',\n name: 'Analytics',\n description: 'These cookies help us understand how visitors interact with our website by collecting and reporting information anonymously.',\n required: false,\n cookies: ['_ga', '_ga_*', '_gid', '_gat', 'lighthouse-*']\n },\n {\n id: 'marketing',\n name: 'Marketing',\n description: 'These cookies are used to track visitors across websites to display relevant advertisements and measure campaign effectiveness.',\n required: false,\n cookies: ['_fbp', '_fbc', 'fr', 'ads-*']\n },\n {\n id: 'preferences',\n name: 'Preferences',\n description: 'These cookies remember your choices and preferences to provide a more personalized experience.',\n required: false,\n cookies: ['theme-preference', 'language-preference', 'ui-settings']\n }\n];\n\n// Current consent version (increment when privacy policy changes)\nexport const CONSENT_VERSION = '1.0';\n\n// Cookie names\nexport const CONSENT_COOKIE_NAME = 'semiont-cookie-consent';\nexport const PREFERENCES_COOKIE_NAME = 'semiont-cookie-preferences';\n\n// Default consent state\nexport const DEFAULT_CONSENT: CookieConsent = {\n necessary: true, // Always true, required for functionality\n analytics: false,\n marketing: false,\n preferences: false,\n timestamp: new Date().toISOString(),\n version: CONSENT_VERSION\n};\n","import type { CookieConsent } from './types';\nimport { COOKIE_CATEGORIES } from './constants';\n\n// Clean up cookies based on consent\nexport const cleanupCookies = (consent: CookieConsent): void => {\n if (typeof window === 'undefined') return;\n\n COOKIE_CATEGORIES.forEach(category => {\n if (category.required) return; // Never clean up required cookies\n\n const hasConsent = consent[category.id];\n if (!hasConsent) {\n // Remove cookies for this category\n category.cookies.forEach(cookieName => {\n if (cookieName.includes('*')) {\n // Handle wildcard cookies\n const prefix = cookieName.replace('*', '');\n document.cookie.split(';').forEach(cookie => {\n const name = cookie.split('=')[0]?.trim();\n if (name && name.startsWith(prefix)) {\n deleteCookie(name);\n }\n });\n } else {\n deleteCookie(cookieName);\n }\n });\n }\n });\n};\n\n// Delete a specific cookie\nexport const deleteCookie = (name: string): void => {\n // Delete for current domain\n document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/`;\n // Delete for parent domain\n document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain=${window.location.hostname}`;\n // Delete for root domain\n const rootDomain = window.location.hostname.split('.').slice(-2).join('.');\n document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain=.${rootDomain}`;\n};\n","import type { CookieConsent } from './types';\nimport { CONSENT_COOKIE_NAME, CONSENT_VERSION, DEFAULT_CONSENT } from './constants';\nimport { cleanupCookies } from './cleanup';\n\nexport const getCookieConsent = (): CookieConsent | null => {\n if (typeof window === 'undefined') return null;\n\n try {\n const consent = localStorage.getItem(CONSENT_COOKIE_NAME);\n if (!consent) return null;\n\n const parsed = JSON.parse(consent) as CookieConsent;\n\n // Check if consent is for current version\n if (parsed.version !== CONSENT_VERSION) {\n return null; // Force re-consent for new version\n }\n\n return parsed;\n } catch (error) {\n console.warn('Failed to parse cookie consent:', error);\n return null;\n }\n};\n\nexport const setCookieConsent = (consent: Partial<CookieConsent>): void => {\n if (typeof window === 'undefined') return;\n\n const fullConsent: CookieConsent = {\n ...DEFAULT_CONSENT,\n ...consent,\n necessary: true, // Always true\n timestamp: new Date().toISOString(),\n version: CONSENT_VERSION\n };\n\n try {\n localStorage.setItem(CONSENT_COOKIE_NAME, JSON.stringify(fullConsent));\n\n // Clean up cookies based on consent\n cleanupCookies(fullConsent);\n\n // Dispatch custom event for components to react to consent changes\n window.dispatchEvent(new CustomEvent('cookieConsentChanged', {\n detail: fullConsent\n }));\n } catch (error) {\n console.error('Failed to save cookie consent:', error);\n }\n};\n\nexport const hasValidConsent = (): boolean => {\n const consent = getCookieConsent();\n if (!consent) return false;\n\n // Check if consent is less than 13 months old (GDPR requirement)\n const consentDate = new Date(consent.timestamp);\n const thirteenMonthsAgo = new Date();\n thirteenMonthsAgo.setMonth(thirteenMonthsAgo.getMonth() - 13);\n\n return consentDate > thirteenMonthsAgo;\n};\n\nexport const shouldShowBanner = (): boolean => {\n if (typeof window === 'undefined') return false;\n return !hasValidConsent();\n};\n","import { deleteCookie } from './cleanup';\n\n// Get user's location for CCPA vs GDPR detection (simplified)\nexport const getUserLocation = async (): Promise<'EU' | 'CA' | 'US' | 'OTHER'> => {\n try {\n // In a real implementation, you'd use a geolocation service\n // For now, we'll detect based on timezone as a rough approximation\n const timezone = Intl.DateTimeFormat().resolvedOptions().timeZone;\n\n if (timezone.includes('Europe/')) return 'EU';\n if (timezone.includes('America/Los_Angeles') || timezone.includes('America/Vancouver')) return 'CA';\n if (timezone.includes('America/')) return 'US';\n\n return 'OTHER';\n } catch {\n return 'OTHER';\n }\n};\n\n// Check if CCPA applies (California residents)\nexport const isCCPAApplicable = async (): Promise<boolean> => {\n const location = await getUserLocation();\n return location === 'CA';\n};\n\n// Check if GDPR applies (EU residents)\nexport const isGDPRApplicable = async (): Promise<boolean> => {\n const location = await getUserLocation();\n return location === 'EU';\n};\n\n// Export all cookies currently set\nexport const exportUserData = (): Record<string, string> => {\n if (typeof window === 'undefined') return {};\n\n const data: Record<string, string> = {};\n\n // Get all cookies\n document.cookie.split(';').forEach(cookie => {\n const [name, value] = cookie.trim().split('=');\n if (name && value) {\n data[`cookie_${name}`] = decodeURIComponent(value);\n }\n });\n\n // Get localStorage data\n for (let i = 0; i < localStorage.length; i++) {\n const key = localStorage.key(i);\n if (key) {\n data[`localStorage_${key}`] = localStorage.getItem(key) || '';\n }\n }\n\n // Get sessionStorage data\n for (let i = 0; i < sessionStorage.length; i++) {\n const key = sessionStorage.key(i);\n if (key) {\n data[`sessionStorage_${key}`] = sessionStorage.getItem(key) || '';\n }\n }\n\n return data;\n};\n\n// Delete all user data (GDPR right to be forgotten)\nexport const deleteAllUserData = (): void => {\n if (typeof window === 'undefined') return;\n\n // Clear all localStorage\n localStorage.clear();\n\n // Clear all sessionStorage\n sessionStorage.clear();\n\n // Delete all cookies\n document.cookie.split(';').forEach(cookie => {\n const name = cookie.split('=')[0]?.trim();\n if (name) {\n deleteCookie(name);\n }\n });\n\n // Reload page to ensure clean state\n window.location.reload();\n};\n"],"names":["GlobalSearchModal","isOpen","onClose","router","useRouter","_t","useTranslation","t","k","p","handleNavigate","type","id","jsx","SearchModal","KeyboardShortcutsContext","createContext","KeyboardShortcutsProvider","children","isSearchOpen","setIsSearchOpen","useState","isHelpOpen","setIsHelpOpen","overlayCloseCallbacks","setOverlayCloseCallbacks","openGlobalSearch","useCallback","openKeyboardHelp","closeAllOverlays","callback","useKeyboardShortcuts","useDoubleKeyPress","contextValue","jsxs","KeyboardShortcutsHelpModal","COOKIE_CATEGORIES","CONSENT_VERSION","CONSENT_COOKIE_NAME","DEFAULT_CONSENT","cleanupCookies","consent","category","cookieName","prefix","cookie","name","_a","deleteCookie","rootDomain","getCookieConsent","parsed","error","setCookieConsent","fullConsent","hasValidConsent","consentDate","thirteenMonthsAgo","shouldShowBanner","getUserLocation","timezone","isCCPAApplicable","isGDPRApplicable","exportUserData","data","value","i","key","deleteAllUserData"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{j as m}from"./query-ATBhtd3K.js";import{b as f,a as c,R as g,L,c as p}from"./vendor-EnoIVk-c.js";import{D as o,i as h}from"./index-DA31r_0s.js";import{u}from"./i18n-BYxb14hm.js";const k=g.forwardRef(function({to:a,...n},s){const{i18n:t}=u(),e=c(),l=t.language||e.locale||o,i=typeof a=="string"?`/${l}${a.startsWith("/")?a:`/${a}`}`:a;return m.jsx(L,{ref:s,to:i,...n})});function w(){const r=f(),{i18n:a}=u(),n=c();function s(t,e){return`/${e||a.language||n.locale||o}${t.startsWith("/")?t:`/${t}`}`}return{push(t,e){r(s(t,e==null?void 0:e.locale))},replace(t,e){r(s(t,e==null?void 0:e.locale),{replace:!0})},back(){r(-1)},forward(){r(1)},refresh(){window.location.reload()},prefetch(t){}}}function b(){const{pathname:r}=p(),a=r.match(/^\/[a-z]{2}(\/.*)?$/);return a?a[1]??"/":r}function j(){const r=c(),{i18n:a}=u(),n=r.locale;return n&&h(n)?n:a.language||o}export{k as L,j as a,b,w as u};
2
+ //# sourceMappingURL=routing-DMdXWYXo.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"routing-BLuuVVPN.js","sources":["../../src/i18n/routing.tsx"],"sourcesContent":["/**\n * Routing abstraction layer — React Router implementation\n *\n * All call sites import from @/i18n/routing and do not need to change\n * when the underlying router changes.\n *\n * Key behaviours:\n * - Link: locale-prefixed anchor rendered via react-router-dom\n * - useRouter: locale-aware push/replace/back\n * - usePathname: returns path WITHOUT locale prefix\n * - redirect: programmatic navigation without locale prefix\n */\n\nimport React from 'react';\nimport {\n Link as RouterLink,\n useNavigate,\n useLocation,\n useParams,\n Navigate,\n} from 'react-router-dom';\nimport { useTranslation } from 'react-i18next';\nimport { SUPPORTED_LOCALES, DEFAULT_LOCALE, isSupportedLocale } from './config';\n\nexport { SUPPORTED_LOCALES, DEFAULT_LOCALE };\n\n// ── Link ─────────────────────────────────────────────────────────────────────\n\ntype LinkProps = React.ComponentProps<typeof RouterLink>;\n\n/**\n * Locale-aware Link. Prepends the current locale to the href.\n */\nexport const Link = React.forwardRef<HTMLAnchorElement, LinkProps>(\n function Link({ to, ...props }, ref) {\n const { i18n } = useTranslation();\n const params = useParams<{ locale?: string }>();\n const locale = i18n.language || params.locale || DEFAULT_LOCALE;\n const target = typeof to === 'string' ? `/${locale}${to.startsWith('/') ? to : `/${to}`}` : to;\n return <RouterLink ref={ref} to={target} {...props} />;\n },\n);\n\n// ── useRouter ─────────────────────────────────────────────────────────────────\n\ntype RouterOptions = { locale?: string };\n\nexport function useRouter() {\n const navigate = useNavigate();\n const { i18n } = useTranslation();\n const params = useParams<{ locale?: string }>();\n\n function prefixLocale(path: string, locale?: string): string {\n const lang = locale || i18n.language || params.locale || DEFAULT_LOCALE;\n return `/${lang}${path.startsWith('/') ? path : `/${path}`}`;\n }\n\n return {\n push(path: string, options?: RouterOptions) {\n navigate(prefixLocale(path, options?.locale));\n },\n replace(path: string, options?: RouterOptions) {\n navigate(prefixLocale(path, options?.locale), { replace: true });\n },\n back() {\n navigate(-1);\n },\n forward() {\n navigate(1);\n },\n refresh() {\n window.location.reload();\n },\n prefetch(_path: string) {\n // No-op: Vite/React Router handles prefetching differently\n },\n };\n}\n\n// ── usePathname ───────────────────────────────────────────────────────────────\n\n/**\n * Returns the path WITHOUT the locale prefix.\n * e.g. /en/know/discover → /know/discover\n */\nexport function usePathname(): string {\n const { pathname } = useLocation();\n // Strip leading /{locale}\n const match = pathname.match(/^\\/[a-z]{2}(\\/.*)?$/);\n if (match) {\n return match[1] ?? '/';\n }\n return pathname;\n}\n\n// ── redirect ─────────────────────────────────────────────────────────────────\n\n/**\n * Render a redirect component. Pass { href, locale } to redirect with locale,\n * or just a string href to redirect to an absolute path.\n */\nexport function redirect(target: string | { href: string; locale?: string }): React.ReactElement {\n const { i18n } = useTranslation();\n const locale = typeof target === 'string' ? (i18n.language || DEFAULT_LOCALE) : (target.locale || i18n.language || DEFAULT_LOCALE);\n const href = typeof target === 'string' ? target : target.href;\n const to = `/${locale}${href.startsWith('/') ? href : `/${href}`}`;\n return <Navigate to={to} replace />;\n}\n\n// ── useParams with locale ────────────────────────────────────────────────────\n\nexport function useLocale(): string {\n const params = useParams<{ locale?: string }>();\n const { i18n } = useTranslation();\n const localeFromParams = params.locale;\n if (localeFromParams && isSupportedLocale(localeFromParams)) {\n return localeFromParams;\n }\n return i18n.language || DEFAULT_LOCALE;\n}\n"],"names":["Link","React","to","props","ref","i18n","useTranslation","params","useParams","locale","DEFAULT_LOCALE","target","RouterLink","useRouter","navigate","useNavigate","prefixLocale","path","options","_path","usePathname","pathname","useLocation","match","useLocale","localeFromParams","isSupportedLocale"],"mappings":"8LAiCO,MAAMA,EAAOC,EAAM,WACxB,SAAc,CAAE,GAAAC,EAAI,GAAGC,CAAA,EAASC,EAAK,CACnC,KAAM,CAAE,KAAAC,CAAA,EAASC,EAAA,EACXC,EAASC,EAAA,EACTC,EAASJ,EAAK,UAAYE,EAAO,QAAUG,EAC3CC,EAAS,OAAOT,GAAO,SAAW,IAAIO,CAAM,GAAGP,EAAG,WAAW,GAAG,EAAIA,EAAK,IAAIA,CAAE,EAAE,GAAKA,EAC5F,aAAQU,EAAA,CAAW,IAAAR,EAAU,GAAIO,EAAS,GAAGR,EAAO,CACtD,CACF,EAMO,SAASU,GAAY,CAC1B,MAAMC,EAAWC,EAAA,EACX,CAAE,KAAAV,CAAA,EAASC,EAAA,EACXC,EAASC,EAAA,EAEf,SAASQ,EAAaC,EAAcR,EAAyB,CAE3D,MAAO,IADMA,GAAUJ,EAAK,UAAYE,EAAO,QAAUG,CAC1C,GAAGO,EAAK,WAAW,GAAG,EAAIA,EAAO,IAAIA,CAAI,EAAE,EAC5D,CAEA,MAAO,CACL,KAAKA,EAAcC,EAAyB,CAC1CJ,EAASE,EAAaC,EAAMC,GAAA,YAAAA,EAAS,MAAM,CAAC,CAC9C,EACA,QAAQD,EAAcC,EAAyB,CAC7CJ,EAASE,EAAaC,EAAMC,GAAA,YAAAA,EAAS,MAAM,EAAG,CAAE,QAAS,GAAM,CACjE,EACA,MAAO,CACLJ,EAAS,EAAE,CACb,EACA,SAAU,CACRA,EAAS,CAAC,CACZ,EACA,SAAU,CACR,OAAO,SAAS,OAAA,CAClB,EACA,SAASK,EAAe,CAExB,CAAA,CAEJ,CAQO,SAASC,GAAsB,CACpC,KAAM,CAAE,SAAAC,CAAA,EAAaC,EAAA,EAEfC,EAAQF,EAAS,MAAM,qBAAqB,EAClD,OAAIE,EACKA,EAAM,CAAC,GAAK,IAEdF,CACT,CAkBO,SAASG,GAAoB,CAClC,MAAMjB,EAASC,EAAA,EACT,CAAE,KAAAH,CAAA,EAASC,EAAA,EACXmB,EAAmBlB,EAAO,OAChC,OAAIkB,GAAoBC,EAAkBD,CAAgB,EACjDA,EAEFpB,EAAK,UAAYK,CAC1B"}
1
+ {"version":3,"file":"routing-DMdXWYXo.js","sources":["../../src/i18n/routing.tsx"],"sourcesContent":["/**\n * Routing abstraction layer — React Router implementation\n *\n * All call sites import from @/i18n/routing and do not need to change\n * when the underlying router changes.\n *\n * Key behaviours:\n * - Link: locale-prefixed anchor rendered via react-router-dom\n * - useRouter: locale-aware push/replace/back\n * - usePathname: returns path WITHOUT locale prefix\n * - redirect: programmatic navigation without locale prefix\n */\n\nimport React from 'react';\nimport {\n Link as RouterLink,\n useNavigate,\n useLocation,\n useParams,\n Navigate,\n} from 'react-router-dom';\nimport { useTranslation } from 'react-i18next';\nimport { SUPPORTED_LOCALES, DEFAULT_LOCALE, isSupportedLocale } from './config';\n\nexport { SUPPORTED_LOCALES, DEFAULT_LOCALE };\n\n// ── Link ─────────────────────────────────────────────────────────────────────\n\ntype LinkProps = React.ComponentProps<typeof RouterLink>;\n\n/**\n * Locale-aware Link. Prepends the current locale to the href.\n */\nexport const Link = React.forwardRef<HTMLAnchorElement, LinkProps>(\n function Link({ to, ...props }, ref) {\n const { i18n } = useTranslation();\n const params = useParams<{ locale?: string }>();\n const locale = i18n.language || params.locale || DEFAULT_LOCALE;\n const target = typeof to === 'string' ? `/${locale}${to.startsWith('/') ? to : `/${to}`}` : to;\n return <RouterLink ref={ref} to={target} {...props} />;\n },\n);\n\n// ── useRouter ─────────────────────────────────────────────────────────────────\n\ntype RouterOptions = { locale?: string };\n\nexport function useRouter() {\n const navigate = useNavigate();\n const { i18n } = useTranslation();\n const params = useParams<{ locale?: string }>();\n\n function prefixLocale(path: string, locale?: string): string {\n const lang = locale || i18n.language || params.locale || DEFAULT_LOCALE;\n return `/${lang}${path.startsWith('/') ? path : `/${path}`}`;\n }\n\n return {\n push(path: string, options?: RouterOptions) {\n navigate(prefixLocale(path, options?.locale));\n },\n replace(path: string, options?: RouterOptions) {\n navigate(prefixLocale(path, options?.locale), { replace: true });\n },\n back() {\n navigate(-1);\n },\n forward() {\n navigate(1);\n },\n refresh() {\n window.location.reload();\n },\n prefetch(_path: string) {\n // No-op: Vite/React Router handles prefetching differently\n },\n };\n}\n\n// ── usePathname ───────────────────────────────────────────────────────────────\n\n/**\n * Returns the path WITHOUT the locale prefix.\n * e.g. /en/know/discover → /know/discover\n */\nexport function usePathname(): string {\n const { pathname } = useLocation();\n // Strip leading /{locale}\n const match = pathname.match(/^\\/[a-z]{2}(\\/.*)?$/);\n if (match) {\n return match[1] ?? '/';\n }\n return pathname;\n}\n\n// ── redirect ─────────────────────────────────────────────────────────────────\n\n/**\n * Render a redirect component. Pass { href, locale } to redirect with locale,\n * or just a string href to redirect to an absolute path.\n */\nexport function redirect(target: string | { href: string; locale?: string }): React.ReactElement {\n const { i18n } = useTranslation();\n const locale = typeof target === 'string' ? (i18n.language || DEFAULT_LOCALE) : (target.locale || i18n.language || DEFAULT_LOCALE);\n const href = typeof target === 'string' ? target : target.href;\n const to = `/${locale}${href.startsWith('/') ? href : `/${href}`}`;\n return <Navigate to={to} replace />;\n}\n\n// ── useParams with locale ────────────────────────────────────────────────────\n\nexport function useLocale(): string {\n const params = useParams<{ locale?: string }>();\n const { i18n } = useTranslation();\n const localeFromParams = params.locale;\n if (localeFromParams && isSupportedLocale(localeFromParams)) {\n return localeFromParams;\n }\n return i18n.language || DEFAULT_LOCALE;\n}\n"],"names":["Link","React","to","props","ref","i18n","useTranslation","params","useParams","locale","DEFAULT_LOCALE","target","RouterLink","useRouter","navigate","useNavigate","prefixLocale","path","options","_path","usePathname","pathname","useLocation","match","useLocale","localeFromParams","isSupportedLocale"],"mappings":"yLAiCO,MAAMA,EAAOC,EAAM,WACxB,SAAc,CAAE,GAAAC,EAAI,GAAGC,CAAA,EAASC,EAAK,CACnC,KAAM,CAAE,KAAAC,CAAA,EAASC,EAAA,EACXC,EAASC,EAAA,EACTC,EAASJ,EAAK,UAAYE,EAAO,QAAUG,EAC3CC,EAAS,OAAOT,GAAO,SAAW,IAAIO,CAAM,GAAGP,EAAG,WAAW,GAAG,EAAIA,EAAK,IAAIA,CAAE,EAAE,GAAKA,EAC5F,aAAQU,EAAA,CAAW,IAAAR,EAAU,GAAIO,EAAS,GAAGR,EAAO,CACtD,CACF,EAMO,SAASU,GAAY,CAC1B,MAAMC,EAAWC,EAAA,EACX,CAAE,KAAAV,CAAA,EAASC,EAAA,EACXC,EAASC,EAAA,EAEf,SAASQ,EAAaC,EAAcR,EAAyB,CAE3D,MAAO,IADMA,GAAUJ,EAAK,UAAYE,EAAO,QAAUG,CAC1C,GAAGO,EAAK,WAAW,GAAG,EAAIA,EAAO,IAAIA,CAAI,EAAE,EAC5D,CAEA,MAAO,CACL,KAAKA,EAAcC,EAAyB,CAC1CJ,EAASE,EAAaC,EAAMC,GAAA,YAAAA,EAAS,MAAM,CAAC,CAC9C,EACA,QAAQD,EAAcC,EAAyB,CAC7CJ,EAASE,EAAaC,EAAMC,GAAA,YAAAA,EAAS,MAAM,EAAG,CAAE,QAAS,GAAM,CACjE,EACA,MAAO,CACLJ,EAAS,EAAE,CACb,EACA,SAAU,CACRA,EAAS,CAAC,CACZ,EACA,SAAU,CACR,OAAO,SAAS,OAAA,CAClB,EACA,SAASK,EAAe,CAExB,CAAA,CAEJ,CAQO,SAASC,GAAsB,CACpC,KAAM,CAAE,SAAAC,CAAA,EAAaC,EAAA,EAEfC,EAAQF,EAAS,MAAM,qBAAqB,EAClD,OAAIE,EACKA,EAAM,CAAC,GAAK,IAEdF,CACT,CAkBO,SAASG,GAAoB,CAClC,MAAMjB,EAASC,EAAA,EACT,CAAE,KAAAH,CAAA,EAASC,EAAA,EACXmB,EAAmBlB,EAAO,OAChC,OAAIkB,GAAoBC,EAAkBD,CAAgB,EACjDA,EAEFpB,EAAK,UAAYK,CAC1B"}
@@ -1,2 +1,2 @@
1
- import{j as s}from"./query-ATBhtd3K.js";import{R as a}from"./vendor-EnoIVk-c.js";import{L as n}from"./routing-BLuuVVPN.js";const i=a.forwardRef(function({href:e,...o},t){return s.jsx(n,{ref:t,to:e,...o})}),u=i,d={resourceDetail:r=>`/know/resource/${r}`,userProfile:r=>`/users/${r}`,search:r=>`/search?q=${encodeURIComponent(r)}`,home:()=>"/",about:()=>"/about",privacy:()=>"/privacy",terms:()=>"/terms",knowledge:()=>"/know",moderate:()=>"/moderate",admin:()=>"/admin"};export{u as L,d as r};
2
- //# sourceMappingURL=routing-6lnx-g5H.js.map
1
+ import{j as s}from"./query-ATBhtd3K.js";import{R as a}from"./vendor-EnoIVk-c.js";import{L as n}from"./routing-DMdXWYXo.js";const i=a.forwardRef(function({href:e,...o},t){return s.jsx(n,{ref:t,to:e,...o})}),u=i,d={resourceDetail:r=>`/know/resource/${r}`,userProfile:r=>`/users/${r}`,search:r=>`/search?q=${encodeURIComponent(r)}`,home:()=>"/",about:()=>"/about",privacy:()=>"/privacy",terms:()=>"/terms",knowledge:()=>"/know",moderate:()=>"/moderate",admin:()=>"/admin"};export{u as L,d as r};
2
+ //# sourceMappingURL=routing-tJ_HbFRP.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"routing-6lnx-g5H.js","sources":["../../src/lib/routing.tsx"],"sourcesContent":["/**\n * Routing configuration for Semiont frontend\n *\n * This module provides the concrete implementation of the RoutingContext\n * interface for the React Router-based frontend application.\n */\n\nimport React from 'react';\nimport { Link as NextLink } from '@/i18n/routing';\nimport type { RouteBuilder, LinkComponentProps } from '@semiont/react-ui';\nimport type { ComponentType } from 'react';\n\n/**\n * Adapter: react-ui components pass `href`, but React Router Link expects `to`.\n */\nconst LinkAdapter = React.forwardRef<HTMLAnchorElement, LinkComponentProps>(\n function LinkAdapter({ href, ...props }, ref) {\n return <NextLink ref={ref} to={href} {...props} />;\n }\n);\nexport const Link: ComponentType<LinkComponentProps> = LinkAdapter as any;\n\n/**\n * Route builder for Semiont frontend\n */\nexport const routes: RouteBuilder = {\n resourceDetail: (id: string) => `/know/resource/${id}`,\n userProfile: (id: string) => `/users/${id}`,\n search: (query: string) => `/search?q=${encodeURIComponent(query)}`,\n home: () => '/',\n about: () => '/about',\n privacy: () => '/privacy',\n terms: () => '/terms',\n knowledge: () => '/know',\n moderate: () => '/moderate',\n admin: () => '/admin',\n};\n"],"names":["LinkAdapter","React","href","props","ref","NextLink","Link","routes","id","query"],"mappings":"2HAeA,MAAMA,EAAcC,EAAM,WACxB,SAAqB,CAAE,KAAAC,EAAM,GAAGC,CAAA,EAASC,EAAK,CAC5C,aAAQC,EAAA,CAAS,IAAAD,EAAU,GAAIF,EAAO,GAAGC,EAAO,CAClD,CACF,EACaG,EAA0CN,EAK1CO,EAAuB,CAClC,eAAiBC,GAAe,kBAAkBA,CAAE,GACpD,YAAcA,GAAe,UAAUA,CAAE,GACzC,OAASC,GAAkB,aAAa,mBAAmBA,CAAK,CAAC,GACjE,KAAM,IAAM,IACZ,MAAO,IAAM,SACb,QAAS,IAAM,WACf,MAAO,IAAM,SACb,UAAW,IAAM,QACjB,SAAU,IAAM,YAChB,MAAO,IAAM,QACf"}
1
+ {"version":3,"file":"routing-tJ_HbFRP.js","sources":["../../src/lib/routing.tsx"],"sourcesContent":["/**\n * Routing configuration for Semiont frontend\n *\n * This module provides the concrete implementation of the RoutingContext\n * interface for the React Router-based frontend application.\n */\n\nimport React from 'react';\nimport { Link as NextLink } from '@/i18n/routing';\nimport type { RouteBuilder, LinkComponentProps } from '@semiont/react-ui';\nimport type { ComponentType } from 'react';\n\n/**\n * Adapter: react-ui components pass `href`, but React Router Link expects `to`.\n */\nconst LinkAdapter = React.forwardRef<HTMLAnchorElement, LinkComponentProps>(\n function LinkAdapter({ href, ...props }, ref) {\n return <NextLink ref={ref} to={href} {...props} />;\n }\n);\nexport const Link: ComponentType<LinkComponentProps> = LinkAdapter as any;\n\n/**\n * Route builder for Semiont frontend\n */\nexport const routes: RouteBuilder = {\n resourceDetail: (id: string) => `/know/resource/${id}`,\n userProfile: (id: string) => `/users/${id}`,\n search: (query: string) => `/search?q=${encodeURIComponent(query)}`,\n home: () => '/',\n about: () => '/about',\n privacy: () => '/privacy',\n terms: () => '/terms',\n knowledge: () => '/know',\n moderate: () => '/moderate',\n admin: () => '/admin',\n};\n"],"names":["LinkAdapter","React","href","props","ref","NextLink","Link","routes","id","query"],"mappings":"2HAeA,MAAMA,EAAcC,EAAM,WACxB,SAAqB,CAAE,KAAAC,EAAM,GAAGC,CAAA,EAASC,EAAK,CAC5C,aAAQC,EAAA,CAAS,IAAAD,EAAU,GAAIF,EAAO,GAAGC,EAAO,CAClD,CACF,EACaG,EAA0CN,EAK1CO,EAAuB,CAClC,eAAiBC,GAAe,kBAAkBA,CAAE,GACpD,YAAcA,GAAe,UAAUA,CAAE,GACzC,OAASC,GAAkB,aAAa,mBAAmBA,CAAK,CAAC,GACjE,KAAM,IAAM,IACZ,MAAO,IAAM,SACb,QAAS,IAAM,WACf,MAAO,IAAM,SACb,UAAW,IAAM,QACjB,SAAU,IAAM,YAChB,MAAO,IAAM,QACf"}
@@ -0,0 +1,2 @@
1
+ import{r as o}from"./vendor-EnoIVk-c.js";import{j as b}from"./query-ATBhtd3K.js";import{U as E,V as U,X as T,Y as $}from"./en-IUV4ZXKH-BY1RKeLS.js";function P(e){return`${e.protocol}://${e.host}:${e.port}`}function J(e){return e==="localhost"||e==="127.0.0.1"?"http":"https"}const k="semiont.token.";function w(e){return localStorage.getItem(`${k}${e}`)}function V(e,n){localStorage.setItem(`${k}${e}`,n)}function v(e){localStorage.removeItem(`${k}${e}`)}function S(e){try{const n=e.split(".")[1];return n?JSON.parse(atob(n)).exp*1e3<Date.now():!0}catch{return!0}}function Y(e){const n=w(e);return n?S(n)?"expired":"authenticated":"signed-out"}const x="semiont.knowledgeBases",h="semiont.activeKnowledgeBaseId";function M(e){if(e.host!==void 0)return e;try{const n=new URL(e.backendUrl);return{id:e.id,label:e.label,host:n.hostname,port:parseInt(n.port,10)||(n.protocol==="https:"?443:80),protocol:n.protocol==="https:"?"https":"http",email:""}}catch{return{id:e.id,label:e.label||"Unknown",host:"localhost",port:4e3,protocol:"http",email:""}}}function B(){try{const e=localStorage.getItem(x);return e?JSON.parse(e).map(M):[]}catch{return[]}}function O(e){localStorage.setItem(x,JSON.stringify(e))}const C=o.createContext(void 0);function D({children:e}){const[n,i]=o.useState(()=>B()),[t,l]=o.useState(()=>{var f;const s=localStorage.getItem(h),a=B();return s&&a.some(u=>u.id===s)?s:((f=a[0])==null?void 0:f.id)??null});o.useEffect(()=>{O(n)},[n]),o.useEffect(()=>{t?localStorage.setItem(h,t):localStorage.removeItem(h)},[t]);const c=o.useCallback(s=>{i(a=>[...a,s]),l(s.id)},[]),d=o.useCallback(s=>{v(s),i(a=>a.filter(f=>f.id!==s)),l(a=>{var u;return a!==s?a:((u=n.filter(A=>A.id!==s)[0])==null?void 0:u.id)??null})},[n]),m=o.useCallback(s=>{l(s)},[]),g=o.useCallback((s,a)=>{i(f=>f.map(u=>u.id===s?{...u,...a}:u))},[]),p=o.useCallback(s=>{v(s),i(a=>[...a])},[]),r=o.useMemo(()=>n.find(s=>s.id===t)??null,[n,t]),K=o.useMemo(()=>({knowledgeBases:n,activeKnowledgeBaseId:t,activeKnowledgeBase:r,addKnowledgeBase:c,removeKnowledgeBase:d,setActiveKnowledgeBase:m,updateKnowledgeBase:g,signOut:p}),[n,t,r,c,d,m,g,p]);return b.jsx(C.Provider,{value:K,children:e})}function y(){const e=o.useContext(C);if(!e)throw new Error("useKnowledgeBaseContext must be used within KnowledgeBaseProvider");return e}const I=o.createContext(void 0);function F({children:e}){const{activeKnowledgeBase:n}=y(),[i,t]=o.useState(null),l=(n==null?void 0:n.id)??null,[c,d]=o.useState(()=>{if(!l)return!1;const r=w(l);return!!r&&!S(r)});o.useEffect(()=>{if(!l||!n){t(null),d(!1);return}const r=w(l);if(!r||S(r)){t(null),d(!1);return}d(!0),new E({baseUrl:T(P(n)),eventBus:new U}).getMe({auth:$(r)}).then(s=>{t({token:r,user:s})}).catch(()=>{t(null)}).finally(()=>{d(!1)})},[l,n]);const m=o.useCallback(r=>{t(r)},[]),g=o.useCallback(()=>{t(null)},[]),p=o.useMemo(()=>({session:i,isLoading:c,setSession:m,clearSession:g}),[i,c,m,g]);return b.jsx(I.Provider,{value:p,children:e})}const L={session:null,isLoading:!1,setSession:()=>{},clearSession:()=>{}};function N(){return o.useContext(I)??L}function X(){const{session:e,isLoading:n}=N();return o.useMemo(()=>{var l,c;const i=!!e,t=(e==null?void 0:e.user)??null;return{session:e,user:t,backendUser:t,token:(e==null?void 0:e.token)??null,isLoading:n,isAuthenticated:i,hasValidBackendToken:!!(e!=null&&e.token),isFullyAuthenticated:i,userDomain:(t==null?void 0:t.domain)||((l=t==null?void 0:t.email)==null?void 0:l.split("@")[1]),displayName:(t==null?void 0:t.name)??((c=t==null?void 0:t.email)==null?void 0:c.split("@")[0])??"User",avatarUrl:(t==null?void 0:t.image)??null,isAdmin:(t==null?void 0:t.isAdmin)??!1,isModerator:(t==null?void 0:t.isModerator)??!1}},[e,n])}export{F as A,D as K,N as a,y as b,J as d,Y as g,P as k,V as s,X as u};
2
+ //# sourceMappingURL=useAuth-yUx5lBP5.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useAuth-yUx5lBP5.js","sources":["../../src/contexts/KnowledgeBaseContext.tsx","../../src/contexts/AuthContext.tsx","../../src/hooks/useAuth.ts"],"sourcesContent":["import React, { createContext, useContext, useState, useCallback, useMemo, useEffect } from 'react';\n\nexport interface KnowledgeBase {\n id: string;\n label: string;\n host: string;\n port: number;\n protocol: 'http' | 'https';\n email: string;\n}\n\nexport function kbBackendUrl(kb: KnowledgeBase): string {\n return `${kb.protocol}://${kb.host}:${kb.port}`;\n}\n\nexport function defaultProtocol(host: string): 'http' | 'https' {\n return host === 'localhost' || host === '127.0.0.1' ? 'http' : 'https';\n}\n\n// Per-KB JWT token storage\nconst TOKEN_PREFIX = 'semiont.token.';\n\nexport function getKbToken(kbId: string): string | null {\n return localStorage.getItem(`${TOKEN_PREFIX}${kbId}`);\n}\n\nexport function setKbToken(kbId: string, token: string): void {\n localStorage.setItem(`${TOKEN_PREFIX}${kbId}`, token);\n}\n\nexport function clearKbToken(kbId: string): void {\n localStorage.removeItem(`${TOKEN_PREFIX}${kbId}`);\n}\n\nexport function isTokenExpired(token: string): boolean {\n try {\n const payloadPart = token.split('.')[1];\n if (!payloadPart) return true;\n const payload = JSON.parse(atob(payloadPart));\n return payload.exp * 1000 < Date.now();\n } catch {\n return true;\n }\n}\n\nexport type KbSessionStatus = 'authenticated' | 'expired' | 'signed-out' | 'unreachable';\n\nexport function getKbSessionStatus(kbId: string): KbSessionStatus {\n const token = getKbToken(kbId);\n if (!token) return 'signed-out';\n return isTokenExpired(token) ? 'expired' : 'authenticated';\n}\n\ninterface KnowledgeBaseContextValue {\n knowledgeBases: KnowledgeBase[];\n activeKnowledgeBaseId: string | null;\n activeKnowledgeBase: KnowledgeBase | null;\n addKnowledgeBase: (kb: KnowledgeBase) => void;\n removeKnowledgeBase: (id: string) => void;\n setActiveKnowledgeBase: (id: string) => void;\n updateKnowledgeBase: (id: string, updates: Partial<Pick<KnowledgeBase, 'label'>>) => void;\n signOut: (id: string) => void;\n}\n\nconst STORAGE_KEY = 'semiont.knowledgeBases';\nconst ACTIVE_KEY = 'semiont.activeKnowledgeBaseId';\n\n// Migrate legacy entries that have backendUrl instead of host/port/protocol\nfunction migrateLegacyEntry(entry: any): KnowledgeBase {\n if (entry.host !== undefined) return entry as KnowledgeBase;\n // Legacy format: { id, label, backendUrl }\n try {\n const url = new URL(entry.backendUrl);\n return {\n id: entry.id,\n label: entry.label,\n host: url.hostname,\n port: parseInt(url.port, 10) || (url.protocol === 'https:' ? 443 : 80),\n protocol: url.protocol === 'https:' ? 'https' : 'http',\n email: '',\n };\n } catch {\n return {\n id: entry.id,\n label: entry.label || 'Unknown',\n host: 'localhost',\n port: 4000,\n protocol: 'http',\n email: '',\n };\n }\n}\n\nfunction loadKnowledgeBases(): KnowledgeBase[] {\n try {\n const raw = localStorage.getItem(STORAGE_KEY);\n if (!raw) return [];\n const entries = JSON.parse(raw) as any[];\n return entries.map(migrateLegacyEntry);\n } catch {\n return [];\n }\n}\n\nfunction saveKnowledgeBases(knowledgeBases: KnowledgeBase[]): void {\n localStorage.setItem(STORAGE_KEY, JSON.stringify(knowledgeBases));\n}\n\nconst KnowledgeBaseContext = createContext<KnowledgeBaseContextValue | undefined>(undefined);\n\nexport function KnowledgeBaseProvider({ children }: { children: React.ReactNode }) {\n const [knowledgeBases, setKnowledgeBases] = useState<KnowledgeBase[]>(() => loadKnowledgeBases());\n const [activeKnowledgeBaseId, setActiveKnowledgeBaseId] = useState<string | null>(() => {\n const saved = localStorage.getItem(ACTIVE_KEY);\n const loaded = loadKnowledgeBases();\n if (saved && loaded.some(kb => kb.id === saved)) return saved;\n return loaded[0]?.id ?? null;\n });\n\n useEffect(() => {\n saveKnowledgeBases(knowledgeBases);\n }, [knowledgeBases]);\n\n useEffect(() => {\n if (activeKnowledgeBaseId) {\n localStorage.setItem(ACTIVE_KEY, activeKnowledgeBaseId);\n } else {\n localStorage.removeItem(ACTIVE_KEY);\n }\n }, [activeKnowledgeBaseId]);\n\n const addKnowledgeBase = useCallback((kb: KnowledgeBase) => {\n setKnowledgeBases(prev => [...prev, kb]);\n setActiveKnowledgeBaseId(kb.id);\n }, []);\n\n const removeKnowledgeBase = useCallback((id: string) => {\n clearKbToken(id);\n setKnowledgeBases(prev => prev.filter(kb => kb.id !== id));\n setActiveKnowledgeBaseId(prev => {\n if (prev !== id) return prev;\n const remaining = knowledgeBases.filter(kb => kb.id !== id);\n return remaining[0]?.id ?? null;\n });\n }, [knowledgeBases]);\n\n const setActiveKnowledgeBase = useCallback((id: string) => {\n setActiveKnowledgeBaseId(id);\n }, []);\n\n const updateKnowledgeBase = useCallback((id: string, updates: Partial<Pick<KnowledgeBase, 'label'>>) => {\n setKnowledgeBases(prev => prev.map(kb => kb.id === id ? { ...kb, ...updates } : kb));\n }, []);\n\n const signOut = useCallback((id: string) => {\n clearKbToken(id);\n // Force re-render by updating the KB list (same entries, new reference)\n setKnowledgeBases(prev => [...prev]);\n }, []);\n\n const activeKnowledgeBase = useMemo(\n () => knowledgeBases.find(kb => kb.id === activeKnowledgeBaseId) ?? null,\n [knowledgeBases, activeKnowledgeBaseId]\n );\n\n const value = useMemo(\n () => ({ knowledgeBases, activeKnowledgeBaseId, activeKnowledgeBase, addKnowledgeBase, removeKnowledgeBase, setActiveKnowledgeBase, updateKnowledgeBase, signOut }),\n [knowledgeBases, activeKnowledgeBaseId, activeKnowledgeBase, addKnowledgeBase, removeKnowledgeBase, setActiveKnowledgeBase, updateKnowledgeBase, signOut]\n );\n\n return <KnowledgeBaseContext.Provider value={value}>{children}</KnowledgeBaseContext.Provider>;\n}\n\nexport function useKnowledgeBaseContext(): KnowledgeBaseContextValue {\n const ctx = useContext(KnowledgeBaseContext);\n if (!ctx) throw new Error('useKnowledgeBaseContext must be used within KnowledgeBaseProvider');\n return ctx;\n}\n","import React, { createContext, useContext, useState, useEffect, useCallback, useMemo } from 'react';\nimport { SemiontApiClient } from '@semiont/api-client';\nimport type { components } from '@semiont/core';\nimport { baseUrl, EventBus, accessToken } from '@semiont/core';\nimport { useKnowledgeBaseContext, kbBackendUrl, getKbToken, isTokenExpired } from './KnowledgeBaseContext';\n\ntype UserInfo = components['schemas']['UserResponse'];\n\nexport interface AuthSession {\n token: string;\n user: UserInfo;\n}\n\ninterface AuthContextValue {\n session: AuthSession | null;\n isLoading: boolean;\n setSession: (session: AuthSession) => void;\n clearSession: () => void;\n}\n\nconst AuthContext = createContext<AuthContextValue | undefined>(undefined);\n\nexport function AuthProvider({ children }: { children: React.ReactNode }) {\n const { activeKnowledgeBase } = useKnowledgeBaseContext();\n const [session, setSessionState] = useState<AuthSession | null>(null);\n // Start loading if there's a stored token to validate\n const activeKbId = activeKnowledgeBase?.id ?? null;\n const [isLoading, setIsLoading] = useState(() => {\n if (!activeKbId) return false;\n const token = getKbToken(activeKbId);\n return !!token && !isTokenExpired(token);\n });\n\n // When active KB changes, try to restore session from stored token\n useEffect(() => {\n if (!activeKbId || !activeKnowledgeBase) {\n setSessionState(null);\n setIsLoading(false);\n return;\n }\n\n const token = getKbToken(activeKbId);\n if (!token || isTokenExpired(token)) {\n setSessionState(null);\n setIsLoading(false);\n return;\n }\n\n // Validate the token by calling getMe via the API client\n setIsLoading(true);\n const client = new SemiontApiClient({\n baseUrl: baseUrl(kbBackendUrl(activeKnowledgeBase)),\n eventBus: new EventBus(),\n });\n client.getMe({ auth: accessToken(token) })\n .then((data) => {\n setSessionState({ token, user: data as UserInfo });\n })\n .catch(() => {\n setSessionState(null);\n })\n .finally(() => {\n setIsLoading(false);\n });\n }, [activeKbId, activeKnowledgeBase]);\n\n const setSession = useCallback((s: AuthSession) => {\n setSessionState(s);\n }, []);\n\n const clearSession = useCallback(() => {\n setSessionState(null);\n }, []);\n\n const value = useMemo(\n () => ({ session, isLoading, setSession, clearSession }),\n [session, isLoading, setSession, clearSession]\n );\n\n return <AuthContext.Provider value={value}>{children}</AuthContext.Provider>;\n}\n\nconst NO_AUTH: AuthContextValue = {\n session: null,\n isLoading: false,\n setSession: () => {},\n clearSession: () => {},\n};\n\nexport function useAuthContext(): AuthContextValue {\n return useContext(AuthContext) ?? NO_AUTH;\n}\n","import { useMemo } from 'react';\nimport { useAuthContext } from '@/contexts/AuthContext';\n\n/**\n * Enhanced authentication hook\n */\nexport function useAuth() {\n const { session, isLoading } = useAuthContext();\n\n return useMemo(() => {\n const isAuthenticated = !!session;\n const user = session?.user ?? null;\n\n return {\n session,\n user,\n backendUser: user,\n token: session?.token ?? null,\n\n isLoading,\n isAuthenticated,\n hasValidBackendToken: !!session?.token,\n isFullyAuthenticated: isAuthenticated,\n\n userDomain: user?.domain || user?.email?.split('@')[1],\n displayName: user?.name ?? user?.email?.split('@')[0] ?? 'User',\n avatarUrl: user?.image ?? null,\n isAdmin: user?.isAdmin ?? false,\n isModerator: user?.isModerator ?? false,\n };\n }, [session, isLoading]);\n}\n\n/**\n * Hook for getting user preferences and settings\n */\nexport function useUserPreferences() {\n return useMemo(() => ({\n theme: 'system' as 'light' | 'dark' | 'system',\n language: 'en',\n timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n emailNotifications: true,\n }), []);\n}\n\n/**\n * Hook for checking user permissions\n */\nexport function usePermissions() {\n const { isFullyAuthenticated, backendUser } = useAuth();\n\n return useMemo(() => {\n if (!isFullyAuthenticated || !backendUser) {\n return { canRead: false, canWrite: false, canAdmin: false, canManageUsers: false };\n }\n return { canRead: true, canWrite: true, canAdmin: false, canManageUsers: false };\n }, [backendUser, isFullyAuthenticated]);\n}\n"],"names":["kbBackendUrl","kb","defaultProtocol","host","TOKEN_PREFIX","getKbToken","kbId","setKbToken","token","clearKbToken","isTokenExpired","payloadPart","getKbSessionStatus","STORAGE_KEY","ACTIVE_KEY","migrateLegacyEntry","entry","url","loadKnowledgeBases","raw","saveKnowledgeBases","knowledgeBases","KnowledgeBaseContext","createContext","KnowledgeBaseProvider","children","setKnowledgeBases","useState","activeKnowledgeBaseId","setActiveKnowledgeBaseId","saved","loaded","_a","useEffect","addKnowledgeBase","useCallback","prev","removeKnowledgeBase","id","setActiveKnowledgeBase","updateKnowledgeBase","updates","signOut","activeKnowledgeBase","useMemo","value","jsx","useKnowledgeBaseContext","ctx","useContext","AuthContext","AuthProvider","session","setSessionState","activeKbId","isLoading","setIsLoading","SemiontApiClient","baseUrl","EventBus","accessToken","data","setSession","s","clearSession","NO_AUTH","useAuthContext","useAuth","isAuthenticated","user","_b"],"mappings":"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"}
@@ -11,11 +11,11 @@
11
11
  <link rel="apple-touch-icon" href="/apple-touch-icon.png" />
12
12
  <link rel="manifest" href="/favicons/site.webmanifest" />
13
13
  <meta name="theme-color" content="#00FFFF" />
14
- <script type="module" crossorigin src="/assets/index-DKq_l4UW.js"></script>
14
+ <script type="module" crossorigin src="/assets/index-DA31r_0s.js"></script>
15
15
  <link rel="modulepreload" crossorigin href="/assets/vendor-EnoIVk-c.js">
16
16
  <link rel="modulepreload" crossorigin href="/assets/query-ATBhtd3K.js">
17
17
  <link rel="modulepreload" crossorigin href="/assets/i18n-BYxb14hm.js">
18
- <link rel="stylesheet" crossorigin href="/assets/index-CwQxZp6g.css">
18
+ <link rel="stylesheet" crossorigin href="/assets/index-CNb3PHS7.css">
19
19
  </head>
20
20
  <body>
21
21
  <div id="root"></div>