Here, we will talk about how to create AMP blog pages in Middleman . If you are not familiar with AMP, I recommend reading this blog post in which I talk about what AMP is and why it is useful.
So you want to create AMP blogs in a static site generator? Well, first you start by selecting a static site generator - here I have chosen Middleman. While I work with Middleman, this can be effectively used in any Ruby-based static site generator.
It is definitely not recommended to have only AMP blog pages, a normal blog page should also be there for all the desktop viewers.
THE LAYOUT
So let’s create the AMP blog layout first,
So what is this? Here we give the basic layout for all the blog pages. Most of what is on this page is defined in the official AMP description.
In line 7, we give <%= partial "partials/ampmeta" %>
which gives us all the meta tags that are for that specific page, all the meta tags that are supported in normal HTML will be supported here.
In line 8 to 10, we add the styles to the CSS, as the styles should be inlined in AMP - we just add the stylesheet as a partial so that it adds here as an inline style.
Then some styles and scripts which are required by AMP, the social share and sidebar script are provided by the AMP Project to give us the social sharing and sidebar functionality without the use of external Javascript. Oh yeah, you can’t use any other Javascript other that the ones that are provided. This is the point where most of the developers shy away from Javascript, but we’ll move forward.
THE CONFIG
Let’s dive right in,
The fastimage
and nokogiri
gems are used for finding the size of the images, which we will talk about soon.
Then in line 4 and 5 we define the markdown engine which converts .md
files into HTML
, and then in line 7 we see the actual blog gem which helps us make the blog pages using our layout - more info on this can be found here .
Then we have a simple img
to amp-img
converting helper because sometime we inline image tags in our blog post and this can help with that.
THE MAGIC
And then we have some extra work,
In here, we use nokogiri
to select all the images and give them a definite height and width because AMP needs definite size values defined to them.
And then we substitute some image and i-frame tags with proper amp tags.
So there you have it, that was a brief intro on how to write AMP for Middleman, hope you found something useful in it and let me know @praveenjuge if you have something else to discuss.
Some related articles -
Subscribe to our newsletter
Get the latest updates from our team delivered directly to your inbox.
Related Posts
AMP - Showing you the Need for Speed on your websites
We finally got behind the hype of AMP and tried it out, here is what we learned.
Best Mac Apps for a Web Designer
Every Web Designer and Developer has a stash of their favourite, go-to apps. Hear from our Web Designer about his list, and you might even find your favourite in here!
How to create a landing page for your project in 30 minutes
Use this Gulp Nunjucks and NPM starter template to create your own landing page for hackathon in less than 30 minutes.