From b510f3dc8f7e6816df0396100ae39efbfe4d47bb Mon Sep 17 00:00:00 2001 From: grossmj Date: Mon, 23 Dec 2024 15:52:17 +0700 Subject: [PATCH] Fix error when taking PNG screenshots --- .../project-map-menu.component.ts | 49 +++++++++++++------ .../screenshot-dialog.component.ts | 2 +- 2 files changed, 34 insertions(+), 17 deletions(-) diff --git a/src/app/components/project-map/project-map-menu/project-map-menu.component.ts b/src/app/components/project-map/project-map-menu/project-map-menu.component.ts index 06064435..96b9a021 100644 --- a/src/app/components/project-map/project-map-menu/project-map-menu.component.ts +++ b/src/app/components/project-map/project-map-menu/project-map-menu.component.ts @@ -98,25 +98,42 @@ export class ProjectMapMenuComponent implements OnInit, OnDestroy { private async saveImage(screenshotProperties: Screenshot) { if (screenshotProperties.filetype === 'png') { - let splittedSvg = document.getElementsByTagName('svg')[0].outerHTML.split('image'); - let i = 1; + try { + // Get the SVG element and clone it to avoid modifying the original + const originalSvg = document.getElementsByTagName('svg')[0]; + const svgClone = originalSvg.cloneNode(true) as SVGElement; - while (i < splittedSvg.length) { - let splittedImage = splittedSvg[i].split('"'); - let splittedUrl = splittedImage[1].split('/'); + // Process any embedded images + const images = svgClone.getElementsByTagName('image'); + for (let i = 0; i < images.length; i++) { + const image = images[i]; + const href = image.getAttribute('href') || image.getAttribute('xlink:href'); + if (href) { + const urlParts = href.split('/'); + const symbolId = urlParts[urlParts.length - 1]; + try { + const rawSvg = await this.symbolService.raw(this.controller, symbolId).toPromise(); + if (rawSvg) { + // Extract SVG content, fallback to raw content if parsing fails + const svgContent = rawSvg.includes('-->') ? + rawSvg.split('-->')[1].trim() : + rawSvg.trim(); + image.outerHTML = svgContent; + } + } catch (err) { + console.warn(`Failed to process embedded image: ${symbolId}`, err); + } + } + } - let elem = await this.symbolService.raw(this.controller, splittedUrl[7]).toPromise(); - let splittedElement = elem.split('-->'); - splittedSvg[i] = splittedElement[1].substring(2); - i += 2; + // Create a temporary container and save as PNG + const container = document.createElement('div'); + container.appendChild(svgClone); + svg.saveSvgAsPng(svgClone, `${screenshotProperties.name}.png`); + } catch (err) { + console.error('Failed to save PNG:', err); + throw err; } - let svgString = splittedSvg.join(); - - let placeholder = document.createElement('div'); - placeholder.innerHTML = svgString; - let element = placeholder.firstChild; - - svg.saveSvgAsPng(element, `${screenshotProperties.name}.png`); } else { var svg_el = select('svg').attr('version', 1.1).attr('xmlns', 'http://www.w3.org/2000/svg').node(); downloadSvg(select('svg').node(), `${screenshotProperties.name}`); diff --git a/src/app/components/project-map/screenshot-dialog/screenshot-dialog.component.ts b/src/app/components/project-map/screenshot-dialog/screenshot-dialog.component.ts index f7cc74de..1867ca0b 100644 --- a/src/app/components/project-map/screenshot-dialog/screenshot-dialog.component.ts +++ b/src/app/components/project-map/screenshot-dialog/screenshot-dialog.component.ts @@ -25,7 +25,7 @@ export class ScreenshotDialogComponent implements OnInit { this.nameForm = this.formBuilder.group({ screenshotName: new UntypedFormControl(`screenshot-${Date.now()}`, [Validators.required]), }); - this.isPngAvailable = this.electronService.isWindows || this.deviceService.getDeviceInfo().os === 'Windows'; + this.isPngAvailable = true; } ngOnInit() {}