"Failed to read file")); reader.readAsText(file); }); }; return /* @__PURE__ */ jsxDEV(Box, { mt: 4, mb: 4, p: 4, borderWidth: "1px", borderRadius: "md", borderColor: colors.gray.medium, bg: "white", children: [ /* @__PURE__ */ jsxDEV(Text, { fontWeight: "medium", mb: 2, fontFamily: "'Red Hat Display', sans-serif", color: colors.gray.dark, children: "Import certifications from CSV" }, void 0, false, { fileName: "/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", lineNumber: 83, columnNumber: 7 }, this), /* @__PURE__ */ jsxDEV(Box, { display: "flex", alignItems: "center", gap: 2, children: [ /* @__PURE__ */ jsxDEV( Input, { type: "file", accept: ".csv", ref: fileInputRef, onChange: handleFileChange, style: { display: "none" }, id: "csv-file-input" }, void 0, false, { fileName: "/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", lineNumber: 87, columnNumber: 9 }, this ), /* @__PURE__ */ jsxDEV("label", { htmlFor: "csv-file-input", children: /* @__PURE__ */ jsxDEV( Button, { bg: colors.blue, color: "white", disabled: isLoading, cursor: "pointer", fontFamily: "'Red Hat Text', sans-serif", fontWeight: "normal", borderRadius: "3px", _hover: { bg: colors.blueHover }, _active: { bg: colors.blueActive }, children: isLoading ? "Importing..." : "Select CSV File" }, void 0, false, { fileName: "/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", lineNumber: 96, columnNumber: 11 }, this ) }, void 0, false, { fileName: "/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", lineNumber: 95, columnNumber: 9 }, this), /* @__PURE__ */ jsxDEV(Text, { fontSize: "sm", color: colors.gray.dark, fontFamily: "'Red Hat Text', sans-serif", children: "Expected format: columns for Name, Status, and Start date" }, void 0, false, { fileName: "/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", lineNumber: 110, columnNumber: 9 }, this) ] }, void 0, true, { fileName: "/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", lineNumber: 86, columnNumber: 7 }, this), message && /* @__PURE__ */ jsxDEV( Text, { mt: 2, color: message.type === "success" ? colors.green : colors.red, fontWeight: "medium", fontFamily: "'Red Hat Text', sans-serif", children: message.text }, void 0, false, { fileName: "/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", lineNumber: 116, columnNumber: 7 }, this ) ] }, void 0, true, { fileName: "/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", lineNumber: 82, columnNumber: 5 }, this); }; _s(CertificationImport, "1TyPFtsEnn/FJ/+XI+jjsy/BXbA="); _c = CertificationImport; var _c; $RefreshReg$(_c, "CertificationImport"); if (import.meta.hot && !inWebWorker) { window.$RefreshReg$ = prevRefreshReg; window.$RefreshSig$ = prevRefreshSig; } if (import.meta.hot && !inWebWorker) { RefreshRuntime.__hmr_import(import.meta.url).then((currentExports) => { RefreshRuntime.registerExportsForReactRefresh("/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", currentExports); import.meta.hot.accept((nextExports) => { if (!nextExports) return; const invalidateMessage = RefreshRuntime.validateRefreshBoundaryAndEnqueueUpdate("/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx", currentExports, nextExports); if (invalidateMessage) import.meta.hot.invalidate(invalidateMessage); }); }); } //# sourceMappingURL=data:application/json;base64,{"version":3,"mappings":"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","names":["useRef","useState","Box","Button","Input","Text","colors","red","redHover","redActive","blue","blueHover","blueActive","green","gray","light","medium","dark","CertificationImport","onImport","_s","fileInputRef","isLoading","setIsLoading","message","setMessage","handleFileChange","e","files","target","length","file","content","readFileAsText","result","success","text","count","type","error","Error","current","value","Promise","resolve","reject","reader","FileReader","onload","onerror","readAsText","display","bg","_c","$RefreshReg$"],"ignoreList":[],"sources":["CertificationImport.tsx"],"sourcesContent":["import React, { useRef, useState } from 'react';\nimport { Box, Button, Input, Text } from '@chakra-ui/react';\n\n// Red Hat brand colors\nconst colors = {\n  red: \"#ee0000\",\n  redHover: \"#cc0000\",\n  redActive: \"#a30000\",\n  blue: \"#0066cc\",\n  blueHover: \"#004080\", \n  blueActive: \"#002952\",\n  green: \"#3e8635\",\n  gray: {\n    light: \"#f5f5f5\",\n    medium: \"#d2d2d2\",\n    dark: \"#4c4c4c\"\n  }\n};\n\ninterface CertificationImportProps {\n  onImport: (csvContent: string) => { success: boolean; count?: number; error?: string };\n}\n\nexport const CertificationImport: React.FC<CertificationImportProps> = ({ onImport }) => {\n  const fileInputRef = useRef<HTMLInputElement>(null);\n  const [isLoading, setIsLoading] = useState(false);\n  const [message, setMessage] = useState<{text: string, type: 'success' | 'error'} | null>(null);\n\n  const handleFileChange = async (e: React.ChangeEvent<HTMLInputElement>) => {\n    const files = e.target.files;\n    if (!files || files.length === 0) return;\n\n    setIsLoading(true);\n    setMessage(null);\n    \n    try {\n      const file = files[0];\n      const content = await readFileAsText(file);\n      const result = onImport(content);\n      \n      if (result.success) {\n        setMessage({ \n          text: `Successfully imported ${result.count} certifications.`,\n          type: 'success'\n        });\n      } else {\n        setMessage({ \n          text: result.error || 'Unknown error occurred during import.',\n          type: 'error'\n        });\n      }\n    } catch (error) {\n      setMessage({ \n        text: error instanceof Error ? error.message : 'Unknown error reading file.',\n        type: 'error'\n      });\n    } finally {\n      setIsLoading(false);\n      // Reset the file input\n      if (fileInputRef.current) {\n        fileInputRef.current.value = '';\n      }\n    }\n  };\n\n  const readFileAsText = (file: File): Promise<string> => {\n    return new Promise((resolve, reject) => {\n      const reader = new FileReader();\n      reader.onload = (e) => {\n        if (e.target?.result) {\n          resolve(e.target.result as string);\n        } else {\n          reject(new Error('Failed to read file'));\n        }\n      };\n      reader.onerror = () => reject(new Error('Failed to read file'));\n      reader.readAsText(file);\n    });\n  };\n\n  return (\n    <Box mt={4} mb={4} p={4} borderWidth=\"1px\" borderRadius=\"md\" borderColor={colors.gray.medium} bg=\"white\">\n      <Text fontWeight=\"medium\" mb={2} fontFamily=\"'Red Hat Display', sans-serif\" color={colors.gray.dark}>\n        Import certifications from CSV\n      </Text>\n      <Box display=\"flex\" alignItems=\"center\" gap={2}>\n        <Input\n          type=\"file\"\n          accept=\".csv\"\n          ref={fileInputRef}\n          onChange={handleFileChange}\n          style={{ display: 'none' }}\n          id=\"csv-file-input\"\n        />\n        <label htmlFor=\"csv-file-input\">\n          <Button\n            bg={colors.blue}\n            color=\"white\"\n            disabled={isLoading}\n            cursor=\"pointer\"\n            fontFamily=\"'Red Hat Text', sans-serif\"\n            fontWeight=\"normal\"\n            borderRadius=\"3px\"\n            _hover={{ bg: colors.blueHover }}\n            _active={{ bg: colors.blueActive }}\n          >\n            {isLoading ? 'Importing...' : 'Select CSV File'}\n          </Button>\n        </label>\n        <Text fontSize=\"sm\" color={colors.gray.dark} fontFamily=\"'Red Hat Text', sans-serif\">\n          Expected format: columns for Name, Status, and Start date\n        </Text>\n      </Box>\n      \n      {message && (\n        <Text \n          mt={2} \n          color={message.type === 'success' ? colors.green : colors.red}\n          fontWeight=\"medium\"\n          fontFamily=\"'Red Hat Text', sans-serif\"\n        >\n          {message.text}\n        </Text>\n      )}\n    </Box>\n  );\n}; "],"file":"/home/josie/development/services-cv-generator/src/components/CertificationImport.tsx"}Ә