@atjson/renderer-html
v0.36.2
Published
Render HTML documents from atjson
Downloads
988
Keywords
Readme
🧭 @atjson/renderer-html
Take an annotated document and render it into HTML. By default, this will take an offset document and render it to HTML.
🎈 Extending
The HTML renderer has a $
method that's designed to make it easy to extend and write your own output to HTML.
To extend the current HTML renderer to support YouTube embeds (the kind that show up when you use the share menu), we'd use the following code:
import { YouTubeEmbed } from '@atjson/offset-annotations';
import HTMLRenderer from '@atjson/renderer-html';
export default MyHTMLRenderer extends HTMLRenderer {
*YoutubeEmbed(embed: YouTubeEmbed) {
return yield* this.$('iframe', {
attributes: {
width: embed.attributes.width,
height: embed.attributes.height,
src: embed.attributes.url,
frameborder: '0',
allow: 'accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture',
allowfullscreen: true
}
});
}
}
Now when we put in a video, like https://www.youtube.com/watch?v=RrkL9e2w7gQ
, we'll get the following:
<iframe
width="560"
height="315"
src="https://www.youtube.com/embed/RrkL9e2w7gQ"
frameborder="0"
allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture"
allowfullscreen
></iframe>