import React, { Fragment } from 'react';
import ReactDOM from 'react-dom';
import { getMemory } from '../../memory';
import { useEmitter } from '../../util';
import './report-window.scss';
import Questions from './questions';
import EmailContent from './email-content';
import { parseAnswers, ParsedAnswers } from './parse-answers';
import ScreenshotGenerator from './screenshot-generator';
function downloadFiles(link: string) {
let a = document.createElement('a');
a.setAttribute('href', link);
a.setAttribute('download', '');
a.setAttribute('target', '_blank');
a.click();
}
function Report() {
try {
const url = new URL(document.location.toString());
const origin = url.searchParams.get('origin');
if (!origin) {
return
Błąd: brak parametru "origin"
;
}
// Oczekiwanie na gotowość pamięci Chrome
const [memoryReady, setMemoryReady] = React.useState(process.env.TARGET !== 'chrome');
React.useEffect(() => {
if (process.env.TARGET === 'chrome') {
const memory = getMemory();
if (typeof (memory as any).waitUntilReady === 'function') {
(memory as any).waitUntilReady().then(() => {
setMemoryReady(true);
console.log('✅ Memory gotowa dla okna raportu');
});
} else {
setMemoryReady(true);
}
}
}, []);
const [counter] = useEmitter(getMemory());
const rawAnswers = url.searchParams.get('answers');
const [answers, setAnswers] = React.useState(
rawAnswers ? JSON.parse(rawAnswers) : null
);
const [mode, setMode] = React.useState(url.searchParams.get('mode') || 'survey');
const [scrRequestPath, setScrRequestPath] = React.useState('');
// Pobieranie klastrów tylko gdy pamięć jest gotowa
const clusters = memoryReady ? getMemory().getClustersForOrigin(origin || '') : {};
React.useEffect(() => {
if (!origin || !memoryReady) return;
const url = new URL(document.location.toString());
url.searchParams.set('origin', origin);
url.searchParams.set('answers', JSON.stringify(answers));
url.searchParams.set('mode', mode);
history.pushState({}, 'Rentgen', url.toString());
}, [mode, answers, origin, memoryReady]);
// Wyświetlanie wczytywania w trakcie oczekiwania na pamięć
if (!memoryReady) {
return Wczytywanie danych z rozszerzenia...
;
}
const visited_url = Object.values(clusters)
.sort((a, b) => (a.lastModified > b.lastModified ? -1 : 1))
.find((cluster) => !!cluster.lastFullUrl)?.lastFullUrl;
// Jeśli nie znaleziono visited_url, próba skonstruowania z origin
const finalVisitedUrl = visited_url || origin;
if (!finalVisitedUrl) {
return Błąd: nie można znaleźć adresu strony
;
}
const result = (
{mode === 'survey' ? (
cluster.hasMarks()
)}
onComplete={(answers) => {
setAnswers(parseAnswers(answers));
setMode('screenshots');
}}
>
) : (
''
)}
{mode === 'screenshots' ? (
) : (
''
)}
{mode === 'preview' ? (
) : (
''
)}
);
return result;
} catch (e) {
console.error(e);
return (
Wystąpił błąd
Najprawdopodobniej Rentgen napotkał stronę, której nie jest w stanie obsłużyć.
{(e as Error).toString()}
);
}
}
ReactDOM.render(, document.getElementById('app'));