am2studio / laravel-seo-meta
Laravel seo meta
Installs: 6 310
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 7
Forks: 1
Open Issues: 0
Requires
- php: >=5.4.0
- laravel/framework: 5.*
This package is not auto-updated.
Last update: 2024-11-14 14:05:57 UTC
README
Package for handling seo meta tags in Laravel apps
Install
Via Composer
$ composer require am2studio/laravel-seo-meta
Usage
First run migration for this package (src/migration/):
Schema::create('seo_metas', function (Blueprint $table) {
$table->increments('id');
$table->string('model_type');
$table->integer('model_id')->unsigned();
$table->text('key');
$table->text('value');
$table->timestamps();
});
For each model which that use seo meta add trait "SeoMetaTrait" and implement interface "SeoMetaInterface"
use AM2Studio\Laravel\SeoMeta\SeoMetaTrait;
use AM2Studio\Laravel\SeoMeta\SeoMetaInterface;
class User implements SeoMetaInterface
{
use SeoMetaTrait;
Interface "SeoMetaInterface" have 2 function that model need to implement "seoMetasConfig()" and "seoMetas()"
seoMetasConfig() is configuration for meta data for model
seoMetas() is "hasMany" relation to seoMetas of model
public function seoMetasConfig()
{
return [
'title' => ['generator' => 'example.com - '. $this->title],
'description' => ['generator' => 'green-rush.com - '. $this->title . ' - ' . $this->short_description,],
'keywords' => ['generator' => 'greenrush, product, ' . $this->title . ', ' . $this->short_description,
'edit'=> false],
'og:image' => ['generator' => ["http://i.stack.imgur.com/hEobN.jpg", "http://i.stack.imgur.com/hEobN2.jpg"]],
'twitter:site' => [],
];
}
public function seoMetas()
{
return $this->hasMany(SeoMeta::class, 'model_id')->where(['model_type' => __CLASS__]);
}
Each seo meta that you want model to use must be fefined here. List of possible seo meta tags:
title -> string
description -> string
keywords -> string
canonical -> string
article:published_time -> string
article:section -> string
og:description -> string
og:title -> string
og:url -> string
og:type -> string
og:locale -> string
og:locale:alternate -> array
og:site_name -> string
og:image -> array
og:image:url -> array
og:image:size -> string
twitter:card -> string
twitter:title -> string
twitter:site -> string
For each seo meta in config you define generator(how seo meta will be generated) and edit (if seo meta can be edited or will be always generated on model save, default - true)
Finaly add "seoMeta" to Model -> fillable
protected $fillable = [
...
'seoMeta'
];
Show form for meta seo deta on model:
{!! \AM2Studio\Laravel\SeoMeta\SeoMetaHelper::form($product) !!}
Set data in controller:
public function __construct()
{
parent::__construct();
SeoMetaHelper::setSeoMeta(['title' => 'Default title __construct .']);
}
public function index()
{
SeoMetaHelper::setSeoMeta(['description' => 'Default description index .']);
return $this->view('index');
}
public function show($product)
{
SeoMetaHelper::setSeoMeta($product->getSeoMeta());
return $this->view('show', compact('product'));
}
Show meta in view :
{{
\AM2Studio\Laravel\SeoMeta\SeoMetaHelper::render([
//alternative data if is not set anywhere
'keywords' => 'example.com -> frontend layout'
])
}}
Change log
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING and CONDUCT for details.
License
The MIT License (MIT). Please see License File for more information.