From 7ca32db28893269594bd49ef1b26011b5435ab6a Mon Sep 17 00:00:00 2001 From: Sean Perkins <13732623+sean-perkins@users.noreply.github.com> Date: Tue, 5 Dec 2023 15:45:25 -0500 Subject: [PATCH] fix(playground): tabs stackblitz example loads in Safari (#3287) --- src/components/global/Playground/index.tsx | 28 ++++++++++++++++--- .../v6/tabs/router/angular/app_module_ts.md | 2 +- .../v7/tabs/router/angular/app_module_ts.md | 2 +- 3 files changed, 26 insertions(+), 6 deletions(-) diff --git a/src/components/global/Playground/index.tsx b/src/components/global/Playground/index.tsx index 4010db3b372..1ef1dba4489 100644 --- a/src/components/global/Playground/index.tsx +++ b/src/components/global/Playground/index.tsx @@ -546,10 +546,30 @@ export default function Playground({ if (hasUsageTargetOptions) { editorOptions.files = Object.keys(codeSnippets[usageTarget]) - .map((fileName) => ({ - [fileName]: hostRef.current!.querySelector(`#${getCodeSnippetId(usageTarget, fileName)} code`) - .outerText, - })) + .map((fileName) => { + const codeBlock = hostRef.current!.querySelector( + `#${getCodeSnippetId(usageTarget, fileName)} code` + ); + let code = codeBlock.outerText; + + if (code.trim().length === 0) { + /** + * Safari has an issue where accessing the `outerText` on a non-visible + * DOM element results in a string with only whitespace. To work around this, + * we create a clone of the element, not attached to the DOM, and parse + * the outerText from that. + * + * Only in Safari does this persist whitespace & line breaks, so we + * explicitly check for when the code is empty to use this workaround. + */ + const el = document.createElement('div'); + el.innerHTML = codeBlock.innerHTML; + code = el.outerText; + } + return { + [fileName]: code, + }; + }) .reduce((acc, curr) => ({ ...acc, ...curr }), {}); editorOptions.dependencies = (code[usageTarget] as UsageTargetOptions).dependencies; } diff --git a/static/usage/v6/tabs/router/angular/app_module_ts.md b/static/usage/v6/tabs/router/angular/app_module_ts.md index b2d3db7f33d..e36b8c6316e 100644 --- a/static/usage/v6/tabs/router/angular/app_module_ts.md +++ b/static/usage/v6/tabs/router/angular/app_module_ts.md @@ -11,7 +11,7 @@ import { ExampleComponent } from './example.component'; import { AppRoutingModule } from './app-routing.module'; @NgModule({ - imports: [BrowserModule, FormsModule, AppRoutingModule, IonicModule.forRoot()], + imports: [BrowserModule, FormsModule, AppRoutingModule, IonicModule.forRoot({})], declarations: [AppComponent, ExampleComponent], bootstrap: [AppComponent], }) diff --git a/static/usage/v7/tabs/router/angular/app_module_ts.md b/static/usage/v7/tabs/router/angular/app_module_ts.md index b2d3db7f33d..e36b8c6316e 100644 --- a/static/usage/v7/tabs/router/angular/app_module_ts.md +++ b/static/usage/v7/tabs/router/angular/app_module_ts.md @@ -11,7 +11,7 @@ import { ExampleComponent } from './example.component'; import { AppRoutingModule } from './app-routing.module'; @NgModule({ - imports: [BrowserModule, FormsModule, AppRoutingModule, IonicModule.forRoot()], + imports: [BrowserModule, FormsModule, AppRoutingModule, IonicModule.forRoot({})], declarations: [AppComponent, ExampleComponent], bootstrap: [AppComponent], })