@tantainnovative/ndpr-toolkit 1.0.9 → 2.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +295 -124
- package/dist/breach-BpSBPrdk.d.mts +185 -0
- package/dist/breach-BpSBPrdk.d.ts +185 -0
- package/dist/breach-D5zJYNph.d.mts +17 -0
- package/dist/breach-D7NgrdMX.d.ts +17 -0
- package/dist/breach.d.mts +275 -0
- package/dist/breach.d.ts +275 -0
- package/dist/breach.js +2 -0
- package/dist/breach.js.map +1 -0
- package/dist/breach.mjs +2 -0
- package/dist/breach.mjs.map +1 -0
- package/dist/chunk-2SYNHRP6.mjs +2 -0
- package/dist/chunk-2SYNHRP6.mjs.map +1 -0
- package/dist/chunk-2XHD22J7.mjs +7 -0
- package/dist/chunk-2XHD22J7.mjs.map +1 -0
- package/dist/chunk-4A354HL3.js +2 -0
- package/dist/chunk-4A354HL3.js.map +1 -0
- package/dist/chunk-4DKT6IB6.js +94 -0
- package/dist/chunk-4DKT6IB6.js.map +1 -0
- package/dist/chunk-5ZBO2UPH.js +2 -0
- package/dist/chunk-5ZBO2UPH.js.map +1 -0
- package/dist/chunk-6JFTAYXV.mjs +2 -0
- package/dist/chunk-6JFTAYXV.mjs.map +1 -0
- package/dist/chunk-6JVYYLS7.js +2 -0
- package/dist/chunk-6JVYYLS7.js.map +1 -0
- package/dist/chunk-6SGG6WPA.mjs +2 -0
- package/dist/chunk-6SGG6WPA.mjs.map +1 -0
- package/dist/chunk-AQEGDEQM.js +7 -0
- package/dist/chunk-AQEGDEQM.js.map +1 -0
- package/dist/chunk-C2IJWCZQ.mjs +2 -0
- package/dist/chunk-C2IJWCZQ.mjs.map +1 -0
- package/dist/chunk-CMZTI7SG.js +2 -0
- package/dist/chunk-CMZTI7SG.js.map +1 -0
- package/dist/chunk-DB3JH4DS.mjs +2 -0
- package/dist/chunk-DB3JH4DS.mjs.map +1 -0
- package/dist/chunk-EWOZKYLY.mjs +2 -0
- package/dist/chunk-EWOZKYLY.mjs.map +1 -0
- package/dist/chunk-FFW7RUAG.mjs +94 -0
- package/dist/chunk-FFW7RUAG.mjs.map +1 -0
- package/dist/chunk-FK3CSFLJ.js +2 -0
- package/dist/chunk-FK3CSFLJ.js.map +1 -0
- package/dist/chunk-GIV2OHE6.mjs +2 -0
- package/dist/chunk-GIV2OHE6.mjs.map +1 -0
- package/dist/chunk-GMLNWS2N.mjs +2 -0
- package/dist/chunk-GMLNWS2N.mjs.map +1 -0
- package/dist/chunk-IQF726GS.js +2 -0
- package/dist/chunk-IQF726GS.js.map +1 -0
- package/dist/chunk-IWUUVRLJ.js +2 -0
- package/dist/chunk-IWUUVRLJ.js.map +1 -0
- package/dist/chunk-JUN6YPLL.mjs +72 -0
- package/dist/chunk-JUN6YPLL.mjs.map +1 -0
- package/dist/chunk-L3FKTBGV.js +72 -0
- package/dist/chunk-L3FKTBGV.js.map +1 -0
- package/dist/chunk-L52PDW6O.mjs +2 -0
- package/dist/chunk-L52PDW6O.mjs.map +1 -0
- package/dist/chunk-LI6WJ3LZ.js +2 -0
- package/dist/chunk-LI6WJ3LZ.js.map +1 -0
- package/dist/chunk-LXRXDTPI.js +2 -0
- package/dist/chunk-LXRXDTPI.js.map +1 -0
- package/dist/chunk-MQFZHA2D.js +2 -0
- package/dist/chunk-MQFZHA2D.js.map +1 -0
- package/dist/chunk-OITITR6K.mjs +2 -0
- package/dist/chunk-OITITR6K.mjs.map +1 -0
- package/dist/chunk-PDJGTQMY.mjs +2 -0
- package/dist/chunk-PDJGTQMY.mjs.map +1 -0
- package/dist/chunk-PGSA2O5P.mjs +2 -0
- package/dist/chunk-PGSA2O5P.mjs.map +1 -0
- package/dist/chunk-PM7CMTMB.js +4 -0
- package/dist/chunk-PM7CMTMB.js.map +1 -0
- package/dist/chunk-PYEX7DFR.mjs +4 -0
- package/dist/chunk-PYEX7DFR.mjs.map +1 -0
- package/dist/chunk-QKK5S54L.mjs +2 -0
- package/dist/chunk-QKK5S54L.mjs.map +1 -0
- package/dist/chunk-RB26MIRI.js +2 -0
- package/dist/chunk-RB26MIRI.js.map +1 -0
- package/dist/chunk-RGYK4VAY.mjs +2 -0
- package/dist/chunk-RGYK4VAY.mjs.map +1 -0
- package/dist/chunk-RHWW5FDP.js +16 -0
- package/dist/chunk-RHWW5FDP.js.map +1 -0
- package/dist/chunk-RYZEIDNR.js +2 -0
- package/dist/chunk-RYZEIDNR.js.map +1 -0
- package/dist/chunk-SLNMKGQ2.mjs +2 -0
- package/dist/chunk-SLNMKGQ2.mjs.map +1 -0
- package/dist/chunk-SSGJREE3.js +2 -0
- package/dist/chunk-SSGJREE3.js.map +1 -0
- package/dist/chunk-SWF3YVE5.js +4 -0
- package/dist/chunk-SWF3YVE5.js.map +1 -0
- package/dist/chunk-T44JQT2O.mjs +2 -0
- package/dist/chunk-T44JQT2O.mjs.map +1 -0
- package/dist/chunk-TDDAYVKK.js +2 -0
- package/dist/chunk-TDDAYVKK.js.map +1 -0
- package/dist/chunk-TXBZPCGF.mjs +2 -0
- package/dist/chunk-TXBZPCGF.mjs.map +1 -0
- package/dist/chunk-U2CGMEWB.js +2 -0
- package/dist/chunk-U2CGMEWB.js.map +1 -0
- package/dist/chunk-UUWVBENC.js +2 -0
- package/dist/chunk-UUWVBENC.js.map +1 -0
- package/dist/chunk-UYP64PV7.mjs +4 -0
- package/dist/chunk-UYP64PV7.mjs.map +1 -0
- package/dist/chunk-VMJBW3EF.mjs +2 -0
- package/dist/chunk-VMJBW3EF.mjs.map +1 -0
- package/dist/chunk-WW3X3ELF.js +2 -0
- package/dist/chunk-WW3X3ELF.js.map +1 -0
- package/dist/chunk-WWT2ZSNU.mjs +2 -0
- package/dist/chunk-WWT2ZSNU.mjs.map +1 -0
- package/dist/chunk-XMKA6GVK.mjs +16 -0
- package/dist/chunk-XMKA6GVK.mjs.map +1 -0
- package/dist/chunk-Y34DQYS7.js +2 -0
- package/dist/chunk-Y34DQYS7.js.map +1 -0
- package/dist/chunk-ZU73VG3X.js +2 -0
- package/dist/chunk-ZU73VG3X.js.map +1 -0
- package/dist/consent-CmVzqZUk.d.mts +99 -0
- package/dist/consent-CmVzqZUk.d.ts +99 -0
- package/dist/consent-DCc5zjXI.d.mts +24 -0
- package/dist/consent-DLWb5ota.d.ts +24 -0
- package/dist/consent.d.mts +197 -0
- package/dist/consent.d.ts +197 -0
- package/dist/consent.js +2 -0
- package/dist/consent.js.map +1 -0
- package/dist/consent.mjs +2 -0
- package/dist/consent.mjs.map +1 -0
- package/dist/core.d.mts +14 -0
- package/dist/core.d.ts +14 -0
- package/dist/core.js +2 -0
- package/dist/core.js.map +1 -0
- package/dist/core.mjs +2 -0
- package/dist/core.mjs.map +1 -0
- package/dist/cross-border-BrIy1ieh.d.mts +192 -0
- package/dist/cross-border-BrIy1ieh.d.ts +192 -0
- package/dist/cross-border.d.mts +58 -0
- package/dist/cross-border.d.ts +58 -0
- package/dist/cross-border.js +2 -0
- package/dist/cross-border.js.map +1 -0
- package/dist/cross-border.mjs +2 -0
- package/dist/cross-border.mjs.map +1 -0
- package/dist/dpia-B9ZZJG5a.d.mts +15 -0
- package/dist/dpia-fdtTd2DI.d.ts +15 -0
- package/dist/dpia-vWfE_9bO.d.mts +137 -0
- package/dist/dpia-vWfE_9bO.d.ts +137 -0
- package/dist/dpia.d.mts +179 -0
- package/dist/dpia.d.ts +179 -0
- package/dist/dpia.js +2 -0
- package/dist/dpia.js.map +1 -0
- package/dist/dpia.mjs +2 -0
- package/dist/dpia.mjs.map +1 -0
- package/dist/dsr-jq5NUEdz.d.ts +14 -0
- package/dist/dsr-pQzQ3H1O.d.mts +128 -0
- package/dist/dsr-pQzQ3H1O.d.ts +128 -0
- package/dist/dsr-whPkiI0_.d.mts +14 -0
- package/dist/dsr.d.mts +192 -0
- package/dist/dsr.d.ts +192 -0
- package/dist/dsr.js +2 -0
- package/dist/dsr.js.map +1 -0
- package/dist/dsr.mjs +2 -0
- package/dist/dsr.mjs.map +1 -0
- package/dist/hooks.d.mts +17 -0
- package/dist/hooks.d.ts +17 -0
- package/dist/hooks.js +2 -0
- package/dist/hooks.js.map +1 -0
- package/dist/hooks.mjs +2 -0
- package/dist/hooks.mjs.map +1 -0
- package/dist/index.d.mts +31 -448
- package/dist/index.d.ts +31 -448
- package/dist/index.js +1 -190
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +1 -190
- package/dist/index.mjs.map +1 -1
- package/dist/lawful-basis-CWtvDG1x.d.mts +112 -0
- package/dist/lawful-basis-CWtvDG1x.d.ts +112 -0
- package/dist/lawful-basis-D-oXFizg.d.mts +57 -0
- package/dist/lawful-basis-v04AhbK2.d.ts +57 -0
- package/dist/lawful-basis.d.mts +55 -0
- package/dist/lawful-basis.d.ts +55 -0
- package/dist/lawful-basis.js +2 -0
- package/dist/lawful-basis.js.map +1 -0
- package/dist/lawful-basis.mjs +2 -0
- package/dist/lawful-basis.mjs.map +1 -0
- package/dist/policy.d.mts +195 -0
- package/dist/policy.d.ts +195 -0
- package/dist/policy.js +2 -0
- package/dist/policy.js.map +1 -0
- package/dist/policy.mjs +2 -0
- package/dist/policy.mjs.map +1 -0
- package/dist/privacy-9FcJceMr.d.mts +15 -0
- package/dist/privacy-BXz7O2ej.d.ts +15 -0
- package/dist/privacy-Ca6te9Ir.d.mts +138 -0
- package/dist/privacy-Ca6te9Ir.d.ts +138 -0
- package/dist/ropa-BebGfqKQ.d.ts +200 -0
- package/dist/ropa-Rb4dsFSz.d.mts +200 -0
- package/dist/ropa.d.mts +45 -0
- package/dist/ropa.d.ts +45 -0
- package/dist/ropa.js +2 -0
- package/dist/ropa.js.map +1 -0
- package/dist/ropa.mjs +2 -0
- package/dist/ropa.mjs.map +1 -0
- package/dist/unstyled.d.mts +4 -4
- package/dist/unstyled.d.ts +4 -4
- package/dist/unstyled.js +1 -1
- package/dist/unstyled.js.map +1 -1
- package/dist/unstyled.mjs +1 -1
- package/dist/unstyled.mjs.map +1 -1
- package/dist/useBreach-DRKnexsk.d.mts +99 -0
- package/dist/useBreach-DuT0N0K1.d.ts +99 -0
- package/dist/useConsent-D0pAfTlb.d.ts +65 -0
- package/dist/useConsent-DOt2Njst.d.mts +65 -0
- package/dist/useCrossBorderTransfer-D4FQYfFt.d.ts +66 -0
- package/dist/useCrossBorderTransfer-TVnY8_UX.d.mts +66 -0
- package/dist/useDPIA-DFDHBLSa.d.ts +94 -0
- package/dist/useDPIA-FqPofFaV.d.mts +94 -0
- package/dist/useDSR-DAqqOBXb.d.ts +74 -0
- package/dist/useDSR-OXM5Q9rf.d.mts +74 -0
- package/dist/useLawfulBasis-DNQ8YszQ.d.mts +68 -0
- package/dist/useLawfulBasis-RILM_xsx.d.ts +68 -0
- package/dist/usePrivacyPolicy-CfySfBLS.d.ts +89 -0
- package/dist/usePrivacyPolicy-Dit2sFuV.d.mts +89 -0
- package/dist/useROPA-Bcs6cRdi.d.ts +64 -0
- package/dist/useROPA-nmcSiUYv.d.mts +64 -0
- package/package.json +162 -35
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {d,c,b as b$1,a as a$1}from'./chunk-TXBZPCGF.mjs';import {b,a}from'./chunk-WWT2ZSNU.mjs';import e,{useState,useEffect}from'react';var S={name:"",description:"",lawfulBasis:"consent",lawfulBasisJustification:"",dataCategories:"",involvesSensitiveData:false,sensitiveDataCondition:"",dataSubjectCategories:"",purposes:"",retentionPeriod:"",retentionJustification:"",recipients:"",crossBorderTransfer:false,reviewDate:"",liaPurposeTest:"",liaNecessityTest:"",liaBalancingTest:"",liaSafeguards:"",liaConclusion:""},M=[{value:"consent",label:"Consent"},{value:"contract",label:"Contract"},{value:"legal_obligation",label:"Legal Obligation"},{value:"vital_interests",label:"Vital Interests"},{value:"public_interest",label:"Public Interest"},{value:"legitimate_interests",label:"Legitimate Interests"}],G=[{value:"explicit_consent",label:"Explicit Consent"},{value:"employment_law",label:"Employment Law"},{value:"vital_interests_incapable",label:"Vital Interests (Incapable)"},{value:"nonprofit_legitimate",label:"Nonprofit Legitimate Activities"},{value:"publicly_available",label:"Publicly Available Data"},{value:"legal_claims",label:"Legal Claims"},{value:"substantial_public_interest",label:"Substantial Public Interest"},{value:"health_purposes",label:"Health Purposes"},{value:"public_health",label:"Public Health"},{value:"archiving_research",label:"Archiving / Research"}],me=({activities:p,onAddActivity:B,onUpdateActivity:P,onArchiveActivity:T,title:U="Lawful Basis Tracker",description:Y="Document and track the lawful basis for each processing activity as required by NDPA 2023 Section 25.",className:H="",buttonClassName:g="",showSummary:W=true,showComplianceGaps:q=true})=>{let[b$2,u]=useState("list"),[s,l]=useState(S),[v,k]=useState(null),[L,z]=useState(null),[x,K]=useState("all"),[y,Q]=useState("all"),[N,X]=useState(""),[F,c$1]=useState([]),[_,Z]=useState(p);useEffect(()=>{let t=[...p];if(x!=="all"&&(t=t.filter(i=>i.status===x)),y!=="all"&&(t=t.filter(i=>i.lawfulBasis===y)),N){let i=N.toLowerCase();t=t.filter(r=>r.name.toLowerCase().includes(i)||r.description.toLowerCase().includes(i)||r.purposes.some(m=>m.toLowerCase().includes(i)));}t.sort((i,r)=>r.updatedAt-i.updatedAt),Z(t);},[p,x,y,N]);let f=t=>new Date(t).toLocaleDateString(),h=d(p),C=c(p),w=t=>t.split(",").map(i=>i.trim()).filter(i=>i.length>0),R=()=>{l(S),k(null),c$1([]),u("form");},j=t=>{l({name:t.name,description:t.description,lawfulBasis:t.lawfulBasis,lawfulBasisJustification:t.lawfulBasisJustification,dataCategories:t.dataCategories.join(", "),involvesSensitiveData:t.involvesSensitiveData,sensitiveDataCondition:t.sensitiveDataCondition||"",dataSubjectCategories:t.dataSubjectCategories.join(", "),purposes:t.purposes.join(", "),retentionPeriod:t.retentionPeriod,retentionJustification:t.retentionJustification||"",recipients:(t.recipients||[]).join(", "),crossBorderTransfer:t.crossBorderTransfer,reviewDate:t.reviewDate?new Date(t.reviewDate).toISOString().split("T")[0]:"",liaPurposeTest:"",liaNecessityTest:"",liaBalancingTest:"",liaSafeguards:"",liaConclusion:""}),k(t.id),c$1([]),u("form");},ee=()=>{let t={name:s.name,description:s.description,lawfulBasis:s.lawfulBasis,lawfulBasisJustification:s.lawfulBasisJustification,dataCategories:w(s.dataCategories),involvesSensitiveData:s.involvesSensitiveData,sensitiveDataCondition:s.sensitiveDataCondition||void 0,dataSubjectCategories:w(s.dataSubjectCategories),purposes:w(s.purposes),retentionPeriod:s.retentionPeriod,retentionJustification:s.retentionJustification||void 0,recipients:s.recipients?w(s.recipients):void 0,crossBorderTransfer:s.crossBorderTransfer,reviewDate:s.reviewDate?new Date(s.reviewDate).getTime():void 0,status:"active"},i=b(a({},t),{id:v||"temp",createdAt:Date.now(),updatedAt:Date.now()}),r=a$1(i);if(!r.isValid){c$1(r.errors);return}v&&P?P(v,t):B&&B(t),l(S),k(null),c$1([]),u("list");},I=t=>{T&&T(t);},te=t=>{z(t),u("detail");},a$2=L?p.find(t=>t.id===L):null,J=t=>{let i={active:"bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200",inactive:"bg-gray-100 text-gray-800 dark:bg-gray-900 dark:text-gray-200",under_review:"bg-yellow-100 text-yellow-800 dark:bg-yellow-900 dark:text-yellow-200",archived:"bg-red-100 text-red-800 dark:bg-red-900 dark:text-red-200"},r={active:"Active",inactive:"Inactive",under_review:"Under Review",archived:"Archived"};return e.createElement("span",{className:`px-2 py-1 rounded text-xs font-medium ${i[t]}`},r[t])},E=t=>{let i={consent:"bg-blue-100 text-blue-800 dark:bg-blue-900 dark:text-blue-200",contract:"bg-teal-100 text-teal-800 dark:bg-teal-900 dark:text-teal-200",legal_obligation:"bg-purple-100 text-purple-800 dark:bg-purple-900 dark:text-purple-200",vital_interests:"bg-red-100 text-red-800 dark:bg-red-900 dark:text-red-200",public_interest:"bg-orange-100 text-orange-800 dark:bg-orange-900 dark:text-orange-200",legitimate_interests:"bg-indigo-100 text-indigo-800 dark:bg-indigo-900 dark:text-indigo-200"},r={consent:"Consent",contract:"Contract",legal_obligation:"Legal Obligation",vital_interests:"Vital Interests",public_interest:"Public Interest",legitimate_interests:"Legitimate Interests"};return e.createElement("span",{className:`px-2 py-1 rounded text-xs font-medium ${i[t]}`},r[t])},O=t=>t.dpoApproval?t.dpoApproval.approved?e.createElement("span",{className:"px-2 py-1 rounded text-xs font-medium bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200"},"Approved"):e.createElement("span",{className:"px-2 py-1 rounded text-xs font-medium bg-yellow-100 text-yellow-800 dark:bg-yellow-900 dark:text-yellow-200"},"Pending Approval"):e.createElement("span",{className:"px-2 py-1 rounded text-xs font-medium bg-gray-100 text-gray-600 dark:bg-gray-700 dark:text-gray-400"},"No DPO Review"),se=()=>e.createElement("div",{className:"grid grid-cols-2 md:grid-cols-4 gap-4 mb-6"},e.createElement("div",{className:"bg-blue-50 dark:bg-blue-900/20 p-4 rounded-lg"},e.createElement("p",{className:"text-2xl font-bold text-blue-800 dark:text-blue-200"},h.totalActivities),e.createElement("p",{className:"text-sm text-blue-600 dark:text-blue-300"},"Total Activities")),e.createElement("div",{className:"bg-orange-50 dark:bg-orange-900/20 p-4 rounded-lg"},e.createElement("p",{className:"text-2xl font-bold text-orange-800 dark:text-orange-200"},h.sensitiveDataActivities),e.createElement("p",{className:"text-sm text-orange-600 dark:text-orange-300"},"Sensitive Data")),e.createElement("div",{className:"bg-purple-50 dark:bg-purple-900/20 p-4 rounded-lg"},e.createElement("p",{className:"text-2xl font-bold text-purple-800 dark:text-purple-200"},h.crossBorderActivities),e.createElement("p",{className:"text-sm text-purple-600 dark:text-purple-300"},"Cross-Border Transfers")),e.createElement("div",{className:"bg-red-50 dark:bg-red-900/20 p-4 rounded-lg"},e.createElement("p",{className:"text-2xl font-bold text-red-800 dark:text-red-200"},h.activitiesWithoutApproval.length),e.createElement("p",{className:"text-sm text-red-600 dark:text-red-300"},"Pending Approval"))),ae=()=>{if(C.length===0)return e.createElement("div",{className:"bg-green-50 dark:bg-green-900/20 p-4 rounded-lg mb-6"},e.createElement("p",{className:"text-sm text-green-800 dark:text-green-200 font-medium"},"No compliance gaps detected."),e.createElement("p",{className:"text-xs text-green-700 dark:text-green-300 mt-1"},"All processing activities appear to be properly documented."));let t=C.filter(r=>r.severity==="high"),i=C.filter(r=>r.severity==="medium");return e.createElement("div",{className:"mb-6"},t.length>0&&e.createElement("div",{className:"bg-red-50 dark:bg-red-900/20 p-4 rounded-lg mb-3"},e.createElement("p",{className:"text-sm text-red-800 dark:text-red-200 font-medium mb-2"},"High Priority (",t.length,")"),e.createElement("ul",{className:"space-y-1"},t.map((r,m)=>e.createElement("li",{key:m,className:"text-xs text-red-700 dark:text-red-300"},r.description)))),i.length>0&&e.createElement("div",{className:"bg-yellow-50 dark:bg-yellow-900/20 p-4 rounded-lg"},e.createElement("p",{className:"text-sm text-yellow-800 dark:text-yellow-200 font-medium mb-2"},"Medium Priority (",i.length,")"),e.createElement("ul",{className:"space-y-1"},i.map((r,m)=>e.createElement("li",{key:m,className:"text-xs text-yellow-700 dark:text-yellow-300"},r.description)))))},ie=()=>e.createElement("div",null,e.createElement("div",{className:"flex justify-between items-center mb-4"},e.createElement("h3",{className:"text-lg font-medium"},v?"Edit Processing Activity":"New Processing Activity"),e.createElement("button",{onClick:()=>{u("list"),c$1([]);},className:`px-4 py-2 text-gray-600 dark:text-gray-300 bg-gray-100 dark:bg-gray-700 rounded hover:bg-gray-200 dark:hover:bg-gray-600 ${g}`},"Cancel")),F.length>0&&e.createElement("div",{className:"bg-red-50 dark:bg-red-900/20 p-4 rounded-lg mb-4"},e.createElement("p",{className:"text-sm text-red-800 dark:text-red-200 font-medium mb-2"},"Please correct the following errors:"),e.createElement("ul",{className:"list-disc list-inside space-y-1"},F.map((t,i)=>e.createElement("li",{key:i,className:"text-xs text-red-700 dark:text-red-300"},t)))),e.createElement("div",{className:"space-y-4"},e.createElement("div",null,e.createElement("label",{htmlFor:"activityName",className:"block text-sm font-medium mb-1"},"Activity Name *"),e.createElement("input",{type:"text",id:"activityName",value:s.name,onChange:t=>l(b(a({},s),{name:t.target.value})),placeholder:"e.g., Customer Account Management",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{htmlFor:"activityDescription",className:"block text-sm font-medium mb-1"},"Description *"),e.createElement("textarea",{id:"activityDescription",value:s.description,onChange:t=>l(b(a({},s),{description:t.target.value})),placeholder:"Describe what processing is performed...",rows:3,className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{htmlFor:"lawfulBasis",className:"block text-sm font-medium mb-1"},"Lawful Basis (NDPA Section 25) *"),e.createElement("select",{id:"lawfulBasis",value:s.lawfulBasis,onChange:t=>l(b(a({},s),{lawfulBasis:t.target.value})),className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"},M.map(t=>e.createElement("option",{key:t.value,value:t.value},t.label))),e.createElement("p",{className:"mt-1 text-xs text-gray-500 dark:text-gray-400"},b$1(s.lawfulBasis))),e.createElement("div",null,e.createElement("label",{htmlFor:"justification",className:"block text-sm font-medium mb-1"},"Lawful Basis Justification *"),e.createElement("textarea",{id:"justification",value:s.lawfulBasisJustification,onChange:t=>l(b(a({},s),{lawfulBasisJustification:t.target.value})),placeholder:"Document why this lawful basis applies to this processing activity...",rows:3,className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),s.lawfulBasis==="legitimate_interests"&&e.createElement("div",{className:"border border-indigo-200 dark:border-indigo-800 rounded-lg p-4 bg-indigo-50 dark:bg-indigo-900/20"},e.createElement("h4",{className:"text-sm font-semibold text-indigo-800 dark:text-indigo-200 mb-3"},"Legitimate Interest Assessment (LIA)"),e.createElement("p",{className:"text-xs text-indigo-600 dark:text-indigo-300 mb-4"},"NDPA Section 25(1)(f) requires a balancing test when relying on legitimate interests."),e.createElement("div",{className:"space-y-3"},e.createElement("div",null,e.createElement("label",{htmlFor:"liaPurpose",className:"block text-sm font-medium mb-1"},"Purpose Test"),e.createElement("textarea",{id:"liaPurpose",value:s.liaPurposeTest,onChange:t=>l(b(a({},s),{liaPurposeTest:t.target.value})),placeholder:"Describe the legitimate interest being pursued...",rows:2,className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{htmlFor:"liaNecessity",className:"block text-sm font-medium mb-1"},"Necessity Test"),e.createElement("textarea",{id:"liaNecessity",value:s.liaNecessityTest,onChange:t=>l(b(a({},s),{liaNecessityTest:t.target.value})),placeholder:"Explain why this processing is necessary for the stated purpose...",rows:2,className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{htmlFor:"liaBalancing",className:"block text-sm font-medium mb-1"},"Balancing Test"),e.createElement("textarea",{id:"liaBalancing",value:s.liaBalancingTest,onChange:t=>l(b(a({},s),{liaBalancingTest:t.target.value})),placeholder:"Assess the impact on data subjects' rights and interests...",rows:2,className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{htmlFor:"liaSafeguards",className:"block text-sm font-medium mb-1"},"Safeguards"),e.createElement("input",{type:"text",id:"liaSafeguards",value:s.liaSafeguards,onChange:t=>l(b(a({},s),{liaSafeguards:t.target.value})),placeholder:"List safeguards (comma-separated)...",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{htmlFor:"liaConclusion",className:"block text-sm font-medium mb-1"},"Conclusion"),e.createElement("textarea",{id:"liaConclusion",value:s.liaConclusion,onChange:t=>l(b(a({},s),{liaConclusion:t.target.value})),placeholder:"State your overall conclusion...",rows:2,className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})))),e.createElement("div",null,e.createElement("label",{htmlFor:"dataCategories",className:"block text-sm font-medium mb-1"},"Data Categories *"),e.createElement("input",{type:"text",id:"dataCategories",value:s.dataCategories,onChange:t=>l(b(a({},s),{dataCategories:t.target.value})),placeholder:"e.g., Name, Email, Phone Number (comma-separated)",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{className:"flex items-center space-x-2"},e.createElement("input",{type:"checkbox",checked:s.involvesSensitiveData,onChange:t=>l(b(a({},s),{involvesSensitiveData:t.target.checked,sensitiveDataCondition:t.target.checked?s.sensitiveDataCondition:""})),className:"rounded border-gray-300 dark:border-gray-600 text-blue-600 focus:ring-blue-500"}),e.createElement("span",{className:"text-sm font-medium"},"Involves Sensitive Personal Data (NDPA Section 27)"))),s.involvesSensitiveData&&e.createElement("div",null,e.createElement("label",{htmlFor:"sensitiveCondition",className:"block text-sm font-medium mb-1"},"Sensitive Data Condition (NDPA Section 27) *"),e.createElement("select",{id:"sensitiveCondition",value:s.sensitiveDataCondition,onChange:t=>l(b(a({},s),{sensitiveDataCondition:t.target.value})),className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"},e.createElement("option",{value:""},"Select a condition..."),G.map(t=>e.createElement("option",{key:t.value,value:t.value},t.label)))),e.createElement("div",null,e.createElement("label",{htmlFor:"dataSubjectCategories",className:"block text-sm font-medium mb-1"},"Data Subject Categories *"),e.createElement("input",{type:"text",id:"dataSubjectCategories",value:s.dataSubjectCategories,onChange:t=>l(b(a({},s),{dataSubjectCategories:t.target.value})),placeholder:"e.g., Customers, Employees, Vendors (comma-separated)",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{htmlFor:"purposes",className:"block text-sm font-medium mb-1"},"Processing Purposes *"),e.createElement("input",{type:"text",id:"purposes",value:s.purposes,onChange:t=>l(b(a({},s),{purposes:t.target.value})),placeholder:"e.g., Account management, Service delivery (comma-separated)",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-4"},e.createElement("div",null,e.createElement("label",{htmlFor:"retentionPeriod",className:"block text-sm font-medium mb-1"},"Retention Period *"),e.createElement("input",{type:"text",id:"retentionPeriod",value:s.retentionPeriod,onChange:t=>l(b(a({},s),{retentionPeriod:t.target.value})),placeholder:"e.g., 3 years after account closure",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{htmlFor:"retentionJustification",className:"block text-sm font-medium mb-1"},"Retention Justification"),e.createElement("input",{type:"text",id:"retentionJustification",value:s.retentionJustification,onChange:t=>l(b(a({},s),{retentionJustification:t.target.value})),placeholder:"Reason for the retention period",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"}))),e.createElement("div",null,e.createElement("label",{htmlFor:"recipients",className:"block text-sm font-medium mb-1"},"Recipients"),e.createElement("input",{type:"text",id:"recipients",value:s.recipients,onChange:t=>l(b(a({},s),{recipients:t.target.value})),placeholder:"e.g., Payment processor, Cloud provider (comma-separated)",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",null,e.createElement("label",{className:"flex items-center space-x-2"},e.createElement("input",{type:"checkbox",checked:s.crossBorderTransfer,onChange:t=>l(b(a({},s),{crossBorderTransfer:t.target.checked})),className:"rounded border-gray-300 dark:border-gray-600 text-blue-600 focus:ring-blue-500"}),e.createElement("span",{className:"text-sm font-medium"},"Involves Cross-Border Transfer Outside Nigeria"))),e.createElement("div",null,e.createElement("label",{htmlFor:"reviewDate",className:"block text-sm font-medium mb-1"},"Next Review Date"),e.createElement("input",{type:"date",id:"reviewDate",value:s.reviewDate,onChange:t=>l(b(a({},s),{reviewDate:t.target.value})),className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",{className:"flex justify-end space-x-3 pt-4"},e.createElement("button",{onClick:()=>{u("list"),c$1([]);},className:`px-4 py-2 text-gray-600 dark:text-gray-300 bg-gray-100 dark:bg-gray-700 rounded hover:bg-gray-200 dark:hover:bg-gray-600 ${g}`},"Cancel"),e.createElement("button",{onClick:ee,className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${g}`},v?"Update Activity":"Create Activity")))),re=()=>{var i;if(!a$2)return e.createElement("div",{className:"flex items-center justify-center h-64 bg-gray-50 dark:bg-gray-700 rounded-md"},e.createElement("p",{className:"text-gray-500 dark:text-gray-400"},"Activity not found."));let t=a$1(a$2);return e.createElement("div",null,e.createElement("div",{className:"flex justify-between items-start mb-4"},e.createElement("div",null,e.createElement("button",{onClick:()=>u("list"),className:"text-sm text-blue-600 dark:text-blue-400 hover:underline mb-2"},"Back to list"),e.createElement("h3",{className:"text-lg font-medium"},a$2.name)),e.createElement("div",{className:"flex space-x-2"},E(a$2.lawfulBasis),J(a$2.status),O(a$2))),t.warnings.length>0&&e.createElement("div",{className:"bg-yellow-50 dark:bg-yellow-900/20 p-3 rounded-md mb-4"},e.createElement("p",{className:"text-sm text-yellow-800 dark:text-yellow-200 font-medium mb-1"},"Warnings"),e.createElement("ul",{className:"list-disc list-inside space-y-1"},t.warnings.map((r,m)=>e.createElement("li",{key:m,className:"text-xs text-yellow-700 dark:text-yellow-300"},r)))),e.createElement("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-4 mb-6"},e.createElement("div",null,e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Description:")," ",a$2.description),e.createElement("p",{className:"text-sm mt-2"},e.createElement("span",{className:"font-medium"},"Lawful Basis:")," ",b$1(a$2.lawfulBasis)),e.createElement("p",{className:"text-sm mt-2"},e.createElement("span",{className:"font-medium"},"Justification:")," ",a$2.lawfulBasisJustification)),e.createElement("div",null,e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Data Categories:")," ",a$2.dataCategories.join(", ")),e.createElement("p",{className:"text-sm mt-2"},e.createElement("span",{className:"font-medium"},"Data Subject Categories:")," ",a$2.dataSubjectCategories.join(", ")),e.createElement("p",{className:"text-sm mt-2"},e.createElement("span",{className:"font-medium"},"Purposes:")," ",a$2.purposes.join(", ")),e.createElement("p",{className:"text-sm mt-2"},e.createElement("span",{className:"font-medium"},"Retention Period:")," ",a$2.retentionPeriod,a$2.retentionJustification&&e.createElement("span",{className:"text-gray-500 dark:text-gray-400"}," ","(",a$2.retentionJustification,")")))),e.createElement("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-4 mb-6"},e.createElement("div",null,e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Sensitive Data:")," ",a$2.involvesSensitiveData?"Yes":"No",a$2.sensitiveDataCondition&&e.createElement("span",null," ","(Condition:"," ",((i=G.find(r=>r.value===a$2.sensitiveDataCondition))==null?void 0:i.label)||a$2.sensitiveDataCondition,")")),e.createElement("p",{className:"text-sm mt-2"},e.createElement("span",{className:"font-medium"},"Cross-Border Transfer:")," ",a$2.crossBorderTransfer?"Yes":"No"),a$2.recipients&&a$2.recipients.length>0&&e.createElement("p",{className:"text-sm mt-2"},e.createElement("span",{className:"font-medium"},"Recipients:")," ",a$2.recipients.join(", "))),e.createElement("div",null,e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Created:")," ",f(a$2.createdAt)),e.createElement("p",{className:"text-sm mt-2"},e.createElement("span",{className:"font-medium"},"Last Updated:")," ",f(a$2.updatedAt)),a$2.reviewDate&&e.createElement("p",{className:"text-sm mt-2"},e.createElement("span",{className:"font-medium"},"Next Review:")," ",f(a$2.reviewDate),a$2.reviewDate<Date.now()&&e.createElement("span",{className:"text-red-600 dark:text-red-400 font-medium"}," (Overdue)")))),a$2.dpoApproval&&e.createElement("div",{className:"bg-gray-50 dark:bg-gray-700 p-4 rounded-md mb-6"},e.createElement("h4",{className:"text-sm font-semibold mb-2"},"DPO Approval"),e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Status:")," ",a$2.dpoApproval.approved?"Approved":"Not Approved"),e.createElement("p",{className:"text-sm mt-1"},e.createElement("span",{className:"font-medium"},"Approved By:")," ",a$2.dpoApproval.approvedBy),e.createElement("p",{className:"text-sm mt-1"},e.createElement("span",{className:"font-medium"},"Date:")," ",f(a$2.dpoApproval.approvedAt)),a$2.dpoApproval.notes&&e.createElement("p",{className:"text-sm mt-1"},e.createElement("span",{className:"font-medium"},"Notes:")," ",a$2.dpoApproval.notes)),e.createElement("div",{className:"flex space-x-3"},e.createElement("button",{onClick:()=>j(a$2),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${g}`},"Edit"),a$2.status!=="archived"&&e.createElement("button",{onClick:()=>I(a$2.id),className:`px-4 py-2 bg-gray-600 text-white rounded hover:bg-gray-700 ${g}`},"Archive")))},le=()=>e.createElement("div",null,e.createElement("div",{className:"mb-6 grid grid-cols-1 md:grid-cols-4 gap-4"},e.createElement("div",null,e.createElement("label",{htmlFor:"basisFilter",className:"block text-sm font-medium mb-1"},"Lawful Basis"),e.createElement("select",{id:"basisFilter",value:y,onChange:t=>Q(t.target.value),className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"},e.createElement("option",{value:"all"},"All Bases"),M.map(t=>e.createElement("option",{key:t.value,value:t.value},t.label)))),e.createElement("div",null,e.createElement("label",{htmlFor:"statusFilterSelect",className:"block text-sm font-medium mb-1"},"Status"),e.createElement("select",{id:"statusFilterSelect",value:x,onChange:t=>K(t.target.value),className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"},e.createElement("option",{value:"all"},"All Statuses"),e.createElement("option",{value:"active"},"Active"),e.createElement("option",{value:"inactive"},"Inactive"),e.createElement("option",{value:"under_review"},"Under Review"),e.createElement("option",{value:"archived"},"Archived"))),e.createElement("div",null,e.createElement("label",{htmlFor:"searchInput",className:"block text-sm font-medium mb-1"},"Search"),e.createElement("input",{type:"text",id:"searchInput",value:N,onChange:t=>X(t.target.value),placeholder:"Search activities...",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),e.createElement("div",{className:"flex items-end"},e.createElement("button",{onClick:R,className:`w-full px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${g}`},"Add Activity"))),_.length===0?e.createElement("div",{className:"flex items-center justify-center h-32 bg-gray-50 dark:bg-gray-700 rounded-md"},e.createElement("p",{className:"text-gray-500 dark:text-gray-400 text-sm"},"No processing activities found.")):e.createElement("div",{className:"overflow-x-auto"},e.createElement("table",{className:"w-full text-sm text-left"},e.createElement("thead",{className:"text-xs uppercase bg-gray-50 dark:bg-gray-700"},e.createElement("tr",null,e.createElement("th",{className:"px-4 py-3"},"Activity"),e.createElement("th",{className:"px-4 py-3"},"Lawful Basis"),e.createElement("th",{className:"px-4 py-3"},"Status"),e.createElement("th",{className:"px-4 py-3"},"DPO Approval"),e.createElement("th",{className:"px-4 py-3"},"Sensitive Data"),e.createElement("th",{className:"px-4 py-3"},"Last Updated"),e.createElement("th",{className:"px-4 py-3"},"Actions"))),e.createElement("tbody",null,_.map(t=>e.createElement("tr",{key:t.id,className:"border-b border-gray-200 dark:border-gray-600 hover:bg-gray-50 dark:hover:bg-gray-700"},e.createElement("td",{className:"px-4 py-3"},e.createElement("button",{onClick:()=>te(t.id),className:"font-medium text-blue-600 dark:text-blue-400 hover:underline text-left"},t.name),e.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400 mt-1 truncate max-w-xs"},t.description)),e.createElement("td",{className:"px-4 py-3"},E(t.lawfulBasis)),e.createElement("td",{className:"px-4 py-3"},J(t.status)),e.createElement("td",{className:"px-4 py-3"},O(t)),e.createElement("td",{className:"px-4 py-3"},e.createElement("span",{className:`text-xs ${t.involvesSensitiveData?"text-orange-600 dark:text-orange-400 font-medium":"text-gray-500 dark:text-gray-400"}`},t.involvesSensitiveData?"Yes":"No")),e.createElement("td",{className:"px-4 py-3 text-xs text-gray-500 dark:text-gray-400"},f(t.updatedAt)),e.createElement("td",{className:"px-4 py-3"},e.createElement("div",{className:"flex space-x-2"},e.createElement("button",{onClick:()=>j(t),className:"text-xs text-blue-600 dark:text-blue-400 hover:underline"},"Edit"),t.status!=="archived"&&e.createElement("button",{onClick:()=>I(t.id),className:"text-xs text-gray-600 dark:text-gray-400 hover:underline"},"Archive")))))))));return e.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${H}`},e.createElement("h2",{className:"text-xl font-bold mb-2"},U),e.createElement("p",{className:"mb-6 text-gray-600 dark:text-gray-300"},Y),W&&b$2==="list"&&se(),q&&b$2==="list"&&ae(),b$2==="list"&&le(),b$2==="form"&&ie(),b$2==="detail"&&re())};export{me as a};//# sourceMappingURL=chunk-C2IJWCZQ.mjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-C2IJWCZQ.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../packages/ndpr-toolkit/src/components/lawful-basis/LawfulBasisTracker.tsx"],"names":["EMPTY_FORM","LAWFUL_BASIS_OPTIONS","SENSITIVE_DATA_OPTIONS","LawfulBasisTracker","activities","onAddActivity","onUpdateActivity","onArchiveActivity","title","description","className","buttonClassName","showSummary","showComplianceGaps","viewMode","setViewMode","useState","formData","setFormData","editingId","setEditingId","selectedActivityId","setSelectedActivityId","statusFilter","setStatusFilter","basisFilter","setBasisFilter","searchTerm","setSearchTerm","formErrors","setFormErrors","filteredActivities","setFilteredActivities","useEffect","filtered","a","term","p","b","formatDate","timestamp","summary","generateLawfulBasisSummary","complianceGaps","assessComplianceGaps","parseList","value","s","handleNewActivity","handleEditActivity","activity","handleSubmitForm","activityData","tempActivity","__spreadProps","__spreadValues","validation","validateProcessingActivity","handleArchiveActivity","id","handleViewDetail","selectedActivity","renderStatusBadge","status","colorClasses","labels","React","renderBasisBadge","basis","renderApprovalIndicator","renderSummary","renderComplianceGaps","highSeverity","g","mediumSeverity","gap","index","renderForm","error","e","option","getLawfulBasisDescription","renderDetail","_a","warning","o","renderList"],"mappings":"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","file":"chunk-C2IJWCZQ.mjs","sourcesContent":["import React, { useState, useEffect } from 'react';\nimport {\n LawfulBasis,\n ProcessingActivity,\n SensitiveDataCondition,\n LawfulBasisSummary,\n} from '../../types/lawful-basis';\nimport {\n validateProcessingActivity,\n getLawfulBasisDescription,\n assessComplianceGaps,\n generateLawfulBasisSummary,\n LawfulBasisComplianceGap,\n} from '../../utils/lawful-basis';\n\nexport interface LawfulBasisTrackerProps {\n /**\n * List of processing activities to display\n */\n activities: ProcessingActivity[];\n\n /**\n * Callback when a new activity is created\n */\n onAddActivity?: (activity: Omit<ProcessingActivity, 'id' | 'createdAt' | 'updatedAt'>) => void;\n\n /**\n * Callback when an activity is updated\n */\n onUpdateActivity?: (id: string, updates: Partial<ProcessingActivity>) => void;\n\n /**\n * Callback when an activity is archived\n */\n onArchiveActivity?: (id: string) => void;\n\n /**\n * Title displayed on the tracker\n * @default \"Lawful Basis Tracker\"\n */\n title?: string;\n\n /**\n * Description text displayed on the tracker\n * @default \"Document and track the lawful basis for each processing activity as required by NDPA 2023 Section 25.\"\n */\n description?: string;\n\n /**\n * Custom CSS class for the tracker container\n */\n className?: string;\n\n /**\n * Custom CSS class for buttons\n */\n buttonClassName?: string;\n\n /**\n * Whether to show the compliance summary at the top\n * @default true\n */\n showSummary?: boolean;\n\n /**\n * Whether to show compliance gap alerts\n * @default true\n */\n showComplianceGaps?: boolean;\n}\n\ntype ViewMode = 'list' | 'form' | 'detail';\n\ninterface FormData {\n name: string;\n description: string;\n lawfulBasis: LawfulBasis;\n lawfulBasisJustification: string;\n dataCategories: string;\n involvesSensitiveData: boolean;\n sensitiveDataCondition: SensitiveDataCondition | '';\n dataSubjectCategories: string;\n purposes: string;\n retentionPeriod: string;\n retentionJustification: string;\n recipients: string;\n crossBorderTransfer: boolean;\n reviewDate: string;\n // LIA fields\n liaPurposeTest: string;\n liaNecessityTest: string;\n liaBalancingTest: string;\n liaSafeguards: string;\n liaConclusion: string;\n}\n\nconst EMPTY_FORM: FormData = {\n name: '',\n description: '',\n lawfulBasis: 'consent',\n lawfulBasisJustification: '',\n dataCategories: '',\n involvesSensitiveData: false,\n sensitiveDataCondition: '',\n dataSubjectCategories: '',\n purposes: '',\n retentionPeriod: '',\n retentionJustification: '',\n recipients: '',\n crossBorderTransfer: false,\n reviewDate: '',\n liaPurposeTest: '',\n liaNecessityTest: '',\n liaBalancingTest: '',\n liaSafeguards: '',\n liaConclusion: '',\n};\n\nconst LAWFUL_BASIS_OPTIONS: { value: LawfulBasis; label: string }[] = [\n { value: 'consent', label: 'Consent' },\n { value: 'contract', label: 'Contract' },\n { value: 'legal_obligation', label: 'Legal Obligation' },\n { value: 'vital_interests', label: 'Vital Interests' },\n { value: 'public_interest', label: 'Public Interest' },\n { value: 'legitimate_interests', label: 'Legitimate Interests' },\n];\n\nconst SENSITIVE_DATA_OPTIONS: { value: SensitiveDataCondition; label: string }[] = [\n { value: 'explicit_consent', label: 'Explicit Consent' },\n { value: 'employment_law', label: 'Employment Law' },\n { value: 'vital_interests_incapable', label: 'Vital Interests (Incapable)' },\n { value: 'nonprofit_legitimate', label: 'Nonprofit Legitimate Activities' },\n { value: 'publicly_available', label: 'Publicly Available Data' },\n { value: 'legal_claims', label: 'Legal Claims' },\n { value: 'substantial_public_interest', label: 'Substantial Public Interest' },\n { value: 'health_purposes', label: 'Health Purposes' },\n { value: 'public_health', label: 'Public Health' },\n { value: 'archiving_research', label: 'Archiving / Research' },\n];\n\nexport const LawfulBasisTracker: React.FC<LawfulBasisTrackerProps> = ({\n activities,\n onAddActivity,\n onUpdateActivity,\n onArchiveActivity,\n title = 'Lawful Basis Tracker',\n description = 'Document and track the lawful basis for each processing activity as required by NDPA 2023 Section 25.',\n className = '',\n buttonClassName = '',\n showSummary = true,\n showComplianceGaps = true,\n}) => {\n const [viewMode, setViewMode] = useState<ViewMode>('list');\n const [formData, setFormData] = useState<FormData>(EMPTY_FORM);\n const [editingId, setEditingId] = useState<string | null>(null);\n const [selectedActivityId, setSelectedActivityId] = useState<string | null>(null);\n const [statusFilter, setStatusFilter] = useState<string>('all');\n const [basisFilter, setBasisFilter] = useState<string>('all');\n const [searchTerm, setSearchTerm] = useState<string>('');\n const [formErrors, setFormErrors] = useState<string[]>([]);\n const [filteredActivities, setFilteredActivities] = useState<ProcessingActivity[]>(activities);\n\n // Filter activities when filters change\n useEffect(() => {\n let filtered = [...activities];\n\n if (statusFilter !== 'all') {\n filtered = filtered.filter(a => a.status === statusFilter);\n }\n\n if (basisFilter !== 'all') {\n filtered = filtered.filter(a => a.lawfulBasis === basisFilter);\n }\n\n if (searchTerm) {\n const term = searchTerm.toLowerCase();\n filtered = filtered.filter(\n a =>\n a.name.toLowerCase().includes(term) ||\n a.description.toLowerCase().includes(term) ||\n a.purposes.some(p => p.toLowerCase().includes(term))\n );\n }\n\n filtered.sort((a, b) => b.updatedAt - a.updatedAt);\n\n setFilteredActivities(filtered);\n }, [activities, statusFilter, basisFilter, searchTerm]);\n\n const formatDate = (timestamp: number): string => {\n return new Date(timestamp).toLocaleDateString();\n };\n\n const summary: LawfulBasisSummary = generateLawfulBasisSummary(activities);\n const complianceGaps: LawfulBasisComplianceGap[] = assessComplianceGaps(activities);\n\n // Parse comma-separated string into array\n const parseList = (value: string): string[] => {\n return value\n .split(',')\n .map(s => s.trim())\n .filter(s => s.length > 0);\n };\n\n // Open form for creating a new activity\n const handleNewActivity = () => {\n setFormData(EMPTY_FORM);\n setEditingId(null);\n setFormErrors([]);\n setViewMode('form');\n };\n\n // Open form for editing an existing activity\n const handleEditActivity = (activity: ProcessingActivity) => {\n setFormData({\n name: activity.name,\n description: activity.description,\n lawfulBasis: activity.lawfulBasis,\n lawfulBasisJustification: activity.lawfulBasisJustification,\n dataCategories: activity.dataCategories.join(', '),\n involvesSensitiveData: activity.involvesSensitiveData,\n sensitiveDataCondition: activity.sensitiveDataCondition || '',\n dataSubjectCategories: activity.dataSubjectCategories.join(', '),\n purposes: activity.purposes.join(', '),\n retentionPeriod: activity.retentionPeriod,\n retentionJustification: activity.retentionJustification || '',\n recipients: (activity.recipients || []).join(', '),\n crossBorderTransfer: activity.crossBorderTransfer,\n reviewDate: activity.reviewDate\n ? new Date(activity.reviewDate).toISOString().split('T')[0]\n : '',\n liaPurposeTest: '',\n liaNecessityTest: '',\n liaBalancingTest: '',\n liaSafeguards: '',\n liaConclusion: '',\n });\n setEditingId(activity.id);\n setFormErrors([]);\n setViewMode('form');\n };\n\n // Handle form submission\n const handleSubmitForm = () => {\n const activityData: Omit<ProcessingActivity, 'id' | 'createdAt' | 'updatedAt'> = {\n name: formData.name,\n description: formData.description,\n lawfulBasis: formData.lawfulBasis,\n lawfulBasisJustification: formData.lawfulBasisJustification,\n dataCategories: parseList(formData.dataCategories),\n involvesSensitiveData: formData.involvesSensitiveData,\n sensitiveDataCondition: formData.sensitiveDataCondition || undefined,\n dataSubjectCategories: parseList(formData.dataSubjectCategories),\n purposes: parseList(formData.purposes),\n retentionPeriod: formData.retentionPeriod,\n retentionJustification: formData.retentionJustification || undefined,\n recipients: formData.recipients ? parseList(formData.recipients) : undefined,\n crossBorderTransfer: formData.crossBorderTransfer,\n reviewDate: formData.reviewDate ? new Date(formData.reviewDate).getTime() : undefined,\n status: 'active',\n };\n\n // Validate using our utility\n const tempActivity: ProcessingActivity = {\n ...activityData,\n id: editingId || 'temp',\n createdAt: Date.now(),\n updatedAt: Date.now(),\n };\n\n const validation = validateProcessingActivity(tempActivity);\n if (!validation.isValid) {\n setFormErrors(validation.errors);\n return;\n }\n\n if (editingId && onUpdateActivity) {\n onUpdateActivity(editingId, activityData);\n } else if (onAddActivity) {\n onAddActivity(activityData);\n }\n\n setFormData(EMPTY_FORM);\n setEditingId(null);\n setFormErrors([]);\n setViewMode('list');\n };\n\n // Handle archiving\n const handleArchiveActivity = (id: string) => {\n if (onArchiveActivity) {\n onArchiveActivity(id);\n }\n };\n\n // View activity detail\n const handleViewDetail = (id: string) => {\n setSelectedActivityId(id);\n setViewMode('detail');\n };\n\n const selectedActivity = selectedActivityId\n ? activities.find(a => a.id === selectedActivityId)\n : null;\n\n // Render status badge\n const renderStatusBadge = (status: ProcessingActivity['status']) => {\n const colorClasses: Record<ProcessingActivity['status'], string> = {\n active: 'bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200',\n inactive: 'bg-gray-100 text-gray-800 dark:bg-gray-900 dark:text-gray-200',\n under_review: 'bg-yellow-100 text-yellow-800 dark:bg-yellow-900 dark:text-yellow-200',\n archived: 'bg-red-100 text-red-800 dark:bg-red-900 dark:text-red-200',\n };\n\n const labels: Record<ProcessingActivity['status'], string> = {\n active: 'Active',\n inactive: 'Inactive',\n under_review: 'Under Review',\n archived: 'Archived',\n };\n\n return (\n <span className={`px-2 py-1 rounded text-xs font-medium ${colorClasses[status]}`}>\n {labels[status]}\n </span>\n );\n };\n\n // Render lawful basis badge\n const renderBasisBadge = (basis: LawfulBasis) => {\n const colorClasses: Record<LawfulBasis, string> = {\n consent: 'bg-blue-100 text-blue-800 dark:bg-blue-900 dark:text-blue-200',\n contract: 'bg-teal-100 text-teal-800 dark:bg-teal-900 dark:text-teal-200',\n legal_obligation: 'bg-purple-100 text-purple-800 dark:bg-purple-900 dark:text-purple-200',\n vital_interests: 'bg-red-100 text-red-800 dark:bg-red-900 dark:text-red-200',\n public_interest: 'bg-orange-100 text-orange-800 dark:bg-orange-900 dark:text-orange-200',\n legitimate_interests: 'bg-indigo-100 text-indigo-800 dark:bg-indigo-900 dark:text-indigo-200',\n };\n\n const labels: Record<LawfulBasis, string> = {\n consent: 'Consent',\n contract: 'Contract',\n legal_obligation: 'Legal Obligation',\n vital_interests: 'Vital Interests',\n public_interest: 'Public Interest',\n legitimate_interests: 'Legitimate Interests',\n };\n\n return (\n <span className={`px-2 py-1 rounded text-xs font-medium ${colorClasses[basis]}`}>\n {labels[basis]}\n </span>\n );\n };\n\n // Render DPO approval indicator\n const renderApprovalIndicator = (activity: ProcessingActivity) => {\n if (!activity.dpoApproval) {\n return (\n <span className=\"px-2 py-1 rounded text-xs font-medium bg-gray-100 text-gray-600 dark:bg-gray-700 dark:text-gray-400\">\n No DPO Review\n </span>\n );\n }\n\n if (activity.dpoApproval.approved) {\n return (\n <span className=\"px-2 py-1 rounded text-xs font-medium bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200\">\n Approved\n </span>\n );\n }\n\n return (\n <span className=\"px-2 py-1 rounded text-xs font-medium bg-yellow-100 text-yellow-800 dark:bg-yellow-900 dark:text-yellow-200\">\n Pending Approval\n </span>\n );\n };\n\n // Render compliance summary\n const renderSummary = () => {\n return (\n <div className=\"grid grid-cols-2 md:grid-cols-4 gap-4 mb-6\">\n <div className=\"bg-blue-50 dark:bg-blue-900/20 p-4 rounded-lg\">\n <p className=\"text-2xl font-bold text-blue-800 dark:text-blue-200\">\n {summary.totalActivities}\n </p>\n <p className=\"text-sm text-blue-600 dark:text-blue-300\">Total Activities</p>\n </div>\n <div className=\"bg-orange-50 dark:bg-orange-900/20 p-4 rounded-lg\">\n <p className=\"text-2xl font-bold text-orange-800 dark:text-orange-200\">\n {summary.sensitiveDataActivities}\n </p>\n <p className=\"text-sm text-orange-600 dark:text-orange-300\">Sensitive Data</p>\n </div>\n <div className=\"bg-purple-50 dark:bg-purple-900/20 p-4 rounded-lg\">\n <p className=\"text-2xl font-bold text-purple-800 dark:text-purple-200\">\n {summary.crossBorderActivities}\n </p>\n <p className=\"text-sm text-purple-600 dark:text-purple-300\">Cross-Border Transfers</p>\n </div>\n <div className=\"bg-red-50 dark:bg-red-900/20 p-4 rounded-lg\">\n <p className=\"text-2xl font-bold text-red-800 dark:text-red-200\">\n {summary.activitiesWithoutApproval.length}\n </p>\n <p className=\"text-sm text-red-600 dark:text-red-300\">Pending Approval</p>\n </div>\n </div>\n );\n };\n\n // Render compliance gaps\n const renderComplianceGaps = () => {\n if (complianceGaps.length === 0) {\n return (\n <div className=\"bg-green-50 dark:bg-green-900/20 p-4 rounded-lg mb-6\">\n <p className=\"text-sm text-green-800 dark:text-green-200 font-medium\">\n No compliance gaps detected.\n </p>\n <p className=\"text-xs text-green-700 dark:text-green-300 mt-1\">\n All processing activities appear to be properly documented.\n </p>\n </div>\n );\n }\n\n const highSeverity = complianceGaps.filter(g => g.severity === 'high');\n const mediumSeverity = complianceGaps.filter(g => g.severity === 'medium');\n\n return (\n <div className=\"mb-6\">\n {highSeverity.length > 0 && (\n <div className=\"bg-red-50 dark:bg-red-900/20 p-4 rounded-lg mb-3\">\n <p className=\"text-sm text-red-800 dark:text-red-200 font-medium mb-2\">\n High Priority ({highSeverity.length})\n </p>\n <ul className=\"space-y-1\">\n {highSeverity.map((gap, index) => (\n <li key={index} className=\"text-xs text-red-700 dark:text-red-300\">\n {gap.description}\n </li>\n ))}\n </ul>\n </div>\n )}\n {mediumSeverity.length > 0 && (\n <div className=\"bg-yellow-50 dark:bg-yellow-900/20 p-4 rounded-lg\">\n <p className=\"text-sm text-yellow-800 dark:text-yellow-200 font-medium mb-2\">\n Medium Priority ({mediumSeverity.length})\n </p>\n <ul className=\"space-y-1\">\n {mediumSeverity.map((gap, index) => (\n <li key={index} className=\"text-xs text-yellow-700 dark:text-yellow-300\">\n {gap.description}\n </li>\n ))}\n </ul>\n </div>\n )}\n </div>\n );\n };\n\n // Render form\n const renderForm = () => {\n return (\n <div>\n <div className=\"flex justify-between items-center mb-4\">\n <h3 className=\"text-lg font-medium\">\n {editingId ? 'Edit Processing Activity' : 'New Processing Activity'}\n </h3>\n <button\n onClick={() => {\n setViewMode('list');\n setFormErrors([]);\n }}\n className={`px-4 py-2 text-gray-600 dark:text-gray-300 bg-gray-100 dark:bg-gray-700 rounded hover:bg-gray-200 dark:hover:bg-gray-600 ${buttonClassName}`}\n >\n Cancel\n </button>\n </div>\n\n {formErrors.length > 0 && (\n <div className=\"bg-red-50 dark:bg-red-900/20 p-4 rounded-lg mb-4\">\n <p className=\"text-sm text-red-800 dark:text-red-200 font-medium mb-2\">\n Please correct the following errors:\n </p>\n <ul className=\"list-disc list-inside space-y-1\">\n {formErrors.map((error, index) => (\n <li key={index} className=\"text-xs text-red-700 dark:text-red-300\">\n {error}\n </li>\n ))}\n </ul>\n </div>\n )}\n\n <div className=\"space-y-4\">\n {/* Name */}\n <div>\n <label htmlFor=\"activityName\" className=\"block text-sm font-medium mb-1\">\n Activity Name *\n </label>\n <input\n type=\"text\"\n id=\"activityName\"\n value={formData.name}\n onChange={e => setFormData({ ...formData, name: e.target.value })}\n placeholder=\"e.g., Customer Account Management\"\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n {/* Description */}\n <div>\n <label htmlFor=\"activityDescription\" className=\"block text-sm font-medium mb-1\">\n Description *\n </label>\n <textarea\n id=\"activityDescription\"\n value={formData.description}\n onChange={e => setFormData({ ...formData, description: e.target.value })}\n placeholder=\"Describe what processing is performed...\"\n rows={3}\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n {/* Lawful Basis */}\n <div>\n <label htmlFor=\"lawfulBasis\" className=\"block text-sm font-medium mb-1\">\n Lawful Basis (NDPA Section 25) *\n </label>\n <select\n id=\"lawfulBasis\"\n value={formData.lawfulBasis}\n onChange={e =>\n setFormData({ ...formData, lawfulBasis: e.target.value as LawfulBasis })\n }\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n >\n {LAWFUL_BASIS_OPTIONS.map(option => (\n <option key={option.value} value={option.value}>\n {option.label}\n </option>\n ))}\n </select>\n <p className=\"mt-1 text-xs text-gray-500 dark:text-gray-400\">\n {getLawfulBasisDescription(formData.lawfulBasis)}\n </p>\n </div>\n\n {/* Justification */}\n <div>\n <label htmlFor=\"justification\" className=\"block text-sm font-medium mb-1\">\n Lawful Basis Justification *\n </label>\n <textarea\n id=\"justification\"\n value={formData.lawfulBasisJustification}\n onChange={e =>\n setFormData({ ...formData, lawfulBasisJustification: e.target.value })\n }\n placeholder=\"Document why this lawful basis applies to this processing activity...\"\n rows={3}\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n {/* Legitimate Interest Assessment (conditional) */}\n {formData.lawfulBasis === 'legitimate_interests' && (\n <div className=\"border border-indigo-200 dark:border-indigo-800 rounded-lg p-4 bg-indigo-50 dark:bg-indigo-900/20\">\n <h4 className=\"text-sm font-semibold text-indigo-800 dark:text-indigo-200 mb-3\">\n Legitimate Interest Assessment (LIA)\n </h4>\n <p className=\"text-xs text-indigo-600 dark:text-indigo-300 mb-4\">\n NDPA Section 25(1)(f) requires a balancing test when relying on legitimate interests.\n </p>\n\n <div className=\"space-y-3\">\n <div>\n <label htmlFor=\"liaPurpose\" className=\"block text-sm font-medium mb-1\">\n Purpose Test\n </label>\n <textarea\n id=\"liaPurpose\"\n value={formData.liaPurposeTest}\n onChange={e =>\n setFormData({ ...formData, liaPurposeTest: e.target.value })\n }\n placeholder=\"Describe the legitimate interest being pursued...\"\n rows={2}\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n <div>\n <label htmlFor=\"liaNecessity\" className=\"block text-sm font-medium mb-1\">\n Necessity Test\n </label>\n <textarea\n id=\"liaNecessity\"\n value={formData.liaNecessityTest}\n onChange={e =>\n setFormData({ ...formData, liaNecessityTest: e.target.value })\n }\n placeholder=\"Explain why this processing is necessary for the stated purpose...\"\n rows={2}\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n <div>\n <label htmlFor=\"liaBalancing\" className=\"block text-sm font-medium mb-1\">\n Balancing Test\n </label>\n <textarea\n id=\"liaBalancing\"\n value={formData.liaBalancingTest}\n onChange={e =>\n setFormData({ ...formData, liaBalancingTest: e.target.value })\n }\n placeholder=\"Assess the impact on data subjects' rights and interests...\"\n rows={2}\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n <div>\n <label htmlFor=\"liaSafeguards\" className=\"block text-sm font-medium mb-1\">\n Safeguards\n </label>\n <input\n type=\"text\"\n id=\"liaSafeguards\"\n value={formData.liaSafeguards}\n onChange={e =>\n setFormData({ ...formData, liaSafeguards: e.target.value })\n }\n placeholder=\"List safeguards (comma-separated)...\"\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n <div>\n <label htmlFor=\"liaConclusion\" className=\"block text-sm font-medium mb-1\">\n Conclusion\n </label>\n <textarea\n id=\"liaConclusion\"\n value={formData.liaConclusion}\n onChange={e =>\n setFormData({ ...formData, liaConclusion: e.target.value })\n }\n placeholder=\"State your overall conclusion...\"\n rows={2}\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n </div>\n </div>\n )}\n\n {/* Data Categories */}\n <div>\n <label htmlFor=\"dataCategories\" className=\"block text-sm font-medium mb-1\">\n Data Categories *\n </label>\n <input\n type=\"text\"\n id=\"dataCategories\"\n value={formData.dataCategories}\n onChange={e => setFormData({ ...formData, dataCategories: e.target.value })}\n placeholder=\"e.g., Name, Email, Phone Number (comma-separated)\"\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n {/* Sensitive Data */}\n <div>\n <label className=\"flex items-center space-x-2\">\n <input\n type=\"checkbox\"\n checked={formData.involvesSensitiveData}\n onChange={e =>\n setFormData({\n ...formData,\n involvesSensitiveData: e.target.checked,\n sensitiveDataCondition: e.target.checked\n ? formData.sensitiveDataCondition\n : '',\n })\n }\n className=\"rounded border-gray-300 dark:border-gray-600 text-blue-600 focus:ring-blue-500\"\n />\n <span className=\"text-sm font-medium\">\n Involves Sensitive Personal Data (NDPA Section 27)\n </span>\n </label>\n </div>\n\n {/* Sensitive Data Condition (conditional) */}\n {formData.involvesSensitiveData && (\n <div>\n <label htmlFor=\"sensitiveCondition\" className=\"block text-sm font-medium mb-1\">\n Sensitive Data Condition (NDPA Section 27) *\n </label>\n <select\n id=\"sensitiveCondition\"\n value={formData.sensitiveDataCondition}\n onChange={e =>\n setFormData({\n ...formData,\n sensitiveDataCondition: e.target.value as SensitiveDataCondition,\n })\n }\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n >\n <option value=\"\">Select a condition...</option>\n {SENSITIVE_DATA_OPTIONS.map(option => (\n <option key={option.value} value={option.value}>\n {option.label}\n </option>\n ))}\n </select>\n </div>\n )}\n\n {/* Data Subject Categories */}\n <div>\n <label htmlFor=\"dataSubjectCategories\" className=\"block text-sm font-medium mb-1\">\n Data Subject Categories *\n </label>\n <input\n type=\"text\"\n id=\"dataSubjectCategories\"\n value={formData.dataSubjectCategories}\n onChange={e =>\n setFormData({ ...formData, dataSubjectCategories: e.target.value })\n }\n placeholder=\"e.g., Customers, Employees, Vendors (comma-separated)\"\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n {/* Purposes */}\n <div>\n <label htmlFor=\"purposes\" className=\"block text-sm font-medium mb-1\">\n Processing Purposes *\n </label>\n <input\n type=\"text\"\n id=\"purposes\"\n value={formData.purposes}\n onChange={e => setFormData({ ...formData, purposes: e.target.value })}\n placeholder=\"e.g., Account management, Service delivery (comma-separated)\"\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n {/* Retention Period */}\n <div className=\"grid grid-cols-1 md:grid-cols-2 gap-4\">\n <div>\n <label htmlFor=\"retentionPeriod\" className=\"block text-sm font-medium mb-1\">\n Retention Period *\n </label>\n <input\n type=\"text\"\n id=\"retentionPeriod\"\n value={formData.retentionPeriod}\n onChange={e => setFormData({ ...formData, retentionPeriod: e.target.value })}\n placeholder=\"e.g., 3 years after account closure\"\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n <div>\n <label htmlFor=\"retentionJustification\" className=\"block text-sm font-medium mb-1\">\n Retention Justification\n </label>\n <input\n type=\"text\"\n id=\"retentionJustification\"\n value={formData.retentionJustification}\n onChange={e =>\n setFormData({ ...formData, retentionJustification: e.target.value })\n }\n placeholder=\"Reason for the retention period\"\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n </div>\n\n {/* Recipients */}\n <div>\n <label htmlFor=\"recipients\" className=\"block text-sm font-medium mb-1\">\n Recipients\n </label>\n <input\n type=\"text\"\n id=\"recipients\"\n value={formData.recipients}\n onChange={e => setFormData({ ...formData, recipients: e.target.value })}\n placeholder=\"e.g., Payment processor, Cloud provider (comma-separated)\"\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n {/* Cross-Border Transfer */}\n <div>\n <label className=\"flex items-center space-x-2\">\n <input\n type=\"checkbox\"\n checked={formData.crossBorderTransfer}\n onChange={e =>\n setFormData({ ...formData, crossBorderTransfer: e.target.checked })\n }\n className=\"rounded border-gray-300 dark:border-gray-600 text-blue-600 focus:ring-blue-500\"\n />\n <span className=\"text-sm font-medium\">\n Involves Cross-Border Transfer Outside Nigeria\n </span>\n </label>\n </div>\n\n {/* Review Date */}\n <div>\n <label htmlFor=\"reviewDate\" className=\"block text-sm font-medium mb-1\">\n Next Review Date\n </label>\n <input\n type=\"date\"\n id=\"reviewDate\"\n value={formData.reviewDate}\n onChange={e => setFormData({ ...formData, reviewDate: e.target.value })}\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n {/* Submit button */}\n <div className=\"flex justify-end space-x-3 pt-4\">\n <button\n onClick={() => {\n setViewMode('list');\n setFormErrors([]);\n }}\n className={`px-4 py-2 text-gray-600 dark:text-gray-300 bg-gray-100 dark:bg-gray-700 rounded hover:bg-gray-200 dark:hover:bg-gray-600 ${buttonClassName}`}\n >\n Cancel\n </button>\n <button\n onClick={handleSubmitForm}\n className={`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${buttonClassName}`}\n >\n {editingId ? 'Update Activity' : 'Create Activity'}\n </button>\n </div>\n </div>\n </div>\n );\n };\n\n // Render activity detail view\n const renderDetail = () => {\n if (!selectedActivity) {\n return (\n <div className=\"flex items-center justify-center h-64 bg-gray-50 dark:bg-gray-700 rounded-md\">\n <p className=\"text-gray-500 dark:text-gray-400\">Activity not found.</p>\n </div>\n );\n }\n\n const validation = validateProcessingActivity(selectedActivity);\n\n return (\n <div>\n <div className=\"flex justify-between items-start mb-4\">\n <div>\n <button\n onClick={() => setViewMode('list')}\n className=\"text-sm text-blue-600 dark:text-blue-400 hover:underline mb-2\"\n >\n Back to list\n </button>\n <h3 className=\"text-lg font-medium\">{selectedActivity.name}</h3>\n </div>\n <div className=\"flex space-x-2\">\n {renderBasisBadge(selectedActivity.lawfulBasis)}\n {renderStatusBadge(selectedActivity.status)}\n {renderApprovalIndicator(selectedActivity)}\n </div>\n </div>\n\n {/* Validation warnings */}\n {validation.warnings.length > 0 && (\n <div className=\"bg-yellow-50 dark:bg-yellow-900/20 p-3 rounded-md mb-4\">\n <p className=\"text-sm text-yellow-800 dark:text-yellow-200 font-medium mb-1\">\n Warnings\n </p>\n <ul className=\"list-disc list-inside space-y-1\">\n {validation.warnings.map((warning, index) => (\n <li key={index} className=\"text-xs text-yellow-700 dark:text-yellow-300\">\n {warning}\n </li>\n ))}\n </ul>\n </div>\n )}\n\n {/* Activity details */}\n <div className=\"grid grid-cols-1 md:grid-cols-2 gap-4 mb-6\">\n <div>\n <p className=\"text-sm\">\n <span className=\"font-medium\">Description:</span> {selectedActivity.description}\n </p>\n <p className=\"text-sm mt-2\">\n <span className=\"font-medium\">Lawful Basis:</span>{' '}\n {getLawfulBasisDescription(selectedActivity.lawfulBasis)}\n </p>\n <p className=\"text-sm mt-2\">\n <span className=\"font-medium\">Justification:</span>{' '}\n {selectedActivity.lawfulBasisJustification}\n </p>\n </div>\n <div>\n <p className=\"text-sm\">\n <span className=\"font-medium\">Data Categories:</span>{' '}\n {selectedActivity.dataCategories.join(', ')}\n </p>\n <p className=\"text-sm mt-2\">\n <span className=\"font-medium\">Data Subject Categories:</span>{' '}\n {selectedActivity.dataSubjectCategories.join(', ')}\n </p>\n <p className=\"text-sm mt-2\">\n <span className=\"font-medium\">Purposes:</span>{' '}\n {selectedActivity.purposes.join(', ')}\n </p>\n <p className=\"text-sm mt-2\">\n <span className=\"font-medium\">Retention Period:</span>{' '}\n {selectedActivity.retentionPeriod}\n {selectedActivity.retentionJustification && (\n <span className=\"text-gray-500 dark:text-gray-400\">\n {' '}\n ({selectedActivity.retentionJustification})\n </span>\n )}\n </p>\n </div>\n </div>\n\n <div className=\"grid grid-cols-1 md:grid-cols-2 gap-4 mb-6\">\n <div>\n <p className=\"text-sm\">\n <span className=\"font-medium\">Sensitive Data:</span>{' '}\n {selectedActivity.involvesSensitiveData ? 'Yes' : 'No'}\n {selectedActivity.sensitiveDataCondition && (\n <span>\n {' '}\n (Condition:{' '}\n {SENSITIVE_DATA_OPTIONS.find(\n o => o.value === selectedActivity.sensitiveDataCondition\n )?.label || selectedActivity.sensitiveDataCondition}\n )\n </span>\n )}\n </p>\n <p className=\"text-sm mt-2\">\n <span className=\"font-medium\">Cross-Border Transfer:</span>{' '}\n {selectedActivity.crossBorderTransfer ? 'Yes' : 'No'}\n </p>\n {selectedActivity.recipients && selectedActivity.recipients.length > 0 && (\n <p className=\"text-sm mt-2\">\n <span className=\"font-medium\">Recipients:</span>{' '}\n {selectedActivity.recipients.join(', ')}\n </p>\n )}\n </div>\n <div>\n <p className=\"text-sm\">\n <span className=\"font-medium\">Created:</span>{' '}\n {formatDate(selectedActivity.createdAt)}\n </p>\n <p className=\"text-sm mt-2\">\n <span className=\"font-medium\">Last Updated:</span>{' '}\n {formatDate(selectedActivity.updatedAt)}\n </p>\n {selectedActivity.reviewDate && (\n <p className=\"text-sm mt-2\">\n <span className=\"font-medium\">Next Review:</span>{' '}\n {formatDate(selectedActivity.reviewDate)}\n {selectedActivity.reviewDate < Date.now() && (\n <span className=\"text-red-600 dark:text-red-400 font-medium\"> (Overdue)</span>\n )}\n </p>\n )}\n </div>\n </div>\n\n {/* DPO Approval details */}\n {selectedActivity.dpoApproval && (\n <div className=\"bg-gray-50 dark:bg-gray-700 p-4 rounded-md mb-6\">\n <h4 className=\"text-sm font-semibold mb-2\">DPO Approval</h4>\n <p className=\"text-sm\">\n <span className=\"font-medium\">Status:</span>{' '}\n {selectedActivity.dpoApproval.approved ? 'Approved' : 'Not Approved'}\n </p>\n <p className=\"text-sm mt-1\">\n <span className=\"font-medium\">Approved By:</span>{' '}\n {selectedActivity.dpoApproval.approvedBy}\n </p>\n <p className=\"text-sm mt-1\">\n <span className=\"font-medium\">Date:</span>{' '}\n {formatDate(selectedActivity.dpoApproval.approvedAt)}\n </p>\n {selectedActivity.dpoApproval.notes && (\n <p className=\"text-sm mt-1\">\n <span className=\"font-medium\">Notes:</span>{' '}\n {selectedActivity.dpoApproval.notes}\n </p>\n )}\n </div>\n )}\n\n {/* Action buttons */}\n <div className=\"flex space-x-3\">\n <button\n onClick={() => handleEditActivity(selectedActivity)}\n className={`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${buttonClassName}`}\n >\n Edit\n </button>\n {selectedActivity.status !== 'archived' && (\n <button\n onClick={() => handleArchiveActivity(selectedActivity.id)}\n className={`px-4 py-2 bg-gray-600 text-white rounded hover:bg-gray-700 ${buttonClassName}`}\n >\n Archive\n </button>\n )}\n </div>\n </div>\n );\n };\n\n // Render activity list\n const renderList = () => {\n return (\n <div>\n {/* Filters */}\n <div className=\"mb-6 grid grid-cols-1 md:grid-cols-4 gap-4\">\n <div>\n <label htmlFor=\"basisFilter\" className=\"block text-sm font-medium mb-1\">\n Lawful Basis\n </label>\n <select\n id=\"basisFilter\"\n value={basisFilter}\n onChange={e => setBasisFilter(e.target.value)}\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n >\n <option value=\"all\">All Bases</option>\n {LAWFUL_BASIS_OPTIONS.map(option => (\n <option key={option.value} value={option.value}>\n {option.label}\n </option>\n ))}\n </select>\n </div>\n\n <div>\n <label htmlFor=\"statusFilterSelect\" className=\"block text-sm font-medium mb-1\">\n Status\n </label>\n <select\n id=\"statusFilterSelect\"\n value={statusFilter}\n onChange={e => setStatusFilter(e.target.value)}\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n >\n <option value=\"all\">All Statuses</option>\n <option value=\"active\">Active</option>\n <option value=\"inactive\">Inactive</option>\n <option value=\"under_review\">Under Review</option>\n <option value=\"archived\">Archived</option>\n </select>\n </div>\n\n <div>\n <label htmlFor=\"searchInput\" className=\"block text-sm font-medium mb-1\">\n Search\n </label>\n <input\n type=\"text\"\n id=\"searchInput\"\n value={searchTerm}\n onChange={e => setSearchTerm(e.target.value)}\n placeholder=\"Search activities...\"\n className=\"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500\"\n />\n </div>\n\n <div className=\"flex items-end\">\n <button\n onClick={handleNewActivity}\n className={`w-full px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${buttonClassName}`}\n >\n Add Activity\n </button>\n </div>\n </div>\n\n {/* Activities table */}\n {filteredActivities.length === 0 ? (\n <div className=\"flex items-center justify-center h-32 bg-gray-50 dark:bg-gray-700 rounded-md\">\n <p className=\"text-gray-500 dark:text-gray-400 text-sm\">\n No processing activities found.\n </p>\n </div>\n ) : (\n <div className=\"overflow-x-auto\">\n <table className=\"w-full text-sm text-left\">\n <thead className=\"text-xs uppercase bg-gray-50 dark:bg-gray-700\">\n <tr>\n <th className=\"px-4 py-3\">Activity</th>\n <th className=\"px-4 py-3\">Lawful Basis</th>\n <th className=\"px-4 py-3\">Status</th>\n <th className=\"px-4 py-3\">DPO Approval</th>\n <th className=\"px-4 py-3\">Sensitive Data</th>\n <th className=\"px-4 py-3\">Last Updated</th>\n <th className=\"px-4 py-3\">Actions</th>\n </tr>\n </thead>\n <tbody>\n {filteredActivities.map(activity => (\n <tr\n key={activity.id}\n className=\"border-b border-gray-200 dark:border-gray-600 hover:bg-gray-50 dark:hover:bg-gray-700\"\n >\n <td className=\"px-4 py-3\">\n <button\n onClick={() => handleViewDetail(activity.id)}\n className=\"font-medium text-blue-600 dark:text-blue-400 hover:underline text-left\"\n >\n {activity.name}\n </button>\n <p className=\"text-xs text-gray-500 dark:text-gray-400 mt-1 truncate max-w-xs\">\n {activity.description}\n </p>\n </td>\n <td className=\"px-4 py-3\">{renderBasisBadge(activity.lawfulBasis)}</td>\n <td className=\"px-4 py-3\">{renderStatusBadge(activity.status)}</td>\n <td className=\"px-4 py-3\">{renderApprovalIndicator(activity)}</td>\n <td className=\"px-4 py-3\">\n <span\n className={`text-xs ${\n activity.involvesSensitiveData\n ? 'text-orange-600 dark:text-orange-400 font-medium'\n : 'text-gray-500 dark:text-gray-400'\n }`}\n >\n {activity.involvesSensitiveData ? 'Yes' : 'No'}\n </span>\n </td>\n <td className=\"px-4 py-3 text-xs text-gray-500 dark:text-gray-400\">\n {formatDate(activity.updatedAt)}\n </td>\n <td className=\"px-4 py-3\">\n <div className=\"flex space-x-2\">\n <button\n onClick={() => handleEditActivity(activity)}\n className=\"text-xs text-blue-600 dark:text-blue-400 hover:underline\"\n >\n Edit\n </button>\n {activity.status !== 'archived' && (\n <button\n onClick={() => handleArchiveActivity(activity.id)}\n className=\"text-xs text-gray-600 dark:text-gray-400 hover:underline\"\n >\n Archive\n </button>\n )}\n </div>\n </td>\n </tr>\n ))}\n </tbody>\n </table>\n </div>\n )}\n </div>\n );\n };\n\n return (\n <div className={`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${className}`}>\n <h2 className=\"text-xl font-bold mb-2\">{title}</h2>\n <p className=\"mb-6 text-gray-600 dark:text-gray-300\">{description}</p>\n\n {/* Compliance Summary */}\n {showSummary && viewMode === 'list' && renderSummary()}\n\n {/* Compliance Gaps */}\n {showComplianceGaps && viewMode === 'list' && renderComplianceGaps()}\n\n {/* Main content area */}\n {viewMode === 'list' && renderList()}\n {viewMode === 'form' && renderForm()}\n {viewMode === 'detail' && renderDetail()}\n </div>\n );\n};\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';function o(i){var a,d;let t=[];return i.id||t.push("Request ID is required"),i.type||t.push("Request type is required"),i.status||t.push("Request status is required"),i.createdAt||t.push("Creation timestamp is required"),(a=i.subject)!=null&&a.name||t.push("Data subject name is required"),(d=i.subject)!=null&&d.email||t.push("Data subject email is required"),{formattedRequest:{requestId:i.id,requestType:i.type,status:i.status,createdDate:new Date(i.createdAt).toISOString(),lastUpdated:i.updatedAt?new Date(i.updatedAt).toISOString():void 0,dueDate:i.dueDate?new Date(i.dueDate).toISOString():void 0,dataSubject:{name:i.subject.name,email:i.subject.email,phone:i.subject.phone||"Not provided",identifier:{type:i.subject.identifierType||"Not specified",value:i.subject.identifierValue||"Not provided"}},additionalInformation:i.additionalInfo||{},verificationStatus:i.verification?`${i.verification.verified?"Verified":"Not verified"}${i.verification.method?` via ${i.verification.method}`:""}`:"Pending verification",attachments:i.attachments?i.attachments.map(e=>({name:e.name,type:e.type,addedOn:new Date(e.addedAt).toISOString()})):[]},isValid:t.length===0,validationErrors:t}}exports.a=o;//# sourceMappingURL=chunk-CMZTI7SG.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-CMZTI7SG.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../packages/ndpr-toolkit/src/utils/dsr.ts"],"names":["formatDSRRequest","request","_a","_b","validationErrors","attachment"],"mappings":"aAOO,SAASA,EAAiBC,CAAAA,CAI/B,CAXF,IAAAC,CAAAA,CAAAC,CAAAA,CAYE,IAAMC,CAAAA,CAA6B,GAGnC,OAAKH,CAAAA,CAAQ,IACXG,CAAAA,CAAiB,IAAA,CAAK,wBAAwB,CAAA,CAG3CH,CAAAA,CAAQ,MACXG,CAAAA,CAAiB,IAAA,CAAK,0BAA0B,CAAA,CAG7CH,CAAAA,CAAQ,QACXG,CAAAA,CAAiB,IAAA,CAAK,4BAA4B,CAAA,CAG/CH,CAAAA,CAAQ,WACXG,CAAAA,CAAiB,IAAA,CAAK,gCAAgC,CAAA,CAAA,CAGnDF,CAAAA,CAAAD,EAAQ,OAAA,GAAR,IAAA,EAAAC,EAAiB,IAAA,EACpBE,CAAAA,CAAiB,KAAK,+BAA+B,CAAA,CAAA,CAGlDD,CAAAA,CAAAF,CAAAA,CAAQ,UAAR,IAAA,EAAAE,CAAAA,CAAiB,OACpBC,CAAAA,CAAiB,IAAA,CAAK,gCAAgC,CAAA,CAmCjD,CACL,iBAhCuB,CACvB,SAAA,CAAWH,EAAQ,EAAA,CACnB,WAAA,CAAaA,EAAQ,IAAA,CACrB,MAAA,CAAQA,EAAQ,MAAA,CAChB,WAAA,CAAa,IAAI,IAAA,CAAKA,CAAAA,CAAQ,SAAS,CAAA,CAAE,WAAA,GACzC,WAAA,CAAaA,CAAAA,CAAQ,UAAY,IAAI,IAAA,CAAKA,EAAQ,SAAS,CAAA,CAAE,aAAY,CAAI,MAAA,CAC7E,QAASA,CAAAA,CAAQ,OAAA,CACb,IAAI,IAAA,CAAKA,CAAAA,CAAQ,OAAO,CAAA,CAAE,aAAY,CACtC,MAAA,CACJ,YAAa,CACX,IAAA,CAAMA,EAAQ,OAAA,CAAQ,IAAA,CACtB,MAAOA,CAAAA,CAAQ,OAAA,CAAQ,MACvB,KAAA,CAAOA,CAAAA,CAAQ,QAAQ,KAAA,EAAS,cAAA,CAChC,WAAY,CACV,IAAA,CAAMA,EAAQ,OAAA,CAAQ,cAAA,EAAkB,gBACxC,KAAA,CAAOA,CAAAA,CAAQ,QAAQ,eAAA,EAAmB,cAC5C,CACF,CAAA,CACA,qBAAA,CAAuBA,EAAQ,cAAA,EAAkB,GACjD,kBAAA,CAAoBA,CAAAA,CAAQ,aACxB,CAAA,EAAGA,CAAAA,CAAQ,aAAa,QAAA,CAAW,UAAA,CAAa,cAAc,CAAA,EAAGA,CAAAA,CAAQ,aAAa,MAAA,CAAS,CAAA,KAAA,EAAQA,EAAQ,YAAA,CAAa,MAAM,GAAK,EAAE,CAAA,CAAA,CACzI,uBACJ,WAAA,CAAaA,CAAAA,CAAQ,YACjBA,CAAAA,CAAQ,WAAA,CAAY,IAAII,CAAAA,GAAe,CACrC,KAAMA,CAAAA,CAAW,IAAA,CACjB,KAAMA,CAAAA,CAAW,IAAA,CACjB,QAAS,IAAI,IAAA,CAAKA,EAAW,OAAO,CAAA,CAAE,aACxC,CAAA,CAAE,EACF,EACN,EAIE,OAAA,CAASD,CAAAA,CAAiB,SAAW,CAAA,CACrC,gBAAA,CAAAA,CACF,CACF","file":"chunk-CMZTI7SG.js","sourcesContent":["import { DSRRequest } from '../types/dsr';\n\n/**\n * Formats a DSR request for display or submission\n * @param request The DSR request to format\n * @returns Formatted request data\n */\nexport function formatDSRRequest(request: DSRRequest): {\n formattedRequest: Record<string, any>;\n isValid: boolean;\n validationErrors: string[];\n} {\n const validationErrors: string[] = [];\n \n // Validate required fields\n if (!request.id) {\n validationErrors.push('Request ID is required');\n }\n \n if (!request.type) {\n validationErrors.push('Request type is required');\n }\n \n if (!request.status) {\n validationErrors.push('Request status is required');\n }\n \n if (!request.createdAt) {\n validationErrors.push('Creation timestamp is required');\n }\n \n if (!request.subject?.name) {\n validationErrors.push('Data subject name is required');\n }\n \n if (!request.subject?.email) {\n validationErrors.push('Data subject email is required');\n }\n \n // Format the request for display or submission\n const formattedRequest = {\n requestId: request.id,\n requestType: request.type,\n status: request.status,\n createdDate: new Date(request.createdAt).toISOString(),\n lastUpdated: request.updatedAt ? new Date(request.updatedAt).toISOString() : undefined,\n dueDate: request.dueDate \n ? new Date(request.dueDate).toISOString() \n : undefined,\n dataSubject: {\n name: request.subject.name,\n email: request.subject.email,\n phone: request.subject.phone || 'Not provided',\n identifier: {\n type: request.subject.identifierType || 'Not specified',\n value: request.subject.identifierValue || 'Not provided'\n }\n },\n additionalInformation: request.additionalInfo || {},\n verificationStatus: request.verification \n ? `${request.verification.verified ? 'Verified' : 'Not verified'}${request.verification.method ? ` via ${request.verification.method}` : ''}`\n : 'Pending verification',\n attachments: request.attachments \n ? request.attachments.map(attachment => ({\n name: attachment.name,\n type: attachment.type,\n addedOn: new Date(attachment.addedAt).toISOString()\n }))\n : []\n };\n \n return {\n formattedRequest,\n isValid: validationErrors.length === 0,\n validationErrors\n };\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {a}from'./chunk-UYP64PV7.mjs';import {b,a as a$1}from'./chunk-WWT2ZSNU.mjs';import {useState,useEffect}from'react';function U({templates:m,initialPolicy:g,storageKey:d="ndpr_privacy_policy",useLocalStorage:f=true,onGenerate:v}){let[r,u]=useState(g||null),[a$2,y]=useState(null),[c,P]=useState({name:"",website:"",privacyEmail:"",address:"",privacyPhone:"",dpoName:"",dpoEmail:"",industry:""});useEffect(()=>{if(f&&typeof window!="undefined"&&!g)try{let i=localStorage.getItem(d);if(i){let{policy:n,template:e,organizationInfo:t}=JSON.parse(i);if(n&&u(n),e){let s=m.find(E=>E.id===e.id);s&&y(s);}t&&P(t);}}catch(i){console.error("Error loading privacy policy data:",i);}},[d,f,g,m]),useEffect(()=>{if(f&&typeof window!="undefined")try{localStorage.setItem(d,JSON.stringify({policy:r,template:a$2,organizationInfo:c}));}catch(i){console.error("Error saving privacy policy data:",i);}},[r,a$2,c,d,f]);let I=i=>{let n=m.find(s=>s.id===i);if(!n)return false;y(n);n.sections.map(s=>b(a$1({},s),{customContent:void 0}));return Object.keys(n.variables).forEach(s=>{n.variables[s].defaultValue||"";}),true},h=i=>{P(n=>a$1(a$1({},n),i));},V=(i,n)=>{a$2&&(r?u(e=>e&&b(a$1({},e),{sections:e.sections.map(t=>t.id===i?b(a$1({},t),{included:n}):t)})):y(e=>e&&b(a$1({},e),{sections:e.sections.map(t=>t.id===i?b(a$1({},t),{included:n}):t)})));},w=(i,n)=>{a$2&&(r?u(e=>e&&b(a$1({},e),{sections:e.sections.map(t=>t.id===i?b(a$1({},t),{customContent:n}):t)})):y(e=>e&&b(a$1({},e),{sections:e.sections.map(t=>t.id===i?b(a$1({},t),{customContent:n}):t)})));},O=(i,n)=>{r&&u(e=>e&&b(a$1({},e),{variableValues:b(a$1({},e.variableValues),{[i]:n})}));},z=()=>"policy_"+Date.now()+"_"+Math.random().toString(36).substr(2,9);return {policy:r,selectedTemplate:a$2,organizationInfo:c,selectTemplate:I,updateOrganizationInfo:h,toggleSection:V,updateSectionContent:w,updateVariableValue:O,generatePolicy:()=>{if(!a$2)throw new Error("No template selected");let i=Date.now(),n={id:(r==null?void 0:r.id)||z(),title:`Privacy Policy for ${c.name}`,templateId:a$2.id,organizationInfo:c,sections:a$2.sections.map(e=>{var t;return b(a$1({},e),{customContent:(t=r==null?void 0:r.sections.find(s=>s.id===e.id))==null?void 0:t.customContent})}),variableValues:(r==null?void 0:r.variableValues)||{},effectiveDate:i,lastUpdated:i,version:"1.0"};return u(n),v&&v(n),n},getPolicyText:()=>{if(!r)return {fullText:"",sectionTexts:{},missingVariables:[]};let i=a(r.sections,r.organizationInfo);return typeof i=="string"?{fullText:i,sectionTexts:{full:i},missingVariables:[]}:i},resetPolicy:()=>{u(null),y(null),P({name:"",website:"",privacyEmail:"",address:"",privacyPhone:"",dpoName:"",dpoEmail:"",industry:""}),f&&typeof window!="undefined"&&localStorage.removeItem(d);},isValid:()=>{let i=[];if(a$2||i.push("No template selected"),c.name||i.push("Organization name is required"),c.website||i.push("Organization website is required"),c.privacyEmail||i.push("Privacy contact email is required"),a$2){let n=a$2.sections.filter(t=>t.required),e=(r==null?void 0:r.sections.filter(t=>t.included))||[];n.forEach(t=>{e.some(s=>s.id===t.id)||i.push(`Required section "${t.title}" must be included`);});}return a$2&&r&&Object.entries(a$2.variables).forEach(([n,e])=>{e.required&&!r.variableValues[n]&&i.push(`Required variable "${e.name}" must have a value`);}),{valid:i.length===0,errors:i}}}}export{U as a};//# sourceMappingURL=chunk-DB3JH4DS.mjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-DB3JH4DS.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../packages/ndpr-toolkit/src/hooks/usePrivacyPolicy.ts"],"names":["usePrivacyPolicy","templates","initialPolicy","storageKey","useLocalStorage","onGenerate","policy","setPolicy","useState","selectedTemplate","setSelectedTemplate","organizationInfo","setOrganizationInfo","useEffect","savedData","template","foundTemplate","t","error","selectTemplate","templateId","section","__spreadProps","__spreadValues","variable","updateOrganizationInfo","updates","prev","toggleSection","sectionId","included","updateSectionContent","content","updateVariableValue","value","generateId","now","newPolicy","_a","result","generatePolicyText","errors","requiredSections","includedSections","info"],"mappings":"0HAyGO,SAASA,EAAiB,CAC/B,SAAA,CAAAC,EACA,aAAA,CAAAC,CAAAA,CACA,WAAAC,CAAAA,CAAa,qBAAA,CACb,gBAAAC,CAAAA,CAAkB,IAAA,CAClB,WAAAC,CACF,CAAA,CAAoD,CAClD,GAAM,CAACC,CAAAA,CAAQC,CAAS,EAAIC,QAAAA,CAA+BN,CAAAA,EAAiB,IAAI,CAAA,CAC1E,CAACO,IAAkBC,CAAmB,CAAA,CAAIF,SAAgC,IAAI,CAAA,CAC9E,CAACG,CAAAA,CAAkBC,CAAmB,EAAIJ,QAAAA,CAA2B,CACzE,IAAA,CAAM,EAAA,CACN,QAAS,EAAA,CACT,YAAA,CAAc,GACd,OAAA,CAAS,EAAA,CACT,aAAc,EAAA,CACd,OAAA,CAAS,GACT,QAAA,CAAU,EAAA,CACV,SAAU,EACZ,CAAC,EAGDK,SAAAA,CAAU,IAAM,CACd,GAAIT,CAAAA,EAAmB,OAAO,MAAA,EAAW,aAAe,CAACF,CAAAA,CACvD,GAAI,CACF,IAAMY,EAAY,YAAA,CAAa,OAAA,CAAQX,CAAU,CAAA,CACjD,GAAIW,EAAW,CACb,GAAM,CAAE,MAAA,CAAAR,CAAAA,CAAQ,SAAAS,CAAAA,CAAU,gBAAA,CAAAJ,CAAiB,CAAA,CAAI,KAAK,KAAA,CAAMG,CAAS,EAMnE,GAJIR,CAAAA,EACFC,EAAUD,CAAM,CAAA,CAGdS,EAAU,CACZ,IAAMC,EAAgBf,CAAAA,CAAU,IAAA,CAAKgB,GAAKA,CAAAA,CAAE,EAAA,GAAOF,EAAS,EAAE,CAAA,CAC1DC,CAAAA,EACFN,CAAAA,CAAoBM,CAAa,EAErC,CAEIL,GACFC,CAAAA,CAAoBD,CAAgB,EAExC,CACF,CAAA,MAASO,EAAO,CACd,OAAA,CAAQ,MAAM,oCAAA,CAAsCA,CAAK,EAC3D,CAEJ,CAAA,CAAG,CAACf,CAAAA,CAAYC,CAAAA,CAAiBF,CAAAA,CAAeD,CAAS,CAAC,CAAA,CAG1DY,SAAAA,CAAU,IAAM,CACd,GAAIT,GAAmB,OAAO,MAAA,EAAW,YACvC,GAAI,CACF,aAAa,OAAA,CAAQD,CAAAA,CAAY,KAAK,SAAA,CAAU,CAC9C,OAAAG,CAAAA,CACA,QAAA,CAAUG,GAAAA,CACV,gBAAA,CAAAE,CACF,CAAC,CAAC,EACJ,CAAA,MAASO,CAAAA,CAAO,CACd,OAAA,CAAQ,KAAA,CAAM,oCAAqCA,CAAK,EAC1D,CAEJ,CAAA,CAAG,CAACZ,EAAQG,GAAAA,CAAkBE,CAAAA,CAAkBR,EAAYC,CAAe,CAAC,CAAA,CAG5E,IAAMe,EAAkBC,CAAAA,EAAgC,CACtD,IAAML,CAAAA,CAAWd,CAAAA,CAAU,KAAKgB,CAAAA,EAAKA,CAAAA,CAAE,KAAOG,CAAU,CAAA,CAExD,GAAI,CAACL,CAAAA,CACH,OAAO,MAAA,CAGTL,CAAAA,CAAoBK,CAAQ,CAAA,CAGXA,CAAAA,CAAS,SAAS,GAAA,CAAIM,CAAAA,EAAYC,EAAAC,GAAAA,CAAA,EAAA,CAC9CF,GAD8C,CAEjD,aAAA,CAAe,MACjB,CAAA,CAAE,CAAA,CAIF,cAAO,IAAA,CAAKN,CAAAA,CAAS,SAAS,CAAA,CAAE,OAAA,CAAQS,CAAAA,EAAY,CACvBT,EAAS,SAAA,CAAUS,CAAQ,EAAE,YAAA,EAAgB,GAC1E,CAAC,CAAA,CAEM,IACT,EAGMC,CAAAA,CAA0BC,CAAAA,EAAuC,CACrEd,CAAAA,CAAoBe,CAAAA,EAASJ,QAAA,EAAA,CACxBI,CAAAA,CAAAA,CACAD,CAAAA,CACH,EACJ,EAGME,CAAAA,CAAgB,CAACC,EAAmBC,CAAAA,GAAsB,CACzDrB,MAIDH,CAAAA,CACFC,CAAAA,CAAUoB,GACHA,CAAAA,EAEEL,CAAAA,CAAAC,IAAA,EAAA,CACFI,CAAAA,CAAAA,CADE,CAEL,QAAA,CAAUA,CAAAA,CAAK,SAAS,GAAA,CAAIN,CAAAA,EAC1BA,CAAAA,CAAQ,EAAA,GAAOQ,EAAYP,CAAAA,CAAAC,GAAAA,CAAA,GAAKF,CAAAA,CAAAA,CAAL,CAAc,SAAAS,CAAS,CAAA,CAAA,CAAIT,CACxD,CACF,CAAA,CACD,EAGDX,CAAAA,CAAoBiB,CAAAA,EACbA,GAEEL,CAAAA,CAAAC,GAAAA,CAAA,GACFI,CAAAA,CAAAA,CADE,CAEL,QAAA,CAAUA,CAAAA,CAAK,SAAS,GAAA,CAAIN,CAAAA,EAC1BA,EAAQ,EAAA,GAAOQ,CAAAA,CAAYP,EAAAC,GAAAA,CAAA,EAAA,CAAKF,GAAL,CAAc,QAAA,CAAAS,CAAS,CAAA,CAAA,CAAIT,CACxD,CACF,CAAA,CACD,CAAA,EAEL,EAGMU,CAAAA,CAAuB,CAACF,CAAAA,CAAmBG,CAAAA,GAAoB,CAC9DvB,GAAAA,GAIDH,CAAAA,CACFC,EAAUoB,CAAAA,EACHA,CAAAA,EAEEL,EAAAC,GAAAA,CAAA,EAAA,CACFI,GADE,CAEL,QAAA,CAAUA,EAAK,QAAA,CAAS,GAAA,CAAIN,GAC1BA,CAAAA,CAAQ,EAAA,GAAOQ,EAAYP,CAAAA,CAAAC,GAAAA,CAAA,EAAA,CAAKF,CAAAA,CAAAA,CAAL,CAAc,aAAA,CAAeW,CAAQ,GAAIX,CACtE,CACF,EACD,CAAA,CAGDX,CAAAA,CAAoBiB,GACbA,CAAAA,EAEEL,CAAAA,CAAAC,IAAA,EAAA,CACFI,CAAAA,CAAAA,CADE,CAEL,QAAA,CAAUA,CAAAA,CAAK,SAAS,GAAA,CAAIN,CAAAA,EAC1BA,CAAAA,CAAQ,EAAA,GAAOQ,EAAYP,CAAAA,CAAAC,GAAAA,CAAA,GAAKF,CAAAA,CAAAA,CAAL,CAAc,cAAeW,CAAQ,CAAA,CAAA,CAAIX,CACtE,CACF,CAAA,CACD,GAEL,CAAA,CAGMY,CAAAA,CAAsB,CAACT,CAAAA,CAAkBU,CAAAA,GAAkB,CAC1D5B,CAAAA,EAILC,CAAAA,CAAUoB,CAAAA,EACHA,CAAAA,EAEEL,EAAAC,GAAAA,CAAA,EAAA,CACFI,GADE,CAEL,cAAA,CAAgBL,EAAAC,GAAAA,CAAA,EAAA,CACXI,EAAK,cAAA,CAAA,CADM,CAEd,CAACH,CAAQ,EAAGU,CACd,CAAA,CACF,CAAA,CACD,EACH,CAAA,CAGMC,CAAAA,CAAa,IACV,SAAA,CAAY,KAAK,GAAA,EAAI,CAAI,IAAM,IAAA,CAAK,MAAA,GAAS,QAAA,CAAS,EAAE,EAAE,MAAA,CAAO,CAAA,CAAG,CAAC,CAAA,CA8H9E,OAAO,CACL,MAAA,CAAA7B,CAAAA,CACA,iBAAAG,GAAAA,CACA,gBAAA,CAAAE,CAAAA,CACA,cAAA,CAAAQ,EACA,sBAAA,CAAAM,CAAAA,CACA,cAAAG,CAAAA,CACA,oBAAA,CAAAG,EACA,mBAAA,CAAAE,CAAAA,CACA,eAnIqB,IAAqB,CAC1C,GAAI,CAACxB,GAAAA,CACH,MAAM,IAAI,KAAA,CAAM,sBAAsB,CAAA,CAGxC,IAAM2B,CAAAA,CAAM,IAAA,CAAK,KAAI,CAEfC,CAAAA,CAA2B,CAC/B,EAAA,CAAA,CAAI/B,CAAAA,EAAA,YAAAA,CAAAA,CAAQ,EAAA,GAAM6B,GAAW,CAC7B,KAAA,CAAO,sBAAsBxB,CAAAA,CAAiB,IAAI,GAClD,UAAA,CAAYF,GAAAA,CAAiB,GAC7B,gBAAA,CAAAE,CAAAA,CACA,QAAA,CAAUF,GAAAA,CAAiB,SAAS,GAAA,CAAIY,CAAAA,EAAQ,CA/StD,IAAAiB,CAAAA,CA+S0D,OAAAhB,CAAAA,CAAAC,GAAAA,CAAA,GAC/CF,CAAAA,CAAAA,CAD+C,CAElD,eAAeiB,CAAAA,CAAAhC,CAAAA,EAAA,YAAAA,CAAAA,CAAQ,QAAA,CAAS,KAAK,CAAA,EAAK,CAAA,CAAE,EAAA,GAAOe,CAAAA,CAAQ,MAA5C,IAAA,CAAA,MAAA,CAAAiB,CAAAA,CAAiD,aAClE,CAAA,CAAA,CAAE,CAAA,CACF,gBAAgBhC,CAAAA,EAAA,IAAA,CAAA,MAAA,CAAAA,EAAQ,cAAA,GAAkB,GAC1C,aAAA,CAAe8B,CAAAA,CACf,YAAaA,CAAAA,CACb,OAAA,CAAS,KACX,CAAA,CAEA,OAAA7B,CAAAA,CAAU8B,CAAS,EAEfhC,CAAAA,EACFA,CAAAA,CAAWgC,CAAS,CAAA,CAGfA,CACT,EAuGE,aAAA,CApGoB,IAAM,CAC1B,GAAI,CAAC/B,EACH,OAAO,CACL,SAAU,EAAA,CACV,YAAA,CAAc,EAAC,CACf,gBAAA,CAAkB,EACpB,EAGF,IAAMiC,CAAAA,CAASC,EAAmBlC,CAAAA,CAAO,QAAA,CAAUA,EAAO,gBAAgB,CAAA,CAG1E,OAAI,OAAOiC,CAAAA,EAAW,SACb,CACL,QAAA,CAAUA,EACV,YAAA,CAAc,CAAE,KAAQA,CAAO,CAAA,CAC/B,gBAAA,CAAkB,EACpB,CAAA,CAGKA,CACT,EAgFE,WAAA,CA7EkB,IAAM,CACxBhC,CAAAA,CAAU,IAAI,EACdG,CAAAA,CAAoB,IAAI,EACxBE,CAAAA,CAAoB,CAClB,KAAM,EAAA,CACN,OAAA,CAAS,GACT,YAAA,CAAc,EAAA,CACd,OAAA,CAAS,EAAA,CACT,aAAc,EAAA,CACd,OAAA,CAAS,GACT,QAAA,CAAU,EAAA,CACV,SAAU,EACZ,CAAC,EAEGR,CAAAA,EAAmB,OAAO,QAAW,WAAA,EACvC,YAAA,CAAa,WAAWD,CAAU,EAEtC,EA6DE,OAAA,CA1Dc,IAAM,CACpB,IAAMsC,EAAmB,EAAC,CAmB1B,GAjBKhC,GAAAA,EACHgC,CAAAA,CAAO,KAAK,sBAAsB,CAAA,CAG/B9B,EAAiB,IAAA,EACpB8B,CAAAA,CAAO,KAAK,+BAA+B,CAAA,CAGxC9B,EAAiB,OAAA,EACpB8B,CAAAA,CAAO,KAAK,kCAAkC,CAAA,CAG3C9B,CAAAA,CAAiB,YAAA,EACpB8B,EAAO,IAAA,CAAK,mCAAmC,EAI7ChC,GAAAA,CAAkB,CACpB,IAAMiC,CAAAA,CAAmBjC,GAAAA,CAAiB,SAAS,MAAA,CAAOY,CAAAA,EAAWA,EAAQ,QAAQ,CAAA,CAC/EsB,GAAmBrC,CAAAA,EAAA,IAAA,CAAA,MAAA,CAAAA,EAAQ,QAAA,CAAS,MAAA,CAAOe,CAAAA,EAAWA,CAAAA,CAAQ,YAAa,EAAC,CAElFqB,EAAiB,OAAA,CAAQrB,CAAAA,EAAW,CAC7BsB,CAAAA,CAAiB,IAAA,CAAK,GAAK,CAAA,CAAE,EAAA,GAAOtB,EAAQ,EAAE,CAAA,EACjDoB,EAAO,IAAA,CAAK,CAAA,kBAAA,EAAqBpB,EAAQ,KAAK,CAAA,kBAAA,CAAoB,EAEtE,CAAC,EACH,CAGA,OAAIZ,KAAoBH,CAAAA,EACtB,MAAA,CAAO,QAAQG,GAAAA,CAAiB,SAAS,EAAE,OAAA,CAAQ,CAAC,CAACe,CAAAA,CAAUoB,CAAI,IAAM,CACnEA,CAAAA,CAAK,UAAY,CAACtC,CAAAA,CAAO,cAAA,CAAekB,CAAQ,GAClDiB,CAAAA,CAAO,IAAA,CAAK,sBAAsBG,CAAAA,CAAK,IAAI,qBAAqB,EAEpE,CAAC,EAGI,CACL,KAAA,CAAOH,EAAO,MAAA,GAAW,CAAA,CACzB,OAAAA,CACF,CACF,CAeA,CACF","file":"chunk-DB3JH4DS.mjs","sourcesContent":["import { useState, useEffect } from 'react';\nimport { PolicySection, PolicyTemplate, OrganizationInfo, PrivacyPolicy } from '../types/privacy';\nimport { generatePolicyText } from '../utils/privacy';\n\ninterface UsePrivacyPolicyOptions {\n /**\n * Available policy templates\n */\n templates: PolicyTemplate[];\n \n /**\n * Initial policy data (if editing an existing policy)\n */\n initialPolicy?: PrivacyPolicy;\n \n /**\n * Storage key for policy data\n * @default \"ndpr_privacy_policy\"\n */\n storageKey?: string;\n \n /**\n * Whether to use local storage to persist policy data\n * @default true\n */\n useLocalStorage?: boolean;\n \n /**\n * Callback function called when a policy is generated\n */\n onGenerate?: (policy: PrivacyPolicy) => void;\n}\n\ninterface UsePrivacyPolicyReturn {\n /**\n * Current policy data\n */\n policy: PrivacyPolicy | null;\n \n /**\n * Selected template\n */\n selectedTemplate: PolicyTemplate | null;\n \n /**\n * Organization information\n */\n organizationInfo: OrganizationInfo;\n \n /**\n * Select a template\n */\n selectTemplate: (templateId: string) => boolean;\n \n /**\n * Update organization information\n */\n updateOrganizationInfo: (updates: Partial<OrganizationInfo>) => void;\n \n /**\n * Toggle whether a section is included in the policy\n */\n toggleSection: (sectionId: string, included: boolean) => void;\n \n /**\n * Update section content\n */\n updateSectionContent: (sectionId: string, content: string) => void;\n \n /**\n * Update variable values\n */\n updateVariableValue: (variable: string, value: string) => void;\n \n /**\n * Generate the policy\n */\n generatePolicy: () => PrivacyPolicy;\n \n /**\n * Get the generated policy text\n */\n getPolicyText: () => {\n fullText: string;\n sectionTexts: Record<string, string>;\n missingVariables: string[];\n };\n \n /**\n * Reset the policy\n */\n resetPolicy: () => void;\n \n /**\n * Check if the policy is valid\n */\n isValid: () => {\n valid: boolean;\n errors: string[];\n };\n}\n\n/**\n * Hook for generating NDPA-compliant privacy policies\n */\nexport function usePrivacyPolicy({\n templates,\n initialPolicy,\n storageKey = \"ndpr_privacy_policy\",\n useLocalStorage = true,\n onGenerate\n}: UsePrivacyPolicyOptions): UsePrivacyPolicyReturn {\n const [policy, setPolicy] = useState<PrivacyPolicy | null>(initialPolicy || null);\n const [selectedTemplate, setSelectedTemplate] = useState<PolicyTemplate | null>(null);\n const [organizationInfo, setOrganizationInfo] = useState<OrganizationInfo>({\n name: '',\n website: '',\n privacyEmail: '',\n address: '',\n privacyPhone: '',\n dpoName: '',\n dpoEmail: '',\n industry: ''\n });\n \n // Load policy data from storage on mount\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined' && !initialPolicy) {\n try {\n const savedData = localStorage.getItem(storageKey);\n if (savedData) {\n const { policy, template, organizationInfo } = JSON.parse(savedData);\n \n if (policy) {\n setPolicy(policy);\n }\n \n if (template) {\n const foundTemplate = templates.find(t => t.id === template.id);\n if (foundTemplate) {\n setSelectedTemplate(foundTemplate);\n }\n }\n \n if (organizationInfo) {\n setOrganizationInfo(organizationInfo);\n }\n }\n } catch (error) {\n console.error('Error loading privacy policy data:', error);\n }\n }\n }, [storageKey, useLocalStorage, initialPolicy, templates]);\n \n // Save policy data to storage when it changes\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined') {\n try {\n localStorage.setItem(storageKey, JSON.stringify({\n policy,\n template: selectedTemplate,\n organizationInfo\n }));\n } catch (error) {\n console.error('Error saving privacy policy data:', error);\n }\n }\n }, [policy, selectedTemplate, organizationInfo, storageKey, useLocalStorage]);\n \n // Select a template\n const selectTemplate = (templateId: string): boolean => {\n const template = templates.find(t => t.id === templateId);\n \n if (!template) {\n return false;\n }\n \n setSelectedTemplate(template);\n \n // Initialize sections from the template\n const sections = template.sections.map(section => ({\n ...section,\n customContent: undefined\n }));\n \n // Initialize variable values\n const variableValues: Record<string, string> = {};\n Object.keys(template.variables).forEach(variable => {\n variableValues[variable] = template.variables[variable].defaultValue || '';\n });\n \n return true;\n };\n \n // Update organization information\n const updateOrganizationInfo = (updates: Partial<OrganizationInfo>) => {\n setOrganizationInfo(prev => ({\n ...prev,\n ...updates\n }));\n };\n \n // Toggle whether a section is included in the policy\n const toggleSection = (sectionId: string, included: boolean) => {\n if (!selectedTemplate) {\n return;\n }\n \n if (policy) {\n setPolicy(prev => {\n if (!prev) return prev;\n \n return {\n ...prev,\n sections: prev.sections.map(section => \n section.id === sectionId ? { ...section, included } : section\n )\n };\n });\n } else {\n // If no policy exists yet, update the template sections\n setSelectedTemplate(prev => {\n if (!prev) return prev;\n \n return {\n ...prev,\n sections: prev.sections.map(section => \n section.id === sectionId ? { ...section, included } : section\n )\n };\n });\n }\n };\n \n // Update section content\n const updateSectionContent = (sectionId: string, content: string) => {\n if (!selectedTemplate) {\n return;\n }\n \n if (policy) {\n setPolicy(prev => {\n if (!prev) return prev;\n \n return {\n ...prev,\n sections: prev.sections.map(section => \n section.id === sectionId ? { ...section, customContent: content } : section\n )\n };\n });\n } else {\n // If no policy exists yet, update the template sections\n setSelectedTemplate(prev => {\n if (!prev) return prev;\n \n return {\n ...prev,\n sections: prev.sections.map(section => \n section.id === sectionId ? { ...section, customContent: content } : section\n )\n };\n });\n }\n };\n \n // Update variable values\n const updateVariableValue = (variable: string, value: string) => {\n if (!policy) {\n return;\n }\n \n setPolicy(prev => {\n if (!prev) return prev;\n \n return {\n ...prev,\n variableValues: {\n ...prev.variableValues,\n [variable]: value\n }\n };\n });\n };\n \n // Generate a unique ID\n const generateId = (): string => {\n return 'policy_' + Date.now() + '_' + Math.random().toString(36).substr(2, 9);\n };\n \n // Generate the policy\n const generatePolicy = (): PrivacyPolicy => {\n if (!selectedTemplate) {\n throw new Error('No template selected');\n }\n \n const now = Date.now();\n \n const newPolicy: PrivacyPolicy = {\n id: policy?.id || generateId(),\n title: `Privacy Policy for ${organizationInfo.name}`,\n templateId: selectedTemplate.id,\n organizationInfo,\n sections: selectedTemplate.sections.map(section => ({\n ...section,\n customContent: policy?.sections.find(s => s.id === section.id)?.customContent\n })),\n variableValues: policy?.variableValues || {},\n effectiveDate: now,\n lastUpdated: now,\n version: '1.0'\n };\n \n setPolicy(newPolicy);\n \n if (onGenerate) {\n onGenerate(newPolicy);\n }\n \n return newPolicy;\n };\n \n // Get the generated policy text\n const getPolicyText = () => {\n if (!policy) {\n return {\n fullText: '',\n sectionTexts: {},\n missingVariables: []\n };\n }\n \n const result = generatePolicyText(policy.sections, policy.organizationInfo);\n \n // Handle both string and object return types from generatePolicyText\n if (typeof result === 'string') {\n return {\n fullText: result,\n sectionTexts: { 'full': result },\n missingVariables: []\n };\n }\n \n return result;\n };\n \n // Reset the policy\n const resetPolicy = () => {\n setPolicy(null);\n setSelectedTemplate(null);\n setOrganizationInfo({\n name: '',\n website: '',\n privacyEmail: '',\n address: '',\n privacyPhone: '',\n dpoName: '',\n dpoEmail: '',\n industry: ''\n });\n \n if (useLocalStorage && typeof window !== 'undefined') {\n localStorage.removeItem(storageKey);\n }\n };\n \n // Check if the policy is valid\n const isValid = () => {\n const errors: string[] = [];\n \n if (!selectedTemplate) {\n errors.push('No template selected');\n }\n \n if (!organizationInfo.name) {\n errors.push('Organization name is required');\n }\n \n if (!organizationInfo.website) {\n errors.push('Organization website is required');\n }\n \n if (!organizationInfo.privacyEmail) {\n errors.push('Privacy contact email is required');\n }\n \n // Check if all required sections are included\n if (selectedTemplate) {\n const requiredSections = selectedTemplate.sections.filter(section => section.required);\n const includedSections = policy?.sections.filter(section => section.included) || [];\n \n requiredSections.forEach(section => {\n if (!includedSections.some(s => s.id === section.id)) {\n errors.push(`Required section \"${section.title}\" must be included`);\n }\n });\n }\n \n // Check if all required variables have values\n if (selectedTemplate && policy) {\n Object.entries(selectedTemplate.variables).forEach(([variable, info]) => {\n if (info.required && !policy.variableValues[variable]) {\n errors.push(`Required variable \"${info.name}\" must have a value`);\n }\n });\n }\n \n return {\n valid: errors.length === 0,\n errors\n };\n };\n \n return {\n policy,\n selectedTemplate,\n organizationInfo,\n selectTemplate,\n updateOrganizationInfo,\n toggleSection,\n updateSectionContent,\n updateVariableValue,\n generatePolicy,\n getPolicyText,\n resetPolicy,\n isValid\n };\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {a as a$1}from'./chunk-PGSA2O5P.mjs';import {b,a}from'./chunk-WWT2ZSNU.mjs';import {useState,useEffect}from'react';function N({sections:d,initialAnswers:Q={},storageKey:f="ndpr_dpia_data",useLocalStorage:m=true,onComplete:I}){let[l,c]=useState(0),[i,g]=useState(Q);useEffect(()=>{if(m&&typeof window!="undefined")try{let r=localStorage.getItem(f);if(r){let{answers:t,sectionIndex:e}=JSON.parse(r);g(t||{}),c(e||0);}}catch(r){console.error("Error loading DPIA data:",r);}},[f,m]),useEffect(()=>{if(m&&typeof window!="undefined")try{localStorage.setItem(f,JSON.stringify({answers:i,sectionIndex:l}));}catch(r){console.error("Error saving DPIA data:",r);}},[i,l,f,m]);let p=d[l]||null,E=(r,t)=>{g(e=>b(a({},e),{[r]:t}));},v=r=>r.showWhen?r.showWhen.every(t=>{let e=i[t.questionId];switch(t.operator){case "equals":return e===t.value;case "contains":return Array.isArray(e)?e.includes(t.value):false;case "greaterThan":return typeof e=="number"?e>t.value:false;case "lessThan":return typeof e=="number"?e<t.value:false;default:return true}}):true,A=()=>p?p.questions.filter(v):[],h=()=>p?A().every(t=>{if(!t.required)return true;let e=i[t.id];return !(e==null||typeof e=="string"&&e.trim()===""||Array.isArray(e)&&e.length===0)}):false,x=()=>{let r={};return p&&A().forEach(e=>{if(!e.required)return;let s=i[e.id];s==null||typeof s=="string"&&s.trim()===""?r[e.id]="This question is required":Array.isArray(s)&&s.length===0&&(r[e.id]="At least one option must be selected");}),r},C=()=>h()&&l<d.length-1?(c(r=>r+1),true):false,L=()=>l>0?(c(r=>r-1),true):false,O=r=>r>=0&&r<d.length?(c(r),true):false,T=()=>d.every((r,t)=>{c(t);let e=h();return c(l),e}),_=()=>{let r=[];return d.forEach(t=>{t.questions.forEach(e=>{let s=i[e.id];if(s!=null&&e.riskLevel)if(["select","radio","checkbox"].includes(e.type)&&e.options)(Array.isArray(s)?s:[s]).forEach(o=>{var w;let a=(w=e.options)==null?void 0:w.find(u=>u.value===o);if(a!=null&&a.riskLevel){let u=a.riskLevel,D=u==="low"?1:u==="medium"?3:5,P=u==="low"?1:u==="medium"?3:5;r.push({id:`risk_${r.length+1}`,description:`${e.text} - ${a.label}`,likelihood:D,impact:P,score:D*P,level:u,mitigated:false,relatedQuestionIds:[e.id]});}});else {let n=e.riskLevel,o=n==="low"?1:n==="medium"?3:5,a=n==="low"?1:n==="medium"?3:5;r.push({id:`risk_${r.length+1}`,description:e.text,likelihood:o,impact:a,score:o*a,level:n,mitigated:false,relatedQuestionIds:[e.id]});}});}),r},$=(r,t,e)=>{let s=_(),n={id:`dpia_${Date.now()}`,title:t,processingDescription:e,startedAt:Date.now(),completedAt:Date.now(),assessor:r,answers:i,risks:s,overallRiskLevel:"low",canProceed:true,conclusion:"",version:"1.0"},o=a$1(n);return n.overallRiskLevel=o.overallRiskLevel,n.canProceed=o.canProceed,n.conclusion=o.canProceed?"Based on the assessment, the processing can proceed with appropriate safeguards.":"Based on the assessment, the processing should not proceed without further mitigation measures.",n.recommendations=o.recommendations,I&&I(n),n},U=()=>{g({}),c(0),m&&typeof window!="undefined"&&localStorage.removeItem(f);},V=(()=>{let r=0,t=0;return d.forEach(e=>{e.questions.forEach(s=>{if(s.required&&v(s)){t++;let n=i[s.id];n!=null&&!(typeof n=="string"&&n.trim()==="")&&!(Array.isArray(n)&&n.length===0)&&r++;}});}),t>0?Math.round(r/t*100):0})();return {currentSectionIndex:l,currentSection:p,answers:i,updateAnswer:E,nextSection:C,prevSection:L,goToSection:O,isCurrentSectionValid:h,getCurrentSectionErrors:x,isComplete:T,completeDPIA:$,getVisibleQuestions:A,resetDPIA:U,progress:V}}export{N as a};//# sourceMappingURL=chunk-EWOZKYLY.mjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-EWOZKYLY.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../packages/ndpr-toolkit/src/hooks/useDPIA.ts"],"names":["useDPIA","sections","initialAnswers","storageKey","useLocalStorage","onComplete","currentSectionIndex","setCurrentSectionIndex","useState","answers","setAnswers","useEffect","savedData","savedAnswers","sectionIndex","error","currentSection","updateAnswer","questionId","value","prevAnswers","__spreadProps","__spreadValues","shouldShowQuestion","question","condition","answer","getVisibleQuestions","isCurrentSectionValid","getCurrentSectionErrors","errors","nextSection","prevIndex","prevSection","goToSection","index","isComplete","section","valid","identifyRisks","risks","selectedOption","_a","option","opt","riskLevel","likelihood","impact","completeDPIA","assessorInfo","title","processingDescription","result","assessment","assessDPIARisk","resetDPIA","progress","answeredQuestions","totalRequiredQuestions"],"mappings":"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","file":"chunk-EWOZKYLY.mjs","sourcesContent":["import { useState, useEffect } from 'react';\nimport { DPIAQuestion, DPIASection, DPIAResult, DPIARisk } from '../types/dpia';\nimport { assessDPIARisk } from '../utils/dpia';\n\ninterface UseDPIAOptions {\n /**\n * Sections of the DPIA questionnaire\n */\n sections: DPIASection[];\n \n /**\n * Initial answers (if resuming a DPIA)\n */\n initialAnswers?: Record<string, any>;\n \n /**\n * Storage key for DPIA data\n * @default \"ndpr_dpia_data\"\n */\n storageKey?: string;\n \n /**\n * Whether to use local storage to persist DPIA data\n * @default true\n */\n useLocalStorage?: boolean;\n \n /**\n * Callback function called when the DPIA is completed\n */\n onComplete?: (result: DPIAResult) => void;\n}\n\ninterface UseDPIAReturn {\n /**\n * Current section index\n */\n currentSectionIndex: number;\n \n /**\n * Current section\n */\n currentSection: DPIASection | null;\n \n /**\n * All answers\n */\n answers: Record<string, any>;\n \n /**\n * Update an answer\n */\n updateAnswer: (questionId: string, value: any) => void;\n \n /**\n * Go to the next section\n */\n nextSection: () => boolean;\n \n /**\n * Go to the previous section\n */\n prevSection: () => boolean;\n \n /**\n * Go to a specific section\n */\n goToSection: (index: number) => boolean;\n \n /**\n * Check if the current section is valid\n */\n isCurrentSectionValid: () => boolean;\n \n /**\n * Get validation errors for the current section\n */\n getCurrentSectionErrors: () => Record<string, string>;\n \n /**\n * Check if the DPIA is complete\n */\n isComplete: () => boolean;\n \n /**\n * Complete the DPIA and generate a result\n */\n completeDPIA: (assessorInfo: { name: string; role: string; email: string; }, title: string, processingDescription: string) => DPIAResult;\n \n /**\n * Get the visible questions for the current section\n */\n getVisibleQuestions: () => DPIAQuestion[];\n \n /**\n * Reset the DPIA\n */\n resetDPIA: () => void;\n \n /**\n * Progress percentage\n */\n progress: number;\n}\n\n/**\n * Hook for conducting Data Protection Impact Assessments in compliance with the NDPA 2023\n */\nexport function useDPIA({\n sections,\n initialAnswers = {},\n storageKey = \"ndpr_dpia_data\",\n useLocalStorage = true,\n onComplete\n}: UseDPIAOptions): UseDPIAReturn {\n const [currentSectionIndex, setCurrentSectionIndex] = useState<number>(0);\n const [answers, setAnswers] = useState<Record<string, any>>(initialAnswers);\n \n // Load DPIA data from storage on mount\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined') {\n try {\n const savedData = localStorage.getItem(storageKey);\n if (savedData) {\n const { answers: savedAnswers, sectionIndex } = JSON.parse(savedData);\n setAnswers(savedAnswers || {});\n setCurrentSectionIndex(sectionIndex || 0);\n }\n } catch (error) {\n console.error('Error loading DPIA data:', error);\n }\n }\n }, [storageKey, useLocalStorage]);\n \n // Save DPIA data to storage when it changes\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined') {\n try {\n localStorage.setItem(storageKey, JSON.stringify({\n answers,\n sectionIndex: currentSectionIndex\n }));\n } catch (error) {\n console.error('Error saving DPIA data:', error);\n }\n }\n }, [answers, currentSectionIndex, storageKey, useLocalStorage]);\n \n // Get the current section\n const currentSection = sections[currentSectionIndex] || null;\n \n // Update an answer\n const updateAnswer = (questionId: string, value: any) => {\n setAnswers(prevAnswers => ({\n ...prevAnswers,\n [questionId]: value\n }));\n };\n \n // Check if a question should be shown based on its conditions\n const shouldShowQuestion = (question: DPIAQuestion): boolean => {\n if (!question.showWhen) {\n return true;\n }\n \n return question.showWhen.every(condition => {\n const answer = answers[condition.questionId];\n \n switch (condition.operator) {\n case 'equals':\n return answer === condition.value;\n case 'contains':\n return Array.isArray(answer) ? answer.includes(condition.value) : false;\n case 'greaterThan':\n return typeof answer === 'number' ? answer > condition.value : false;\n case 'lessThan':\n return typeof answer === 'number' ? answer < condition.value : false;\n default:\n return true;\n }\n });\n };\n \n // Get the visible questions for the current section\n const getVisibleQuestions = (): DPIAQuestion[] => {\n if (!currentSection) {\n return [];\n }\n \n return currentSection.questions.filter(shouldShowQuestion);\n };\n \n // Check if the current section is valid\n const isCurrentSectionValid = (): boolean => {\n if (!currentSection) {\n return false;\n }\n \n const visibleQuestions = getVisibleQuestions();\n \n return visibleQuestions.every(question => {\n if (!question.required) {\n return true;\n }\n \n const answer = answers[question.id];\n \n if (answer === undefined || answer === null) {\n return false;\n }\n \n if (typeof answer === 'string' && answer.trim() === '') {\n return false;\n }\n \n if (Array.isArray(answer) && answer.length === 0) {\n return false;\n }\n \n return true;\n });\n };\n \n // Get validation errors for the current section\n const getCurrentSectionErrors = (): Record<string, string> => {\n const errors: Record<string, string> = {};\n \n if (!currentSection) {\n return errors;\n }\n \n const visibleQuestions = getVisibleQuestions();\n \n visibleQuestions.forEach(question => {\n if (!question.required) {\n return;\n }\n \n const answer = answers[question.id];\n \n if (answer === undefined || answer === null) {\n errors[question.id] = 'This question is required';\n } else if (typeof answer === 'string' && answer.trim() === '') {\n errors[question.id] = 'This question is required';\n } else if (Array.isArray(answer) && answer.length === 0) {\n errors[question.id] = 'At least one option must be selected';\n }\n });\n \n return errors;\n };\n \n // Go to the next section\n const nextSection = (): boolean => {\n if (!isCurrentSectionValid()) {\n return false;\n }\n \n if (currentSectionIndex < sections.length - 1) {\n setCurrentSectionIndex(prevIndex => prevIndex + 1);\n return true;\n }\n \n return false;\n };\n \n // Go to the previous section\n const prevSection = (): boolean => {\n if (currentSectionIndex > 0) {\n setCurrentSectionIndex(prevIndex => prevIndex - 1);\n return true;\n }\n \n return false;\n };\n \n // Go to a specific section\n const goToSection = (index: number): boolean => {\n if (index >= 0 && index < sections.length) {\n setCurrentSectionIndex(index);\n return true;\n }\n \n return false;\n };\n \n // Check if the DPIA is complete\n const isComplete = (): boolean => {\n return sections.every((section, index) => {\n // Temporarily set the current section to check ifit's valid\n setCurrentSectionIndex(index);\n const valid = isCurrentSectionValid();\n // Restore the current section\n setCurrentSectionIndex(currentSectionIndex);\n return valid;\n });\n };\n \n // Identify risks based on answers\n const identifyRisks = (): DPIARisk[] => {\n const risks: DPIARisk[] = [];\n \n // Check each question for risk indicators\n sections.forEach(section => {\n section.questions.forEach(question => {\n const answer = answers[question.id];\n \n // Skip if no answer\n if (answer === undefined || answer === null) {\n return;\n }\n \n // Check if the question has a risk level\n if (question.riskLevel) {\n // For select/radio/checkbox questions, check if the selected option has a risk level\n if (['select', 'radio', 'checkbox'].includes(question.type) && question.options) {\n const selectedOptions = Array.isArray(answer) ? answer : [answer];\n \n selectedOptions.forEach(selectedOption => {\n const option = question.options?.find(opt => opt.value === selectedOption);\n \n if (option?.riskLevel) {\n const riskLevel = option.riskLevel;\n const likelihood = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n const impact = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n \n risks.push({\n id: `risk_${risks.length + 1}`,\n description: `${question.text} - ${option.label}`,\n likelihood,\n impact,\n score: likelihood * impact,\n level: riskLevel,\n mitigated: false,\n relatedQuestionIds: [question.id]\n });\n }\n });\n } else {\n // For other question types, use the question's risk level\n const riskLevel = question.riskLevel;\n const likelihood = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n const impact = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n \n risks.push({\n id: `risk_${risks.length + 1}`,\n description: question.text,\n likelihood,\n impact,\n score: likelihood * impact,\n level: riskLevel,\n mitigated: false,\n relatedQuestionIds: [question.id]\n });\n }\n }\n });\n });\n \n return risks;\n };\n \n // Complete the DPIA and generate a result\n const completeDPIA = (\n assessorInfo: { name: string; role: string; email: string; },\n title: string,\n processingDescription: string\n ): DPIAResult => {\n const risks = identifyRisks();\n \n const result: DPIAResult = {\n id: `dpia_${Date.now()}`,\n title,\n processingDescription,\n startedAt: Date.now(),\n completedAt: Date.now(),\n assessor: assessorInfo,\n answers,\n risks,\n overallRiskLevel: 'low',\n canProceed: true,\n conclusion: '',\n version: '1.0'\n };\n \n // Assess the risks\n const assessment = assessDPIARisk(result);\n \n result.overallRiskLevel = assessment.overallRiskLevel;\n result.canProceed = assessment.canProceed;\n result.conclusion = assessment.canProceed\n ? 'Based on the assessment, the processing can proceed with appropriate safeguards.'\n : 'Based on the assessment, the processing should not proceed without further mitigation measures.';\n result.recommendations = assessment.recommendations;\n \n if (onComplete) {\n onComplete(result);\n }\n \n return result;\n };\n \n // Reset the DPIA\n const resetDPIA = () => {\n setAnswers({});\n setCurrentSectionIndex(0);\n \n if (useLocalStorage && typeof window !== 'undefined') {\n localStorage.removeItem(storageKey);\n }\n };\n \n // Calculate progress percentage\n const progress = (() => {\n let answeredQuestions = 0;\n let totalRequiredQuestions = 0;\n \n sections.forEach(section => {\n section.questions.forEach(question => {\n if (question.required && shouldShowQuestion(question)) {\n totalRequiredQuestions++;\n \n const answer = answers[question.id];\n if (\n answer !== undefined && \n answer !== null && \n !(typeof answer === 'string' && answer.trim() === '') &&\n !(Array.isArray(answer) && answer.length === 0)\n ) {\n answeredQuestions++;\n }\n }\n });\n });\n \n return totalRequiredQuestions > 0 \n ? Math.round((answeredQuestions / totalRequiredQuestions) * 100) \n : 0;\n })();\n \n return {\n currentSectionIndex,\n currentSection,\n answers,\n updateAnswer,\n nextSection,\n prevSection,\n goToSection,\n isCurrentSectionValid,\n getCurrentSectionErrors,\n isComplete,\n completeDPIA,\n getVisibleQuestions,\n resetDPIA,\n progress\n };\n}\n"]}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import {a as a$1}from'./chunk-UYP64PV7.mjs';import {d,b,a}from'./chunk-WWT2ZSNU.mjs';import t,{useState,useEffect}from'react';var ae=({sections:g,variables:E,onGenerate:v,title:T="NDPA Privacy Policy Generator",description:D="Generate an NDPA-compliant privacy policy for your organization.",className:q="",buttonClassName:k="",generateButtonText:V="Generate Policy",showPreview:$=true,allowEditing:A=true})=>{let[w,O]=useState(g),[N,S]=useState(E),[x,y]=useState("sections"),[f,W]=useState(""),[P,h]=useState(""),[j,H]=useState(false),[u,U]=useState({});useEffect(()=>{O(g);},[g]),useEffect(()=>{S(E);},[E]);let n=a$1=>{O(d=>d.map(s=>s.id===a$1?b(a({},s),{included:!s.included}):s));},l=(a$1,d)=>{S(s=>s.map(m=>m.id===a$1?b(a({},m),{value:d}):m)),u[a$1]&&U(s=>{let m=a({},s);return delete m[a$1],m});},c=()=>{let a={},d=true;return N.forEach(s=>{s.required&&!s.value&&(a[s.id]=`${s.name} is required`,d=false);}),U(a),d},p=()=>{if(!c()){y("variables");return}let a=w.filter(m=>m.included),d=Object.fromEntries(N.map(m=>[m.name,m.value])),s="";a.forEach(m=>{s+=`## ${m.title}
|
|
2
|
+
|
|
3
|
+
`,s+=a$1(m.template,d),s+=`
|
|
4
|
+
|
|
5
|
+
`;}),W(s),h(s),H(true),y("preview");},L=()=>{v({sections:w,variables:N,content:A?P:f});},M=()=>t.createElement("div",{className:"space-y-4"},t.createElement("h3",{className:"text-lg font-medium mb-4"},"Select Policy Sections"),w.map(a=>t.createElement("div",{key:a.id,className:"border border-gray-200 dark:border-gray-700 rounded-md p-4"},t.createElement("div",{className:"flex items-start"},t.createElement("div",{className:"flex items-center h-5"},t.createElement("input",{id:`section-${a.id}`,type:"checkbox",checked:a.included,onChange:()=>n(a.id),disabled:a.required,className:"w-4 h-4 text-blue-600 border-gray-300 rounded focus:ring-blue-500 dark:focus:ring-blue-600 dark:ring-offset-gray-800 dark:focus:ring-offset-gray-800 focus:ring-2 dark:bg-gray-700 dark:border-gray-600"})),t.createElement("div",{className:"ml-3 text-sm"},t.createElement("label",{htmlFor:`section-${a.id}`,className:"font-medium text-gray-900 dark:text-white"},a.title," ",a.required&&t.createElement("span",{className:"text-red-500"},"*")),a.description&&t.createElement("p",{className:"text-gray-500 dark:text-gray-400 mt-1"},a.description))))),t.createElement("div",{className:"mt-6"},t.createElement("button",{onClick:()=>y("variables"),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${k}`},"Next: Fill Variables"))),B=()=>{let a={};return N.forEach(d=>{let s=d.id.split(".")[0];a[s]||(a[s]=[]),a[s].push(d);}),t.createElement("div",null,t.createElement("h3",{className:"text-lg font-medium mb-4"},"Fill Policy Variables"),t.createElement("div",{className:"space-y-6"},Object.entries(a).map(([d,s])=>{let m=w.find(e=>e.id===d);return m&&!m.included?null:t.createElement("div",{key:d,className:"border border-gray-200 dark:border-gray-700 rounded-md p-4"},t.createElement("h4",{className:"font-medium text-lg mb-3"},m?m.title:"General Information"),t.createElement("div",{className:"space-y-4"},s.map(e=>t.createElement("div",{key:e.id},t.createElement("label",{htmlFor:`var-${e.id}`,className:"block text-sm font-medium mb-1"},e.name," ",e.required&&t.createElement("span",{className:"text-red-500"},"*")),e.description&&t.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400 mb-2"},e.description),e.inputType==="textarea"?t.createElement("textarea",{id:`var-${e.id}`,value:e.value,onChange:i=>l(e.id,i.target.value),rows:4,className:`w-full px-3 py-2 border ${u[e.id]?"border-red-500 focus:ring-red-500":"border-gray-300 dark:border-gray-600 focus:ring-blue-500"} rounded-md focus:outline-none focus:ring-2`,required:e.required}):e.inputType==="select"&&e.options?t.createElement("select",{id:`var-${e.id}`,value:e.value,onChange:i=>l(e.id,i.target.value),className:`w-full px-3 py-2 border ${u[e.id]?"border-red-500 focus:ring-red-500":"border-gray-300 dark:border-gray-600 focus:ring-blue-500"} rounded-md focus:outline-none focus:ring-2`,required:e.required},t.createElement("option",{value:""},"Select an option"),e.options.map(i=>t.createElement("option",{key:i,value:i},i))):t.createElement("input",{id:`var-${e.id}`,type:e.inputType,value:e.value,onChange:i=>l(e.id,i.target.value),className:`w-full px-3 py-2 border ${u[e.id]?"border-red-500 focus:ring-red-500":"border-gray-300 dark:border-gray-600 focus:ring-blue-500"} rounded-md focus:outline-none focus:ring-2`,required:e.required}),u[e.id]&&t.createElement("p",{className:"mt-1 text-sm text-red-600 dark:text-red-500"},u[e.id])))))})),t.createElement("div",{className:"mt-6 flex space-x-4"},t.createElement("button",{onClick:()=>y("sections"),className:`px-4 py-2 bg-gray-200 text-gray-800 dark:bg-gray-700 dark:text-white rounded hover:bg-gray-300 dark:hover:bg-gray-600 ${k}`},"Back to Sections"),t.createElement("button",{onClick:p,className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${k}`},V)))},Y=()=>t.createElement("div",null,t.createElement("h3",{className:"text-lg font-medium mb-4"},"Preview Generated Policy"),A?t.createElement("div",{className:"mb-4"},t.createElement("label",{htmlFor:"policy-content",className:"block text-sm font-medium mb-1"},"Edit Policy Content"),t.createElement("textarea",{id:"policy-content",value:P,onChange:a=>h(a.target.value),rows:20,className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500 font-mono text-sm"})):t.createElement("div",{className:"bg-gray-50 dark:bg-gray-700 p-4 rounded-md mb-4"},t.createElement("div",{className:"prose dark:prose-invert max-w-none"},f.split(`
|
|
6
|
+
`).map((a,d)=>a.startsWith("## ")?t.createElement("h2",{key:d,className:"text-xl font-bold mt-6 mb-3"},a.substring(3)):a.startsWith("### ")?t.createElement("h3",{key:d,className:"text-lg font-bold mt-4 mb-2"},a.substring(4)):a===""?t.createElement("br",{key:d}):t.createElement("p",{key:d,className:"mb-2"},a)))),t.createElement("div",{className:"mt-6 flex space-x-4"},t.createElement("button",{onClick:()=>y("variables"),className:`px-4 py-2 bg-gray-200 text-gray-800 dark:bg-gray-700 dark:text-white rounded hover:bg-gray-300 dark:hover:bg-gray-600 ${k}`},"Back to Variables"),t.createElement("button",{onClick:L,className:`px-4 py-2 bg-green-600 text-white rounded hover:bg-green-700 ${k}`},"Save Policy"))),z=()=>{switch(x){case "sections":return M();case "variables":return B();case "preview":return Y();default:return M()}};return t.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${q}`},t.createElement("h2",{className:"text-xl font-bold mb-2"},T),t.createElement("p",{className:"mb-6 text-gray-600 dark:text-gray-300"},D),t.createElement("div",{className:"mb-8"},t.createElement("ol",{className:"flex items-center w-full"},t.createElement("li",{className:`flex w-full items-center ${x==="sections"?"text-blue-600 dark:text-blue-500":"text-gray-500 dark:text-gray-400"} after:content-[''] after:w-full after:h-1 after:border-b after:border-gray-200 after:border-1 after:hidden sm:after:inline-block after:mx-6 xl:after:mx-10`},t.createElement("span",{className:`flex items-center justify-center w-8 h-8 ${x==="sections"?"bg-blue-100 dark:bg-blue-800":"bg-gray-100 dark:bg-gray-700"} rounded-full shrink-0`},"1"),t.createElement("span",{className:"hidden sm:inline-flex sm:ml-2"},"Sections")),t.createElement("li",{className:`flex w-full items-center ${x==="variables"?"text-blue-600 dark:text-blue-500":"text-gray-500 dark:text-gray-400"} after:content-[''] after:w-full after:h-1 after:border-b after:border-gray-200 after:border-1 after:hidden sm:after:inline-block after:mx-6 xl:after:mx-10`},t.createElement("span",{className:`flex items-center justify-center w-8 h-8 ${x==="variables"?"bg-blue-100 dark:bg-blue-800":"bg-gray-100 dark:bg-gray-700"} rounded-full shrink-0`},"2"),t.createElement("span",{className:"hidden sm:inline-flex sm:ml-2"},"Variables")),t.createElement("li",{className:`flex items-center ${x==="preview"?"text-blue-600 dark:text-blue-500":"text-gray-500 dark:text-gray-400"}`},t.createElement("span",{className:`flex items-center justify-center w-8 h-8 ${x==="preview"?"bg-blue-100 dark:bg-blue-800":"bg-gray-100 dark:bg-gray-700"} rounded-full shrink-0`},"3"),t.createElement("span",{className:"hidden sm:inline-flex sm:ml-2"},"Preview")))),t.createElement("div",{className:"mb-6 p-4 bg-blue-50 dark:bg-blue-900/20 rounded-md"},t.createElement("h3",{className:"text-sm font-bold text-blue-800 dark:text-blue-200 mb-2"},"NDPA Compliance Notice"),t.createElement("p",{className:"text-blue-700 dark:text-blue-300 text-sm"},"This tool helps you generate a privacy policy that aligns with the Nigeria Data Protection Act (NDPA) 2023. While we strive to ensure compliance, we recommend having the final policy reviewed by a legal professional familiar with NDPA requirements.")),z())};var ne=({content:g,sections:E,variables:v,onExport:T,onEdit:D,title:q="Privacy Policy Preview",description:k="Preview your NDPA-compliant privacy policy before exporting.",className:V="",buttonClassName:$="",showExportOptions:A=true,showEditButton:w=true,showTableOfContents:O=true,showMetadata:N=true,organizationName:S,lastUpdated:x=new Date})=>{let[y,f]=useState("preview"),P=(()=>{let n=g.split(`
|
|
7
|
+
`),l=[];return n.forEach(c=>{if(c.startsWith("## ")){let p=c.substring(3).trim(),L=p.toLowerCase().replace(/[^a-z0-9]+/g,"-");l.push({id:L,title:p,level:2});}else if(c.startsWith("### ")){let p=c.substring(4).trim(),L=p.toLowerCase().replace(/[^a-z0-9]+/g,"-");l.push({id:L,title:p,level:3});}}),l})(),h=n=>{if(T)T(n);else if(n==="markdown"){let l=document.createElement("a"),c=new Blob([g],{type:"text/markdown"});l.href=URL.createObjectURL(c),l.download=`privacy-policy-${new Date().toISOString().split("T")[0]}.md`,document.body.appendChild(l),l.click(),document.body.removeChild(l);}},j=()=>!O||P.length===0?null:t.createElement("div",{className:"mb-6 p-4 bg-gray-50 dark:bg-gray-700 rounded-md"},t.createElement("h3",{className:"text-lg font-medium mb-3"},"Table of Contents"),t.createElement("ul",{className:"space-y-1"},P.map((n,l)=>t.createElement("li",{key:l,style:{marginLeft:`${(n.level-2)*1.5}rem`}},t.createElement("a",{href:`#${n.id}`,className:"text-blue-600 dark:text-blue-400 hover:underline"},n.title))))),H=()=>N?t.createElement("div",{className:"mb-6"},t.createElement("h1",{className:"text-2xl font-bold mb-2"},S?`${S} Privacy Policy`:"Privacy Policy"),t.createElement("p",{className:"text-sm text-gray-500 dark:text-gray-400"},"Last Updated: ",x.toLocaleDateString())):null,u=()=>t.createElement("div",{className:"prose dark:prose-invert max-w-none"},g.split(`
|
|
8
|
+
`).map((n,l)=>{if(n.startsWith("## ")){let c=n.substring(3).trim(),p=c.toLowerCase().replace(/[^a-z0-9]+/g,"-");return t.createElement("h2",{id:p,key:l,className:"text-xl font-bold mt-6 mb-3"},c)}else if(n.startsWith("### ")){let c=n.substring(4).trim(),p=c.toLowerCase().replace(/[^a-z0-9]+/g,"-");return t.createElement("h3",{id:p,key:l,className:"text-lg font-bold mt-4 mb-2"},c)}else return n===""?t.createElement("br",{key:l}):t.createElement("p",{key:l,className:"mb-2"},n)})),U=()=>A?t.createElement("div",{className:"mt-6"},t.createElement("h3",{className:"text-lg font-medium mb-3"},"Export Options"),t.createElement("div",{className:"flex flex-wrap gap-3"},t.createElement("button",{onClick:()=>h("pdf"),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${$}`},"Export as PDF"),t.createElement("button",{onClick:()=>h("docx"),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${$}`},"Export as DOCX"),t.createElement("button",{onClick:()=>h("html"),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${$}`},"Export as HTML"),t.createElement("button",{onClick:()=>h("markdown"),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${$}`},"Export as Markdown"))):null;return t.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${V}`},t.createElement("div",{className:"flex justify-between items-start mb-6"},t.createElement("div",null,t.createElement("h2",{className:"text-xl font-bold mb-2"},q),t.createElement("p",{className:"text-gray-600 dark:text-gray-300"},k)),w&&D&&t.createElement("button",{onClick:D,className:`px-4 py-2 bg-gray-200 text-gray-800 dark:bg-gray-700 dark:text-white rounded hover:bg-gray-300 dark:hover:bg-gray-600 ${$}`},"Edit Policy")),t.createElement("div",{className:"mb-6 p-4 bg-blue-50 dark:bg-blue-900/20 rounded-md"},t.createElement("h3",{className:"text-sm font-bold text-blue-800 dark:text-blue-200 mb-2"},"NDPA Compliance Notice"),t.createElement("p",{className:"text-blue-700 dark:text-blue-300 text-sm"},"This privacy policy has been generated to align with the Nigeria Data Protection Act (NDPA) 2023. We recommend having the final policy reviewed by a legal professional familiar with NDPA requirements before publishing it on your website or sharing it with your users.")),t.createElement("div",{className:"mb-6 border-b border-gray-200 dark:border-gray-700"},t.createElement("ul",{className:"flex flex-wrap -mb-px"},t.createElement("li",{className:"mr-2"},t.createElement("button",{onClick:()=>f("preview"),className:`inline-block p-4 ${y==="preview"?"text-blue-600 border-b-2 border-blue-600 dark:text-blue-500 dark:border-blue-500":"text-gray-500 hover:text-gray-600 hover:border-gray-300 dark:text-gray-400 dark:hover:text-gray-300"}`},"Preview")),t.createElement("li",{className:"mr-2"},t.createElement("button",{onClick:()=>f("markdown"),className:`inline-block p-4 ${y==="markdown"?"text-blue-600 border-b-2 border-blue-600 dark:text-blue-500 dark:border-blue-500":"text-gray-500 hover:text-gray-600 hover:border-gray-300 dark:text-gray-400 dark:hover:text-gray-300"}`},"Markdown")))),t.createElement("div",{className:"bg-white dark:bg-gray-800 p-4 rounded-md"},y==="preview"?t.createElement("div",null,H(),j(),t.createElement("div",{className:"bg-gray-50 dark:bg-gray-700 p-6 rounded-md"},u())):t.createElement("div",null,t.createElement("pre",{className:"bg-gray-50 dark:bg-gray-700 p-4 rounded-md overflow-auto whitespace-pre-wrap font-mono text-sm text-gray-800 dark:text-gray-200"},g))),U())};var ce=({content:g,title:E="Privacy Policy",organizationName:v,lastUpdated:T=new Date,onExportComplete:D,componentTitle:q="Export Privacy Policy",description:k="Export your NDPA-compliant privacy policy in various formats.",className:V="",buttonClassName:$="",showExportHistory:A=true,includeComplianceNotice:w=true,includeLogo:O=false,logoUrl:N,customStyles:S})=>{let[x,y]=useState([]),[f,W]=useState("pdf"),[P,h]=useState(false),[j,H]=useState(null),[u,U]=useState(""),[n,l]=useState(""),[c,p]=useState(""),[L,M]=useState(false),B=e=>{let i=new Date().toISOString().split("T")[0];return `${v?v.toLowerCase().replace(/[^a-z0-9]+/g,"-"):"privacy-policy"}-privacy-policy-${i}.${e.toLowerCase()}`},Y=e=>u?u.endsWith(`.${e.toLowerCase()}`)?u:`${u}.${e.toLowerCase()}`:B(e),z=()=>{let e=v?`${v} ${E}`:E,i=T.toLocaleDateString(),b=`<!DOCTYPE html>
|
|
9
|
+
<html lang="en">
|
|
10
|
+
<head>
|
|
11
|
+
<meta charset="UTF-8">
|
|
12
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
13
|
+
<title>${e}</title>
|
|
14
|
+
<style>
|
|
15
|
+
body {
|
|
16
|
+
font-family: Arial, sans-serif;
|
|
17
|
+
line-height: 1.6;
|
|
18
|
+
color: #333;
|
|
19
|
+
max-width: 800px;
|
|
20
|
+
margin: 0 auto;
|
|
21
|
+
padding: 20px;
|
|
22
|
+
}
|
|
23
|
+
h1 {
|
|
24
|
+
font-size: 24px;
|
|
25
|
+
margin-bottom: 10px;
|
|
26
|
+
}
|
|
27
|
+
h2 {
|
|
28
|
+
font-size: 20px;
|
|
29
|
+
margin-top: 30px;
|
|
30
|
+
margin-bottom: 10px;
|
|
31
|
+
border-bottom: 1px solid #eee;
|
|
32
|
+
padding-bottom: 5px;
|
|
33
|
+
}
|
|
34
|
+
h3 {
|
|
35
|
+
font-size: 18px;
|
|
36
|
+
margin-top: 20px;
|
|
37
|
+
margin-bottom: 10px;
|
|
38
|
+
}
|
|
39
|
+
p {
|
|
40
|
+
margin-bottom: 15px;
|
|
41
|
+
}
|
|
42
|
+
.header {
|
|
43
|
+
text-align: center;
|
|
44
|
+
margin-bottom: 30px;
|
|
45
|
+
}
|
|
46
|
+
.footer {
|
|
47
|
+
margin-top: 50px;
|
|
48
|
+
text-align: center;
|
|
49
|
+
font-size: 12px;
|
|
50
|
+
color: #666;
|
|
51
|
+
border-top: 1px solid #eee;
|
|
52
|
+
padding-top: 20px;
|
|
53
|
+
}
|
|
54
|
+
.logo {
|
|
55
|
+
max-width: 200px;
|
|
56
|
+
margin-bottom: 20px;
|
|
57
|
+
}
|
|
58
|
+
.last-updated {
|
|
59
|
+
font-size: 12px;
|
|
60
|
+
color: #666;
|
|
61
|
+
margin-bottom: 30px;
|
|
62
|
+
}
|
|
63
|
+
.compliance-notice {
|
|
64
|
+
background-color: #f8f9fa;
|
|
65
|
+
border: 1px solid #e9ecef;
|
|
66
|
+
padding: 15px;
|
|
67
|
+
margin-bottom: 30px;
|
|
68
|
+
font-size: 14px;
|
|
69
|
+
}
|
|
70
|
+
${S||""}
|
|
71
|
+
</style>
|
|
72
|
+
</head>
|
|
73
|
+
<body>
|
|
74
|
+
<div class="header">
|
|
75
|
+
${O&&N?`<img src="${N}" alt="${v||"Company"} Logo" class="logo">`:""}
|
|
76
|
+
${n?`<div class="custom-header">${n}</div>`:""}
|
|
77
|
+
<h1>${e}</h1>
|
|
78
|
+
<div class="last-updated">Last Updated: ${i}</div>
|
|
79
|
+
</div>`;w&&(b+=`
|
|
80
|
+
<div class="compliance-notice">
|
|
81
|
+
<strong>NDPA Compliance Notice:</strong> This privacy policy has been created to comply with the Nigeria Data Protection Act (NDPA) 2023.
|
|
82
|
+
It outlines how we collect, use, disclose, and protect your personal information in accordance with NDPA requirements.
|
|
83
|
+
</div>`);let I=g.replace(/^## (.*?)$/gm,"<h2>$1</h2>").replace(/^### (.*?)$/gm,"<h3>$1</h3>").replace(/\n\n/g,"</p><p>").replace(/\n/g,"<br>");return b+=`
|
|
84
|
+
<div class="content">
|
|
85
|
+
<p>${I}</p>
|
|
86
|
+
</div>
|
|
87
|
+
|
|
88
|
+
<div class="footer">
|
|
89
|
+
${c?`<div class="custom-footer">${c}</div>`:""}
|
|
90
|
+
<p>© ${new Date().getFullYear()} ${v||"Company"}. All rights reserved.</p>
|
|
91
|
+
</div>
|
|
92
|
+
</body>
|
|
93
|
+
</html>`,b},a=()=>d(null,null,function*(){h(true),H(null);try{let e=f.toLowerCase(),i="",b;switch(e){case "pdf":let _=z();b=new Blob([_],{type:"text/html"}),i=URL.createObjectURL(b);break;case "docx":b=new Blob([g],{type:"text/plain"}),i=URL.createObjectURL(b);break;case "html":let ee=z();b=new Blob([ee],{type:"text/html"}),i=URL.createObjectURL(b);break;case "markdown":default:b=new Blob([g],{type:"text/markdown"}),i=URL.createObjectURL(b);break}let I=Y(e),G=document.createElement("a");G.href=i,G.download=I,document.body.appendChild(G),G.click(),document.body.removeChild(G);let R={id:`export_${Date.now()}`,format:e,timestamp:Date.now(),url:i,filename:I};y(_=>[R,..._]),D&&D(e,i);}catch(e){console.error("Export error:",e),H("An error occurred during export. Please try again.");}finally{h(false);}}),d$1=()=>t.createElement("div",{className:"mb-6"},t.createElement("label",{htmlFor:"export-format",className:"block text-sm font-medium mb-1"},"Export Format"),t.createElement("select",{id:"export-format",value:f,onChange:i=>W(i.target.value),className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"},[{value:"pdf",label:"PDF Document (.pdf)"},{value:"docx",label:"Word Document (.docx)"},{value:"html",label:"Web Page (.html)"},{value:"markdown",label:"Markdown (.md)"}].map(i=>t.createElement("option",{key:i.value,value:i.value},i.label)))),s=()=>L?t.createElement("div",{className:"mb-6 space-y-4 border border-gray-200 dark:border-gray-700 rounded-md p-4"},t.createElement("div",{className:"flex justify-between items-center"},t.createElement("h3",{className:"text-md font-medium"},"Advanced Export Options"),t.createElement("button",{type:"button",onClick:()=>M(false),className:"text-blue-600 dark:text-blue-400 text-sm"},"Hide Advanced Options")),t.createElement("div",null,t.createElement("label",{htmlFor:"custom-filename",className:"block text-sm font-medium mb-1"},"Custom Filename"),t.createElement("input",{type:"text",id:"custom-filename",value:u,onChange:e=>U(e.target.value),placeholder:B(f),className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"}),t.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400 mt-1"},"Leave blank to use the default filename format.")),t.createElement("div",null,t.createElement("label",{htmlFor:"custom-header",className:"block text-sm font-medium mb-1"},"Custom Header HTML (for HTML/PDF exports)"),t.createElement("textarea",{id:"custom-header",value:n,onChange:e=>l(e.target.value),rows:3,placeholder:"<div>Custom header content</div>",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),t.createElement("div",null,t.createElement("label",{htmlFor:"custom-footer",className:"block text-sm font-medium mb-1"},"Custom Footer HTML (for HTML/PDF exports)"),t.createElement("textarea",{id:"custom-footer",value:c,onChange:e=>p(e.target.value),rows:3,placeholder:"<div>Custom footer content</div>",className:"w-full px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"})),t.createElement("div",{className:"flex items-start"},t.createElement("div",{className:"flex items-center h-5"},t.createElement("input",{id:"include-compliance-notice",type:"checkbox",checked:w,onChange:e=>M(e.target.checked),className:"w-4 h-4 text-blue-600 border-gray-300 rounded focus:ring-blue-500 dark:focus:ring-blue-600 dark:ring-offset-gray-800 dark:focus:ring-offset-gray-800 focus:ring-2 dark:bg-gray-700 dark:border-gray-600"})),t.createElement("div",{className:"ml-3 text-sm"},t.createElement("label",{htmlFor:"include-compliance-notice",className:"font-medium text-gray-900 dark:text-white"},"Include NDPA Compliance Notice"),t.createElement("p",{className:"text-gray-500 dark:text-gray-400"},"Adds a notice explaining that this policy complies with NDPA requirements.")))):t.createElement("button",{type:"button",onClick:()=>M(true),className:"text-blue-600 dark:text-blue-400 text-sm mb-6"},"Show Advanced Options"),m=()=>!A||x.length===0?null:t.createElement("div",{className:"mt-6"},t.createElement("h3",{className:"text-lg font-medium mb-3"},"Export History"),t.createElement("div",{className:"bg-gray-50 dark:bg-gray-700 rounded-md overflow-hidden"},t.createElement("table",{className:"min-w-full divide-y divide-gray-200 dark:divide-gray-600"},t.createElement("thead",{className:"bg-gray-100 dark:bg-gray-800"},t.createElement("tr",null,t.createElement("th",{scope:"col",className:"px-6 py-3 text-left text-xs font-medium text-gray-500 dark:text-gray-300 uppercase tracking-wider"},"Date"),t.createElement("th",{scope:"col",className:"px-6 py-3 text-left text-xs font-medium text-gray-500 dark:text-gray-300 uppercase tracking-wider"},"Format"),t.createElement("th",{scope:"col",className:"px-6 py-3 text-left text-xs font-medium text-gray-500 dark:text-gray-300 uppercase tracking-wider"},"Filename"),t.createElement("th",{scope:"col",className:"px-6 py-3 text-left text-xs font-medium text-gray-500 dark:text-gray-300 uppercase tracking-wider"},"Actions"))),t.createElement("tbody",{className:"bg-white dark:bg-gray-700 divide-y divide-gray-200 dark:divide-gray-600"},x.map(e=>t.createElement("tr",{key:e.id},t.createElement("td",{className:"px-6 py-4 whitespace-nowrap text-sm text-gray-500 dark:text-gray-300"},new Date(e.timestamp).toLocaleString()),t.createElement("td",{className:"px-6 py-4 whitespace-nowrap text-sm text-gray-500 dark:text-gray-300"},e.format.toUpperCase()),t.createElement("td",{className:"px-6 py-4 whitespace-nowrap text-sm text-gray-500 dark:text-gray-300"},e.filename),t.createElement("td",{className:"px-6 py-4 whitespace-nowrap text-sm font-medium"},t.createElement("a",{href:e.url,download:e.filename,className:"text-blue-600 dark:text-blue-400 hover:text-blue-900 dark:hover:text-blue-300 mr-4"},"Download"))))))));return t.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${V}`},t.createElement("h2",{className:"text-xl font-bold mb-2"},q),t.createElement("p",{className:"mb-6 text-gray-600 dark:text-gray-300"},k),d$1(),s(),t.createElement("div",{className:"mb-6"},t.createElement("button",{onClick:a,disabled:P,className:`px-6 py-3 bg-blue-600 text-white rounded-md hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-offset-2 ${$} ${P?"opacity-70 cursor-not-allowed":""}`},P?"Exporting...":`Export as ${f.toUpperCase()}`),j&&t.createElement("p",{className:"mt-2 text-sm text-red-600 dark:text-red-500"},j)),t.createElement("div",{className:"mb-6 p-4 bg-blue-50 dark:bg-blue-900/20 rounded-md"},t.createElement("h3",{className:"text-sm font-bold text-blue-800 dark:text-blue-200 mb-2"},"Export Tips"),t.createElement("ul",{className:"text-blue-700 dark:text-blue-300 text-sm list-disc list-inside space-y-1"},t.createElement("li",null,"PDF format is recommended for printing or sharing with stakeholders."),t.createElement("li",null,"HTML format is ideal for publishing on your website."),t.createElement("li",null,"DOCX format allows for further editing in Microsoft Word or similar applications."),t.createElement("li",null,"Markdown format is useful for version control systems or technical documentation."))),m())};export{ae as a,ne as b,ce as c};//# sourceMappingURL=chunk-FFW7RUAG.mjs.map
|
|
94
|
+
//# sourceMappingURL=chunk-FFW7RUAG.mjs.map
|