//= require views/pages/base
app.views.JqueryPage = class JqueryPage extends app.views.BasePage {
static demoClassName = "_jquery-demo";
afterRender() {
// Prevent jQuery Mobile's demo iframes from scrolling the page
for (var iframe of this.findAllByTag("iframe")) {
iframe.style.display = "none";
this.onIframeLoaded = this.onIframeLoaded.bind(this);
$.on(iframe, "load", this.onIframeLoaded);
}
return this.runExamples();
}
onIframeLoaded(event) {
event.target.style.display = "";
$.off(event.target, "load", this.onIframeLoaded);
}
runExamples() {
for (var el of this.findAllByClass("entry-example")) {
try {
this.runExample(el);
} catch (error) {}
}
}
runExample(el) {
let iframe;
const source = el.getElementsByClassName("syntaxhighlighter")[0];
if (!source || source.innerHTML.indexOf("!doctype") === -1) {
return;
}
if (!(iframe = el.getElementsByClassName(JqueryPage.demoClassName)[0])) {
iframe = document.createElement("iframe");
iframe.className = JqueryPage.demoClassName;
iframe.width = "100%";
iframe.height = 200;
el.appendChild(iframe);
}
const doc = iframe.contentDocument;
doc.write(this.fixIframeSource(source.textContent));
doc.close();
}
fixIframeSource(source) {
source = source.replace(
'"/resources/',
'"https://api.jquery.com/resources/',
); // attr(), keydown()
source = source.replace(
"",
`\
\
`,
);
return source.replace(/