@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 @@
|
|
|
1
|
+
{"version":3,"sources":["../packages/ndpr-toolkit/src/hooks/useROPA.ts"],"names":["useROPA","initialData","onRecordAdd","onRecordUpdate","onRecordArchive","ropa","setROPA","useState","addRecord","useCallback","record","prev","__spreadProps","__spreadValues","updateRecord","id","updates","archiveRecord","getRecord","getSummary","generateROPASummary","exportCSV","exportROPAToCSV","getComplianceGaps","identifyComplianceGaps"],"mappings":"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","file":"chunk-4A354HL3.js","sourcesContent":["import { useState, useCallback, useMemo } from 'react';\nimport type {\n ProcessingRecord,\n RecordOfProcessingActivities,\n ROPASummary,\n} from '../types/ropa';\nimport {\n generateROPASummary,\n exportROPAToCSV,\n identifyComplianceGaps,\n type ROPAComplianceGap,\n} from '../utils/ropa';\n\nexport interface UseROPAOptions {\n /**\n * Initial ROPA state\n */\n initialData: RecordOfProcessingActivities;\n\n /**\n * Callback when a record is added\n */\n onRecordAdd?: (record: ProcessingRecord) => void;\n\n /**\n * Callback when a record is updated\n */\n onRecordUpdate?: (id: string, updates: Partial<ProcessingRecord>) => void;\n\n /**\n * Callback when a record is archived\n */\n onRecordArchive?: (id: string) => void;\n}\n\nexport interface UseROPAReturn {\n /**\n * Current state of the Record of Processing Activities\n */\n ropa: RecordOfProcessingActivities;\n\n /**\n * Add a new processing record\n */\n addRecord: (record: ProcessingRecord) => void;\n\n /**\n * Update an existing processing record\n */\n updateRecord: (id: string, updates: Partial<ProcessingRecord>) => void;\n\n /**\n * Archive a processing record by setting its status to 'archived'\n */\n archiveRecord: (id: string) => void;\n\n /**\n * Get a single processing record by ID\n */\n getRecord: (id: string) => ProcessingRecord | undefined;\n\n /**\n * Get a summary of the ROPA including statistics\n */\n getSummary: () => ROPASummary;\n\n /**\n * Export the ROPA as a CSV string\n */\n exportCSV: () => string;\n\n /**\n * Identify compliance gaps across all records\n */\n getComplianceGaps: () => ROPAComplianceGap[];\n}\n\n/**\n * Hook for managing a Record of Processing Activities (ROPA)\n * in compliance with NDPA 2023 requirements.\n *\n * Provides state management and utility functions for maintaining\n * a comprehensive register of all data processing activities.\n */\nexport function useROPA({\n initialData,\n onRecordAdd,\n onRecordUpdate,\n onRecordArchive,\n}: UseROPAOptions): UseROPAReturn {\n const [ropa, setROPA] = useState<RecordOfProcessingActivities>(initialData);\n\n const addRecord = useCallback(\n (record: ProcessingRecord) => {\n setROPA((prev) => ({\n ...prev,\n records: [...prev.records, record],\n lastUpdated: Date.now(),\n }));\n onRecordAdd?.(record);\n },\n [onRecordAdd]\n );\n\n const updateRecord = useCallback(\n (id: string, updates: Partial<ProcessingRecord>) => {\n setROPA((prev) => ({\n ...prev,\n records: prev.records.map((record) =>\n record.id === id\n ? { ...record, ...updates, updatedAt: Date.now() }\n : record\n ),\n lastUpdated: Date.now(),\n }));\n onRecordUpdate?.(id, updates);\n },\n [onRecordUpdate]\n );\n\n const archiveRecord = useCallback(\n (id: string) => {\n setROPA((prev) => ({\n ...prev,\n records: prev.records.map((record) =>\n record.id === id\n ? { ...record, status: 'archived' as const, updatedAt: Date.now() }\n : record\n ),\n lastUpdated: Date.now(),\n }));\n onRecordArchive?.(id);\n },\n [onRecordArchive]\n );\n\n const getRecord = useCallback(\n (id: string): ProcessingRecord | undefined => {\n return ropa.records.find((record) => record.id === id);\n },\n [ropa.records]\n );\n\n const getSummary = useCallback((): ROPASummary => {\n return generateROPASummary(ropa);\n }, [ropa]);\n\n const exportCSV = useCallback((): string => {\n return exportROPAToCSV(ropa);\n }, [ropa]);\n\n const getComplianceGaps = useCallback((): ROPAComplianceGap[] => {\n return identifyComplianceGaps(ropa);\n }, [ropa]);\n\n return {\n ropa,\n addRecord,\n updateRecord,\n archiveRecord,\n getRecord,\n getSummary,\n exportCSV,\n getComplianceGaps,\n };\n}\n"]}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
'use strict';var chunkPM7CMTMB_js=require('./chunk-PM7CMTMB.js'),chunkMQFZHA2D_js=require('./chunk-MQFZHA2D.js'),t=require('react');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var t__default=/*#__PURE__*/_interopDefault(t);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]=t.useState(g),[N,S]=t.useState(E),[x,y]=t.useState("sections"),[f,W]=t.useState(""),[P,h]=t.useState(""),[j,H]=t.useState(false),[u,U]=t.useState({});t.useEffect(()=>{O(g);},[g]),t.useEffect(()=>{S(E);},[E]);let n=a=>{O(d=>d.map(s=>s.id===a?chunkMQFZHA2D_js.b(chunkMQFZHA2D_js.a({},s),{included:!s.included}):s));},l=(a,d)=>{S(s=>s.map(m=>m.id===a?chunkMQFZHA2D_js.b(chunkMQFZHA2D_js.a({},m),{value:d}):m)),u[a]&&U(s=>{let m=chunkMQFZHA2D_js.a({},s);return delete m[a],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+=chunkPM7CMTMB_js.a(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__default.default.createElement("div",{className:"space-y-4"},t__default.default.createElement("h3",{className:"text-lg font-medium mb-4"},"Select Policy Sections"),w.map(a=>t__default.default.createElement("div",{key:a.id,className:"border border-gray-200 dark:border-gray-700 rounded-md p-4"},t__default.default.createElement("div",{className:"flex items-start"},t__default.default.createElement("div",{className:"flex items-center h-5"},t__default.default.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__default.default.createElement("div",{className:"ml-3 text-sm"},t__default.default.createElement("label",{htmlFor:`section-${a.id}`,className:"font-medium text-gray-900 dark:text-white"},a.title," ",a.required&&t__default.default.createElement("span",{className:"text-red-500"},"*")),a.description&&t__default.default.createElement("p",{className:"text-gray-500 dark:text-gray-400 mt-1"},a.description))))),t__default.default.createElement("div",{className:"mt-6"},t__default.default.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__default.default.createElement("div",null,t__default.default.createElement("h3",{className:"text-lg font-medium mb-4"},"Fill Policy Variables"),t__default.default.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__default.default.createElement("div",{key:d,className:"border border-gray-200 dark:border-gray-700 rounded-md p-4"},t__default.default.createElement("h4",{className:"font-medium text-lg mb-3"},m?m.title:"General Information"),t__default.default.createElement("div",{className:"space-y-4"},s.map(e=>t__default.default.createElement("div",{key:e.id},t__default.default.createElement("label",{htmlFor:`var-${e.id}`,className:"block text-sm font-medium mb-1"},e.name," ",e.required&&t__default.default.createElement("span",{className:"text-red-500"},"*")),e.description&&t__default.default.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400 mb-2"},e.description),e.inputType==="textarea"?t__default.default.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__default.default.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__default.default.createElement("option",{value:""},"Select an option"),e.options.map(i=>t__default.default.createElement("option",{key:i,value:i},i))):t__default.default.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__default.default.createElement("p",{className:"mt-1 text-sm text-red-600 dark:text-red-500"},u[e.id])))))})),t__default.default.createElement("div",{className:"mt-6 flex space-x-4"},t__default.default.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__default.default.createElement("button",{onClick:p,className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${k}`},V)))},Y=()=>t__default.default.createElement("div",null,t__default.default.createElement("h3",{className:"text-lg font-medium mb-4"},"Preview Generated Policy"),A?t__default.default.createElement("div",{className:"mb-4"},t__default.default.createElement("label",{htmlFor:"policy-content",className:"block text-sm font-medium mb-1"},"Edit Policy Content"),t__default.default.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__default.default.createElement("div",{className:"bg-gray-50 dark:bg-gray-700 p-4 rounded-md mb-4"},t__default.default.createElement("div",{className:"prose dark:prose-invert max-w-none"},f.split(`
|
|
6
|
+
`).map((a,d)=>a.startsWith("## ")?t__default.default.createElement("h2",{key:d,className:"text-xl font-bold mt-6 mb-3"},a.substring(3)):a.startsWith("### ")?t__default.default.createElement("h3",{key:d,className:"text-lg font-bold mt-4 mb-2"},a.substring(4)):a===""?t__default.default.createElement("br",{key:d}):t__default.default.createElement("p",{key:d,className:"mb-2"},a)))),t__default.default.createElement("div",{className:"mt-6 flex space-x-4"},t__default.default.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__default.default.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__default.default.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${q}`},t__default.default.createElement("h2",{className:"text-xl font-bold mb-2"},T),t__default.default.createElement("p",{className:"mb-6 text-gray-600 dark:text-gray-300"},D),t__default.default.createElement("div",{className:"mb-8"},t__default.default.createElement("ol",{className:"flex items-center w-full"},t__default.default.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__default.default.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__default.default.createElement("span",{className:"hidden sm:inline-flex sm:ml-2"},"Sections")),t__default.default.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__default.default.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__default.default.createElement("span",{className:"hidden sm:inline-flex sm:ml-2"},"Variables")),t__default.default.createElement("li",{className:`flex items-center ${x==="preview"?"text-blue-600 dark:text-blue-500":"text-gray-500 dark:text-gray-400"}`},t__default.default.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__default.default.createElement("span",{className:"hidden sm:inline-flex sm:ml-2"},"Preview")))),t__default.default.createElement("div",{className:"mb-6 p-4 bg-blue-50 dark:bg-blue-900/20 rounded-md"},t__default.default.createElement("h3",{className:"text-sm font-bold text-blue-800 dark:text-blue-200 mb-2"},"NDPA Compliance Notice"),t__default.default.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]=t.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__default.default.createElement("div",{className:"mb-6 p-4 bg-gray-50 dark:bg-gray-700 rounded-md"},t__default.default.createElement("h3",{className:"text-lg font-medium mb-3"},"Table of Contents"),t__default.default.createElement("ul",{className:"space-y-1"},P.map((n,l)=>t__default.default.createElement("li",{key:l,style:{marginLeft:`${(n.level-2)*1.5}rem`}},t__default.default.createElement("a",{href:`#${n.id}`,className:"text-blue-600 dark:text-blue-400 hover:underline"},n.title))))),H=()=>N?t__default.default.createElement("div",{className:"mb-6"},t__default.default.createElement("h1",{className:"text-2xl font-bold mb-2"},S?`${S} Privacy Policy`:"Privacy Policy"),t__default.default.createElement("p",{className:"text-sm text-gray-500 dark:text-gray-400"},"Last Updated: ",x.toLocaleDateString())):null,u=()=>t__default.default.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__default.default.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__default.default.createElement("h3",{id:p,key:l,className:"text-lg font-bold mt-4 mb-2"},c)}else return n===""?t__default.default.createElement("br",{key:l}):t__default.default.createElement("p",{key:l,className:"mb-2"},n)})),U=()=>A?t__default.default.createElement("div",{className:"mt-6"},t__default.default.createElement("h3",{className:"text-lg font-medium mb-3"},"Export Options"),t__default.default.createElement("div",{className:"flex flex-wrap gap-3"},t__default.default.createElement("button",{onClick:()=>h("pdf"),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${$}`},"Export as PDF"),t__default.default.createElement("button",{onClick:()=>h("docx"),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${$}`},"Export as DOCX"),t__default.default.createElement("button",{onClick:()=>h("html"),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${$}`},"Export as HTML"),t__default.default.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__default.default.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${V}`},t__default.default.createElement("div",{className:"flex justify-between items-start mb-6"},t__default.default.createElement("div",null,t__default.default.createElement("h2",{className:"text-xl font-bold mb-2"},q),t__default.default.createElement("p",{className:"text-gray-600 dark:text-gray-300"},k)),w&&D&&t__default.default.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__default.default.createElement("div",{className:"mb-6 p-4 bg-blue-50 dark:bg-blue-900/20 rounded-md"},t__default.default.createElement("h3",{className:"text-sm font-bold text-blue-800 dark:text-blue-200 mb-2"},"NDPA Compliance Notice"),t__default.default.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__default.default.createElement("div",{className:"mb-6 border-b border-gray-200 dark:border-gray-700"},t__default.default.createElement("ul",{className:"flex flex-wrap -mb-px"},t__default.default.createElement("li",{className:"mr-2"},t__default.default.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__default.default.createElement("li",{className:"mr-2"},t__default.default.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__default.default.createElement("div",{className:"bg-white dark:bg-gray-800 p-4 rounded-md"},y==="preview"?t__default.default.createElement("div",null,H(),j(),t__default.default.createElement("div",{className:"bg-gray-50 dark:bg-gray-700 p-6 rounded-md"},u())):t__default.default.createElement("div",null,t__default.default.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]=t.useState([]),[f,W]=t.useState("pdf"),[P,h]=t.useState(false),[j,H]=t.useState(null),[u,U]=t.useState(""),[n,l]=t.useState(""),[c,p]=t.useState(""),[L,M]=t.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=()=>chunkMQFZHA2D_js.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=()=>t__default.default.createElement("div",{className:"mb-6"},t__default.default.createElement("label",{htmlFor:"export-format",className:"block text-sm font-medium mb-1"},"Export Format"),t__default.default.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__default.default.createElement("option",{key:i.value,value:i.value},i.label)))),s=()=>L?t__default.default.createElement("div",{className:"mb-6 space-y-4 border border-gray-200 dark:border-gray-700 rounded-md p-4"},t__default.default.createElement("div",{className:"flex justify-between items-center"},t__default.default.createElement("h3",{className:"text-md font-medium"},"Advanced Export Options"),t__default.default.createElement("button",{type:"button",onClick:()=>M(false),className:"text-blue-600 dark:text-blue-400 text-sm"},"Hide Advanced Options")),t__default.default.createElement("div",null,t__default.default.createElement("label",{htmlFor:"custom-filename",className:"block text-sm font-medium mb-1"},"Custom Filename"),t__default.default.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__default.default.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400 mt-1"},"Leave blank to use the default filename format.")),t__default.default.createElement("div",null,t__default.default.createElement("label",{htmlFor:"custom-header",className:"block text-sm font-medium mb-1"},"Custom Header HTML (for HTML/PDF exports)"),t__default.default.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__default.default.createElement("div",null,t__default.default.createElement("label",{htmlFor:"custom-footer",className:"block text-sm font-medium mb-1"},"Custom Footer HTML (for HTML/PDF exports)"),t__default.default.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__default.default.createElement("div",{className:"flex items-start"},t__default.default.createElement("div",{className:"flex items-center h-5"},t__default.default.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__default.default.createElement("div",{className:"ml-3 text-sm"},t__default.default.createElement("label",{htmlFor:"include-compliance-notice",className:"font-medium text-gray-900 dark:text-white"},"Include NDPA Compliance Notice"),t__default.default.createElement("p",{className:"text-gray-500 dark:text-gray-400"},"Adds a notice explaining that this policy complies with NDPA requirements.")))):t__default.default.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__default.default.createElement("div",{className:"mt-6"},t__default.default.createElement("h3",{className:"text-lg font-medium mb-3"},"Export History"),t__default.default.createElement("div",{className:"bg-gray-50 dark:bg-gray-700 rounded-md overflow-hidden"},t__default.default.createElement("table",{className:"min-w-full divide-y divide-gray-200 dark:divide-gray-600"},t__default.default.createElement("thead",{className:"bg-gray-100 dark:bg-gray-800"},t__default.default.createElement("tr",null,t__default.default.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__default.default.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__default.default.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__default.default.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__default.default.createElement("tbody",{className:"bg-white dark:bg-gray-700 divide-y divide-gray-200 dark:divide-gray-600"},x.map(e=>t__default.default.createElement("tr",{key:e.id},t__default.default.createElement("td",{className:"px-6 py-4 whitespace-nowrap text-sm text-gray-500 dark:text-gray-300"},new Date(e.timestamp).toLocaleString()),t__default.default.createElement("td",{className:"px-6 py-4 whitespace-nowrap text-sm text-gray-500 dark:text-gray-300"},e.format.toUpperCase()),t__default.default.createElement("td",{className:"px-6 py-4 whitespace-nowrap text-sm text-gray-500 dark:text-gray-300"},e.filename),t__default.default.createElement("td",{className:"px-6 py-4 whitespace-nowrap text-sm font-medium"},t__default.default.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__default.default.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${V}`},t__default.default.createElement("h2",{className:"text-xl font-bold mb-2"},q),t__default.default.createElement("p",{className:"mb-6 text-gray-600 dark:text-gray-300"},k),d(),s(),t__default.default.createElement("div",{className:"mb-6"},t__default.default.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__default.default.createElement("p",{className:"mt-2 text-sm text-red-600 dark:text-red-500"},j)),t__default.default.createElement("div",{className:"mb-6 p-4 bg-blue-50 dark:bg-blue-900/20 rounded-md"},t__default.default.createElement("h3",{className:"text-sm font-bold text-blue-800 dark:text-blue-200 mb-2"},"Export Tips"),t__default.default.createElement("ul",{className:"text-blue-700 dark:text-blue-300 text-sm list-disc list-inside space-y-1"},t__default.default.createElement("li",null,"PDF format is recommended for printing or sharing with stakeholders."),t__default.default.createElement("li",null,"HTML format is ideal for publishing on your website."),t__default.default.createElement("li",null,"DOCX format allows for further editing in Microsoft Word or similar applications."),t__default.default.createElement("li",null,"Markdown format is useful for version control systems or technical documentation."))),m())};exports.a=ae;exports.b=ne;exports.c=ce;//# sourceMappingURL=chunk-4DKT6IB6.js.map
|
|
94
|
+
//# sourceMappingURL=chunk-4DKT6IB6.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../packages/ndpr-toolkit/src/components/policy/PolicyGenerator.tsx","../packages/ndpr-toolkit/src/components/policy/PolicyPreview.tsx","../packages/ndpr-toolkit/src/components/policy/PolicyExporter.tsx"],"names":["PolicyGenerator","initialSections","initialVariables","onGenerate","title","description","className","buttonClassName","generateButtonText","showPreview","allowEditing","sections","setSections","useState","variables","setVariables","activeStep","setActiveStep","generatedPolicy","setGeneratedPolicy","editedPolicy","setEditedPolicy","isGenerated","setIsGenerated","errors","setErrors","useEffect","handleSectionToggle","sectionId","prevSections","section","__spreadProps","__spreadValues","handleVariableChange","variableId","value","prevVariables","variable","prevErrors","newErrors","validateVariables","isValid","generatePolicy","includedSections","variableMap","policyContent","generatePolicyText","handleSubmit","renderSectionList","React","renderVariableForm","variablesBySection","sectionVariables","s","e","option","renderPolicyPreview","line","index","renderStep","PolicyPreview","content","onExport","onEdit","showExportOptions","showEditButton","showTableOfContents","showMetadata","organizationName","lastUpdated","activeTab","setActiveTab","sectionTitles","lines","id","handleExport","format","element","file","renderTableOfContents","renderMetadata","renderHTMLContent","renderExportOptions","PolicyExporter","onExportComplete","componentTitle","showExportHistory","includeComplianceNotice","includeLogo","logoUrl","customStyles","exportHistory","setExportHistory","selectedFormat","setSelectedFormat","isExporting","setIsExporting","exportError","setExportError","customFilename","setCustomFilename","customHeader","setCustomHeader","customFooter","setCustomFooter","showAdvancedOptions","setShowAdvancedOptions","generateDefaultFilename","dateStr","getFilename","generateHTMLContent","fullTitle","html","htmlContent","__async","url","blob","htmlForPdf","filename","exportRecord","prevHistory","error","renderFormatOptions","renderAdvancedOptions","renderExportHistory","record"],"mappings":"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","file":"chunk-4DKT6IB6.js","sourcesContent":["import React, { useState, useEffect } from 'react';\nimport { generatePolicyText } from '../../utils/privacy';\nimport { PolicySection, PolicyVariable } from '../../types/privacy';\n\n// Using PolicySection and PolicyVariable from types/privacy.ts\n\nexport interface PolicyGeneratorProps {\n /**\n * List of policy sections\n */\n sections: PolicySection[];\n \n /**\n * List of policy variables\n */\n variables: PolicyVariable[];\n \n /**\n * Callback function called when the policy is generated\n */\n onGenerate: (policy: { sections: PolicySection[], variables: PolicyVariable[], content: string }) => void;\n \n /**\n * Title displayed on the generator\n * @default \"NDPA Privacy Policy Generator\"\n */\n title?: string;\n\n /**\n * Description text displayed on the generator\n * @default \"Generate an NDPA-compliant privacy policy for your organization.\"\n */\n description?: string;\n \n /**\n * Custom CSS class for the generator\n */\n className?: string;\n \n /**\n * Custom CSS class for the buttons\n */\n buttonClassName?: string;\n \n /**\n * Text for the generate button\n * @default \"Generate Policy\"\n */\n generateButtonText?: string;\n \n /**\n * Whether to show a preview of the generated policy\n * @default true\n */\n showPreview?: boolean;\n \n /**\n * Whether to allow editing the policy content\n * @default true\n */\n allowEditing?: boolean;\n}\n\nexport const PolicyGenerator: React.FC<PolicyGeneratorProps> = ({\n sections: initialSections,\n variables: initialVariables,\n onGenerate,\n title = \"NDPA Privacy Policy Generator\",\n description = \"Generate an NDPA-compliant privacy policy for your organization.\",\n className = \"\",\n buttonClassName = \"\",\n generateButtonText = \"Generate Policy\",\n showPreview = true,\n allowEditing = true\n}) => {\n const [sections, setSections] = useState<PolicySection[]>(initialSections);\n const [variables, setVariables] = useState<PolicyVariable[]>(initialVariables);\n const [activeStep, setActiveStep] = useState<'sections' | 'variables' | 'preview'>('sections');\n const [generatedPolicy, setGeneratedPolicy] = useState<string>('');\n const [editedPolicy, setEditedPolicy] = useState<string>('');\n const [isGenerated, setIsGenerated] = useState<boolean>(false);\n const [errors, setErrors] = useState<Record<string, string>>({});\n \n // Update sections when initialSections changes\n useEffect(() => {\n setSections(initialSections);\n }, [initialSections]);\n \n // Update variables when initialVariables changes\n useEffect(() => {\n setVariables(initialVariables);\n }, [initialVariables]);\n \n // Handle section toggle\n const handleSectionToggle = (sectionId: string) => {\n setSections(prevSections => \n prevSections.map(section => \n section.id === sectionId \n ? { ...section, included: !section.included } \n : section\n )\n );\n };\n \n // Handle variable change\n const handleVariableChange = (variableId: string, value: string) => {\n setVariables(prevVariables => \n prevVariables.map(variable => \n variable.id === variableId \n ? { ...variable, value } \n : variable\n )\n );\n \n // Clear error for this variable if it exists\n if (errors[variableId]) {\n setErrors(prevErrors => {\n const newErrors = { ...prevErrors };\n delete newErrors[variableId];\n return newErrors;\n });\n }\n };\n \n // Validate variables\n const validateVariables = (): boolean => {\n const newErrors: Record<string, string> = {};\n let isValid = true;\n \n variables.forEach(variable => {\n if (variable.required && !variable.value) {\n newErrors[variable.id] = `${variable.name} is required`;\n isValid = false;\n }\n });\n \n setErrors(newErrors);\n return isValid;\n };\n \n // Generate policy\n const generatePolicy = () => {\n if (!validateVariables()) {\n setActiveStep('variables');\n return;\n }\n \n const includedSections = sections.filter(section => section.included);\n const variableMap = Object.fromEntries(\n variables.map(variable => [variable.name, variable.value])\n );\n \n let policyContent = '';\n \n includedSections.forEach(section => {\n policyContent += `## ${section.title}\\n\\n`;\n policyContent += generatePolicyText(section.template, variableMap);\n policyContent += '\\n\\n';\n });\n \n setGeneratedPolicy(policyContent);\n setEditedPolicy(policyContent);\n setIsGenerated(true);\n setActiveStep('preview');\n };\n \n // Handle policy submission\n const handleSubmit = () => {\n const policy = {\n sections,\n variables,\n content: allowEditing ? editedPolicy : generatedPolicy\n };\n \n onGenerate(policy);\n };\n \n // Render section list\n const renderSectionList = () => {\n return (\n <div className=\"space-y-4\">\n <h3 className=\"text-lg font-medium mb-4\">Select Policy Sections</h3>\n \n {sections.map(section => (\n <div key={section.id} className=\"border border-gray-200 dark:border-gray-700 rounded-md p-4\">\n <div className=\"flex items-start\">\n <div className=\"flex items-center h-5\">\n <input\n id={`section-${section.id}`}\n type=\"checkbox\"\n checked={section.included}\n onChange={() => handleSectionToggle(section.id)}\n disabled={section.required}\n 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\"\n />\n </div>\n <div className=\"ml-3 text-sm\">\n <label htmlFor={`section-${section.id}`} className=\"font-medium text-gray-900 dark:text-white\">\n {section.title} {section.required && <span className=\"text-red-500\">*</span>}\n </label>\n {section.description && (\n <p className=\"text-gray-500 dark:text-gray-400 mt-1\">{section.description}</p>\n )}\n </div>\n </div>\n </div>\n ))}\n \n <div className=\"mt-6\">\n <button\n onClick={() => setActiveStep('variables')}\n className={`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${buttonClassName}`}\n >\n Next: Fill Variables\n </button>\n </div>\n </div>\n );\n };\n \n // Render variable form\n const renderVariableForm = () => {\n // Group variables by section\n const variablesBySection: Record<string, PolicyVariable[]> = {};\n \n variables.forEach(variable => {\n const sectionId = variable.id.split('.')[0];\n if (!variablesBySection[sectionId]) {\n variablesBySection[sectionId] = [];\n }\n variablesBySection[sectionId].push(variable);\n });\n \n return (\n <div>\n <h3 className=\"text-lg font-medium mb-4\">Fill Policy Variables</h3>\n \n <div className=\"space-y-6\">\n {Object.entries(variablesBySection).map(([sectionId, sectionVariables]) => {\n const section = sections.find(s => s.id === sectionId);\n \n // Skip sections that are not included\n if (section && !section.included) {\n return null;\n }\n \n return (\n <div key={sectionId} className=\"border border-gray-200 dark:border-gray-700 rounded-md p-4\">\n <h4 className=\"font-medium text-lg mb-3\">\n {section ? section.title : 'General Information'}\n </h4>\n \n <div className=\"space-y-4\">\n {sectionVariables.map(variable => (\n <div key={variable.id}>\n <label htmlFor={`var-${variable.id}`} className=\"block text-sm font-medium mb-1\">\n {variable.name} {variable.required && <span className=\"text-red-500\">*</span>}\n </label>\n \n {variable.description && (\n <p className=\"text-xs text-gray-500 dark:text-gray-400 mb-2\">\n {variable.description}\n </p>\n )}\n \n {variable.inputType === 'textarea' ? (\n <textarea\n id={`var-${variable.id}`}\n value={variable.value}\n onChange={e => handleVariableChange(variable.id, e.target.value)}\n rows={4}\n className={`w-full px-3 py-2 border ${\n errors[variable.id] \n ? 'border-red-500 focus:ring-red-500' \n : 'border-gray-300 dark:border-gray-600 focus:ring-blue-500'\n } rounded-md focus:outline-none focus:ring-2`}\n required={variable.required}\n />\n ) : variable.inputType === 'select' && variable.options ? (\n <select\n id={`var-${variable.id}`}\n value={variable.value}\n onChange={e => handleVariableChange(variable.id, e.target.value)}\n className={`w-full px-3 py-2 border ${\n errors[variable.id] \n ? 'border-red-500 focus:ring-red-500' \n : 'border-gray-300 dark:border-gray-600 focus:ring-blue-500'\n } rounded-md focus:outline-none focus:ring-2`}\n required={variable.required}\n >\n <option value=\"\">Select an option</option>\n {variable.options.map(option => (\n <option key={option} value={option}>{option}</option>\n ))}\n </select>\n ) : (\n <input\n id={`var-${variable.id}`}\n type={variable.inputType}\n value={variable.value}\n onChange={e => handleVariableChange(variable.id, e.target.value)}\n className={`w-full px-3 py-2 border ${\n errors[variable.id] \n ? 'border-red-500 focus:ring-red-500' \n : 'border-gray-300 dark:border-gray-600 focus:ring-blue-500'\n } rounded-md focus:outline-none focus:ring-2`}\n required={variable.required}\n />\n )}\n \n {errors[variable.id] && (\n <p className=\"mt-1 text-sm text-red-600 dark:text-red-500\">\n {errors[variable.id]}\n </p>\n )}\n </div>\n ))}\n </div>\n </div>\n );\n })}\n </div>\n \n <div className=\"mt-6 flex space-x-4\">\n <button\n onClick={() => setActiveStep('sections')}\n 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 ${buttonClassName}`}\n >\n Back to Sections\n </button>\n <button\n onClick={generatePolicy}\n className={`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${buttonClassName}`}\n >\n {generateButtonText}\n </button>\n </div>\n </div>\n );\n };\n \n // Render policy preview\n const renderPolicyPreview = () => {\n return (\n <div>\n <h3 className=\"text-lg font-medium mb-4\">Preview Generated Policy</h3>\n \n {allowEditing ? (\n <div className=\"mb-4\">\n <label htmlFor=\"policy-content\" className=\"block text-sm font-medium mb-1\">\n Edit Policy Content\n </label>\n <textarea\n id=\"policy-content\"\n value={editedPolicy}\n onChange={e => setEditedPolicy(e.target.value)}\n rows={20}\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 font-mono text-sm\"\n />\n </div>\n ) : (\n <div className=\"bg-gray-50 dark:bg-gray-700 p-4 rounded-md mb-4\">\n <div className=\"prose dark:prose-invert max-w-none\">\n {generatedPolicy.split('\\n').map((line, index) => {\n if (line.startsWith('## ')) {\n return <h2 key={index} className=\"text-xl font-bold mt-6 mb-3\">{line.substring(3)}</h2>;\n } else if (line.startsWith('### ')) {\n return <h3 key={index} className=\"text-lg font-bold mt-4 mb-2\">{line.substring(4)}</h3>;\n } else if (line === '') {\n return <br key={index} />;\n } else {\n return <p key={index} className=\"mb-2\">{line}</p>;\n }\n })}\n </div>\n </div>\n )}\n \n <div className=\"mt-6 flex space-x-4\">\n <button\n onClick={() => setActiveStep('variables')}\n 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 ${buttonClassName}`}\n >\n Back to Variables\n </button>\n <button\n onClick={handleSubmit}\n className={`px-4 py-2 bg-green-600 text-white rounded hover:bg-green-700 ${buttonClassName}`}\n >\n Save Policy\n </button>\n </div>\n </div>\n );\n };\n \n // Render the current step\n const renderStep = () => {\n switch (activeStep) {\n case 'sections':\n return renderSectionList();\n case 'variables':\n return renderVariableForm();\n case 'preview':\n return renderPolicyPreview();\n default:\n return renderSectionList();\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 {/* Steps Indicator */}\n <div className=\"mb-8\">\n <ol className=\"flex items-center w-full\">\n <li className={`flex w-full items-center ${activeStep === '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`}>\n <span className={`flex items-center justify-center w-8 h-8 ${activeStep === 'sections' ? 'bg-blue-100 dark:bg-blue-800' : 'bg-gray-100 dark:bg-gray-700'} rounded-full shrink-0`}>\n 1\n </span>\n <span className=\"hidden sm:inline-flex sm:ml-2\">Sections</span>\n </li>\n <li className={`flex w-full items-center ${activeStep === '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`}>\n <span className={`flex items-center justify-center w-8 h-8 ${activeStep === 'variables' ? 'bg-blue-100 dark:bg-blue-800' : 'bg-gray-100 dark:bg-gray-700'} rounded-full shrink-0`}>\n 2\n </span>\n <span className=\"hidden sm:inline-flex sm:ml-2\">Variables</span>\n </li>\n <li className={`flex items-center ${activeStep === 'preview' ? 'text-blue-600 dark:text-blue-500' : 'text-gray-500 dark:text-gray-400'}`}>\n <span className={`flex items-center justify-center w-8 h-8 ${activeStep === 'preview' ? 'bg-blue-100 dark:bg-blue-800' : 'bg-gray-100 dark:bg-gray-700'} rounded-full shrink-0`}>\n 3\n </span>\n <span className=\"hidden sm:inline-flex sm:ml-2\">Preview</span>\n </li>\n </ol>\n </div>\n \n {/* NDPA Notice */}\n <div className=\"mb-6 p-4 bg-blue-50 dark:bg-blue-900/20 rounded-md\">\n <h3 className=\"text-sm font-bold text-blue-800 dark:text-blue-200 mb-2\">NDPA Compliance Notice</h3>\n <p className=\"text-blue-700 dark:text-blue-300 text-sm\">\n This tool helps you generate a privacy policy that aligns with the Nigeria Data Protection Act (NDPA) 2023.\n While we strive to ensure compliance, we recommend having the final policy reviewed by a legal professional\n familiar with NDPA requirements.\n </p>\n </div>\n \n {/* Current Step Content */}\n {renderStep()}\n </div>\n );\n};\n","import React, { useState } from 'react';\nimport { PolicySection, PolicyVariable } from '../../types/privacy';\n\nexport interface PolicyPreviewProps {\n /**\n * The policy content to preview\n */\n content: string;\n \n /**\n * The policy sections\n */\n sections?: PolicySection[];\n \n /**\n * The policy variables\n */\n variables?: PolicyVariable[];\n \n /**\n * Callback function called when the policy is exported\n */\n onExport?: (format: 'pdf' | 'html' | 'markdown' | 'docx') => void;\n \n /**\n * Callback function called when the policy is edited\n */\n onEdit?: () => void;\n \n /**\n * Title displayed on the preview\n * @default \"Privacy Policy Preview\"\n */\n title?: string;\n \n /**\n * Description text displayed on the preview\n * @default \"Preview your NDPA-compliant privacy policy before exporting.\"\n */\n description?: string;\n \n /**\n * Custom CSS class for the preview\n */\n className?: string;\n \n /**\n * Custom CSS class for the buttons\n */\n buttonClassName?: string;\n \n /**\n * Whether to show the export options\n * @default true\n */\n showExportOptions?: boolean;\n \n /**\n * Whether to show the edit button\n * @default true\n */\n showEditButton?: boolean;\n \n /**\n * Whether to show the table of contents\n * @default true\n */\n showTableOfContents?: boolean;\n \n /**\n * Whether to show the policy metadata\n * @default true\n */\n showMetadata?: boolean;\n \n /**\n * The organization name to display in the policy\n */\n organizationName?: string;\n \n /**\n * The last updated date to display in the policy\n */\n lastUpdated?: Date;\n}\n\nexport const PolicyPreview: React.FC<PolicyPreviewProps> = ({\n content,\n sections,\n variables,\n onExport,\n onEdit,\n title = \"Privacy Policy Preview\",\n description = \"Preview your NDPA-compliant privacy policy before exporting.\",\n className = \"\",\n buttonClassName = \"\",\n showExportOptions = true,\n showEditButton = true,\n showTableOfContents = true,\n showMetadata = true,\n organizationName,\n lastUpdated = new Date()\n}) => {\n const [activeTab, setActiveTab] = useState<'preview' | 'markdown'>('preview');\n \n // Parse the content to extract section titles for the table of contents\n const extractSectionTitles = (): { id: string, title: string, level: number }[] => {\n const lines = content.split('\\n');\n const sectionTitles: { id: string, title: string, level: number }[] = [];\n \n lines.forEach(line => {\n if (line.startsWith('## ')) {\n const title = line.substring(3).trim();\n const id = title.toLowerCase().replace(/[^a-z0-9]+/g, '-');\n sectionTitles.push({ id, title, level: 2 });\n } else if (line.startsWith('### ')) {\n const title = line.substring(4).trim();\n const id = title.toLowerCase().replace(/[^a-z0-9]+/g, '-');\n sectionTitles.push({ id, title, level: 3 });\n }\n });\n \n return sectionTitles;\n };\n \n // Get the section titles for the table of contents\n const sectionTitles = extractSectionTitles();\n \n // Handle export button click\n const handleExport = (format: 'pdf' | 'html' | 'markdown' | 'docx') => {\n if (onExport) {\n onExport(format);\n } else {\n // Fallback export functionality\n if (format === 'markdown') {\n const element = document.createElement('a');\n const file = new Blob([content], {type: 'text/markdown'});\n element.href = URL.createObjectURL(file);\n element.download = `privacy-policy-${new Date().toISOString().split('T')[0]}.md`;\n document.body.appendChild(element);\n element.click();\n document.body.removeChild(element);\n }\n }\n };\n \n // Render the table of contents\n const renderTableOfContents = () => {\n if (!showTableOfContents || sectionTitles.length === 0) {\n return null;\n }\n \n return (\n <div className=\"mb-6 p-4 bg-gray-50 dark:bg-gray-700 rounded-md\">\n <h3 className=\"text-lg font-medium mb-3\">Table of Contents</h3>\n <ul className=\"space-y-1\">\n {sectionTitles.map((section, index) => (\n <li key={index} style={{ marginLeft: `${(section.level - 2) * 1.5}rem` }}>\n <a \n href={`#${section.id}`} \n className=\"text-blue-600 dark:text-blue-400 hover:underline\"\n >\n {section.title}\n </a>\n </li>\n ))}\n </ul>\n </div>\n );\n };\n \n // Render the policy metadata\n const renderMetadata = () => {\n if (!showMetadata) {\n return null;\n }\n \n return (\n <div className=\"mb-6\">\n <h1 className=\"text-2xl font-bold mb-2\">\n {organizationName ? `${organizationName} Privacy Policy` : 'Privacy Policy'}\n </h1>\n <p className=\"text-sm text-gray-500 dark:text-gray-400\">\n Last Updated: {lastUpdated.toLocaleDateString()}\n </p>\n </div>\n );\n };\n \n // Render the policy content in HTML format\n const renderHTMLContent = () => {\n return (\n <div className=\"prose dark:prose-invert max-w-none\">\n {content.split('\\n').map((line, index) => {\n if (line.startsWith('## ')) {\n const title = line.substring(3).trim();\n const id = title.toLowerCase().replace(/[^a-z0-9]+/g, '-');\n return <h2 id={id} key={index} className=\"text-xl font-bold mt-6 mb-3\">{title}</h2>;\n } else if (line.startsWith('### ')) {\n const title = line.substring(4).trim();\n const id = title.toLowerCase().replace(/[^a-z0-9]+/g, '-');\n return <h3 id={id} key={index} className=\"text-lg font-bold mt-4 mb-2\">{title}</h3>;\n } else if (line === '') {\n return <br key={index} />;\n } else {\n return <p key={index} className=\"mb-2\">{line}</p>;\n }\n })}\n </div>\n );\n };\n \n // Render the export options\n const renderExportOptions = () => {\n if (!showExportOptions) {\n return null;\n }\n \n return (\n <div className=\"mt-6\">\n <h3 className=\"text-lg font-medium mb-3\">Export Options</h3>\n <div className=\"flex flex-wrap gap-3\">\n <button\n onClick={() => handleExport('pdf')}\n className={`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${buttonClassName}`}\n >\n Export as PDF\n </button>\n <button\n onClick={() => handleExport('docx')}\n className={`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${buttonClassName}`}\n >\n Export as DOCX\n </button>\n <button\n onClick={() => handleExport('html')}\n className={`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${buttonClassName}`}\n >\n Export as HTML\n </button>\n <button\n onClick={() => handleExport('markdown')}\n className={`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${buttonClassName}`}\n >\n Export as Markdown\n </button>\n </div>\n </div>\n );\n };\n \n return (\n <div className={`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${className}`}>\n <div className=\"flex justify-between items-start mb-6\">\n <div>\n <h2 className=\"text-xl font-bold mb-2\">{title}</h2>\n <p className=\"text-gray-600 dark:text-gray-300\">{description}</p>\n </div>\n \n {showEditButton && onEdit && (\n <button\n onClick={onEdit}\n 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 ${buttonClassName}`}\n >\n Edit Policy\n </button>\n )}\n </div>\n \n {/* NDPA Notice */}\n <div className=\"mb-6 p-4 bg-blue-50 dark:bg-blue-900/20 rounded-md\">\n <h3 className=\"text-sm font-bold text-blue-800 dark:text-blue-200 mb-2\">NDPA Compliance Notice</h3>\n <p className=\"text-blue-700 dark:text-blue-300 text-sm\">\n This privacy policy has been generated to align with the Nigeria Data Protection Act (NDPA) 2023.\n We recommend having the final policy reviewed by a legal professional familiar with NDPA requirements\n before publishing it on your website or sharing it with your users.\n </p>\n </div>\n \n {/* Tabs */}\n <div className=\"mb-6 border-b border-gray-200 dark:border-gray-700\">\n <ul className=\"flex flex-wrap -mb-px\">\n <li className=\"mr-2\">\n <button\n onClick={() => setActiveTab('preview')}\n className={`inline-block p-4 ${\n activeTab === 'preview'\n ? 'text-blue-600 border-b-2 border-blue-600 dark:text-blue-500 dark:border-blue-500'\n : 'text-gray-500 hover:text-gray-600 hover:border-gray-300 dark:text-gray-400 dark:hover:text-gray-300'\n }`}\n >\n Preview\n </button>\n </li>\n <li className=\"mr-2\">\n <button\n onClick={() => setActiveTab('markdown')}\n className={`inline-block p-4 ${\n activeTab === 'markdown'\n ? 'text-blue-600 border-b-2 border-blue-600 dark:text-blue-500 dark:border-blue-500'\n : 'text-gray-500 hover:text-gray-600 hover:border-gray-300 dark:text-gray-400 dark:hover:text-gray-300'\n }`}\n >\n Markdown\n </button>\n </li>\n </ul>\n </div>\n \n {/* Content */}\n <div className=\"bg-white dark:bg-gray-800 p-4 rounded-md\">\n {activeTab === 'preview' ? (\n <div>\n {renderMetadata()}\n {renderTableOfContents()}\n <div className=\"bg-gray-50 dark:bg-gray-700 p-6 rounded-md\">\n {renderHTMLContent()}\n </div>\n </div>\n ) : (\n <div>\n <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\">\n {content}\n </pre>\n </div>\n )}\n </div>\n \n {/* Export Options */}\n {renderExportOptions()}\n </div>\n );\n};\n","import React, { useState } from 'react';\n\nexport interface PolicyExporterProps {\n /**\n * The policy content to export\n */\n content: string;\n \n /**\n * The policy title\n */\n title?: string;\n \n /**\n * The organization name to include in the exported policy\n */\n organizationName?: string;\n \n /**\n * The last updated date to include in the exported policy\n */\n lastUpdated?: Date;\n \n /**\n * Callback function called when the export is complete\n */\n onExportComplete?: (format: string, url: string) => void;\n \n /**\n * Title displayed on the exporter\n * @default \"Export Privacy Policy\"\n */\n componentTitle?: string;\n \n /**\n * Description text displayed on the exporter\n * @default \"Export your NDPA-compliant privacy policy in various formats.\"\n */\n description?: string;\n \n /**\n * Custom CSS class for the exporter\n */\n className?: string;\n \n /**\n * Custom CSS class for the buttons\n */\n buttonClassName?: string;\n \n /**\n * Whether to show the export history\n * @default true\n */\n showExportHistory?: boolean;\n \n /**\n * Whether to include the NDPA compliance notice in the exported policy\n * @default true\n */\n includeComplianceNotice?: boolean;\n \n /**\n * Whether to include the organization logo in the exported policy\n * @default false\n */\n includeLogo?: boolean;\n \n /**\n * URL of the organization logo\n */\n logoUrl?: string;\n \n /**\n * Custom CSS styles for the exported policy\n */\n customStyles?: string;\n}\n\ninterface ExportRecord {\n id: string;\n format: string;\n timestamp: number;\n url: string;\n filename: string;\n}\n\nexport const PolicyExporter: React.FC<PolicyExporterProps> = ({\n content,\n title = \"Privacy Policy\",\n organizationName,\n lastUpdated = new Date(),\n onExportComplete,\n componentTitle = \"Export Privacy Policy\",\n description = \"Export your NDPA-compliant privacy policy in various formats.\",\n className = \"\",\n buttonClassName = \"\",\n showExportHistory = true,\n includeComplianceNotice = true,\n includeLogo = false,\n logoUrl,\n customStyles\n}) => {\n const [exportHistory, setExportHistory] = useState<ExportRecord[]>([]);\n const [selectedFormat, setSelectedFormat] = useState<string>('pdf');\n const [isExporting, setIsExporting] = useState<boolean>(false);\n const [exportError, setExportError] = useState<string | null>(null);\n const [customFilename, setCustomFilename] = useState<string>('');\n const [customHeader, setCustomHeader] = useState<string>('');\n const [customFooter, setCustomFooter] = useState<string>('');\n const [showAdvancedOptions, setShowAdvancedOptions] = useState<boolean>(false);\n \n // Generate a default filename based on the organization name and format\n const generateDefaultFilename = (format: string): string => {\n const dateStr = new Date().toISOString().split('T')[0];\n const orgStr = organizationName ? \n organizationName.toLowerCase().replace(/[^a-z0-9]+/g, '-') : \n 'privacy-policy';\n \n return `${orgStr}-privacy-policy-${dateStr}.${format.toLowerCase()}`;\n };\n \n // Get the actual filename to use\n const getFilename = (format: string): string => {\n if (customFilename) {\n // Ensure the filename has the correct extension\n if (customFilename.endsWith(`.${format.toLowerCase()}`)) {\n return customFilename;\n } else {\n return `${customFilename}.${format.toLowerCase()}`;\n }\n }\n \n return generateDefaultFilename(format);\n };\n \n // Generate HTML content for export\n const generateHTMLContent = (): string => {\n const fullTitle = organizationName ? `${organizationName} ${title}` : title;\n const dateStr = lastUpdated.toLocaleDateString();\n \n let html = `<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <title>${fullTitle}</title>\n <style>\n body {\n font-family: Arial, sans-serif;\n line-height: 1.6;\n color: #333;\n max-width: 800px;\n margin: 0 auto;\n padding: 20px;\n }\n h1 {\n font-size: 24px;\n margin-bottom: 10px;\n }\n h2 {\n font-size: 20px;\n margin-top: 30px;\n margin-bottom: 10px;\n border-bottom: 1px solid #eee;\n padding-bottom: 5px;\n }\n h3 {\n font-size: 18px;\n margin-top: 20px;\n margin-bottom: 10px;\n }\n p {\n margin-bottom: 15px;\n }\n .header {\n text-align: center;\n margin-bottom: 30px;\n }\n .footer {\n margin-top: 50px;\n text-align: center;\n font-size: 12px;\n color: #666;\n border-top: 1px solid #eee;\n padding-top: 20px;\n }\n .logo {\n max-width: 200px;\n margin-bottom: 20px;\n }\n .last-updated {\n font-size: 12px;\n color: #666;\n margin-bottom: 30px;\n }\n .compliance-notice {\n background-color: #f8f9fa;\n border: 1px solid #e9ecef;\n padding: 15px;\n margin-bottom: 30px;\n font-size: 14px;\n }\n ${customStyles || ''}\n </style>\n</head>\n<body>\n <div class=\"header\">\n ${includeLogo && logoUrl ? `<img src=\"${logoUrl}\" alt=\"${organizationName || 'Company'} Logo\" class=\"logo\">` : ''}\n ${customHeader ? `<div class=\"custom-header\">${customHeader}</div>` : ''}\n <h1>${fullTitle}</h1>\n <div class=\"last-updated\">Last Updated: ${dateStr}</div>\n </div>`;\n \n if (includeComplianceNotice) {\n html += `\n <div class=\"compliance-notice\">\n <strong>NDPA Compliance Notice:</strong> This privacy policy has been created to comply with the Nigeria Data Protection Act (NDPA) 2023.\n It outlines how we collect, use, disclose, and protect your personal information in accordance with NDPA requirements.\n </div>`;\n }\n \n // Convert markdown content to HTML\n const htmlContent = content\n .replace(/^## (.*?)$/gm, '<h2>$1</h2>')\n .replace(/^### (.*?)$/gm, '<h3>$1</h3>')\n .replace(/\\n\\n/g, '</p><p>')\n .replace(/\\n/g, '<br>');\n \n html += `\n <div class=\"content\">\n <p>${htmlContent}</p>\n </div>\n \n <div class=\"footer\">\n ${customFooter ? `<div class=\"custom-footer\">${customFooter}</div>` : ''}\n <p>© ${new Date().getFullYear()} ${organizationName || 'Company'}. All rights reserved.</p>\n </div>\n</body>\n</html>`;\n \n return html;\n };\n \n // Handle export button click\n const handleExport = async () => {\n setIsExporting(true);\n setExportError(null);\n \n try {\n const format = selectedFormat.toLowerCase();\n let url = '';\n let blob: Blob;\n \n switch (format) {\n case 'pdf':\n // In a real implementation, this would use a PDF generation library\n // For this example, we'll just create an HTML file with a note\n const htmlForPdf = generateHTMLContent();\n blob = new Blob([htmlForPdf], { type: 'text/html' });\n url = URL.createObjectURL(blob);\n break;\n \n case 'docx':\n // In a real implementation, this would use a DOCX generation library\n // For this example, we'll just create a text file with a note\n blob = new Blob([content], { type: 'text/plain' });\n url = URL.createObjectURL(blob);\n break;\n \n case 'html':\n const html = generateHTMLContent();\n blob = new Blob([html], { type: 'text/html' });\n url = URL.createObjectURL(blob);\n break;\n \n case 'markdown':\n default:\n blob = new Blob([content], { type: 'text/markdown' });\n url = URL.createObjectURL(blob);\n break;\n }\n \n // Create a download link and trigger it\n const filename = getFilename(format);\n const element = document.createElement('a');\n element.href = url;\n element.download = filename;\n document.body.appendChild(element);\n element.click();\n document.body.removeChild(element);\n \n // Add to export history\n const exportRecord: ExportRecord = {\n id: `export_${Date.now()}`,\n format,\n timestamp: Date.now(),\n url,\n filename\n };\n \n setExportHistory(prevHistory => [exportRecord, ...prevHistory]);\n \n // Call the callback\n if (onExportComplete) {\n onExportComplete(format, url);\n }\n } catch (error) {\n console.error('Export error:', error);\n setExportError('An error occurred during export. Please try again.');\n } finally {\n setIsExporting(false);\n }\n };\n \n // Render export format options\n const renderFormatOptions = () => {\n const formats = [\n { value: 'pdf', label: 'PDF Document (.pdf)' },\n { value: 'docx', label: 'Word Document (.docx)' },\n { value: 'html', label: 'Web Page (.html)' },\n { value: 'markdown', label: 'Markdown (.md)' }\n ];\n \n return (\n <div className=\"mb-6\">\n <label htmlFor=\"export-format\" className=\"block text-sm font-medium mb-1\">\n Export Format\n </label>\n <select\n id=\"export-format\"\n value={selectedFormat}\n onChange={e => setSelectedFormat(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 {formats.map(format => (\n <option key={format.value} value={format.value}>\n {format.label}\n </option>\n ))}\n </select>\n </div>\n );\n };\n \n // Render advanced options\n const renderAdvancedOptions = () => {\n if (!showAdvancedOptions) {\n return (\n <button\n type=\"button\"\n onClick={() => setShowAdvancedOptions(true)}\n className=\"text-blue-600 dark:text-blue-400 text-sm mb-6\"\n >\n Show Advanced Options\n </button>\n );\n }\n \n return (\n <div className=\"mb-6 space-y-4 border border-gray-200 dark:border-gray-700 rounded-md p-4\">\n <div className=\"flex justify-between items-center\">\n <h3 className=\"text-md font-medium\">Advanced Export Options</h3>\n <button\n type=\"button\"\n onClick={() => setShowAdvancedOptions(false)}\n className=\"text-blue-600 dark:text-blue-400 text-sm\"\n >\n Hide Advanced Options\n </button>\n </div>\n \n <div>\n <label htmlFor=\"custom-filename\" className=\"block text-sm font-medium mb-1\">\n Custom Filename\n </label>\n <input\n type=\"text\"\n id=\"custom-filename\"\n value={customFilename}\n onChange={e => setCustomFilename(e.target.value)}\n placeholder={generateDefaultFilename(selectedFormat)}\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 <p className=\"text-xs text-gray-500 dark:text-gray-400 mt-1\">\n Leave blank to use the default filename format.\n </p>\n </div>\n \n <div>\n <label htmlFor=\"custom-header\" className=\"block text-sm font-medium mb-1\">\n Custom Header HTML (for HTML/PDF exports)\n </label>\n <textarea\n id=\"custom-header\"\n value={customHeader}\n onChange={e => setCustomHeader(e.target.value)}\n rows={3}\n placeholder=\"<div>Custom header content</div>\"\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=\"custom-footer\" className=\"block text-sm font-medium mb-1\">\n Custom Footer HTML (for HTML/PDF exports)\n </label>\n <textarea\n id=\"custom-footer\"\n value={customFooter}\n onChange={e => setCustomFooter(e.target.value)}\n rows={3}\n placeholder=\"<div>Custom footer content</div>\"\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-start\">\n <div className=\"flex items-center h-5\">\n <input\n id=\"include-compliance-notice\"\n type=\"checkbox\"\n checked={includeComplianceNotice}\n onChange={e => setShowAdvancedOptions(e.target.checked)}\n 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\"\n />\n </div>\n <div className=\"ml-3 text-sm\">\n <label htmlFor=\"include-compliance-notice\" className=\"font-medium text-gray-900 dark:text-white\">\n Include NDPA Compliance Notice\n </label>\n <p className=\"text-gray-500 dark:text-gray-400\">\n Adds a notice explaining that this policy complies with NDPA requirements.\n </p>\n </div>\n </div>\n </div>\n );\n };\n \n // Render export history\n const renderExportHistory = () => {\n if (!showExportHistory || exportHistory.length === 0) {\n return null;\n }\n \n return (\n <div className=\"mt-6\">\n <h3 className=\"text-lg font-medium mb-3\">Export History</h3>\n <div className=\"bg-gray-50 dark:bg-gray-700 rounded-md overflow-hidden\">\n <table className=\"min-w-full divide-y divide-gray-200 dark:divide-gray-600\">\n <thead className=\"bg-gray-100 dark:bg-gray-800\">\n <tr>\n <th scope=\"col\" className=\"px-6 py-3 text-left text-xs font-medium text-gray-500 dark:text-gray-300 uppercase tracking-wider\">\n Date\n </th>\n <th scope=\"col\" className=\"px-6 py-3 text-left text-xs font-medium text-gray-500 dark:text-gray-300 uppercase tracking-wider\">\n Format\n </th>\n <th scope=\"col\" className=\"px-6 py-3 text-left text-xs font-medium text-gray-500 dark:text-gray-300 uppercase tracking-wider\">\n Filename\n </th>\n <th scope=\"col\" className=\"px-6 py-3 text-left text-xs font-medium text-gray-500 dark:text-gray-300 uppercase tracking-wider\">\n Actions\n </th>\n </tr>\n </thead>\n <tbody className=\"bg-white dark:bg-gray-700 divide-y divide-gray-200 dark:divide-gray-600\">\n {exportHistory.map(record => (\n <tr key={record.id}>\n <td className=\"px-6 py-4 whitespace-nowrap text-sm text-gray-500 dark:text-gray-300\">\n {new Date(record.timestamp).toLocaleString()}\n </td>\n <td className=\"px-6 py-4 whitespace-nowrap text-sm text-gray-500 dark:text-gray-300\">\n {record.format.toUpperCase()}\n </td>\n <td className=\"px-6 py-4 whitespace-nowrap text-sm text-gray-500 dark:text-gray-300\">\n {record.filename}\n </td>\n <td className=\"px-6 py-4 whitespace-nowrap text-sm font-medium\">\n <a \n href={record.url} \n download={record.filename}\n className=\"text-blue-600 dark:text-blue-400 hover:text-blue-900 dark:hover:text-blue-300 mr-4\"\n >\n Download\n </a>\n </td>\n </tr>\n ))}\n </tbody>\n </table>\n </div>\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\">{componentTitle}</h2>\n <p className=\"mb-6 text-gray-600 dark:text-gray-300\">{description}</p>\n \n {/* Format Selection */}\n {renderFormatOptions()}\n \n {/* Advanced Options */}\n {renderAdvancedOptions()}\n \n {/* Export Button */}\n <div className=\"mb-6\">\n <button\n onClick={handleExport}\n disabled={isExporting}\n 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 ${buttonClassName} ${isExporting ? 'opacity-70 cursor-not-allowed' : ''}`}\n >\n {isExporting ? 'Exporting...' : `Export as ${selectedFormat.toUpperCase()}`}\n </button>\n \n {exportError && (\n <p className=\"mt-2 text-sm text-red-600 dark:text-red-500\">\n {exportError}\n </p>\n )}\n </div>\n \n {/* Export Tips */}\n <div className=\"mb-6 p-4 bg-blue-50 dark:bg-blue-900/20 rounded-md\">\n <h3 className=\"text-sm font-bold text-blue-800 dark:text-blue-200 mb-2\">Export Tips</h3>\n <ul className=\"text-blue-700 dark:text-blue-300 text-sm list-disc list-inside space-y-1\">\n <li>PDF format is recommended for printing or sharing with stakeholders.</li>\n <li>HTML format is ideal for publishing on your website.</li>\n <li>DOCX format allows for further editing in Microsoft Word or similar applications.</li>\n <li>Markdown format is useful for version control systems or technical documentation.</li>\n </ul>\n </div>\n \n {/* Export History */}\n {renderExportHistory()}\n </div>\n );\n};\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var chunkIQF726GS_js=require('./chunk-IQF726GS.js'),chunkMQFZHA2D_js=require('./chunk-MQFZHA2D.js'),react=require('react');function J({initialTransfers:w=[],storageKey:c="ndpr_cross_border_transfers",useLocalStorage:u=true,onAdd:m,onUpdate:p,onRemove:C}={}){let[t,l]=react.useState(w);react.useEffect(()=>{if(u&&typeof window!="undefined")try{let r=localStorage.getItem(c);r&&l(JSON.parse(r));}catch(r){console.error("Error loading cross-border transfers:",r);}},[c,u]),react.useEffect(()=>{if(u&&typeof window!="undefined")try{localStorage.setItem(c,JSON.stringify(t));}catch(r){console.error("Error saving cross-border transfers:",r);}},[t,c,u]);let _=()=>"cbt_"+Date.now()+"_"+Math.random().toString(36).substring(2,11),b=react.useCallback(r=>{let n=Date.now(),s=chunkMQFZHA2D_js.b(chunkMQFZHA2D_js.a({},r),{id:_(),createdAt:n,updatedAt:n});return l(a=>[...a,s]),m&&m(s),s},[m]),A=react.useCallback((r,n)=>{let s=null;return l(a=>{let o=a.findIndex(g=>g.id===r);if(o===-1)return a;s=chunkMQFZHA2D_js.b(chunkMQFZHA2D_js.a(chunkMQFZHA2D_js.a({},a[o]),n),{updatedAt:Date.now()});let f=[...a];return f[o]=s,f}),s&&p&&p(s),s},[p]),S=react.useCallback(r=>{let n=false;return l(s=>s.findIndex(o=>o.id===r)===-1?s:(n=true,s.filter(o=>o.id!==r))),n&&C&&C(r),n},[C]),q=react.useCallback(r=>t.find(n=>n.id===r)||null,[t]),D=react.useCallback(()=>{let r=Date.now(),n=t.filter(e=>e.status==="active"),s=["adequacy_decision","standard_clauses","binding_corporate_rules","ndpc_authorization","explicit_consent","contract_performance","public_interest","legal_claims","vital_interests"],a={};for(let e of s)a[e]=n.filter(i=>i.transferMechanism===e).length;let o=["adequate","inadequate","pending_review","unknown"],f={};for(let e of o)f[e]=n.filter(i=>i.adequacyStatus===e).length;let g=t.filter(e=>{var i,v;return e.status==="pending_approval"||((i=e.ndpcApproval)==null?void 0:i.required)&&!((v=e.ndpcApproval)!=null&&v.approved)}),R=720*60*60*1e3,x=t.filter(e=>e.reviewDate&&e.reviewDate<=r+R&&e.status==="active"),I=t.filter(e=>!e.tiaCompleted&&e.status==="active"),O=t.filter(e=>e.riskLevel==="high"&&e.status==="active");return {totalActiveTransfers:n.length,byMechanism:a,byAdequacy:f,pendingApproval:g,dueForReview:x,missingTIA:I,highRiskTransfers:O,lastUpdated:r}},[t]),M=react.useCallback(r=>chunkIQF726GS_js.c(r),[]);return {transfers:t,addTransfer:b,updateTransfer:A,removeTransfer:S,getTransfer:q,getSummary:D,validateTransfer:M}}exports.a=J;//# sourceMappingURL=chunk-5ZBO2UPH.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-5ZBO2UPH.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../packages/ndpr-toolkit/src/hooks/useCrossBorderTransfer.ts"],"names":["useCrossBorderTransfer","initialTransfers","storageKey","useLocalStorage","onAdd","onUpdate","onRemove","transfers","setTransfers","useState","useEffect","savedData","error","generateId","addTransfer","useCallback","transferData","now","newTransfer","__spreadProps","__spreadValues","prev","updateTransfer","id","updates","updatedTransfer","index","t","newTransfers","removeTransfer","found","getTransfer","getSummary","activeTransfers","allMechanisms","byMechanism","mechanism","allStatuses","byAdequacy","status","pendingApproval","_a","_b","thirtyDaysMs","dueForReview","missingTIA","highRiskTransfers","validateTransfer","transfer"],"mappings":"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","file":"chunk-5ZBO2UPH.js","sourcesContent":["import { useState, useEffect, useCallback } from 'react';\nimport {\n CrossBorderTransfer,\n CrossBorderSummary,\n TransferMechanism,\n AdequacyStatus,\n} from '../types/cross-border';\nimport {\n validateTransfer as validateTransferUtil,\n TransferValidationResult,\n} from '../utils/cross-border';\n\ninterface UseCrossBorderTransferOptions {\n /**\n * Initial transfers to load\n */\n initialTransfers?: CrossBorderTransfer[];\n\n /**\n * Storage key for transfer data\n * @default \"ndpr_cross_border_transfers\"\n */\n storageKey?: string;\n\n /**\n * Whether to use local storage to persist transfers\n * @default true\n */\n useLocalStorage?: boolean;\n\n /**\n * Callback function called when a transfer is added\n */\n onAdd?: (transfer: CrossBorderTransfer) => void;\n\n /**\n * Callback function called when a transfer is updated\n */\n onUpdate?: (transfer: CrossBorderTransfer) => void;\n\n /**\n * Callback function called when a transfer is removed\n */\n onRemove?: (id: string) => void;\n}\n\ninterface UseCrossBorderTransferReturn {\n /**\n * All cross-border transfers\n */\n transfers: CrossBorderTransfer[];\n\n /**\n * Add a new cross-border transfer\n */\n addTransfer: (\n transfer: Omit<CrossBorderTransfer, 'id' | 'createdAt' | 'updatedAt'>\n ) => CrossBorderTransfer;\n\n /**\n * Update an existing cross-border transfer\n */\n updateTransfer: (\n id: string,\n updates: Partial<CrossBorderTransfer>\n ) => CrossBorderTransfer | null;\n\n /**\n * Remove a cross-border transfer\n */\n removeTransfer: (id: string) => boolean;\n\n /**\n * Get a cross-border transfer by ID\n */\n getTransfer: (id: string) => CrossBorderTransfer | null;\n\n /**\n * Get a compliance summary of all cross-border transfers\n */\n getSummary: () => CrossBorderSummary;\n\n /**\n * Validate a cross-border transfer\n */\n validateTransfer: (transfer: CrossBorderTransfer) => TransferValidationResult;\n}\n\n/**\n * Hook for managing cross-border data transfers in compliance with NDPA Part VI (Sections 41-45)\n */\nexport function useCrossBorderTransfer({\n initialTransfers = [],\n storageKey = 'ndpr_cross_border_transfers',\n useLocalStorage = true,\n onAdd,\n onUpdate,\n onRemove,\n}: UseCrossBorderTransferOptions = {}): UseCrossBorderTransferReturn {\n const [transfers, setTransfers] = useState<CrossBorderTransfer[]>(initialTransfers);\n\n // Load transfers from storage on mount\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined') {\n try {\n const savedData = localStorage.getItem(storageKey);\n if (savedData) {\n setTransfers(JSON.parse(savedData));\n }\n } catch (error) {\n console.error('Error loading cross-border transfers:', error);\n }\n }\n }, [storageKey, useLocalStorage]);\n\n // Save transfers to storage when they change\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined') {\n try {\n localStorage.setItem(storageKey, JSON.stringify(transfers));\n } catch (error) {\n console.error('Error saving cross-border transfers:', error);\n }\n }\n }, [transfers, storageKey, useLocalStorage]);\n\n // Generate a unique ID\n const generateId = (): string => {\n return 'cbt_' + Date.now() + '_' + Math.random().toString(36).substring(2, 11);\n };\n\n // Add a new transfer\n const addTransfer = useCallback(\n (\n transferData: Omit<CrossBorderTransfer, 'id' | 'createdAt' | 'updatedAt'>\n ): CrossBorderTransfer => {\n const now = Date.now();\n const newTransfer: CrossBorderTransfer = {\n ...transferData,\n id: generateId(),\n createdAt: now,\n updatedAt: now,\n };\n\n setTransfers((prev) => [...prev, newTransfer]);\n\n if (onAdd) {\n onAdd(newTransfer);\n }\n\n return newTransfer;\n },\n [onAdd]\n );\n\n // Update an existing transfer\n const updateTransfer = useCallback(\n (id: string, updates: Partial<CrossBorderTransfer>): CrossBorderTransfer | null => {\n let updatedTransfer: CrossBorderTransfer | null = null;\n\n setTransfers((prev) => {\n const index = prev.findIndex((t) => t.id === id);\n if (index === -1) {\n return prev;\n }\n\n updatedTransfer = {\n ...prev[index],\n ...updates,\n updatedAt: Date.now(),\n };\n\n const newTransfers = [...prev];\n newTransfers[index] = updatedTransfer as CrossBorderTransfer;\n return newTransfers;\n });\n\n if (updatedTransfer && onUpdate) {\n onUpdate(updatedTransfer);\n }\n\n return updatedTransfer;\n },\n [onUpdate]\n );\n\n // Remove a transfer\n const removeTransfer = useCallback(\n (id: string): boolean => {\n let found = false;\n\n setTransfers((prev) => {\n const index = prev.findIndex((t) => t.id === id);\n if (index === -1) {\n return prev;\n }\n found = true;\n return prev.filter((t) => t.id !== id);\n });\n\n if (found && onRemove) {\n onRemove(id);\n }\n\n return found;\n },\n [onRemove]\n );\n\n // Get a transfer by ID\n const getTransfer = useCallback(\n (id: string): CrossBorderTransfer | null => {\n return transfers.find((t) => t.id === id) || null;\n },\n [transfers]\n );\n\n // Get compliance summary\n const getSummary = useCallback((): CrossBorderSummary => {\n const now = Date.now();\n const activeTransfers = transfers.filter((t) => t.status === 'active');\n\n // Breakdown by mechanism\n const allMechanisms: TransferMechanism[] = [\n 'adequacy_decision',\n 'standard_clauses',\n 'binding_corporate_rules',\n 'ndpc_authorization',\n 'explicit_consent',\n 'contract_performance',\n 'public_interest',\n 'legal_claims',\n 'vital_interests',\n ];\n const byMechanism = {} as Record<TransferMechanism, number>;\n for (const mechanism of allMechanisms) {\n byMechanism[mechanism] = activeTransfers.filter(\n (t) => t.transferMechanism === mechanism\n ).length;\n }\n\n // Breakdown by adequacy\n const allStatuses: AdequacyStatus[] = ['adequate', 'inadequate', 'pending_review', 'unknown'];\n const byAdequacy = {} as Record<AdequacyStatus, number>;\n for (const status of allStatuses) {\n byAdequacy[status] = activeTransfers.filter(\n (t) => t.adequacyStatus === status\n ).length;\n }\n\n // Transfers pending NDPC approval\n const pendingApproval = transfers.filter(\n (t) => t.status === 'pending_approval' || (t.ndpcApproval?.required && !t.ndpcApproval?.approved)\n );\n\n // Transfers due for review (within the next 30 days or overdue)\n const thirtyDaysMs = 30 * 24 * 60 * 60 * 1000;\n const dueForReview = transfers.filter(\n (t) => t.reviewDate && t.reviewDate <= now + thirtyDaysMs && t.status === 'active'\n );\n\n // Transfers missing TIA\n const missingTIA = transfers.filter(\n (t) => !t.tiaCompleted && t.status === 'active'\n );\n\n // High-risk transfers\n const highRiskTransfers = transfers.filter(\n (t) => t.riskLevel === 'high' && t.status === 'active'\n );\n\n return {\n totalActiveTransfers: activeTransfers.length,\n byMechanism,\n byAdequacy,\n pendingApproval,\n dueForReview,\n missingTIA,\n highRiskTransfers,\n lastUpdated: now,\n };\n }, [transfers]);\n\n // Validate a transfer (wrapper around utility)\n const validateTransfer = useCallback(\n (transfer: CrossBorderTransfer): TransferValidationResult => {\n return validateTransferUtil(transfer);\n },\n []\n );\n\n return {\n transfers,\n addTransfer,\n updateTransfer,\n removeTransfer,\n getTransfer,\n getSummary,\n validateTransfer,\n };\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {a}from'./chunk-2SYNHRP6.mjs';import {b,a as a$1}from'./chunk-WWT2ZSNU.mjs';import e,{useState,useEffect}from'react';var ae=({requestTypes:f,onSubmit:P,title:O="Submit a Data Subject Request",description:M="Use this form to exercise your rights under the Nigeria Data Protection Act (NDPA).",submitButtonText:H="Submit Request",className:K="",buttonClassName:_="",showConfirmation:B=true,confirmationMessage:W="Your request has been submitted successfully. You will receive a confirmation email shortly.",requireIdentityVerification:U=true,identifierTypes:F=[{id:"email",label:"Email Address"},{id:"account",label:"Account Number"},{id:"customer_id",label:"Customer ID"}],collectAdditionalContact:A=true,labels:y={}})=>{var m;let[p,N]=useState(""),[T,j]=useState(""),[k,C]=useState(""),[$,w]=useState(""),[I,V]=useState(((m=F[0])==null?void 0:m.id)||""),[E,L]=useState(""),[h,v]=useState({}),[z,Y]=useState(false),[x,G]=useState({}),g=f.find(t=>t.id===p),J=t=>{N(t.target.value),v({});},l=(t,o)=>{v(u=>b(a$1({},u),{[t]:o}));},a=()=>{let t={};return T.trim()||(t.fullName="Full name is required"),k.trim()?/\S+@\S+\.\S+/.test(k)||(t.email="Email is invalid"):t.email="Email is required",p||(t.requestType="Please select a request type"),U&&!E.trim()&&(t.identifierValue="Identifier value is required"),g!=null&&g.requiresAdditionalInfo&&g.additionalFields&&g.additionalFields.forEach(o=>{o.required&&!h[o.id]&&(t[`additional_${o.id}`]=`${o.label} is required`);}),G(t),Object.keys(t).length===0},n=t=>{if(t.preventDefault(),!a())return;let o={requestType:p,dataSubject:{fullName:T,email:k,phone:$||void 0,identifierType:I,identifierValue:E},additionalInfo:Object.keys(h).length>0?h:void 0,submittedAt:Date.now()};P(o),B&&Y(true);};return z?e.createElement("div",{className:`p-4 bg-green-50 dark:bg-green-900/20 rounded-md ${K}`},e.createElement("h2",{className:"text-lg font-bold text-green-800 dark:text-green-200 mb-2"},"Request Submitted"),e.createElement("p",{className:"text-green-700 dark:text-green-300"},W),e.createElement("button",{onClick:()=>Y(false),className:`mt-4 px-4 py-2 bg-green-600 text-white rounded hover:bg-green-700 ${_}`},"Submit Another Request")):e.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${K}`},e.createElement("h2",{className:"text-xl font-bold mb-2"},O),e.createElement("p",{className:"mb-6 text-gray-600 dark:text-gray-300"},M),e.createElement("form",{onSubmit:n},e.createElement("div",{className:"space-y-4"},e.createElement("div",null,e.createElement("h3",{className:"text-lg font-semibold mb-3"},"Personal Information"),e.createElement("div",{className:"grid grid-cols-1 gap-4 md:grid-cols-2"},e.createElement("div",null,e.createElement("label",{htmlFor:"fullName",className:"block text-sm font-medium mb-1"},y.name||"Full Name"," ",e.createElement("span",{className:"text-red-500"},"*")),e.createElement("input",{type:"text",id:"fullName",value:T,onChange:t=>j(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",required:true}),x.fullName&&e.createElement("p",{className:"mt-1 text-sm text-red-500"},x.fullName)),e.createElement("div",null,e.createElement("label",{htmlFor:"email",className:"block text-sm font-medium mb-1"},y.email||"Email Address"," ",e.createElement("span",{className:"text-red-500"},"*")),e.createElement("input",{type:"email",id:"email",value:k,onChange:t=>C(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",required:true}),x.email&&e.createElement("p",{className:"mt-1 text-sm text-red-500"},x.email)),A&&e.createElement("div",null,e.createElement("label",{htmlFor:"phone",className:"block text-sm font-medium mb-1"},"Phone Number (Optional)"),e.createElement("input",{type:"tel",id:"phone",value:$,onChange:t=>w(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",null,e.createElement("h3",{className:"text-lg font-semibold mb-3"},"Request Details"),e.createElement("div",{className:"mb-4"},e.createElement("label",{htmlFor:"requestType",className:"block text-sm font-medium mb-1"},y.requestType||"Request Type"," ",e.createElement("span",{className:"text-red-500"},"*")),e.createElement("select",{id:"requestType",value:p,onChange:J,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",required:true},e.createElement("option",{value:""},"Select a request type"),f.map(t=>e.createElement("option",{key:t.id,value:t.id},t.name))),x.requestType&&e.createElement("p",{className:"mt-1 text-sm text-red-500"},x.requestType)),g&&e.createElement("div",{className:"mb-4 p-3 bg-gray-50 dark:bg-gray-700 rounded-md"},e.createElement("p",{className:"text-sm text-gray-600 dark:text-gray-300 mb-2"},g.description),e.createElement("p",{className:"text-sm text-gray-500 dark:text-gray-400"},"Estimated completion time: ",g.estimatedCompletionTime," ",g.estimatedCompletionTime===1?"day":"days")),e.createElement("div",{className:"mb-4"},e.createElement("label",{htmlFor:"requestDescription",className:"block text-sm font-medium mb-1"},y.description||"Additional Information"),e.createElement("textarea",{id:"requestDescription",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",rows:4,placeholder:"Please provide any additional details that might help us process your request"}))),U&&e.createElement("div",null,e.createElement("h3",{className:"text-lg font-semibold mb-3"},"Identity Verification"),e.createElement("p",{className:"text-sm text-gray-600 dark:text-gray-300 mb-3"},"To protect your privacy, we need to verify your identity before processing your request."),e.createElement("div",{className:"grid grid-cols-1 gap-4 md:grid-cols-2"},e.createElement("div",null,e.createElement("label",{htmlFor:"identifierType",className:"block text-sm font-medium mb-1"},"Identifier Type ",e.createElement("span",{className:"text-red-500"},"*")),e.createElement("select",{id:"identifierType",value:I,onChange:t=>V(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",required:true},F.map(t=>e.createElement("option",{key:t.id,value:t.id},t.label)))),e.createElement("div",null,e.createElement("label",{htmlFor:"identifierValue",className:"block text-sm font-medium mb-1"},"Identifier Value ",e.createElement("span",{className:"text-red-500"},"*")),e.createElement("input",{type:"text",id:"identifierValue",value:E,onChange:t=>L(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",required:true}),x.identifierValue&&e.createElement("p",{className:"mt-1 text-sm text-red-500"},x.identifierValue)))),(g==null?void 0:g.requiresAdditionalInfo)&&g.additionalFields&&g.additionalFields.length>0&&e.createElement("div",null,e.createElement("h3",{className:"text-lg font-semibold mb-3"},"Additional Information"),e.createElement("div",{className:"space-y-4"},g.additionalFields.map(t=>e.createElement("div",{key:t.id},e.createElement("label",{htmlFor:t.id,className:"block text-sm font-medium mb-1"},t.label," ",t.required&&e.createElement("span",{className:"text-red-500"},"*")),t.type==="text"&&e.createElement("input",{type:"text",id:t.id,value:h[t.id]||"",onChange:o=>l(t.id,o.target.value),placeholder:t.placeholder,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",required:t.required}),t.type==="textarea"&&e.createElement("textarea",{id:t.id,value:h[t.id]||"",onChange:o=>l(t.id,o.target.value),placeholder:t.placeholder,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",rows:4,required:t.required}),t.type==="select"&&t.options&&e.createElement("select",{id:t.id,value:h[t.id]||"",onChange:o=>l(t.id,o.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",required:t.required},e.createElement("option",{value:""},t.placeholder||"Select an option"),t.options.map(o=>e.createElement("option",{key:o,value:o},o))),t.type==="checkbox"&&e.createElement("div",{className:"flex items-start"},e.createElement("div",{className:"flex items-center h-5"},e.createElement("input",{type:"checkbox",id:t.id,checked:!!h[t.id],onChange:o=>l(t.id,o.target.checked),className:"h-4 w-4 rounded border-gray-300 text-blue-600 focus:ring-blue-500",required:t.required})),e.createElement("div",{className:"ml-3 text-sm"},e.createElement("label",{htmlFor:t.id,className:"text-gray-700 dark:text-gray-300"},t.placeholder||t.label))),t.type==="file"&&e.createElement("input",{type:"file",id:t.id,onChange:o=>{var b;let u=(b=o.target.files)==null?void 0:b[0];u&&l(t.id,u);},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",required:t.required}),x[`additional_${t.id}`]&&e.createElement("p",{className:"mt-1 text-sm text-red-500"},x[`additional_${t.id}`]))))),e.createElement("div",{className:"mt-6 p-4 bg-gray-50 dark:bg-gray-700 rounded-md"},e.createElement("h3",{className:"text-sm font-semibold mb-2"},"Privacy Notice"),e.createElement("p",{className:"text-xs text-gray-600 dark:text-gray-300"},"The information you provide in this form will be used solely for the purpose of processing your data subject request. We will retain this information for as long as necessary to fulfill your request and to comply with our legal obligations. For more information, please refer to our Privacy Policy.")),e.createElement("div",{className:"mt-6"},e.createElement("button",{type:"submit",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 ${_}`},y.submit||H)))))};var ne=({requests:f,onSelectRequest:P,onUpdateStatus:O,onAssignRequest:M,title:H="Data Subject Request Dashboard",description:K="Track and manage data subject requests in compliance with NDPA requirements.",className:_="",buttonClassName:B="",showRequestDetails:W=true,showRequestTimeline:U=true,showDeadlineAlerts:F=true,assignees:A=[]})=>{let[y,p]=useState(null),[N,T]=useState(f),[j,k]=useState("all"),[C,$]=useState("all"),[w,I]=useState(""),[V,E]=useState("createdAt"),[L,h]=useState("desc"),[v,z]=useState("");useEffect(()=>{let s=[...f];if(j!=="all"&&(s=s.filter(d=>d.status===j)),C!=="all"&&(s=s.filter(d=>d.type===C)),w){let d=w.toLowerCase();s=s.filter(c=>c.subject.name.toLowerCase().includes(d)||c.subject.email.toLowerCase().includes(d)||c.description&&c.description.toLowerCase().includes(d));}s.sort((d,c)=>{let D=0;switch(V){case "createdAt":D=d.createdAt-c.createdAt;break;case "dueDate":D=(d.dueDate||0)-(c.dueDate||0);break;case "type":D=d.type.localeCompare(c.type);break;case "status":D=d.status.localeCompare(c.status);break;default:D=d.createdAt-c.createdAt;}return L==="asc"?D:-D}),T(s);},[f,j,C,w,V,L]),useEffect(()=>{N.length>0&&!y&&p(N[0].id);},[N,y]);let Y=s=>{p(s),P&&P(s);},x=s=>{y&&O&&O(y,s);},G=()=>{y&&v&&M&&(M(y,v),z(""));},g=s=>new Date(s).toLocaleDateString(),J=s=>{let d=Date.now(),c=(s-d)/(1440*60*1e3);return Math.ceil(c)},l=y?f.find(s=>s.id===y):null,a$1=s=>{let d={information:"bg-teal-100 text-teal-800 dark:bg-teal-900 dark:text-teal-200",access:"bg-blue-100 text-blue-800 dark:bg-blue-900 dark:text-blue-200",rectification:"bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200",erasure:"bg-red-100 text-red-800 dark:bg-red-900 dark:text-red-200",restriction:"bg-yellow-100 text-yellow-800 dark:bg-yellow-900 dark:text-yellow-200",portability:"bg-purple-100 text-purple-800 dark:bg-purple-900 dark:text-purple-200",objection:"bg-orange-100 text-orange-800 dark:bg-orange-900 dark:text-orange-200",automated_decision_making:"bg-indigo-100 text-indigo-800 dark:bg-indigo-900 dark:text-indigo-200"},c={information:"Information",access:"Access",rectification:"Rectification",erasure:"Erasure",restriction:"Restriction",portability:"Portability",objection:"Objection",automated_decision_making:"Automated Decision-Making"};return e.createElement("span",{className:`px-2 py-1 rounded text-xs font-medium ${d[s]}`},c[s])},n=s=>e.createElement("span",{className:`px-2 py-1 rounded text-xs font-medium ${{pending:"bg-yellow-100 text-yellow-800 dark:bg-yellow-900 dark:text-yellow-200",inProgress:"bg-blue-100 text-blue-800 dark:bg-blue-900 dark:text-blue-200",completed:"bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200",rejected:"bg-red-100 text-red-800 dark:bg-red-900 dark:text-red-200",awaitingVerification:"bg-purple-100 text-purple-800 dark:bg-purple-900 dark:text-purple-200"}[s]}`},s==="inProgress"?"In Progress":s==="awaitingVerification"?"Awaiting Verification":s.charAt(0).toUpperCase()+s.slice(1)),m=s=>{if(!s.dueDate)return null;let d=J(s.dueDate);return d<=0?e.createElement("div",{className:"bg-red-50 dark:bg-red-900/20 p-3 rounded-md"},e.createElement("p",{className:"text-sm text-red-800 dark:text-red-200 font-medium"},"Deadline Passed"),e.createElement("p",{className:"text-xs text-red-700 dark:text-red-300 mt-1"},"The response deadline has passed. Immediate action is required.")):d<=3?e.createElement("div",{className:"bg-red-50 dark:bg-red-900/20 p-3 rounded-md"},e.createElement("p",{className:"text-sm text-red-800 dark:text-red-200 font-medium"},"Urgent: Deadline Approaching"),e.createElement("p",{className:"text-xs text-red-700 dark:text-red-300 mt-1"},"Only ",d," day",d!==1?"s":""," remaining until the response deadline.")):d<=7?e.createElement("div",{className:"bg-yellow-50 dark:bg-yellow-900/20 p-3 rounded-md"},e.createElement("p",{className:"text-sm text-yellow-800 dark:text-yellow-200 font-medium"},"Deadline Approaching"),e.createElement("p",{className:"text-xs text-yellow-700 dark:text-yellow-300 mt-1"},d," days remaining until the response deadline.")):e.createElement("div",{className:"bg-green-50 dark:bg-green-900/20 p-3 rounded-md"},e.createElement("p",{className:"text-sm text-green-800 dark:text-green-200 font-medium"},"Deadline Tracking"),e.createElement("p",{className:"text-xs text-green-700 dark:text-green-300 mt-1"},d," days remaining until the response deadline."))},t=s=>{let d=[{title:"Request Received",date:s.createdAt,completed:true,description:`Request was received on ${g(s.createdAt)}.`}];return s.verifiedAt?d.push({title:"Identity Verified",date:s.verifiedAt,completed:true,description:`Data subject's identity was verified on ${g(s.verifiedAt)}.`}):s.status==="awaitingVerification"&&d.push({title:"Identity Verification",date:Date.now(),completed:false,description:"Awaiting verification of data subject's identity."}),(s.status==="inProgress"||s.status==="completed"||s.status==="rejected")&&d.push({title:"Processing Started",date:s.updatedAt,completed:true,description:`Request processing started on ${g(s.updatedAt)}.`}),s.status==="completed"?d.push({title:"Request Completed",date:s.completedAt||Date.now(),completed:true,description:`Request was completed on ${g(s.completedAt||Date.now())}.`}):s.status==="rejected"&&d.push({title:"Request Rejected",date:s.completedAt||Date.now(),completed:true,description:`Request was rejected on ${g(s.completedAt||Date.now())}.${s.rejectionReason?` Reason: ${s.rejectionReason}`:""}`}),s.dueDate&&d.push({title:"Response Deadline",date:s.dueDate,completed:Date.now()>s.dueDate,description:`Response is due by ${g(s.dueDate)}.`}),e.createElement("div",{className:"mt-6"},e.createElement("h3",{className:"text-lg font-medium mb-4"},"Request Timeline"),e.createElement("ol",{className:"relative border-l border-gray-200 dark:border-gray-700"},d.map((c,D)=>e.createElement("li",{key:D,className:"mb-6 ml-4"},e.createElement("div",{className:`absolute w-3 h-3 rounded-full mt-1.5 -left-1.5 border ${c.completed?"bg-green-500 border-green-500 dark:border-green-500":"bg-gray-200 border-gray-200 dark:bg-gray-700 dark:border-gray-700"}`}),e.createElement("time",{className:"mb-1 text-sm font-normal leading-none text-gray-400 dark:text-gray-500"},c.date?g(c.date):"Pending"),e.createElement("h4",{className:"text-sm font-semibold text-gray-900 dark:text-white"},c.title),e.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400"},c.description)))))},o=()=>[{value:"all",label:"All Types"},{value:"information",label:"Information (NDPA Section 29)"},{value:"access",label:"Access (NDPA Section 30)"},{value:"rectification",label:"Rectification (NDPA Section 31)"},{value:"erasure",label:"Erasure (NDPA Section 32)"},{value:"restriction",label:"Restriction (NDPA Section 33)"},{value:"portability",label:"Portability (NDPA Section 34)"},{value:"objection",label:"Objection (NDPA Section 35)"},{value:"automated_decision_making",label:"Automated Decision-Making (NDPA Section 36)"}].map(d=>e.createElement("option",{key:d.value,value:d.value},d.label)),u=()=>[{value:"all",label:"All Statuses"},{value:"pending",label:"Pending"},{value:"awaitingVerification",label:"Awaiting Verification"},{value:"inProgress",label:"In Progress"},{value:"completed",label:"Completed"},{value:"rejected",label:"Rejected"}].map(d=>e.createElement("option",{key:d.value,value:d.value},d.label)),b=()=>[{value:"pending",label:"Pending"},{value:"awaitingVerification",label:"Awaiting Verification"},{value:"inProgress",label:"In Progress"},{value:"completed",label:"Completed"},{value:"rejected",label:"Rejected"}].map(d=>e.createElement("option",{key:d.value,value:d.value},d.label));return e.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${_}`},e.createElement("h2",{className:"text-xl font-bold mb-2"},H),e.createElement("p",{className:"mb-6 text-gray-600 dark:text-gray-300"},K),e.createElement("div",{className:"mb-6 grid grid-cols-1 md:grid-cols-4 gap-4"},e.createElement("div",null,e.createElement("label",{htmlFor:"statusFilter",className:"block text-sm font-medium mb-1"},"Status Filter"),e.createElement("select",{id:"statusFilter",value:j,onChange:s=>k(s.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"},u())),e.createElement("div",null,e.createElement("label",{htmlFor:"typeFilter",className:"block text-sm font-medium mb-1"},"Request Type Filter"),e.createElement("select",{id:"typeFilter",value:C,onChange:s=>$(s.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"},o())),e.createElement("div",null,e.createElement("label",{htmlFor:"sortBy",className:"block text-sm font-medium mb-1"},"Sort By"),e.createElement("select",{id:"sortBy",value:V,onChange:s=>E(s.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:"createdAt"},"Date Received"),e.createElement("option",{value:"dueDate"},"Due Date"),e.createElement("option",{value:"type"},"Request Type"),e.createElement("option",{value:"status"},"Status"))),e.createElement("div",null,e.createElement("label",{htmlFor:"searchTerm",className:"block text-sm font-medium mb-1"},"Search"),e.createElement("input",{type:"text",id:"searchTerm",value:w,onChange:s=>I(s.target.value),placeholder:"Search requests...",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-3 gap-6"},e.createElement("div",{className:"md:col-span-1"},e.createElement("h3",{className:"text-lg font-medium mb-3"},"DSR Requests"),N.length===0?e.createElement("p",{className:"text-gray-500 dark:text-gray-400 text-sm"},"No data subject requests found."):e.createElement("div",{className:"space-y-2 max-h-96 overflow-y-auto pr-2"},N.map(s=>{let d=s.dueDate?J(s.dueDate):null,c=null;return d!==null&&(d<=0?c=e.createElement("span",{className:"text-xs text-red-600 dark:text-red-400 font-bold"},"Overdue"):d<=3?c=e.createElement("span",{className:"text-xs text-red-600 dark:text-red-400"},"Urgent"):d<=7&&(c=e.createElement("span",{className:"text-xs text-yellow-600 dark:text-yellow-400"},"Soon"))),e.createElement("div",{key:s.id,className:`p-3 rounded-md cursor-pointer ${y===s.id?"bg-blue-50 dark:bg-blue-900/20 border border-blue-200 dark:border-blue-800":"bg-gray-50 dark:bg-gray-700 hover:bg-gray-100 dark:hover:bg-gray-600"}`,onClick:()=>Y(s.id)},e.createElement("div",{className:"flex justify-between items-start mb-1"},e.createElement("h4",{className:"font-medium text-sm"},s.subject.name),a$1(s.type)),e.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400 mb-1"},s.subject.email),e.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400 mb-1"},"Received: ",g(s.createdAt)),e.createElement("div",{className:"flex justify-between items-center mt-2"},e.createElement("div",null,n(s.status)),e.createElement("div",null,c)))}))),e.createElement("div",{className:"md:col-span-2"},l?e.createElement("div",null,e.createElement("div",{className:"flex justify-between items-start mb-4"},e.createElement("h3",{className:"text-lg font-medium"},l.subject.name),e.createElement("div",{className:"flex space-x-2"},a$1(l.type),n(l.status))),F&&l.dueDate&&e.createElement("div",{className:"mb-4"},m(l)),W&&e.createElement("div",{className:"mb-6"},e.createElement("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-4 mb-4"},e.createElement("div",null,e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Email:")," ",l.subject.email),l.subject.phone&&e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Phone:")," ",l.subject.phone),e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Received:")," ",g(l.createdAt))),e.createElement("div",null,e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Request Type:")," ",{information:"Information",access:"Access",rectification:"Rectification",erasure:"Erasure",restriction:"Restriction",portability:"Portability",objection:"Objection",automated_decision_making:"Automated Decision-Making"}[l.type]||l.type),e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Status:")," ",l.status==="inProgress"?"In Progress":l.status==="awaitingVerification"?"Awaiting Verification":l.status.charAt(0).toUpperCase()+l.status.slice(1)),l.dueDate&&e.createElement("p",{className:"text-sm"},e.createElement("span",{className:"font-medium"},"Due Date:")," ",g(l.dueDate)))),l.description&&e.createElement("div",{className:"mb-4"},e.createElement("p",{className:"text-sm font-medium"},"Request Details:"),e.createElement("p",{className:"text-sm text-gray-600 dark:text-gray-300 bg-gray-50 dark:bg-gray-700 p-2 rounded-md mt-1"},l.description)),l.additionalInfo&&e.createElement("div",null,e.createElement("p",{className:"text-sm font-medium"},"Additional Information:"),e.createElement("p",{className:"text-sm text-gray-600 dark:text-gray-300 bg-gray-50 dark:bg-gray-700 p-2 rounded-md mt-1"},typeof l.additionalInfo=="object"?JSON.stringify(l.additionalInfo,null,2):String(l.additionalInfo||"No additional information provided")))),e.createElement("div",{className:"mb-6 grid grid-cols-1 md:grid-cols-2 gap-4"},e.createElement("div",null,e.createElement("h3",{className:"text-md font-medium mb-2"},"Update Status"),e.createElement("div",{className:"flex space-x-2"},e.createElement("select",{value:l.status,onChange:s=>x(s.target.value),className:"flex-grow px-3 py-2 border border-gray-300 dark:border-gray-600 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"},b()),e.createElement("button",{onClick:()=>x(l.status),className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 ${B}`},"Update"))),A.length>0&&e.createElement("div",null,e.createElement("h3",{className:"text-md font-medium mb-2"},"Assign Request"),e.createElement("div",{className:"flex space-x-2"},e.createElement("select",{value:v,onChange:s=>z(s.target.value),className:"flex-grow 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 Assignee"),A.map(s=>e.createElement("option",{key:s,value:s},s))),e.createElement("button",{onClick:G,disabled:!v,className:`px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700 disabled:bg-gray-300 disabled:text-gray-500 ${B}`},"Assign")))),e.createElement("div",{className:"mb-6"},e.createElement("h3",{className:"text-lg font-medium mb-3"},"Request Summary"),e.createElement("div",{className:"bg-gray-50 dark:bg-gray-700 p-3 rounded-md"},e.createElement("pre",{className:"whitespace-pre-wrap text-sm font-mono text-gray-800 dark:text-gray-200"},e.createElement("pre",null,JSON.stringify(a(l),null,2))))),U&&t(l)):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"},"Select a request to view details")))))};var ue=({requests:f,onSelectRequest:P,title:O="DSR Request Tracker",description:M="Track the status and progress of data subject requests.",className:H="",buttonClassName:K="",showSummaryStats:_=true,showTypeBreakdown:B=true,showStatusBreakdown:W=true,showTimelineChart:U=true,showOverdueRequests:F=true})=>{let[A,y]=useState("30days"),[p,N]=useState(f),[T,j]=useState([]),[k,C]=useState([]);useEffect(()=>{let a=Date.now(),n;switch(A){case "7days":n=f.filter(o=>a-o.createdAt<=10080*60*1e3);break;case "30days":n=f.filter(o=>a-o.createdAt<=720*60*60*1e3);break;case "90days":n=f.filter(o=>a-o.createdAt<=2160*60*60*1e3);break;default:n=[...f];}N(n);let m=n.filter(o=>o.dueDate&&a>o.dueDate&&o.status!=="completed"&&o.status!=="rejected");j(m);let t=n.filter(o=>o.dueDate&&a<o.dueDate&&o.dueDate-a<=10080*60*1e3&&o.status!=="completed"&&o.status!=="rejected");C(t);},[f,A]);let $=a=>{P&&P(a);},w=a=>new Date(a).toLocaleDateString(),I=a=>{let n=Date.now(),m=(a-n)/(1440*60*1e3);return Math.ceil(m)},V=()=>{let a=p.filter(m=>m.status==="completed"&&m.completedAt&&m.createdAt);if(a.length===0)return null;let n=a.reduce((m,t)=>{let o=((t.completedAt||0)-t.createdAt)/864e5;return m+o},0);return Number((n/a.length).toFixed(1))},E=()=>{let a=p.filter(m=>(m.status==="completed"||m.status==="rejected")&&m.completedAt&&m.dueDate);if(a.length===0)return null;let n=a.filter(m=>(m.completedAt||0)<=(m.dueDate||0));return Math.round(n.length/a.length*100)},L=()=>{let a={};return p.forEach(n=>{a[n.type]=(a[n.type]||0)+1;}),{information:a.information||0,access:a.access||0,rectification:a.rectification||0,erasure:a.erasure||0,restriction:a.restriction||0,portability:a.portability||0,objection:a.objection||0,automated_decision_making:a.automated_decision_making||0}},h=()=>{let a={};return p.forEach(n=>{a[n.status]=(a[n.status]||0)+1;}),{pending:a.pending||0,awaitingVerification:a.awaitingVerification||0,inProgress:a.inProgress||0,completed:a.completed||0,rejected:a.rejected||0}},v=a=>{let n={information:"bg-teal-100 text-teal-800 dark:bg-teal-900 dark:text-teal-200",access:"bg-blue-100 text-blue-800 dark:bg-blue-900 dark:text-blue-200",rectification:"bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200",erasure:"bg-red-100 text-red-800 dark:bg-red-900 dark:text-red-200",restriction:"bg-yellow-100 text-yellow-800 dark:bg-yellow-900 dark:text-yellow-200",portability:"bg-purple-100 text-purple-800 dark:bg-purple-900 dark:text-purple-200",objection:"bg-orange-100 text-orange-800 dark:bg-orange-900 dark:text-orange-200",automated_decision_making:"bg-indigo-100 text-indigo-800 dark:bg-indigo-900 dark:text-indigo-200"},m={information:"Information",access:"Access",rectification:"Rectification",erasure:"Erasure",restriction:"Restriction",portability:"Portability",objection:"Objection",automated_decision_making:"Automated Decision-Making"};return e.createElement("span",{className:`px-2 py-1 rounded text-xs font-medium ${n[a]}`},m[a])},Y=()=>{let a=p.length,n=p.filter(u=>u.status!=="completed"&&u.status!=="rejected").length;p.filter(u=>u.status==="completed"||u.status==="rejected").length;let t=V(),o=E();return e.createElement("div",{className:"grid grid-cols-2 md:grid-cols-4 gap-4 mb-6"},e.createElement("div",{className:"bg-white dark:bg-gray-700 p-4 rounded-lg shadow"},e.createElement("h4",{className:"text-sm font-medium text-gray-500 dark:text-gray-400 mb-1"},"Total Requests"),e.createElement("p",{className:"text-2xl font-bold"},a)),e.createElement("div",{className:"bg-white dark:bg-gray-700 p-4 rounded-lg shadow"},e.createElement("h4",{className:"text-sm font-medium text-gray-500 dark:text-gray-400 mb-1"},"Pending Requests"),e.createElement("p",{className:"text-2xl font-bold"},n)),e.createElement("div",{className:"bg-white dark:bg-gray-700 p-4 rounded-lg shadow"},e.createElement("h4",{className:"text-sm font-medium text-gray-500 dark:text-gray-400 mb-1"},"Avg. Response Time"),e.createElement("p",{className:"text-2xl font-bold"},t!==null?`${t} days`:"N/A")),e.createElement("div",{className:"bg-white dark:bg-gray-700 p-4 rounded-lg shadow"},e.createElement("h4",{className:"text-sm font-medium text-gray-500 dark:text-gray-400 mb-1"},"Compliance Rate"),e.createElement("p",{className:"text-2xl font-bold"},o!==null?`${o}%`:"N/A")))},x=()=>{let a=L(),n=p.length,m=Object.entries(a).sort(([,t],[,o])=>o-t).map(([t])=>t);return e.createElement("div",{className:"bg-white dark:bg-gray-700 p-4 rounded-lg shadow mb-6"},e.createElement("h3",{className:"text-lg font-medium mb-4"},"Request Types"),n===0?e.createElement("p",{className:"text-gray-500 dark:text-gray-400 text-sm"},"No data available for the selected timeframe."):e.createElement("div",{className:"space-y-4"},m.map(t=>{let o=a[t],u=Math.round(o/n*100);return e.createElement("div",{key:t},e.createElement("div",{className:"flex justify-between items-center mb-1"},e.createElement("div",{className:"flex items-center"},v(t),e.createElement("span",{className:"ml-2 text-sm"},o," requests")),e.createElement("span",{className:"text-sm font-medium"},u,"%")),e.createElement("div",{className:"w-full bg-gray-200 dark:bg-gray-600 rounded-full h-2.5"},e.createElement("div",{className:"bg-blue-600 h-2.5 rounded-full",style:{width:`${u}%`}})))})))},G=()=>{let a=h(),n=p.length,m=["pending","awaitingVerification","inProgress","completed","rejected"],t={pending:"bg-yellow-500",awaitingVerification:"bg-purple-500",inProgress:"bg-blue-500",completed:"bg-green-500",rejected:"bg-red-500"};return e.createElement("div",{className:"bg-white dark:bg-gray-700 p-4 rounded-lg shadow mb-6"},e.createElement("h3",{className:"text-lg font-medium mb-4"},"Request Status"),n===0?e.createElement("p",{className:"text-gray-500 dark:text-gray-400 text-sm"},"No data available for the selected timeframe."):e.createElement("div",null,e.createElement("div",{className:"flex h-4 mb-2"},m.map(o=>{let u=a[o],b=u/n*100;return b>0?e.createElement("div",{key:o,className:`${t[o]} first:rounded-l-full last:rounded-r-full`,style:{width:`${b}%`},title:`${o}: ${u} (${Math.round(b)}%)`}):null})),e.createElement("div",{className:"grid grid-cols-2 md:grid-cols-5 gap-2 mt-4"},m.map(o=>{let u=a[o],b=Math.round(u/n*100);return e.createElement("div",{key:o,className:"flex items-center"},e.createElement("div",{className:`w-3 h-3 rounded-full ${t[o]} mr-2`}),e.createElement("div",null,e.createElement("p",{className:"text-xs font-medium"},o==="inProgress"?"In Progress":o==="awaitingVerification"?"Awaiting Verification":o.charAt(0).toUpperCase()+o.slice(1)),e.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400"},u," (",b,"%)")))}))))},g=()=>{let a={};p.forEach(u=>{let b=new Date(u.createdAt),s=`${b.getFullYear()}-${String(b.getMonth()+1).padStart(2,"0")}`;a[s]=(a[s]||0)+1;});let m=Object.keys(a).sort().slice(-6),t=Math.max(...Object.values(a).filter(u=>u>0),1),o=u=>{let[b,s]=u.split("-");return `${s}/${b.slice(2)}`};return e.createElement("div",{className:"bg-white dark:bg-gray-700 p-4 rounded-lg shadow mb-6"},e.createElement("h3",{className:"text-lg font-medium mb-4"},"Request Timeline"),m.length===0?e.createElement("p",{className:"text-gray-500 dark:text-gray-400 text-sm"},"No data available for the selected timeframe."):e.createElement("div",{className:"h-40"},e.createElement("div",{className:"flex h-32 items-end justify-between space-x-2"},m.map(u=>{let b=a[u],s=`${b/t*100}%`;return e.createElement("div",{key:u,className:"flex flex-col items-center flex-1"},e.createElement("div",{className:"w-full bg-blue-500 rounded-t",style:{height:s},title:`${o(u)}: ${b} requests`}))})),e.createElement("div",{className:"flex justify-between mt-2"},m.map(u=>e.createElement("div",{key:u,className:"text-xs text-center"},o(u))))))},J=()=>e.createElement("div",{className:"bg-white dark:bg-gray-700 p-4 rounded-lg shadow mb-6"},e.createElement("h3",{className:"text-lg font-medium mb-4"},"Overdue Requests"),T.length===0?e.createElement("p",{className:"text-gray-500 dark:text-gray-400 text-sm"},"No overdue requests."):e.createElement("div",{className:"space-y-2 max-h-60 overflow-y-auto"},T.map(a=>e.createElement("div",{key:a.id,className:"p-3 bg-red-50 dark:bg-red-900/20 rounded-md cursor-pointer hover:bg-red-100 dark:hover:bg-red-900/30",onClick:()=>$(a.id)},e.createElement("div",{className:"flex justify-between items-start mb-1"},e.createElement("h4",{className:"font-medium text-sm"},a.subject.name),v(a.type)),e.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400 mb-1"},a.subject.email),e.createElement("div",{className:"flex justify-between items-center"},e.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400"},"Due: ",w(a.dueDate||0)),e.createElement("p",{className:"text-xs font-bold text-red-600 dark:text-red-400"},"Overdue by ",Math.abs(I(a.dueDate||0))," days")))))),l=()=>e.createElement("div",{className:"bg-white dark:bg-gray-700 p-4 rounded-lg shadow mb-6"},e.createElement("h3",{className:"text-lg font-medium mb-4"},"Upcoming Deadlines"),k.length===0?e.createElement("p",{className:"text-gray-500 dark:text-gray-400 text-sm"},"No upcoming deadlines in the next 7 days."):e.createElement("div",{className:"space-y-2 max-h-60 overflow-y-auto"},k.map(a=>{let n=I(a.dueDate||0);return e.createElement("div",{key:a.id,className:"p-3 bg-yellow-50 dark:bg-yellow-900/20 rounded-md cursor-pointer hover:bg-yellow-100 dark:hover:bg-yellow-900/30",onClick:()=>$(a.id)},e.createElement("div",{className:"flex justify-between items-start mb-1"},e.createElement("h4",{className:"font-medium text-sm"},a.subject.name),v(a.type)),e.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400 mb-1"},a.subject.email),e.createElement("div",{className:"flex justify-between items-center"},e.createElement("p",{className:"text-xs text-gray-500 dark:text-gray-400"},"Due: ",w(a.dueDate||0)),e.createElement("p",{className:`text-xs font-bold ${n<=3?"text-red-600 dark:text-red-400":"text-yellow-600 dark:text-yellow-400"}`},"Due in ",n," days")))})));return e.createElement("div",{className:`bg-white dark:bg-gray-800 p-6 rounded-lg shadow-md ${H}`},e.createElement("div",{className:"flex flex-col md:flex-row md:justify-between md:items-center mb-6"},e.createElement("div",null,e.createElement("h2",{className:"text-xl font-bold mb-2"},O),e.createElement("p",{className:"text-gray-600 dark:text-gray-300"},M)),e.createElement("div",{className:"mt-4 md:mt-0"},e.createElement("label",{htmlFor:"timeframe",className:"block text-sm font-medium mb-1"},"Timeframe"),e.createElement("select",{id:"timeframe",value:A,onChange:a=>y(a.target.value),className:"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:"7days"},"Last 7 Days"),e.createElement("option",{value:"30days"},"Last 30 Days"),e.createElement("option",{value:"90days"},"Last 90 Days"),e.createElement("option",{value:"all"},"All Time")))),_&&Y(),e.createElement("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-6"},e.createElement("div",null,B&&x(),W&&G()),e.createElement("div",null,U&&g(),F&&J(),F&&l())))};export{ae as a,ne as b,ue as c};//# sourceMappingURL=chunk-6JFTAYXV.mjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-6JFTAYXV.mjs.map
|