litstack/meta

v2.0.6 2022-02-24 10:36 UTC

This package is auto-updated.

Last update: 2024-04-24 14:57:57 UTC


README

Edit default meta-fields inside your crud-models and forms and receive them in your blade templates.

Installation

The package can be installed via composer and will autoregister.

composer require litstack/meta

You can now publish and migrate the migration for your meta model:

php artisan vendor:publish --provider="Litstack\Meta\MetaServiceProvider" --tag=migrations
php artisan migrate

Usage

Start by perparing your Crud-Model by using the HasMeta Trait and implement the metaable Contract:

use Litstack\Meta\Metaable;
use Litstack\Meta\Traits\HasMeta;

class Post extends Model implements Metaable
{
    use HasMeta;
}

In order to display the form in litstack edit your model-config:

public function show() 
{
    $page->card(function($form) {
        $form->seo();
    });
}
        

To display the meta-fields in your template, simply use the <x-lit-meta /> component and pass it the metaFields of your model.

@extends('app')

@section('meta')
    <x-lit-meta :for="$post" />
@endsection

And in your main template:

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    @yield('meta')
</head>

Default Values / Customizing / Overriding

If you want to use meta attributes directly from model attributes you can specify them in metaAttributes in your config. You may as well override the meta methods like metaAuthor to return dynamic meta attributes:

class Post extends Model implements Metaable
{
    use HasMeta;

    protected $metaAttributes = [
        'author' => 'author.name',
        'image'  => 'header_image',
    ];

    public function getHeaderImageAttribute()
    {
        // ...
    }

    public function metaTitle(): ?string
    {
        // Return a prefix:
        return "Awesome Blog: " . parent::metaTitle();
    }
}

You may set default attributes by setting defaultMetaAttributes or add a method defaultMeta... method:

class Post extends Model implements Metaable
{
    use HasMeta;

    protected $defaultMetaAttribute = [
        'description' => 'description',
    ];

    public function defaultMetaTitle()
    {

    }
}