Hire Me! I'm currently looking for my next role in developer relations and advocacy. If you've got an open role and think I'd be a fit, please reach out. You can also find me on LinkedIn.

I've covered in the past how to use the Adobe PDF Embed API with Eleventy ("Using PDFs with the Jamstack"). While the Embed API is relatively simple to add to a page, I thought it would be kind of fun to build an Eleventy plugin to make it simpler. Last week, I released it: https://www.npmjs.com/package/eleventy-plugin-pdfembed.

To use it, first add the plugin via npm to your Eleventy project:

npm i eleventy-plugin-pdfembed

Then, in your .eleventy.js file, require it and add it:

const pluginPDFEmbed = require('eleventy-plugin-pdfembed');

module.exports = (eleventyConfig) => {

	// more stuff here

	eleventyConfig.addPlugin(pluginPDFEmbed, {
		key: '<YOUR CREDENTIAL KEY>'
	});

}

To use it you'll need to get your credentials first, which are free. Also keep in mind that your credentials are host based, so most likely you'll want to use an environment variable for it.

Once done, you can then use the shortcode. It takes an argument for the URL at minimum, but you can also specify the viewing mode. Here's a simple example:

{% pdfembed 'https://documentcloud.adobe.com/view-sdk-demo/PDFs/Bodea Brochure.pdf' %}

The plugin takes a second argument for viewing mode which is best demonstrated at our online demo. Finally, a third argument lets you rename the default ID value used for the div that renders the PDF. This defaults to adobe-pdf-view if you want to tweak the size via CSS.

Anyway, let me know if this helps!