avassilenko / meta-resolver by crumby

Automatic canonical and hreflang output for Laravel 5.4
32
0
1
Package Data
Maintainer Username: crumby
Maintainer Contact: avassilenko2@gmail.com (Andrei Vassilenko)
Package Create Date: 2017-08-14
Package Last Update: 2017-09-26
Language: PHP
License: MIT License
Last Refreshed: 2024-04-26 03:05:10
Package Statistics
Total Downloads: 32
Monthly Downloads: 0
Daily Downloads: 0
Total Stars: 0
Total Watchers: 1
Total Forks: 0
Total Open Issues: 0

Installation:

> composer require crumby/meta-resolver
> php artisan vendor:publish --provider="Crumby\MetaResolver\MetaResolverServiceProvider" --tag=config

Register service and facade:

File: config/app.php

'providers' => [
    ......................
    'Crumby\MetaResolver\MetaResolverServiceProvider',
    ........................
 ];
 
 'aliases' => [ 
    ......................
    'MetaResolver' => 'Crumby\MetaResolver\Facades\MetaResolver',
    ......................
 ];

Create Resolver classes:

To fill Schema.org JSON-LD structure on your page you will need to create class which can extract data from current content. The class needs to implement interface Crumby\MetaResolver\Contracts\MetaResolver.php

<?php
namespace App\Resolvers;
use Crumby\MetaResolver\Contracts\MetaResolver as MetaResolver;

class CreativeWorkResolver implements MetaResolver {
    const IRI_FRAGMENT = '#creative';
    protected $service;
    public function __construct($service) {
        $this->service = $service;
    }
    
    public function type() {
        return 'CreativeWork';
    }
    
    public function hasPart() {
        return [
            "mainEntity" => [
                "author" => "Person" , 
                "publisher" => "Organization"
                ], 
            "breadcrumb" => "BreadcrumbList"
            ];
    }
    
    public function title() {
        return $this->service->title();
    }

    public function description() {
        return $this->service->description();
    }
    
    public function publishedAt() {
        return $this->service->content()->created_at->format('Y-m-d');
    }
    
    public function modifiedAt() {
        return $this->service->content()->updated_at->format('Y-m-d');
    }
    
    public function image() {
        return false;
    }
    
    public function url() {
        return $this->service->url();
    }
    
    public function iri() {
        return $this->url() . '/' . self::IRI_FRAGMENT;
    }
    
    public function schema($includeContext = true) {
        return [
            "@context" => "http://schema.org",
            "@type" => "WebPage",
            "url" => $this->url(),
            "isPartOf" => [
                "@type" => "WebSite",
                "@id" => \Request::root()
             ],
            "mainEntity" => [    
                "@type" => $this->type(),
                "@id" => $this->iri(),
                "mainEntityOfPage" => [
                    "@type" => "WebPage",
                    "@id" => $this->url(),
                ],
                "url" => $this->url(),
                "headline" => $this->title(),
                "description" => $this->description(),
                "dateCreated" => $this->publishedAt(),
                "dateModified" => $this->modifiedAt(),
            ],
        ];
    }
}

Configuration:

Map Schema.org type to resolver class: File config/meta-resolver.php

return [
        .........................
        'ContactPoint' => 'App\Resolvers\ContactPointResolver',
        'CreativeWork' => 'App\Resolvers\CreativeWorkResolver'
        ........................
];

Example:

Main method is \MetaResolver::addMeta().

  • add to your controller
    /**
     * Show the application dashboard.
     *
     * @return \Illuminate\Http\Response
     */
    public function article(ContentPackage $package, ContentItem $article) {
        \MetaResolver::addMeta(new CreativeWorkResolver($article), $article);
        $collection = new FrontPackages();
        return view('pages.package', ['collection' => $collection]);
    }
  • use in you Blade template {{ $MetaResolver }}