@tantainnovative/ndpr-toolkit 2.1.1 → 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (192) hide show
  1. package/README.md +56 -0
  2. package/dist/{breach-6z0r-KuE.d.mts → breach-B_-6lDqS.d.mts} +1 -1
  3. package/dist/{breach-BFfnvtRk.d.ts → breach-CzXqSsaY.d.ts} +1 -1
  4. package/dist/{breach-BtFbDOmV.d.mts → breach-Eu9byel8.d.mts} +1 -1
  5. package/dist/{breach-BtFbDOmV.d.ts → breach-Eu9byel8.d.ts} +1 -1
  6. package/dist/breach.d.mts +81 -5
  7. package/dist/breach.d.ts +81 -5
  8. package/dist/breach.js +1 -1
  9. package/dist/breach.mjs +1 -1
  10. package/dist/chunk-4RGDNVR5.mjs +72 -0
  11. package/dist/chunk-6LM3RAFO.js +7 -0
  12. package/dist/chunk-7DNQSOER.js +2 -0
  13. package/dist/chunk-A7DRHSDQ.mjs +2 -0
  14. package/dist/chunk-FC6EG34C.js +72 -0
  15. package/dist/chunk-FDB6KZUD.mjs +2 -0
  16. package/dist/chunk-FZUCKGIM.mjs +7 -0
  17. package/dist/chunk-G3JNFZPT.js +2 -0
  18. package/dist/chunk-HXCRMA4J.mjs +2 -0
  19. package/dist/chunk-IC7VOOKJ.mjs +2 -0
  20. package/dist/chunk-ICUZG6CD.mjs +2 -0
  21. package/dist/chunk-IW5PHOG7.mjs +7 -0
  22. package/dist/chunk-JKEAPTYP.js +7 -0
  23. package/dist/chunk-N52S64SU.js +2 -0
  24. package/dist/chunk-SKAMVXBI.mjs +94 -0
  25. package/dist/chunk-VURIXCGY.js +2 -0
  26. package/dist/chunk-VXRY3V42.js +94 -0
  27. package/dist/chunk-YBPHGEL2.js +2 -0
  28. package/dist/consent.d.mts +68 -2
  29. package/dist/consent.d.ts +68 -2
  30. package/dist/consent.js +1 -1
  31. package/dist/consent.mjs +1 -1
  32. package/dist/core.d.mts +10 -10
  33. package/dist/core.d.ts +10 -10
  34. package/dist/{cross-border-BrIy1ieh.d.ts → cross-border-BMcqLvjC.d.mts} +1 -1
  35. package/dist/{cross-border-BrIy1ieh.d.mts → cross-border-BMcqLvjC.d.ts} +1 -1
  36. package/dist/cross-border-entry-BfF7jw5o.d.mts +84 -0
  37. package/dist/cross-border-entry-CtX8_o-_.d.ts +84 -0
  38. package/dist/cross-border.d.mts +4 -58
  39. package/dist/cross-border.d.ts +4 -58
  40. package/dist/cross-border.js +1 -1
  41. package/dist/cross-border.mjs +1 -1
  42. package/dist/{dpia-vWfE_9bO.d.mts → dpia-5OQVA1R_.d.mts} +1 -1
  43. package/dist/{dpia-vWfE_9bO.d.ts → dpia-5OQVA1R_.d.ts} +1 -1
  44. package/dist/{dpia-fdtTd2DI.d.ts → dpia-B0Pok5us.d.ts} +1 -1
  45. package/dist/{dpia-B9ZZJG5a.d.mts → dpia-CUfOmzvX.d.mts} +1 -1
  46. package/dist/dpia.d.mts +105 -5
  47. package/dist/dpia.d.ts +105 -5
  48. package/dist/dpia.js +1 -1
  49. package/dist/dpia.mjs +1 -1
  50. package/dist/{dsr-pQzQ3H1O.d.mts → dsr-Cm9lzWG7.d.mts} +1 -1
  51. package/dist/{dsr-pQzQ3H1O.d.ts → dsr-Cm9lzWG7.d.ts} +1 -1
  52. package/dist/{dsr-whPkiI0_.d.mts → dsr-D_eTNc4S.d.mts} +1 -1
  53. package/dist/{dsr-jq5NUEdz.d.ts → dsr-pNtVb1BK.d.ts} +1 -1
  54. package/dist/dsr.d.mts +66 -5
  55. package/dist/dsr.d.ts +66 -5
  56. package/dist/dsr.js +1 -1
  57. package/dist/dsr.mjs +1 -1
  58. package/dist/hooks.d.mts +13 -13
  59. package/dist/hooks.d.ts +13 -13
  60. package/dist/index.d.mts +24 -24
  61. package/dist/index.d.ts +24 -24
  62. package/dist/index.js +1 -1
  63. package/dist/index.mjs +1 -1
  64. package/dist/{lawful-basis-v04AhbK2.d.ts → lawful-basis-BEyI0kGg.d.ts} +2 -2
  65. package/dist/{lawful-basis-D-oXFizg.d.mts → lawful-basis-C2eGaoHM.d.mts} +2 -2
  66. package/dist/{lawful-basis-CWtvDG1x.d.mts → lawful-basis-Cv1VmDLn.d.mts} +1 -1
  67. package/dist/{lawful-basis-CWtvDG1x.d.ts → lawful-basis-Cv1VmDLn.d.ts} +1 -1
  68. package/dist/lawful-basis-entry-BeSX7u0U.d.ts +81 -0
  69. package/dist/lawful-basis-entry-CMPPM9Rh.d.mts +81 -0
  70. package/dist/lawful-basis.d.mts +5 -55
  71. package/dist/lawful-basis.d.ts +5 -55
  72. package/dist/lawful-basis.js +1 -1
  73. package/dist/lawful-basis.mjs +1 -1
  74. package/dist/policy-dmsRlqgM.d.ts +283 -0
  75. package/dist/policy-kZN23hrR.d.mts +283 -0
  76. package/dist/policy.d.mts +3 -193
  77. package/dist/policy.d.ts +3 -193
  78. package/dist/policy.js +1 -1
  79. package/dist/policy.mjs +1 -1
  80. package/dist/{ropa-Rb4dsFSz.d.mts → ropa-DP7pPPql.d.mts} +2 -2
  81. package/dist/{ropa-BebGfqKQ.d.ts → ropa-Li6UlL5H.d.ts} +2 -2
  82. package/dist/ropa-entry-CZJ91ymk.d.mts +71 -0
  83. package/dist/ropa-entry-DIEQ9WFs.d.ts +71 -0
  84. package/dist/ropa.d.mts +5 -45
  85. package/dist/ropa.d.ts +5 -45
  86. package/dist/ropa.js +1 -1
  87. package/dist/ropa.mjs +1 -1
  88. package/dist/unstyled.js +1 -1
  89. package/dist/unstyled.mjs +1 -1
  90. package/dist/{useBreach-WrZzJilM.d.mts → useBreach-BBSoIcZO.d.mts} +1 -1
  91. package/dist/{useBreach-vrh_XMpI.d.ts → useBreach-lFLbSyAN.d.ts} +1 -1
  92. package/dist/{useCrossBorderTransfer-TVnY8_UX.d.mts → useCrossBorderTransfer-BZVFCXfr.d.mts} +1 -1
  93. package/dist/{useCrossBorderTransfer-D4FQYfFt.d.ts → useCrossBorderTransfer-DmtACeqW.d.ts} +1 -1
  94. package/dist/{useDPIA-DFDHBLSa.d.ts → useDPIA-DBsg2yZx.d.ts} +1 -1
  95. package/dist/{useDPIA-FqPofFaV.d.mts → useDPIA-Da7-Q_yW.d.mts} +1 -1
  96. package/dist/{useDSR-DAqqOBXb.d.ts → useDSR-CYI7WCXr.d.ts} +1 -1
  97. package/dist/{useDSR-OXM5Q9rf.d.mts → useDSR-YYZ6FYFs.d.mts} +1 -1
  98. package/dist/{useLawfulBasis-RILM_xsx.d.ts → useLawfulBasis-CCWF9waR.d.ts} +2 -2
  99. package/dist/{useLawfulBasis-DNQ8YszQ.d.mts → useLawfulBasis-CpWuHtyh.d.mts} +2 -2
  100. package/dist/{useROPA-Bcs6cRdi.d.ts → useROPA-BhJ3kvHp.d.ts} +1 -1
  101. package/dist/{useROPA-nmcSiUYv.d.mts → useROPA-DLFdjkxP.d.mts} +1 -1
  102. package/package.json +33 -17
  103. package/dist/breach.js.map +0 -1
  104. package/dist/breach.mjs.map +0 -1
  105. package/dist/chunk-2SYNHRP6.mjs.map +0 -1
  106. package/dist/chunk-2XHD22J7.mjs +0 -7
  107. package/dist/chunk-2XHD22J7.mjs.map +0 -1
  108. package/dist/chunk-3YCV2BA6.js.map +0 -1
  109. package/dist/chunk-4A354HL3.js.map +0 -1
  110. package/dist/chunk-4DKT6IB6.js +0 -94
  111. package/dist/chunk-4DKT6IB6.js.map +0 -1
  112. package/dist/chunk-5ZBO2UPH.js.map +0 -1
  113. package/dist/chunk-6GGGTRDZ.mjs.map +0 -1
  114. package/dist/chunk-6JFTAYXV.mjs +0 -2
  115. package/dist/chunk-6JFTAYXV.mjs.map +0 -1
  116. package/dist/chunk-6JVYYLS7.js +0 -2
  117. package/dist/chunk-6JVYYLS7.js.map +0 -1
  118. package/dist/chunk-6SGG6WPA.mjs +0 -2
  119. package/dist/chunk-6SGG6WPA.mjs.map +0 -1
  120. package/dist/chunk-AQEGDEQM.js +0 -7
  121. package/dist/chunk-AQEGDEQM.js.map +0 -1
  122. package/dist/chunk-C2IJWCZQ.mjs +0 -2
  123. package/dist/chunk-C2IJWCZQ.mjs.map +0 -1
  124. package/dist/chunk-CMZTI7SG.js.map +0 -1
  125. package/dist/chunk-DB3JH4DS.mjs.map +0 -1
  126. package/dist/chunk-FFW7RUAG.mjs +0 -94
  127. package/dist/chunk-FFW7RUAG.mjs.map +0 -1
  128. package/dist/chunk-FK3CSFLJ.js +0 -2
  129. package/dist/chunk-FK3CSFLJ.js.map +0 -1
  130. package/dist/chunk-GIV2OHE6.mjs.map +0 -1
  131. package/dist/chunk-GMLNWS2N.mjs.map +0 -1
  132. package/dist/chunk-IQF726GS.js.map +0 -1
  133. package/dist/chunk-IWUUVRLJ.js.map +0 -1
  134. package/dist/chunk-JUN6YPLL.mjs +0 -72
  135. package/dist/chunk-JUN6YPLL.mjs.map +0 -1
  136. package/dist/chunk-L3FKTBGV.js +0 -72
  137. package/dist/chunk-L3FKTBGV.js.map +0 -1
  138. package/dist/chunk-L52PDW6O.mjs.map +0 -1
  139. package/dist/chunk-LI6WJ3LZ.js.map +0 -1
  140. package/dist/chunk-LXRXDTPI.js.map +0 -1
  141. package/dist/chunk-MQFZHA2D.js.map +0 -1
  142. package/dist/chunk-OITITR6K.mjs.map +0 -1
  143. package/dist/chunk-PDJGTQMY.mjs.map +0 -1
  144. package/dist/chunk-PGSA2O5P.mjs.map +0 -1
  145. package/dist/chunk-PM7CMTMB.js.map +0 -1
  146. package/dist/chunk-PYEX7DFR.mjs.map +0 -1
  147. package/dist/chunk-QKK5S54L.mjs.map +0 -1
  148. package/dist/chunk-RB26MIRI.js +0 -2
  149. package/dist/chunk-RB26MIRI.js.map +0 -1
  150. package/dist/chunk-RGYK4VAY.mjs.map +0 -1
  151. package/dist/chunk-RHWW5FDP.js +0 -16
  152. package/dist/chunk-RHWW5FDP.js.map +0 -1
  153. package/dist/chunk-RYZEIDNR.js.map +0 -1
  154. package/dist/chunk-SLNMKGQ2.mjs +0 -2
  155. package/dist/chunk-SLNMKGQ2.mjs.map +0 -1
  156. package/dist/chunk-SSGJREE3.js.map +0 -1
  157. package/dist/chunk-SWF3YVE5.js.map +0 -1
  158. package/dist/chunk-T44JQT2O.mjs.map +0 -1
  159. package/dist/chunk-TDDAYVKK.js.map +0 -1
  160. package/dist/chunk-TXBZPCGF.mjs.map +0 -1
  161. package/dist/chunk-UUWVBENC.js +0 -2
  162. package/dist/chunk-UUWVBENC.js.map +0 -1
  163. package/dist/chunk-UYP64PV7.mjs.map +0 -1
  164. package/dist/chunk-VMJBW3EF.mjs.map +0 -1
  165. package/dist/chunk-WW3X3ELF.js.map +0 -1
  166. package/dist/chunk-WWT2ZSNU.mjs.map +0 -1
  167. package/dist/chunk-XMKA6GVK.mjs +0 -16
  168. package/dist/chunk-XMKA6GVK.mjs.map +0 -1
  169. package/dist/chunk-Y34DQYS7.js.map +0 -1
  170. package/dist/chunk-ZU73VG3X.js.map +0 -1
  171. package/dist/consent.js.map +0 -1
  172. package/dist/consent.mjs.map +0 -1
  173. package/dist/core.js.map +0 -1
  174. package/dist/core.mjs.map +0 -1
  175. package/dist/cross-border.js.map +0 -1
  176. package/dist/cross-border.mjs.map +0 -1
  177. package/dist/dpia.js.map +0 -1
  178. package/dist/dpia.mjs.map +0 -1
  179. package/dist/dsr.js.map +0 -1
  180. package/dist/dsr.mjs.map +0 -1
  181. package/dist/hooks.js.map +0 -1
  182. package/dist/hooks.mjs.map +0 -1
  183. package/dist/index.js.map +0 -1
  184. package/dist/index.mjs.map +0 -1
  185. package/dist/lawful-basis.js.map +0 -1
  186. package/dist/lawful-basis.mjs.map +0 -1
  187. package/dist/policy.js.map +0 -1
  188. package/dist/policy.mjs.map +0 -1
  189. package/dist/ropa.js.map +0 -1
  190. package/dist/ropa.mjs.map +0 -1
  191. package/dist/unstyled.js.map +0 -1
  192. package/dist/unstyled.mjs.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../packages/ndpr-toolkit/src/hooks/useDPIA.ts"],"names":["useDPIA","sections","initialAnswers","storageKey","useLocalStorage","onComplete","currentSectionIndex","setCurrentSectionIndex","useState","answers","setAnswers","useEffect","savedData","savedAnswers","sectionIndex","error","currentSection","updateAnswer","questionId","value","prevAnswers","__spreadProps","__spreadValues","shouldShowQuestion","question","condition","answer","getVisibleQuestions","isCurrentSectionValid","getCurrentSectionErrors","errors","nextSection","prevIndex","prevSection","goToSection","index","isComplete","section","q","identifyRisks","risks","selectedOption","_a","option","opt","riskLevel","likelihood","impact","completeDPIA","assessorInfo","title","processingDescription","result","assessment","assessDPIARisk","resetDPIA","progress","answeredQuestions","totalRequiredQuestions"],"mappings":"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","file":"chunk-3YCV2BA6.js","sourcesContent":["import { useState, useEffect } from 'react';\nimport { DPIAQuestion, DPIASection, DPIAResult, DPIARisk } from '../types/dpia';\nimport { assessDPIARisk } from '../utils/dpia';\n\ninterface UseDPIAOptions {\n /**\n * Sections of the DPIA questionnaire\n */\n sections: DPIASection[];\n \n /**\n * Initial answers (if resuming a DPIA)\n */\n initialAnswers?: Record<string, any>;\n \n /**\n * Storage key for DPIA data\n * @default \"ndpr_dpia_data\"\n */\n storageKey?: string;\n \n /**\n * Whether to use local storage to persist DPIA data\n * @default true\n */\n useLocalStorage?: boolean;\n \n /**\n * Callback function called when the DPIA is completed\n */\n onComplete?: (result: DPIAResult) => void;\n}\n\ninterface UseDPIAReturn {\n /**\n * Current section index\n */\n currentSectionIndex: number;\n \n /**\n * Current section\n */\n currentSection: DPIASection | null;\n \n /**\n * All answers\n */\n answers: Record<string, any>;\n \n /**\n * Update an answer\n */\n updateAnswer: (questionId: string, value: any) => void;\n \n /**\n * Go to the next section\n */\n nextSection: () => boolean;\n \n /**\n * Go to the previous section\n */\n prevSection: () => boolean;\n \n /**\n * Go to a specific section\n */\n goToSection: (index: number) => boolean;\n \n /**\n * Check if the current section is valid\n */\n isCurrentSectionValid: () => boolean;\n \n /**\n * Get validation errors for the current section\n */\n getCurrentSectionErrors: () => Record<string, string>;\n \n /**\n * Check if the DPIA is complete\n */\n isComplete: () => boolean;\n \n /**\n * Complete the DPIA and generate a result\n */\n completeDPIA: (assessorInfo: { name: string; role: string; email: string; }, title: string, processingDescription: string) => DPIAResult;\n \n /**\n * Get the visible questions for the current section\n */\n getVisibleQuestions: () => DPIAQuestion[];\n \n /**\n * Reset the DPIA\n */\n resetDPIA: () => void;\n \n /**\n * Progress percentage\n */\n progress: number;\n}\n\n/**\n * Hook for conducting Data Protection Impact Assessments in compliance with the NDPA 2023\n */\nexport function useDPIA({\n sections,\n initialAnswers = {},\n storageKey = \"ndpr_dpia_data\",\n useLocalStorage = true,\n onComplete\n}: UseDPIAOptions): UseDPIAReturn {\n const [currentSectionIndex, setCurrentSectionIndex] = useState<number>(0);\n const [answers, setAnswers] = useState<Record<string, any>>(initialAnswers);\n \n // Load DPIA data from storage on mount\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined') {\n try {\n const savedData = localStorage.getItem(storageKey);\n if (savedData) {\n const { answers: savedAnswers, sectionIndex } = JSON.parse(savedData);\n setAnswers(savedAnswers || {});\n setCurrentSectionIndex(sectionIndex || 0);\n }\n } catch (error) {\n console.error('Error loading DPIA data:', error);\n }\n }\n }, [storageKey, useLocalStorage]);\n \n // Save DPIA data to storage when it changes\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined') {\n try {\n localStorage.setItem(storageKey, JSON.stringify({\n answers,\n sectionIndex: currentSectionIndex\n }));\n } catch (error) {\n console.error('Error saving DPIA data:', error);\n }\n }\n }, [answers, currentSectionIndex, storageKey, useLocalStorage]);\n \n // Get the current section\n const currentSection = sections[currentSectionIndex] || null;\n \n // Update an answer\n const updateAnswer = (questionId: string, value: any) => {\n setAnswers(prevAnswers => ({\n ...prevAnswers,\n [questionId]: value\n }));\n };\n \n // Check if a question should be shown based on its conditions\n const shouldShowQuestion = (question: DPIAQuestion): boolean => {\n if (!question.showWhen) {\n return true;\n }\n \n return question.showWhen.every(condition => {\n const answer = answers[condition.questionId];\n \n switch (condition.operator) {\n case 'equals':\n return answer === condition.value;\n case 'contains':\n return Array.isArray(answer) ? answer.includes(condition.value) : false;\n case 'greaterThan':\n return typeof answer === 'number' ? answer > condition.value : false;\n case 'lessThan':\n return typeof answer === 'number' ? answer < condition.value : false;\n default:\n return true;\n }\n });\n };\n \n // Get the visible questions for the current section\n const getVisibleQuestions = (): DPIAQuestion[] => {\n if (!currentSection) {\n return [];\n }\n \n return currentSection.questions.filter(shouldShowQuestion);\n };\n \n // Check if the current section is valid\n const isCurrentSectionValid = (): boolean => {\n if (!currentSection) {\n return false;\n }\n \n const visibleQuestions = getVisibleQuestions();\n \n return visibleQuestions.every(question => {\n if (!question.required) {\n return true;\n }\n \n const answer = answers[question.id];\n \n if (answer === undefined || answer === null) {\n return false;\n }\n \n if (typeof answer === 'string' && answer.trim() === '') {\n return false;\n }\n \n if (Array.isArray(answer) && answer.length === 0) {\n return false;\n }\n \n return true;\n });\n };\n \n // Get validation errors for the current section\n const getCurrentSectionErrors = (): Record<string, string> => {\n const errors: Record<string, string> = {};\n \n if (!currentSection) {\n return errors;\n }\n \n const visibleQuestions = getVisibleQuestions();\n \n visibleQuestions.forEach(question => {\n if (!question.required) {\n return;\n }\n \n const answer = answers[question.id];\n \n if (answer === undefined || answer === null) {\n errors[question.id] = 'This question is required';\n } else if (typeof answer === 'string' && answer.trim() === '') {\n errors[question.id] = 'This question is required';\n } else if (Array.isArray(answer) && answer.length === 0) {\n errors[question.id] = 'At least one option must be selected';\n }\n });\n \n return errors;\n };\n \n // Go to the next section\n const nextSection = (): boolean => {\n if (!isCurrentSectionValid()) {\n return false;\n }\n \n if (currentSectionIndex < sections.length - 1) {\n setCurrentSectionIndex(prevIndex => prevIndex + 1);\n return true;\n }\n \n return false;\n };\n \n // Go to the previous section\n const prevSection = (): boolean => {\n if (currentSectionIndex > 0) {\n setCurrentSectionIndex(prevIndex => prevIndex - 1);\n return true;\n }\n \n return false;\n };\n \n // Go to a specific section\n const goToSection = (index: number): boolean => {\n if (index >= 0 && index < sections.length) {\n setCurrentSectionIndex(index);\n return true;\n }\n \n return false;\n };\n \n // Check if the DPIA is complete (pure read — no state mutation)\n const isComplete = (): boolean => {\n return sections.every((section) => {\n const visibleQuestions = section.questions.filter(q => {\n if (!q.showWhen || q.showWhen.length === 0) return true;\n return q.showWhen.some(condition => {\n const answer = answers[condition.questionId];\n switch (condition.operator) {\n case 'equals': return answer === condition.value;\n case 'contains': return Array.isArray(answer) && answer.includes(condition.value);\n case 'greaterThan': return typeof answer === 'number' && answer > condition.value;\n case 'lessThan': return typeof answer === 'number' && answer < condition.value;\n default: return false;\n }\n });\n });\n\n return visibleQuestions.every(q => {\n if (!q.required) return true;\n const answer = answers[q.id];\n if (answer === undefined || answer === null) return false;\n if (typeof answer === 'string' && answer.trim() === '') return false;\n if (Array.isArray(answer) && answer.length === 0) return false;\n return true;\n });\n });\n };\n \n // Identify risks based on answers\n const identifyRisks = (): DPIARisk[] => {\n const risks: DPIARisk[] = [];\n \n // Check each question for risk indicators\n sections.forEach(section => {\n section.questions.forEach(question => {\n const answer = answers[question.id];\n \n // Skip if no answer\n if (answer === undefined || answer === null) {\n return;\n }\n \n // Check if the question has a risk level\n if (question.riskLevel) {\n // For select/radio/checkbox questions, check if the selected option has a risk level\n if (['select', 'radio', 'checkbox'].includes(question.type) && question.options) {\n const selectedOptions = Array.isArray(answer) ? answer : [answer];\n \n selectedOptions.forEach(selectedOption => {\n const option = question.options?.find(opt => opt.value === selectedOption);\n \n if (option?.riskLevel) {\n const riskLevel = option.riskLevel;\n const likelihood = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n const impact = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n \n risks.push({\n id: `risk_${risks.length + 1}`,\n description: `${question.text} - ${option.label}`,\n likelihood,\n impact,\n score: likelihood * impact,\n level: riskLevel,\n mitigated: false,\n relatedQuestionIds: [question.id]\n });\n }\n });\n } else {\n // For other question types, use the question's risk level\n const riskLevel = question.riskLevel;\n const likelihood = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n const impact = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n \n risks.push({\n id: `risk_${risks.length + 1}`,\n description: question.text,\n likelihood,\n impact,\n score: likelihood * impact,\n level: riskLevel,\n mitigated: false,\n relatedQuestionIds: [question.id]\n });\n }\n }\n });\n });\n \n return risks;\n };\n \n // Complete the DPIA and generate a result\n const completeDPIA = (\n assessorInfo: { name: string; role: string; email: string; },\n title: string,\n processingDescription: string\n ): DPIAResult => {\n const risks = identifyRisks();\n \n const result: DPIAResult = {\n id: `dpia_${Date.now()}`,\n title,\n processingDescription,\n startedAt: Date.now(),\n completedAt: Date.now(),\n assessor: assessorInfo,\n answers,\n risks,\n overallRiskLevel: 'low',\n canProceed: true,\n conclusion: '',\n version: '1.0'\n };\n \n // Assess the risks\n const assessment = assessDPIARisk(result);\n \n result.overallRiskLevel = assessment.overallRiskLevel;\n result.canProceed = assessment.canProceed;\n result.conclusion = assessment.canProceed\n ? 'Based on the assessment, the processing can proceed with appropriate safeguards.'\n : 'Based on the assessment, the processing should not proceed without further mitigation measures.';\n result.recommendations = assessment.recommendations;\n \n if (onComplete) {\n onComplete(result);\n }\n \n return result;\n };\n \n // Reset the DPIA\n const resetDPIA = () => {\n setAnswers({});\n setCurrentSectionIndex(0);\n \n if (useLocalStorage && typeof window !== 'undefined') {\n localStorage.removeItem(storageKey);\n }\n };\n \n // Calculate progress percentage\n const progress = (() => {\n let answeredQuestions = 0;\n let totalRequiredQuestions = 0;\n \n sections.forEach(section => {\n section.questions.forEach(question => {\n if (question.required && shouldShowQuestion(question)) {\n totalRequiredQuestions++;\n \n const answer = answers[question.id];\n if (\n answer !== undefined && \n answer !== null && \n !(typeof answer === 'string' && answer.trim() === '') &&\n !(Array.isArray(answer) && answer.length === 0)\n ) {\n answeredQuestions++;\n }\n }\n });\n });\n \n return totalRequiredQuestions > 0 \n ? Math.round((answeredQuestions / totalRequiredQuestions) * 100) \n : 0;\n })();\n \n return {\n currentSectionIndex,\n currentSection,\n answers,\n updateAnswer,\n nextSection,\n prevSection,\n goToSection,\n isCurrentSectionValid,\n getCurrentSectionErrors,\n isComplete,\n completeDPIA,\n getVisibleQuestions,\n resetDPIA,\n progress\n };\n}\n"]}
@@ -1 +0,0 @@
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":"wIAoFO,SAASA,CAAAA,CAAQ,CACtB,WAAA,CAAAC,CAAAA,CACA,WAAA,CAAAC,CAAAA,CACA,eAAAC,CAAAA,CACA,eAAA,CAAAC,CACF,CAAA,CAAkC,CAChC,GAAM,CAACC,CAAAA,CAAMC,CAAO,CAAA,CAAIC,cAAAA,CAAuCN,CAAW,CAAA,CAEpEO,EAAYC,iBAAAA,CACfC,CAAAA,EAA6B,CAC5BJ,CAAAA,CAASK,CAAAA,EAAUC,kBAAAA,CAAAC,mBAAA,EAAA,CACdF,CAAAA,CAAAA,CADc,CAEjB,OAAA,CAAS,CAAC,GAAGA,EAAK,OAAA,CAASD,CAAM,CAAA,CACjC,WAAA,CAAa,IAAA,CAAK,GAAA,EACpB,CAAA,CAAE,CAAA,CACFR,CAAAA,EAAA,IAAA,EAAAA,CAAAA,CAAcQ,CAAAA,EAChB,EACA,CAACR,CAAW,CACd,CAAA,CAEMY,CAAAA,CAAeL,iBAAAA,CACnB,CAACM,CAAAA,CAAYC,CAAAA,GAAuC,CAClDV,CAAAA,CAASK,CAAAA,EAAUC,kBAAAA,CAAAC,mBAAA,EAAA,CACdF,CAAAA,CAAAA,CADc,CAEjB,OAAA,CAASA,CAAAA,CAAK,OAAA,CAAQ,IAAKD,CAAAA,EACzBA,CAAAA,CAAO,EAAA,GAAOK,CAAAA,CACVH,kBAAAA,CAAAC,kBAAAA,CAAAA,kBAAAA,CAAA,GAAKH,CAAAA,CAAAA,CAAWM,CAAAA,CAAAA,CAAhB,CAAyB,SAAA,CAAW,IAAA,CAAK,GAAA,EAAM,CAAA,CAAA,CAC/CN,CACN,CAAA,CACA,WAAA,CAAa,IAAA,CAAK,GAAA,EACpB,CAAA,CAAE,CAAA,CACFP,CAAAA,EAAA,IAAA,EAAAA,CAAAA,CAAiBY,CAAAA,CAAIC,GACvB,CAAA,CACA,CAACb,CAAc,CACjB,CAAA,CAEMc,CAAAA,CAAgBR,kBACnBM,CAAAA,EAAe,CACdT,CAAAA,CAASK,CAAAA,EAAUC,kBAAAA,CAAAC,kBAAAA,CAAA,GACdF,CAAAA,CAAAA,CADc,CAEjB,OAAA,CAASA,CAAAA,CAAK,OAAA,CAAQ,GAAA,CAAKD,GACzBA,CAAAA,CAAO,EAAA,GAAOK,CAAAA,CACVH,kBAAAA,CAAAC,kBAAAA,CAAA,EAAA,CAAKH,GAAL,CAAa,MAAA,CAAQ,UAAA,CAAqB,SAAA,CAAW,IAAA,CAAK,GAAA,EAAM,CAAA,CAAA,CAChEA,CACN,CAAA,CACA,WAAA,CAAa,IAAA,CAAK,GAAA,EACpB,CAAA,CAAE,CAAA,CACFN,CAAAA,EAAA,IAAA,EAAAA,CAAAA,CAAkBW,CAAAA,EACpB,EACA,CAACX,CAAe,CAClB,CAAA,CAEMc,CAAAA,CAAYT,iBAAAA,CACfM,GACQV,CAAAA,CAAK,OAAA,CAAQ,IAAA,CAAMK,CAAAA,EAAWA,CAAAA,CAAO,EAAA,GAAOK,CAAE,CAAA,CAEvD,CAACV,CAAAA,CAAK,OAAO,CACf,CAAA,CAEMc,EAAaV,iBAAAA,CAAY,IACtBW,kBAAAA,CAAoBf,CAAI,CAAA,CAC9B,CAACA,CAAI,CAAC,CAAA,CAEHgB,CAAAA,CAAYZ,iBAAAA,CAAY,IACrBa,kBAAAA,CAAgBjB,CAAI,CAAA,CAC1B,CAACA,CAAI,CAAC,CAAA,CAEHkB,CAAAA,CAAoBd,kBAAY,IAC7Be,kBAAAA,CAAuBnB,CAAI,CAAA,CACjC,CAACA,CAAI,CAAC,CAAA,CAET,OAAO,CACL,IAAA,CAAAA,CAAAA,CACA,SAAA,CAAAG,EACA,YAAA,CAAAM,CAAAA,CACA,aAAA,CAAAG,CAAAA,CACA,SAAA,CAAAC,CAAAA,CACA,UAAA,CAAAC,CAAAA,CACA,SAAA,CAAAE,CAAAA,CACA,iBAAA,CAAAE,CACF,CACF","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"]}
@@ -1,94 +0,0 @@
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>&copy; ${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
@@ -1 +0,0 @@
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>&copy; ${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"]}
@@ -1 +0,0 @@
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":"wIA2FO,SAASA,CAAAA,CAAuB,CACrC,gBAAA,CAAAC,CAAAA,CAAmB,GACnB,UAAA,CAAAC,CAAAA,CAAa,6BAAA,CACb,eAAA,CAAAC,CAAAA,CAAkB,IAAA,CAClB,KAAA,CAAAC,CAAAA,CACA,QAAA,CAAAC,CAAAA,CACA,QAAA,CAAAC,CACF,CAAA,CAAmC,GAAkC,CACnE,GAAM,CAACC,CAAAA,CAAWC,CAAY,CAAA,CAAIC,cAAAA,CAAgCR,CAAgB,CAAA,CAGlFS,eAAAA,CAAU,IAAM,CACd,GAAIP,CAAAA,EAAmB,OAAO,MAAA,EAAW,WAAA,CACvC,GAAI,CACF,IAAMQ,CAAAA,CAAY,YAAA,CAAa,OAAA,CAAQT,CAAU,CAAA,CAC7CS,CAAAA,EACFH,CAAAA,CAAa,IAAA,CAAK,KAAA,CAAMG,CAAS,CAAC,EAEtC,CAAA,MAASC,CAAAA,CAAO,CACd,OAAA,CAAQ,KAAA,CAAM,uCAAA,CAAyCA,CAAK,EAC9D,CAEJ,CAAA,CAAG,CAACV,CAAAA,CAAYC,CAAe,CAAC,CAAA,CAGhCO,eAAAA,CAAU,IAAM,CACd,GAAIP,CAAAA,EAAmB,OAAO,MAAA,EAAW,WAAA,CACvC,GAAI,CACF,YAAA,CAAa,OAAA,CAAQD,EAAY,IAAA,CAAK,SAAA,CAAUK,CAAS,CAAC,EAC5D,CAAA,MAASK,CAAAA,CAAO,CACd,OAAA,CAAQ,KAAA,CAAM,sCAAA,CAAwCA,CAAK,EAC7D,CAEJ,CAAA,CAAG,CAACL,CAAAA,CAAWL,CAAAA,CAAYC,CAAe,CAAC,CAAA,CAG3C,IAAMU,CAAAA,CAAa,IACV,MAAA,CAAS,IAAA,CAAK,GAAA,EAAI,CAAI,GAAA,CAAM,IAAA,CAAK,QAAO,CAAE,QAAA,CAAS,EAAE,CAAA,CAAE,SAAA,CAAU,CAAA,CAAG,EAAE,CAAA,CAIzEC,CAAAA,CAAcC,iBAAAA,CAEhBC,CAAAA,EACwB,CACxB,IAAMC,CAAAA,CAAM,KAAK,GAAA,EAAI,CACfC,CAAAA,CAAmCC,kBAAAA,CAAAC,kBAAAA,CAAA,EAAA,CACpCJ,CAAAA,CAAAA,CADoC,CAEvC,EAAA,CAAIH,CAAAA,EAAW,CACf,SAAA,CAAWI,CAAAA,CACX,SAAA,CAAWA,CACb,CAAA,CAAA,CAEA,OAAAT,CAAAA,CAAca,CAAAA,EAAS,CAAC,GAAGA,CAAAA,CAAMH,CAAW,CAAC,CAAA,CAEzCd,CAAAA,EACFA,CAAAA,CAAMc,CAAW,CAAA,CAGZA,CACT,CAAA,CACA,CAACd,CAAK,CACR,CAAA,CAGMkB,CAAAA,CAAiBP,iBAAAA,CACrB,CAACQ,CAAAA,CAAYC,CAAAA,GAAsE,CACjF,IAAIC,CAAAA,CAA8C,IAAA,CAElD,OAAAjB,CAAAA,CAAca,CAAAA,EAAS,CACrB,IAAMK,CAAAA,CAAQL,CAAAA,CAAK,SAAA,CAAWM,CAAAA,EAAMA,CAAAA,CAAE,EAAA,GAAOJ,CAAE,CAAA,CAC/C,GAAIG,CAAAA,GAAU,GACZ,OAAOL,CAAAA,CAGTI,CAAAA,CAAkBN,kBAAAA,CAAAC,kBAAAA,CAAAA,kBAAAA,CAAA,EAAA,CACbC,CAAAA,CAAKK,CAAK,CAAA,CAAA,CACVF,CAAAA,CAAAA,CAFa,CAGhB,SAAA,CAAW,IAAA,CAAK,GAAA,EAClB,CAAA,CAAA,CAEA,IAAMI,CAAAA,CAAe,CAAC,GAAGP,CAAI,CAAA,CAC7B,OAAAO,CAAAA,CAAaF,CAAK,CAAA,CAAID,CAAAA,CACfG,CACT,CAAC,CAAA,CAEGH,CAAAA,EAAmBpB,CAAAA,EACrBA,CAAAA,CAASoB,CAAe,CAAA,CAGnBA,CACT,CAAA,CACA,CAACpB,CAAQ,CACX,CAAA,CAGMwB,CAAAA,CAAiBd,iBAAAA,CACpBQ,CAAAA,EAAwB,CACvB,IAAIO,CAAAA,CAAQ,KAAA,CAEZ,OAAAtB,CAAAA,CAAca,CAAAA,EACEA,CAAAA,CAAK,SAAA,CAAWM,CAAAA,EAAMA,CAAAA,CAAE,EAAA,GAAOJ,CAAE,CAAA,GACjC,EAAA,CACLF,CAAAA,EAETS,EAAQ,IAAA,CACDT,CAAAA,CAAK,MAAA,CAAQM,CAAAA,EAAMA,CAAAA,CAAE,EAAA,GAAOJ,CAAE,CAAA,CACtC,CAAA,CAEGO,CAAAA,EAASxB,CAAAA,EACXA,CAAAA,CAASiB,CAAE,CAAA,CAGNO,CACT,CAAA,CACA,CAACxB,CAAQ,CACX,CAAA,CAGMyB,CAAAA,CAAchB,iBAAAA,CACjBQ,CAAAA,EACQhB,CAAAA,CAAU,IAAA,CAAMoB,CAAAA,EAAMA,CAAAA,CAAE,EAAA,GAAOJ,CAAE,GAAK,IAAA,CAE/C,CAAChB,CAAS,CACZ,CAAA,CAGMyB,CAAAA,CAAajB,iBAAAA,CAAY,IAA0B,CACvD,IAAME,CAAAA,CAAM,IAAA,CAAK,GAAA,EAAI,CACfgB,EAAkB1B,CAAAA,CAAU,MAAA,CAAQoB,CAAAA,EAAMA,CAAAA,CAAE,MAAA,GAAW,QAAQ,CAAA,CAG/DO,CAAAA,CAAqC,CACzC,mBAAA,CACA,kBAAA,CACA,yBAAA,CACA,oBAAA,CACA,kBAAA,CACA,uBACA,iBAAA,CACA,cAAA,CACA,iBACF,CAAA,CACMC,CAAAA,CAAc,EAAC,CACrB,IAAA,IAAWC,CAAAA,IAAaF,CAAAA,CACtBC,CAAAA,CAAYC,CAAS,CAAA,CAAIH,CAAAA,CAAgB,OACtCN,CAAAA,EAAMA,CAAAA,CAAE,iBAAA,GAAsBS,CACjC,CAAA,CAAE,MAAA,CAIJ,IAAMC,CAAAA,CAAgC,CAAC,UAAA,CAAY,YAAA,CAAc,gBAAA,CAAkB,SAAS,CAAA,CACtFC,CAAAA,CAAa,EAAC,CACpB,IAAA,IAAWC,CAAAA,IAAUF,CAAAA,CACnBC,CAAAA,CAAWC,CAAM,CAAA,CAAIN,CAAAA,CAAgB,MAAA,CAClCN,CAAAA,EAAMA,CAAAA,CAAE,cAAA,GAAmBY,CAC9B,CAAA,CAAE,OAIJ,IAAMC,CAAAA,CAAkBjC,CAAAA,CAAU,MAAA,CAC/BoB,CAAAA,EAAG,CA5PV,IAAAc,CAAAA,CAAAC,CAAAA,CA4Pa,OAAAf,CAAAA,CAAE,MAAA,GAAW,kBAAA,EAAA,CAAA,CAAuBc,CAAAA,CAAAd,EAAE,YAAA,GAAF,IAAA,CAAA,MAAA,CAAAc,CAAAA,CAAgB,QAAA,GAAY,EAAA,CAACC,CAAAA,CAAAf,CAAAA,CAAE,YAAA,GAAF,IAAA,EAAAe,CAAAA,CAAgB,QAAA,CAAA,CAC1F,CAAA,CAGMC,CAAAA,CAAe,GAAA,CAAU,GAAK,EAAA,CAAK,GAAA,CACnCC,CAAAA,CAAerC,CAAAA,CAAU,MAAA,CAC5BoB,CAAAA,EAAMA,CAAAA,CAAE,UAAA,EAAcA,CAAAA,CAAE,UAAA,EAAcV,CAAAA,CAAM0B,CAAAA,EAAgBhB,CAAAA,CAAE,MAAA,GAAW,QAC5E,CAAA,CAGMkB,CAAAA,CAAatC,CAAAA,CAAU,MAAA,CAC1BoB,CAAAA,EAAM,CAACA,CAAAA,CAAE,YAAA,EAAgBA,CAAAA,CAAE,MAAA,GAAW,QACzC,CAAA,CAGMmB,CAAAA,CAAoBvC,CAAAA,CAAU,OACjCoB,CAAAA,EAAMA,CAAAA,CAAE,SAAA,GAAc,MAAA,EAAUA,CAAAA,CAAE,MAAA,GAAW,QAChD,CAAA,CAEA,OAAO,CACL,oBAAA,CAAsBM,CAAAA,CAAgB,MAAA,CACtC,WAAA,CAAAE,EACA,UAAA,CAAAG,CAAAA,CACA,eAAA,CAAAE,CAAAA,CACA,YAAA,CAAAI,CAAAA,CACA,UAAA,CAAAC,CAAAA,CACA,iBAAA,CAAAC,CAAAA,CACA,WAAA,CAAa7B,CACf,CACF,CAAA,CAAG,CAACV,CAAS,CAAC,CAAA,CAGRwC,CAAAA,CAAmBhC,iBAAAA,CACtBiC,CAAAA,EACQD,kBAAAA,CAAqBC,CAAQ,CAAA,CAEtC,EACF,CAAA,CAEA,OAAO,CACL,SAAA,CAAAzC,CAAAA,CACA,WAAA,CAAAO,CAAAA,CACA,cAAA,CAAAQ,CAAAA,CACA,cAAA,CAAAO,CAAAA,CACA,WAAA,CAAAE,CAAAA,CACA,UAAA,CAAAC,CAAAA,CACA,gBAAA,CAAAe,CACF,CACF","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"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../packages/ndpr-toolkit/src/hooks/useDPIA.ts"],"names":["useDPIA","sections","initialAnswers","storageKey","useLocalStorage","onComplete","currentSectionIndex","setCurrentSectionIndex","useState","answers","setAnswers","useEffect","savedData","savedAnswers","sectionIndex","error","currentSection","updateAnswer","questionId","value","prevAnswers","__spreadProps","__spreadValues","shouldShowQuestion","question","condition","answer","getVisibleQuestions","isCurrentSectionValid","getCurrentSectionErrors","errors","nextSection","prevIndex","prevSection","goToSection","index","isComplete","section","q","identifyRisks","risks","selectedOption","_a","option","opt","riskLevel","likelihood","impact","completeDPIA","assessorInfo","title","processingDescription","result","assessment","assessDPIARisk","resetDPIA","progress","answeredQuestions","totalRequiredQuestions"],"mappings":"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","file":"chunk-6GGGTRDZ.mjs","sourcesContent":["import { useState, useEffect } from 'react';\nimport { DPIAQuestion, DPIASection, DPIAResult, DPIARisk } from '../types/dpia';\nimport { assessDPIARisk } from '../utils/dpia';\n\ninterface UseDPIAOptions {\n /**\n * Sections of the DPIA questionnaire\n */\n sections: DPIASection[];\n \n /**\n * Initial answers (if resuming a DPIA)\n */\n initialAnswers?: Record<string, any>;\n \n /**\n * Storage key for DPIA data\n * @default \"ndpr_dpia_data\"\n */\n storageKey?: string;\n \n /**\n * Whether to use local storage to persist DPIA data\n * @default true\n */\n useLocalStorage?: boolean;\n \n /**\n * Callback function called when the DPIA is completed\n */\n onComplete?: (result: DPIAResult) => void;\n}\n\ninterface UseDPIAReturn {\n /**\n * Current section index\n */\n currentSectionIndex: number;\n \n /**\n * Current section\n */\n currentSection: DPIASection | null;\n \n /**\n * All answers\n */\n answers: Record<string, any>;\n \n /**\n * Update an answer\n */\n updateAnswer: (questionId: string, value: any) => void;\n \n /**\n * Go to the next section\n */\n nextSection: () => boolean;\n \n /**\n * Go to the previous section\n */\n prevSection: () => boolean;\n \n /**\n * Go to a specific section\n */\n goToSection: (index: number) => boolean;\n \n /**\n * Check if the current section is valid\n */\n isCurrentSectionValid: () => boolean;\n \n /**\n * Get validation errors for the current section\n */\n getCurrentSectionErrors: () => Record<string, string>;\n \n /**\n * Check if the DPIA is complete\n */\n isComplete: () => boolean;\n \n /**\n * Complete the DPIA and generate a result\n */\n completeDPIA: (assessorInfo: { name: string; role: string; email: string; }, title: string, processingDescription: string) => DPIAResult;\n \n /**\n * Get the visible questions for the current section\n */\n getVisibleQuestions: () => DPIAQuestion[];\n \n /**\n * Reset the DPIA\n */\n resetDPIA: () => void;\n \n /**\n * Progress percentage\n */\n progress: number;\n}\n\n/**\n * Hook for conducting Data Protection Impact Assessments in compliance with the NDPA 2023\n */\nexport function useDPIA({\n sections,\n initialAnswers = {},\n storageKey = \"ndpr_dpia_data\",\n useLocalStorage = true,\n onComplete\n}: UseDPIAOptions): UseDPIAReturn {\n const [currentSectionIndex, setCurrentSectionIndex] = useState<number>(0);\n const [answers, setAnswers] = useState<Record<string, any>>(initialAnswers);\n \n // Load DPIA data from storage on mount\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined') {\n try {\n const savedData = localStorage.getItem(storageKey);\n if (savedData) {\n const { answers: savedAnswers, sectionIndex } = JSON.parse(savedData);\n setAnswers(savedAnswers || {});\n setCurrentSectionIndex(sectionIndex || 0);\n }\n } catch (error) {\n console.error('Error loading DPIA data:', error);\n }\n }\n }, [storageKey, useLocalStorage]);\n \n // Save DPIA data to storage when it changes\n useEffect(() => {\n if (useLocalStorage && typeof window !== 'undefined') {\n try {\n localStorage.setItem(storageKey, JSON.stringify({\n answers,\n sectionIndex: currentSectionIndex\n }));\n } catch (error) {\n console.error('Error saving DPIA data:', error);\n }\n }\n }, [answers, currentSectionIndex, storageKey, useLocalStorage]);\n \n // Get the current section\n const currentSection = sections[currentSectionIndex] || null;\n \n // Update an answer\n const updateAnswer = (questionId: string, value: any) => {\n setAnswers(prevAnswers => ({\n ...prevAnswers,\n [questionId]: value\n }));\n };\n \n // Check if a question should be shown based on its conditions\n const shouldShowQuestion = (question: DPIAQuestion): boolean => {\n if (!question.showWhen) {\n return true;\n }\n \n return question.showWhen.every(condition => {\n const answer = answers[condition.questionId];\n \n switch (condition.operator) {\n case 'equals':\n return answer === condition.value;\n case 'contains':\n return Array.isArray(answer) ? answer.includes(condition.value) : false;\n case 'greaterThan':\n return typeof answer === 'number' ? answer > condition.value : false;\n case 'lessThan':\n return typeof answer === 'number' ? answer < condition.value : false;\n default:\n return true;\n }\n });\n };\n \n // Get the visible questions for the current section\n const getVisibleQuestions = (): DPIAQuestion[] => {\n if (!currentSection) {\n return [];\n }\n \n return currentSection.questions.filter(shouldShowQuestion);\n };\n \n // Check if the current section is valid\n const isCurrentSectionValid = (): boolean => {\n if (!currentSection) {\n return false;\n }\n \n const visibleQuestions = getVisibleQuestions();\n \n return visibleQuestions.every(question => {\n if (!question.required) {\n return true;\n }\n \n const answer = answers[question.id];\n \n if (answer === undefined || answer === null) {\n return false;\n }\n \n if (typeof answer === 'string' && answer.trim() === '') {\n return false;\n }\n \n if (Array.isArray(answer) && answer.length === 0) {\n return false;\n }\n \n return true;\n });\n };\n \n // Get validation errors for the current section\n const getCurrentSectionErrors = (): Record<string, string> => {\n const errors: Record<string, string> = {};\n \n if (!currentSection) {\n return errors;\n }\n \n const visibleQuestions = getVisibleQuestions();\n \n visibleQuestions.forEach(question => {\n if (!question.required) {\n return;\n }\n \n const answer = answers[question.id];\n \n if (answer === undefined || answer === null) {\n errors[question.id] = 'This question is required';\n } else if (typeof answer === 'string' && answer.trim() === '') {\n errors[question.id] = 'This question is required';\n } else if (Array.isArray(answer) && answer.length === 0) {\n errors[question.id] = 'At least one option must be selected';\n }\n });\n \n return errors;\n };\n \n // Go to the next section\n const nextSection = (): boolean => {\n if (!isCurrentSectionValid()) {\n return false;\n }\n \n if (currentSectionIndex < sections.length - 1) {\n setCurrentSectionIndex(prevIndex => prevIndex + 1);\n return true;\n }\n \n return false;\n };\n \n // Go to the previous section\n const prevSection = (): boolean => {\n if (currentSectionIndex > 0) {\n setCurrentSectionIndex(prevIndex => prevIndex - 1);\n return true;\n }\n \n return false;\n };\n \n // Go to a specific section\n const goToSection = (index: number): boolean => {\n if (index >= 0 && index < sections.length) {\n setCurrentSectionIndex(index);\n return true;\n }\n \n return false;\n };\n \n // Check if the DPIA is complete (pure read — no state mutation)\n const isComplete = (): boolean => {\n return sections.every((section) => {\n const visibleQuestions = section.questions.filter(q => {\n if (!q.showWhen || q.showWhen.length === 0) return true;\n return q.showWhen.some(condition => {\n const answer = answers[condition.questionId];\n switch (condition.operator) {\n case 'equals': return answer === condition.value;\n case 'contains': return Array.isArray(answer) && answer.includes(condition.value);\n case 'greaterThan': return typeof answer === 'number' && answer > condition.value;\n case 'lessThan': return typeof answer === 'number' && answer < condition.value;\n default: return false;\n }\n });\n });\n\n return visibleQuestions.every(q => {\n if (!q.required) return true;\n const answer = answers[q.id];\n if (answer === undefined || answer === null) return false;\n if (typeof answer === 'string' && answer.trim() === '') return false;\n if (Array.isArray(answer) && answer.length === 0) return false;\n return true;\n });\n });\n };\n \n // Identify risks based on answers\n const identifyRisks = (): DPIARisk[] => {\n const risks: DPIARisk[] = [];\n \n // Check each question for risk indicators\n sections.forEach(section => {\n section.questions.forEach(question => {\n const answer = answers[question.id];\n \n // Skip if no answer\n if (answer === undefined || answer === null) {\n return;\n }\n \n // Check if the question has a risk level\n if (question.riskLevel) {\n // For select/radio/checkbox questions, check if the selected option has a risk level\n if (['select', 'radio', 'checkbox'].includes(question.type) && question.options) {\n const selectedOptions = Array.isArray(answer) ? answer : [answer];\n \n selectedOptions.forEach(selectedOption => {\n const option = question.options?.find(opt => opt.value === selectedOption);\n \n if (option?.riskLevel) {\n const riskLevel = option.riskLevel;\n const likelihood = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n const impact = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n \n risks.push({\n id: `risk_${risks.length + 1}`,\n description: `${question.text} - ${option.label}`,\n likelihood,\n impact,\n score: likelihood * impact,\n level: riskLevel,\n mitigated: false,\n relatedQuestionIds: [question.id]\n });\n }\n });\n } else {\n // For other question types, use the question's risk level\n const riskLevel = question.riskLevel;\n const likelihood = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n const impact = riskLevel === 'low' ? 1 : riskLevel === 'medium' ? 3 : 5;\n \n risks.push({\n id: `risk_${risks.length + 1}`,\n description: question.text,\n likelihood,\n impact,\n score: likelihood * impact,\n level: riskLevel,\n mitigated: false,\n relatedQuestionIds: [question.id]\n });\n }\n }\n });\n });\n \n return risks;\n };\n \n // Complete the DPIA and generate a result\n const completeDPIA = (\n assessorInfo: { name: string; role: string; email: string; },\n title: string,\n processingDescription: string\n ): DPIAResult => {\n const risks = identifyRisks();\n \n const result: DPIAResult = {\n id: `dpia_${Date.now()}`,\n title,\n processingDescription,\n startedAt: Date.now(),\n completedAt: Date.now(),\n assessor: assessorInfo,\n answers,\n risks,\n overallRiskLevel: 'low',\n canProceed: true,\n conclusion: '',\n version: '1.0'\n };\n \n // Assess the risks\n const assessment = assessDPIARisk(result);\n \n result.overallRiskLevel = assessment.overallRiskLevel;\n result.canProceed = assessment.canProceed;\n result.conclusion = assessment.canProceed\n ? 'Based on the assessment, the processing can proceed with appropriate safeguards.'\n : 'Based on the assessment, the processing should not proceed without further mitigation measures.';\n result.recommendations = assessment.recommendations;\n \n if (onComplete) {\n onComplete(result);\n }\n \n return result;\n };\n \n // Reset the DPIA\n const resetDPIA = () => {\n setAnswers({});\n setCurrentSectionIndex(0);\n \n if (useLocalStorage && typeof window !== 'undefined') {\n localStorage.removeItem(storageKey);\n }\n };\n \n // Calculate progress percentage\n const progress = (() => {\n let answeredQuestions = 0;\n let totalRequiredQuestions = 0;\n \n sections.forEach(section => {\n section.questions.forEach(question => {\n if (question.required && shouldShowQuestion(question)) {\n totalRequiredQuestions++;\n \n const answer = answers[question.id];\n if (\n answer !== undefined && \n answer !== null && \n !(typeof answer === 'string' && answer.trim() === '') &&\n !(Array.isArray(answer) && answer.length === 0)\n ) {\n answeredQuestions++;\n }\n }\n });\n });\n \n return totalRequiredQuestions > 0 \n ? Math.round((answeredQuestions / totalRequiredQuestions) * 100) \n : 0;\n })();\n \n return {\n currentSectionIndex,\n currentSection,\n answers,\n updateAnswer,\n nextSection,\n prevSection,\n goToSection,\n isCurrentSectionValid,\n getCurrentSectionErrors,\n isComplete,\n completeDPIA,\n getVisibleQuestions,\n resetDPIA,\n progress\n };\n}\n"]}