Embed
Responsive wrapper for third-party embeds and raw HTML content.
---
import Embed from "@core-elements/embed/Embed.astro";
---
<Embed
aspectRatio="landscape" html="<iframe width="560" height="315" src="https://www.google.com/maps/embed?pb=!1m18!1m12!1m3!1d12955.990679836792!2d170.70348176537408!3d-45.77400364665351!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!3m3!1m2!1s0xa8294db97f77a0d7%3A0x37080f5515a9b64a!2sAramoana%20Beach!5e0!3m2!1sen!2sus!4v1740597622903!5m2!1sen!2sus" title="Aramoana Beach, Dunedin, New Zealand" frameborder="0" allowfullscreen></iframe>
"
/> ---
blocks:
_component: building-blocks/core-elements/embed
html: |
<iframe width="560" height="315" src="https://www.google.com/maps/embed?pb=!1m18!1m12!1m3!1d12955.990679836792!2d170.70348176537408!3d-45.77400364665351!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!3m3!1m2!1s0xa8294db97f77a0d7%3A0x37080f5515a9b64a!2sAramoana%20Beach!5e0!3m2!1sen!2sus!4v1740597622903!5m2!1sen!2sus" title="Aramoana Beach, Dunedin, New Zealand" frameborder="0" allowfullscreen></iframe>
aspectRatio: landscape
--- Overview
A responsive component for embedding iframes, maps, forms, videos, and any raw HTML content. Maintains consistent aspect ratios with presets for square, landscape, portrait, and widescreen layouts. Can also be used for raw HTML content including scripts and styles.
Properties
html string
The raw HTML content to render.
aspectRatio enum | default: landscape
The aspect ratio of the embed.
Accepted values:
-
square -
landscape -
portrait -
widescreen
Examples
Aspect Ratios
---
import Embed from "@core-elements/embed/Embed.astro";
---
<Embed
aspectRatio="square" html="<iframe width="560" height="560" src="https://www.google.com/maps/embed?pb=!1m18!1m12!1m3!1d1372.6620524183181!2d170.33341713890303!3d-45.94684064277149!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!3m3!1m2!1s0xa82c02d1a756cd97%3A0x44fe11e513ff4adb!2sBrighton%20Beach!5e1!3m2!1sen!2sus!4v1752859116638!5m2!1sen!2sus" title="Brighton Beach, Dunedin, New Zealand" frameborder="0" allowfullscreen></iframe>
"
/> ---
blocks:
- _component: building-blocks/core-elements/embed
html: |
<iframe width="560" height="560" src="https://www.google.com/maps/embed?pb=!1m18!1m12!1m3!1d1372.6620524183181!2d170.33341713890303!3d-45.94684064277149!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!3m3!1m2!1s0xa82c02d1a756cd97%3A0x44fe11e513ff4adb!2sBrighton%20Beach!5e1!3m2!1sen!2sus!4v1752859116638!5m2!1sen!2sus" title="Brighton Beach, Dunedin, New Zealand" frameborder="0" allowfullscreen></iframe>
aspectRatio: square
--- ---
import Embed from "@core-elements/embed/Embed.astro";
---
<Embed
aspectRatio="landscape" html="<iframe width="560" height="315" src="https://codepen.io/chriscoyier/embed/JypLvQ?default-tab=html%2Cresult" title="Form example" frameborder="0" allowfullscreen></iframe>
"
/> ---
blocks:
- _component: building-blocks/core-elements/embed
html: |
<iframe width="560" height="315" src="https://codepen.io/chriscoyier/embed/JypLvQ?default-tab=html%2Cresult" title="Form example" frameborder="0" allowfullscreen></iframe>
aspectRatio: landscape
--- ---
import Embed from "@core-elements/embed/Embed.astro";
---
<Embed
aspectRatio="portrait" html="<iframe width="100%" height="352" src="https://open.spotify.com/embed/playlist/679wCT6dVMDBxrYa5NcrXL?utm_source=generator" title="Coding Playlist" frameborder="0" allowfullscreen allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture" loading="lazy"></iframe>
"
/> ---
blocks:
- _component: building-blocks/core-elements/embed
html: |
<iframe width="100%" height="352" src="https://open.spotify.com/embed/playlist/679wCT6dVMDBxrYa5NcrXL?utm_source=generator" title="Coding Playlist" frameborder="0" allowfullscreen allow="autoplay; clipboard-write; encrypted-media; fullscreen; picture-in-picture" loading="lazy"></iframe>
aspectRatio: portrait
--- ---
import Embed from "@core-elements/embed/Embed.astro";
---
<Embed
aspectRatio="widescreen" html="<iframe width="560" height="315" src="https://www.google.com/maps/embed?pb=!3m2!1sen!2sus!4v1752859271364!5m2!1sen!2sus!6m8!1m7!1sUqPpk1s2lX_p8oUTrYW-oA!2m2!1d-45.9085756428095!2d170.5122221467356!3f247.1793758288432!4f5.098473307474947!5f0.7820865974627469" title="St Kilda beach, Dunedin, New Zealand" frameborder="0" allowfullscreen></iframe>
"
/> ---
blocks:
- _component: building-blocks/core-elements/embed
html: |
<iframe width="560" height="315" src="https://www.google.com/maps/embed?pb=!3m2!1sen!2sus!4v1752859271364!5m2!1sen!2sus!6m8!1m7!1sUqPpk1s2lX_p8oUTrYW-oA!2m2!1d-45.9085756428095!2d170.5122221467356!3f247.1793758288432!4f5.098473307474947!5f0.7820865974627469" title="St Kilda beach, Dunedin, New Zealand" frameborder="0" allowfullscreen></iframe>
aspectRatio: widescreen
---