Package Data | |
---|---|
Maintainer Username: | msamec |
Maintainer Contact: | filip.horvat@am2studio.hr (Filip Horvat) |
Package Create Date: | 2016-02-22 |
Package Last Update: | 2018-12-04 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-12-19 03:01:45 |
Package Statistics | |
---|---|
Total Downloads: | 6,310 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 3 |
Total Watchers: | 7 |
Total Forks: | 1 |
Total Open Issues: | 0 |
Package for handling seo meta tags in Laravel apps
Via Composer
$ composer require am2studio/laravel-seo-meta
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'
])
}}
Please see CHANGELOG for more information what has changed recently.
Please see CONTRIBUTING and CONDUCT for details.
The MIT License (MIT). Please see License File for more information.