aerni/paparazzi

Generate images of your entries and terms

dev-main 2024-05-20 17:05 UTC

This package is auto-updated.

Last update: 2025-01-20 18:35:22 UTC


README

Statamic Packagist version Packagist Total Downloads

Paparazzi

This addon provides an easy-to-use interface to generate images of your entries and terms. A common use case would be to generate social images for Open Graph and Twitter.

Prerequisite

Paparazzi uses Browsershot to generate the images and requires a working installation of Puppeteer on your server and local machine.

Installation

Install the addon using Composer:

composer require aerni/paparazzi

The config will be automatically published to config/paparazzi.php as part of the installation process.

Configuring Models

The first thing you should do is to configure your models in config/paparazzi.php. You can add as many models as you like. The only requirement for a model is the width and height. All other configuration options are passed down from the defaults array. You may override any default value by setting it on the model itself.

'models' => [

    'open_graph' => [
        'width' => 1200,
        'height' => 630,
    ],

    'instagram_post' => [
        'width' => 1080,
        'height' => 1080,
        'extension' => 'jpeg',
        'quality' => 80,
        'container' => 'instagram',
    ],

],

Layouts & Templates

Next, you should create your first layout and templates for your models. Use the following commands to do so:

The views will be saved to resources/views/paparazzi. If you'd like to use another path, you can change it in the config.

Working with models

A model will be created for each template that exists for a given model. The ID of a model will constructed from the model's handle and its template. Let's say you have an open_graph model with a default, article, and video template. This would result in three models with IDs of open_graph::default, open_graph::article, and open_graph::video.

Use the Model facade to get a model by its ID:

use Aerni\Paparazzi\Facades\Model;

Model::find('open_graph::default');

Alternatively, you can use the model's handle as the method and pass the template as an argument:

Model::openGraph('default');

If you don't pass the template as an argument, you will get the model with the default template as defined in the config('paparazzi.defaults.template'). If you don't have a template with that name, it will return the first model it can find.

Model::openGraph();

You can also get all the models at once:

Model::all();

Or only a selection of models:

Model::all(['open_graph::defaults', 'twitter::article']);

Or get all the models of a specific type:

Model::allOfType('open_graph');

Generating an image

Now you can simply call the generate() method on the model:

Model::openGraph()->generate();

Or generate the image in the background by dispatching a job:

Model::openGraph()->dispatch();

If you want the data of an entry or term available in the template, you can add the entry/term with the content() method:

Model::openGraph()->content($entry)->generate();

Generate the images of all models with the content of an entry.

Model::all()->each->content($entry)->generate();

You can also pass a callback to the generate or dispatch method to configure the browsershot instance.

Model::twitter()->generate(fn ($browsershot) => $browsershot->fullPage());

Asset management

The generated images will be saved as a Statamic asset. The asset container, directory, and file reference can be changed in the config.

Variables

You may use a couple of variables to customize the directory and file reference.

File Reference

The reference is used to get the generated images that belong to a model.

'directory' => '{type}/{parent}/{site}/{slug}',
'reference' => '{model}-{layout}-{template}-{parent}-{site}-{slug}',

Previewing Templates

You may preview your templates in the browser according to the following URL schema. The preview is only available in local environment.

// Schema
/{preview_url}/{model}

// Example
/paparazzi/open_graph

This will return the default template of the open_graph model. To show a different model, provide the full ID instead:

/paparazzi/open_graph::article

You may also change the layout that is used with the layout parameter:

/paparazzi/open_graph::article?layout=secondary

To add the content of an entry or term to the rendered template, add the content query parameter containing the entry's or term's ID.

// Entry ID
/paparazzi/open_graph::article&content=c3d19675-c7b8-49c5-84eb-9c5eb9713644

// Term ID
/paparazzi/open_graph::article&content=cars::audi

Use the optional site parameter to get the entry or term in a specific localization.

/paparazzi/open_graph::article&content=c3d19675-c7b8-49c5-84eb-9c5eb9713644?site=german

Live Preview

Add a model to the Live Preview of all collections:

public function handle(EntryBlueprintFound $event)
{
    Model::openGraph()->addLivePreviewToCollection();
}

Add a model to the Live Preview of a specific collection:

public function handle(EntryBlueprintFound $event)
{
    Model::openGraph()->addLivePreviewToCollection('pages');
}

Add a model to the Live Preview of multiple selected collection:

public function handle(EntryBlueprintFound $event)
{
    Model::openGraph()->addLivePreviewToCollection(['pages', 'articles']);
}

Add a model to the Live Preview of all taxonomies:

public function handle(EntryBlueprintFound $event)
{
    Model::openGraph()->addLivePreviewToTaxonomy();
}

Add a model to the Live Preview of a specific taxonomy:

public function handle(EntryBlueprintFound $event)
{
    Model::openGraph()->addLivePreviewToTaxonomy('categories');
}

Add a model to the Live Preview of multiple selected taxonomies:

public function handle(EntryBlueprintFound $event)
{
    Model::openGraph()->addLivePreviewToTaxonomy(['categories', 'tags']);
}

You can also add a model to collections and taxonomies at the same time:

public function handle(TermBlueprintFound $event)
{
    Model::openGraph()
        ->addLivePreviewToCollection(['pages', 'articles']);
        ->addLivePreviewToTaxonomy('tags');
}

License

Paparazzi is free to use software but may not be reused in other projects without the express written consent of Michael Aerni.

Credits

Developed by Michael Aerni