Merge branch 'fix/export_function_windows' into 'develop'

Fix/export function windows

See merge request proj-wise2526-video2document/video2document!75
This commit is contained in:
Hughes, Mike
2025-12-22 14:06:44 +01:00
+22 -19
View File
@@ -30,25 +30,28 @@ async function showSaveDialog(defaultName, format) {
throw err; throw err;
} }
} else if (platform === 'win32') { } else if (platform === 'win32') {
// Windows const safeName = decodeURIComponent(defaultName);
const powershell = `
Add-Type -AssemblyName System.Windows.Forms const powershell = `
$dialog = New-Object System.Windows.Forms.SaveFileDialog Add-Type -AssemblyName System.Windows.Forms;
$dialog.FileName = "${defaultName}.${format}" $dialog = New-Object System.Windows.Forms.SaveFileDialog;
$dialog.Filter = "${format.toUpperCase()} Dateien (*.${format})|*.${format}|Alle Dateien (*.*)|*.*" $dialog.FileName = '${safeName}.${format}';
$dialog.Title = "Dokument speichern als" $dialog.Filter = '${format.toUpperCase()} Dateien (*.${format})|*.${format}|Alle Dateien (*.*)|*.*';
$result = $dialog.ShowDialog() $dialog.Title = 'Dokument speichern als';
if ($result -eq 'OK') { $dialog.FileName } $result = $dialog.ShowDialog();
`; if ($result -eq 'OK') { $dialog.FileName }
`;
try {
const result = execSync(`powershell -Command "${powershell.replace(/\n/g, '; ')}"`, { try {
encoding: 'utf8' const result = execSync(
}); `powershell -NoProfile -Command "${powershell.replace(/\r?\n/g, ' ')}"`,
return result.trim() || null; { encoding: 'utf8' }
} catch (err) { );
throw err; return result.trim() || null;
} } catch (err) {
if (err.status === 1) return null; // User cancelled
throw new Error("Save dialog failed: " + err.message);
}
} else { } else {
// Linux - zenity oder kdialog // Linux - zenity oder kdialog
try { try {