@semiont/cli 0.4.18 → 0.4.19

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 (106) hide show
  1. package/dist/cli.mjs +14 -42
  2. package/dist/frontend/dist/assets/{CookiePreferences-ebe4eB-e.js → CookiePreferences-BBb5XMuG.js} +2 -2
  3. package/dist/frontend/dist/assets/{CookiePreferences-ebe4eB-e.js.map → CookiePreferences-BBb5XMuG.js.map} +1 -1
  4. package/dist/frontend/dist/assets/{PdfAnnotationCanvas.client-CHDCGQBR-BGx2owZ0.js → PdfAnnotationCanvas.client-CHDCGQBR-mCGxablw.js} +2 -2
  5. package/dist/frontend/dist/assets/{PdfAnnotationCanvas.client-CHDCGQBR-BGx2owZ0.js.map → PdfAnnotationCanvas.client-CHDCGQBR-mCGxablw.js.map} +1 -1
  6. package/dist/frontend/dist/assets/ToolbarPanels-CfaOVIc9.js +2 -0
  7. package/dist/frontend/dist/assets/ToolbarPanels-CfaOVIc9.js.map +1 -0
  8. package/dist/frontend/dist/assets/{client-8eRsF4aG.js → client-CWwdB0xQ.js} +2 -2
  9. package/dist/frontend/dist/assets/{client-8eRsF4aG.js.map → client-CWwdB0xQ.js.map} +1 -1
  10. package/dist/frontend/dist/assets/{client-D4vbUf7k.js → client-Cgz-uiSd.js} +2 -2
  11. package/dist/frontend/dist/assets/{client-D4vbUf7k.js.map → client-Cgz-uiSd.js.map} +1 -1
  12. package/dist/frontend/dist/assets/{client-Zl8uXOB2.js → client-D3W9xTBT.js} +2 -2
  13. package/dist/frontend/dist/assets/{client-Zl8uXOB2.js.map → client-D3W9xTBT.js.map} +1 -1
  14. package/dist/frontend/dist/assets/{client-BwxrodJP.js → client-DeL0szs5.js} +2 -2
  15. package/dist/frontend/dist/assets/{client-BwxrodJP.js.map → client-DeL0szs5.js.map} +1 -1
  16. package/dist/frontend/dist/assets/{index-DESF7by4.js → index-C5oI0kaf.js} +49 -49
  17. package/dist/frontend/dist/assets/index-C5oI0kaf.js.map +1 -0
  18. package/dist/frontend/dist/assets/{layout-BInmmVVD.js → layout-B_JLc3yI.js} +2 -2
  19. package/dist/frontend/dist/assets/{layout-BInmmVVD.js.map → layout-B_JLc3yI.js.map} +1 -1
  20. package/dist/frontend/dist/assets/{layout-DvfgC4ds.js → layout-DJI7aibW.js} +2 -2
  21. package/dist/frontend/dist/assets/{layout-DvfgC4ds.js.map → layout-DJI7aibW.js.map} +1 -1
  22. package/dist/frontend/dist/assets/{layout-Bc0HvP9q.js → layout-DXY8hCsB.js} +2 -2
  23. package/dist/frontend/dist/assets/{layout-Bc0HvP9q.js.map → layout-DXY8hCsB.js.map} +1 -1
  24. package/dist/frontend/dist/assets/{layout-CFCI5ndn.js → layout-VBQ97DvJ.js} +2 -2
  25. package/dist/frontend/dist/assets/{layout-CFCI5ndn.js.map → layout-VBQ97DvJ.js.map} +1 -1
  26. package/dist/frontend/dist/assets/{not-found-B-h8U0AW.js → not-found-BKG2_Fv3.js} +2 -2
  27. package/dist/frontend/dist/assets/{not-found-B-h8U0AW.js.map → not-found-BKG2_Fv3.js.map} +1 -1
  28. package/dist/frontend/dist/assets/{page-CwB528Up.js → page-8OrS1-4-.js} +2 -2
  29. package/dist/frontend/dist/assets/{page-CwB528Up.js.map → page-8OrS1-4-.js.map} +1 -1
  30. package/dist/frontend/dist/assets/{page-BRnMt7o2.js → page-B4Qu9WPd.js} +2 -2
  31. package/dist/frontend/dist/assets/{page-BRnMt7o2.js.map → page-B4Qu9WPd.js.map} +1 -1
  32. package/dist/frontend/dist/assets/page-BNJp__R7.js +2 -0
  33. package/dist/frontend/dist/assets/{page-DLQK_cX5.js.map → page-BNJp__R7.js.map} +1 -1
  34. package/dist/frontend/dist/assets/{page-CkjHPT8p.js → page-BRTi-f95.js} +2 -2
  35. package/dist/frontend/dist/assets/{page-CkjHPT8p.js.map → page-BRTi-f95.js.map} +1 -1
  36. package/dist/frontend/dist/assets/{page-B4bD7iN0.js → page-BSB8GP79.js} +2 -2
  37. package/dist/frontend/dist/assets/{page-B4bD7iN0.js.map → page-BSB8GP79.js.map} +1 -1
  38. package/dist/frontend/dist/assets/{page-zo4BeIjA.js → page-Bx8QAzic.js} +2 -2
  39. package/dist/frontend/dist/assets/{page-zo4BeIjA.js.map → page-Bx8QAzic.js.map} +1 -1
  40. package/dist/frontend/dist/assets/page-CDSGl6uY.js +2 -0
  41. package/dist/frontend/dist/assets/{page-EgwcfkeK.js.map → page-CDSGl6uY.js.map} +1 -1
  42. package/dist/frontend/dist/assets/{page-DRQxmzY-.js → page-CJLuuiG8.js} +2 -2
  43. package/dist/frontend/dist/assets/{page-DRQxmzY-.js.map → page-CJLuuiG8.js.map} +1 -1
  44. package/dist/frontend/dist/assets/{page-CNftu-l4.js → page-CyFJt2nP.js} +2 -2
  45. package/dist/frontend/dist/assets/{page-CNftu-l4.js.map → page-CyFJt2nP.js.map} +1 -1
  46. package/dist/frontend/dist/assets/{page-CnYCXW-A.js → page-D1q6VB02.js} +2 -2
  47. package/dist/frontend/dist/assets/{page-CnYCXW-A.js.map → page-D1q6VB02.js.map} +1 -1
  48. package/dist/frontend/dist/assets/{page-DFS-DvYi.js → page-D3THDsqd.js} +2 -2
  49. package/dist/frontend/dist/assets/{page-DFS-DvYi.js.map → page-D3THDsqd.js.map} +1 -1
  50. package/dist/frontend/dist/assets/{page-4JzRN2Q4.js → page-DCxg1lHk.js} +2 -2
  51. package/dist/frontend/dist/assets/{page-4JzRN2Q4.js.map → page-DCxg1lHk.js.map} +1 -1
  52. package/dist/frontend/dist/assets/{page-hTDMMHds.js → page-DbwQv5n_.js} +2 -2
  53. package/dist/frontend/dist/assets/{page-hTDMMHds.js.map → page-DbwQv5n_.js.map} +1 -1
  54. package/dist/frontend/dist/assets/{page-tm2w2bTu.js → page-DddZ9Yxm.js} +2 -2
  55. package/dist/frontend/dist/assets/{page-tm2w2bTu.js.map → page-DddZ9Yxm.js.map} +1 -1
  56. package/dist/frontend/dist/assets/{page-BeWKvJpC.js → page-DzoXV-AN.js} +2 -2
  57. package/dist/frontend/dist/assets/{page-BeWKvJpC.js.map → page-DzoXV-AN.js.map} +1 -1
  58. package/dist/frontend/dist/assets/{page-BD_lMtdf.js → page-IgGNB4a9.js} +2 -2
  59. package/dist/frontend/dist/assets/{page-BD_lMtdf.js.map → page-IgGNB4a9.js.map} +1 -1
  60. package/dist/frontend/dist/assets/{page-BKt53Kee.js → page-aKPxuWo3.js} +2 -2
  61. package/dist/frontend/dist/assets/{page-BKt53Kee.js.map → page-aKPxuWo3.js.map} +1 -1
  62. package/dist/frontend/dist/assets/{page-BRpbSm6U.js → page-jxC42AIR.js} +2 -2
  63. package/dist/frontend/dist/assets/{page-BRpbSm6U.js.map → page-jxC42AIR.js.map} +1 -1
  64. package/dist/frontend/dist/assets/{privacy-DS6wXZXA.js → privacy-BAxopuZI.js} +2 -2
  65. package/dist/frontend/dist/assets/{privacy-DS6wXZXA.js.map → privacy-BAxopuZI.js.map} +1 -1
  66. package/dist/frontend/dist/assets/{routing-DDJ3KSPT.js → routing-Cm_oCwum.js} +2 -2
  67. package/dist/frontend/dist/assets/{routing-DDJ3KSPT.js.map → routing-Cm_oCwum.js.map} +1 -1
  68. package/dist/frontend/dist/assets/{routing-NOxgO9NV.js → routing-rYtBowvy.js} +2 -2
  69. package/dist/frontend/dist/assets/{routing-NOxgO9NV.js.map → routing-rYtBowvy.js.map} +1 -1
  70. package/dist/frontend/dist/index.html +1 -1
  71. package/dist/frontend/dist/messages/ar.json +2 -1
  72. package/dist/frontend/dist/messages/bn.json +2 -1
  73. package/dist/frontend/dist/messages/cs.json +2 -1
  74. package/dist/frontend/dist/messages/da.json +2 -1
  75. package/dist/frontend/dist/messages/de.json +2 -1
  76. package/dist/frontend/dist/messages/el.json +2 -1
  77. package/dist/frontend/dist/messages/en.json +2 -1
  78. package/dist/frontend/dist/messages/es.json +2 -1
  79. package/dist/frontend/dist/messages/fa.json +2 -1
  80. package/dist/frontend/dist/messages/fi.json +2 -1
  81. package/dist/frontend/dist/messages/fr.json +2 -1
  82. package/dist/frontend/dist/messages/he.json +2 -1
  83. package/dist/frontend/dist/messages/hi.json +2 -1
  84. package/dist/frontend/dist/messages/id.json +2 -1
  85. package/dist/frontend/dist/messages/it.json +2 -1
  86. package/dist/frontend/dist/messages/ja.json +2 -1
  87. package/dist/frontend/dist/messages/ko.json +2 -1
  88. package/dist/frontend/dist/messages/ms.json +2 -1
  89. package/dist/frontend/dist/messages/nl.json +2 -1
  90. package/dist/frontend/dist/messages/no.json +2 -1
  91. package/dist/frontend/dist/messages/pl.json +2 -1
  92. package/dist/frontend/dist/messages/pt.json +2 -1
  93. package/dist/frontend/dist/messages/ro.json +2 -1
  94. package/dist/frontend/dist/messages/sv.json +2 -1
  95. package/dist/frontend/dist/messages/th.json +2 -1
  96. package/dist/frontend/dist/messages/tr.json +2 -1
  97. package/dist/frontend/dist/messages/uk.json +2 -1
  98. package/dist/frontend/dist/messages/vi.json +2 -1
  99. package/dist/frontend/dist/messages/zh.json +2 -1
  100. package/dist/frontend/package.json +1 -1
  101. package/package.json +7 -7
  102. package/dist/frontend/dist/assets/ToolbarPanels-C9r6ZyGY.js +0 -2
  103. package/dist/frontend/dist/assets/ToolbarPanels-C9r6ZyGY.js.map +0 -1
  104. package/dist/frontend/dist/assets/index-DESF7by4.js.map +0 -1
  105. package/dist/frontend/dist/assets/page-DLQK_cX5.js +0 -2
  106. package/dist/frontend/dist/assets/page-EgwcfkeK.js +0 -2
@@ -1,2 +1,2 @@
1
- import{j as l}from"./query-B6BuIB0M.js";import{r as c}from"./vendor-DJo4KD8w.js";import{u as m}from"./routing-DDJ3KSPT.js";import{aa as C,ab as S,ac as b,ad as O}from"./index-DESF7by4.js";import{u as v}from"./i18n-BbpF47i1.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-DS6wXZXA.js.map
1
+ import{j as l}from"./query-B6BuIB0M.js";import{r as c}from"./vendor-DJo4KD8w.js";import{u as m}from"./routing-Cm_oCwum.js";import{aa as C,ab as S,ac as b,ad as O}from"./index-C5oI0kaf.js";import{u as v}from"./i18n-BbpF47i1.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-BAxopuZI.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"privacy-DS6wXZXA.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-BAxopuZI.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,2 +1,2 @@
1
- import{j as m}from"./query-B6BuIB0M.js";import{b as f,a as c,R as g,L,c as p}from"./vendor-DJo4KD8w.js";import{I as o,J as h}from"./index-DESF7by4.js";import{u}from"./i18n-BbpF47i1.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-DDJ3KSPT.js.map
1
+ import{j as m}from"./query-B6BuIB0M.js";import{b as f,a as c,R as g,L,c as p}from"./vendor-DJo4KD8w.js";import{I as o,J as h}from"./index-C5oI0kaf.js";import{u}from"./i18n-BbpF47i1.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-Cm_oCwum.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"routing-DDJ3KSPT.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
+ {"version":3,"file":"routing-Cm_oCwum.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-B6BuIB0M.js";import{R as a}from"./vendor-DJo4KD8w.js";import{L as n}from"./routing-DDJ3KSPT.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-NOxgO9NV.js.map
1
+ import{j as s}from"./query-B6BuIB0M.js";import{R as a}from"./vendor-DJo4KD8w.js";import{L as n}from"./routing-Cm_oCwum.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-rYtBowvy.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"routing-NOxgO9NV.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-rYtBowvy.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"}
@@ -11,7 +11,7 @@
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-DESF7by4.js"></script>
14
+ <script type="module" crossorigin src="/assets/index-C5oI0kaf.js"></script>
15
15
  <link rel="modulepreload" crossorigin href="/assets/vendor-DJo4KD8w.js">
16
16
  <link rel="modulepreload" crossorigin href="/assets/query-B6BuIB0M.js">
17
17
  <link rel="modulepreload" crossorigin href="/assets/i18n-BbpF47i1.js">
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "متصل",
970
970
  "statusExpired": "انتهت صلاحية الجلسة",
971
971
  "statusSignedOut": "تم تسجيل الخروج",
972
- "statusUnreachable": "غير قابل للوصول"
972
+ "statusUnreachable": "غير قابل للوصول",
973
+ "invalidHost": "اسم مضيف غير صالح"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "لا توجد قواعد معرفة",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "সংযুক্ত",
970
970
  "statusExpired": "সেশন মেয়াদ শেষ",
971
971
  "statusSignedOut": "সাইন আউট হয়েছে",
972
- "statusUnreachable": "পৌঁছানো যাচ্ছে না"
972
+ "statusUnreachable": "পৌঁছানো যাচ্ছে না",
973
+ "invalidHost": "অবৈধ হোস্টনেম"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "কোনো জ্ঞান ভাণ্ডার নেই",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Připojeno",
970
970
  "statusExpired": "Relace vypršela",
971
971
  "statusSignedOut": "Odhlášeno",
972
- "statusUnreachable": "Nedosažitelné"
972
+ "statusUnreachable": "Nedosažitelné",
973
+ "invalidHost": "Neplatný název hostitele"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Žádné znalostní báze",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Forbundet",
970
970
  "statusExpired": "Session udløbet",
971
971
  "statusSignedOut": "Logget ud",
972
- "statusUnreachable": "Utilgængelig"
972
+ "statusUnreachable": "Utilgængelig",
973
+ "invalidHost": "Ugyldigt værtsnavn"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Ingen videnbaser",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Verbunden",
970
970
  "statusExpired": "Sitzung abgelaufen",
971
971
  "statusSignedOut": "Abgemeldet",
972
- "statusUnreachable": "Nicht erreichbar"
972
+ "statusUnreachable": "Nicht erreichbar",
973
+ "invalidHost": "Ungültiger Hostname"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Keine Wissensbasen",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Συνδεδεμένο",
970
970
  "statusExpired": "Η συνεδρία έληξε",
971
971
  "statusSignedOut": "Αποσυνδεδεμένο",
972
- "statusUnreachable": "Μη προσβάσιμο"
972
+ "statusUnreachable": "Μη προσβάσιμο",
973
+ "invalidHost": "Μη έγκυρο όνομα κεντρικού υπολογιστή"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Δεν υπάρχουν βάσεις γνώσης",
@@ -648,7 +648,8 @@
648
648
  "statusConnected": "Connected",
649
649
  "statusExpired": "Session expired",
650
650
  "statusSignedOut": "Signed out",
651
- "statusUnreachable": "Unreachable"
651
+ "statusUnreachable": "Unreachable",
652
+ "invalidHost": "Invalid hostname"
652
653
  },
653
654
  "DiscoverEmptyState": {
654
655
  "noKnowledgeBases": "No knowledge bases",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Conectado",
970
970
  "statusExpired": "Sesión expirada",
971
971
  "statusSignedOut": "Sesión cerrada",
972
- "statusUnreachable": "Inaccesible"
972
+ "statusUnreachable": "Inaccesible",
973
+ "invalidHost": "Nombre de host no válido"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Sin bases de conocimiento",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "متصل",
970
970
  "statusExpired": "نشست منقضی شده",
971
971
  "statusSignedOut": "خارج شده",
972
- "statusUnreachable": "غیرقابل دسترس"
972
+ "statusUnreachable": "غیرقابل دسترس",
973
+ "invalidHost": "نام هاست نامعتبر"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "هیچ پایگاه دانشی وجود ندارد",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Yhdistetty",
970
970
  "statusExpired": "Istunto vanhentunut",
971
971
  "statusSignedOut": "Kirjautunut ulos",
972
- "statusUnreachable": "Ei tavoitettavissa"
972
+ "statusUnreachable": "Ei tavoitettavissa",
973
+ "invalidHost": "Virheellinen isäntänimi"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Ei tietopankkeja",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Connecté",
970
970
  "statusExpired": "Session expirée",
971
971
  "statusSignedOut": "Déconnecté",
972
- "statusUnreachable": "Inaccessible"
972
+ "statusUnreachable": "Inaccessible",
973
+ "invalidHost": "Nom d'hôte invalide"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Aucune base de connaissances",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "מחובר",
970
970
  "statusExpired": "הפגישה פגה",
971
971
  "statusSignedOut": "מנותק",
972
- "statusUnreachable": "לא ניתן להגיע"
972
+ "statusUnreachable": "לא ניתן להגיע",
973
+ "invalidHost": "שם מארח לא חוקי"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "אין בסיסי ידע",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "जुड़ा हुआ",
970
970
  "statusExpired": "सत्र समाप्त",
971
971
  "statusSignedOut": "साइन आउट",
972
- "statusUnreachable": "अनुपलब्ध"
972
+ "statusUnreachable": "अनुपलब्ध",
973
+ "invalidHost": "अमान्य होस्टनाम"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "कोई ज्ञान आधार नहीं",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Terhubung",
970
970
  "statusExpired": "Sesi berakhir",
971
971
  "statusSignedOut": "Keluar",
972
- "statusUnreachable": "Tidak dapat dijangkau"
972
+ "statusUnreachable": "Tidak dapat dijangkau",
973
+ "invalidHost": "Nama host tidak valid"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Tidak ada basis pengetahuan",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Connesso",
970
970
  "statusExpired": "Sessione scaduta",
971
971
  "statusSignedOut": "Disconnesso",
972
- "statusUnreachable": "Non raggiungibile"
972
+ "statusUnreachable": "Non raggiungibile",
973
+ "invalidHost": "Nome host non valido"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Nessuna base di conoscenza",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "接続済み",
970
970
  "statusExpired": "セッション期限切れ",
971
971
  "statusSignedOut": "サインアウト済み",
972
- "statusUnreachable": "到達不能"
972
+ "statusUnreachable": "到達不能",
973
+ "invalidHost": "無効なホスト名"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "ナレッジベースがありません",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "연결됨",
970
970
  "statusExpired": "세션 만료",
971
971
  "statusSignedOut": "로그아웃됨",
972
- "statusUnreachable": "연결 불가"
972
+ "statusUnreachable": "연결 불가",
973
+ "invalidHost": "잘못된 호스트 이름"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "지식 베이스 없음",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Disambungkan",
970
970
  "statusExpired": "Sesi tamat",
971
971
  "statusSignedOut": "Log keluar",
972
- "statusUnreachable": "Tidak dapat dicapai"
972
+ "statusUnreachable": "Tidak dapat dicapai",
973
+ "invalidHost": "Nama hos tidak sah"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Tiada pangkalan pengetahuan",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Verbonden",
970
970
  "statusExpired": "Sessie verlopen",
971
971
  "statusSignedOut": "Uitgelogd",
972
- "statusUnreachable": "Onbereikbaar"
972
+ "statusUnreachable": "Onbereikbaar",
973
+ "invalidHost": "Ongeldige hostnaam"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Geen kennisbases",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Tilkoblet",
970
970
  "statusExpired": "Økt utløpt",
971
971
  "statusSignedOut": "Logget ut",
972
- "statusUnreachable": "Ikke tilgjengelig"
972
+ "statusUnreachable": "Ikke tilgjengelig",
973
+ "invalidHost": "Ugyldig vertsnavn"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Ingen kunnskapsbaser",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Połączono",
970
970
  "statusExpired": "Sesja wygasła",
971
971
  "statusSignedOut": "Wylogowano",
972
- "statusUnreachable": "Niedostępny"
972
+ "statusUnreachable": "Niedostępny",
973
+ "invalidHost": "Nieprawidłowa nazwa hosta"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Brak baz wiedzy",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Conectado",
970
970
  "statusExpired": "Sessão expirada",
971
971
  "statusSignedOut": "Desconectado",
972
- "statusUnreachable": "Inacessível"
972
+ "statusUnreachable": "Inacessível",
973
+ "invalidHost": "Nome de host inválido"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Nenhuma base de conhecimento",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Conectat",
970
970
  "statusExpired": "Sesiune expirată",
971
971
  "statusSignedOut": "Deconectat",
972
- "statusUnreachable": "Inaccesibil"
972
+ "statusUnreachable": "Inaccesibil",
973
+ "invalidHost": "Nume de gazdă invalid"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Nicio bază de cunoștințe",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Ansluten",
970
970
  "statusExpired": "Session utgången",
971
971
  "statusSignedOut": "Utloggad",
972
- "statusUnreachable": "Onåbar"
972
+ "statusUnreachable": "Onåbar",
973
+ "invalidHost": "Ogiltigt värdnamn"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Inga kunskapsbaser",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "เชื่อมต่อแล้ว",
970
970
  "statusExpired": "เซสชันหมดอายุ",
971
971
  "statusSignedOut": "ออกจากระบบแล้ว",
972
- "statusUnreachable": "เข้าถึงไม่ได้"
972
+ "statusUnreachable": "เข้าถึงไม่ได้",
973
+ "invalidHost": "ชื่อโฮสต์ไม่ถูกต้อง"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "ไม่มีฐานความรู้",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Bağlı",
970
970
  "statusExpired": "Oturum süresi doldu",
971
971
  "statusSignedOut": "Çıkış yapıldı",
972
- "statusUnreachable": "Erişilemiyor"
972
+ "statusUnreachable": "Erişilemiyor",
973
+ "invalidHost": "Geçersiz ana bilgisayar adı"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Bilgi tabanı yok",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Підключено",
970
970
  "statusExpired": "Сеанс завершено",
971
971
  "statusSignedOut": "Вийшли",
972
- "statusUnreachable": "Недоступно"
972
+ "statusUnreachable": "Недоступно",
973
+ "invalidHost": "Недійсне ім'я хоста"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Немає баз знань",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "Đã kết nối",
970
970
  "statusExpired": "Phiên đã hết hạn",
971
971
  "statusSignedOut": "Đã đăng xuất",
972
- "statusUnreachable": "Không thể truy cập"
972
+ "statusUnreachable": "Không thể truy cập",
973
+ "invalidHost": "Tên máy chủ không hợp lệ"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "Không có cơ sở kiến thức",
@@ -969,7 +969,8 @@
969
969
  "statusConnected": "已连接",
970
970
  "statusExpired": "会话已过期",
971
971
  "statusSignedOut": "已退出",
972
- "statusUnreachable": "无法访问"
972
+ "statusUnreachable": "无法访问",
973
+ "invalidHost": "无效的主机名"
973
974
  },
974
975
  "DiscoverEmptyState": {
975
976
  "noKnowledgeBases": "没有知识库",
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@semiont/frontend",
3
- "version": "0.4.18",
3
+ "version": "0.4.19",
4
4
  "description": "Semiont frontend - pre-built Vite SPA with static file server",
5
5
  "main": "server.js",
6
6
  "bin": {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@semiont/cli",
3
- "version": "0.4.18",
3
+ "version": "0.4.19",
4
4
  "description": "Semiont CLI - Unified environment management tool",
5
5
  "_comment": "AWS SDK dependencies (@aws-sdk/*) are only used by platforms/aws",
6
6
  "type": "module",
@@ -47,12 +47,12 @@
47
47
  "test:watch:unit": "vitest --watch --config vitest.config.unit.ts"
48
48
  },
49
49
  "dependencies": {
50
- "@semiont/api-client": "0.4.18",
51
- "@semiont/content": "0.4.18",
52
- "@semiont/core": "0.4.18",
53
- "@semiont/event-sourcing": "0.4.18",
54
- "@semiont/graph": "0.4.18",
55
- "@semiont/make-meaning": "0.4.18",
50
+ "@semiont/api-client": "0.4.19",
51
+ "@semiont/content": "0.4.19",
52
+ "@semiont/core": "0.4.19",
53
+ "@semiont/event-sourcing": "0.4.19",
54
+ "@semiont/graph": "0.4.19",
55
+ "@semiont/make-meaning": "0.4.19",
56
56
  "arg": "^5.0.2",
57
57
  "argon2": "^0.44.0",
58
58
  "express": "^5.2.1",