Skip to content

Commit

Permalink
fix: adjust parseReadalong to preserve the right format
Browse files Browse the repository at this point in the history
parseFromString does a number of strange and undesirable things:
 - remove the <body> element
 - insert xmlns=
 - change ARPABET= attribute to arpabet=
So we need to reverse all this, to match our .readalong DTD format!

Fixes #347

Co-authored-by: Delasie Torkornoo <[email protected]>
  • Loading branch information
joanise and deltork committed Oct 18, 2024
1 parent e247512 commit 3bf2a85
Showing 1 changed file with 13 additions and 8 deletions.
21 changes: 13 additions & 8 deletions packages/studio-web/src/app/editor/editor.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -159,13 +159,13 @@ export class EditorComponent implements OnDestroy, OnInit, AfterViewInit {
let changedSegment =
readalongContainerElement.shadowRoot?.getElementById(id);
if (changedSegment) {
changedSegment.innerText = text;
changedSegment.textContent = text;
}
// Update XML text
if (this.editorService.rasControl$.value) {
changedSegment = this.editorService.rasControl$.value.getElementById(id);
if (changedSegment) {
changedSegment.innerText = text;
changedSegment.textContent = text; // innerText is not supported for XML documents
}
}
}
Expand Down Expand Up @@ -254,22 +254,27 @@ export class EditorComponent implements OnDestroy, OnInit, AfterViewInit {
}

// Store the element as parsed XML
// Create missing body element
const body = document.createElement("body");
body.id = "t0b0";
const textNode = element.children[0];
if (textNode) {
// Create body element, which mysteriously gets removed from the text element.
let textNode = element.querySelector("text");
if (textNode && !textNode.querySelector("body")) {
const body = document.createElement("body");
body.id = "t0b0";
while (textNode.hasChildNodes()) {
// @ts-ignore
body.appendChild(textNode.firstChild);
}
textNode.appendChild(body);
}
const serializer = new XMLSerializer();
const xmlString = serializer.serializeToString(element);
const xmlString = serializer
.serializeToString(element)
.replace(/arpabet=/g, "ARPABET=") // Our DTD says ARPABET is upper case
.replace(/xmlns="[\w\/\:\.]*"/g, ""); // Our DTD does not accept xmlns that the parser inserts
//console.log(xmlString);
this.editorService.rasControl$.setValue(
parser.parseFromString(xmlString, "text/xml"),
); // re-parse as XML
//console.log(this.editorService.rasControl$.value);

// Oh, there's an audio file, okay, try to load it
const audio = element.getAttribute("audio");
Expand Down

0 comments on commit 3bf2a85

Please sign in to comment.