Git Product home page Git Product logo

laravel-blade-anchor's Introduction

Laravel Blade Anchor ⚓

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

Easily enable extending your application's user interface by third-party packages with anchors.

Installation

You can install the package via composer:

composer require kanuni/laravel-blade-anchor

Usage

To allow third-party packages to extend your application's UI, you need to insert anchors into your Blade template files at the points where you want to permit these extensions.

Placing anchors to enable UI extensions

In your Blade file (e.g., resources/views/welcome.blade.php), you can add an anchor directive. For this example, let's create an anchor immediately after the opening <body> tag:

...
<body>
    @anchor('begin.body')
    ...
</body>

You can name the anchor anything you like. In this example, we've named it begin.body.

Creating an extender class

Once you've positioned your anchor, you can now register an extender class that will render a string or a Laravel View at that anchor point. Ideally, you should register your anchor extenders in the boot() method of your AppServiceProvider class.

But first, let's create a new anchor extender class using the Artisan command:

php artisan make:anchor-extender WelcomePageExtender

This command generates a new extender class in app/BladeExtenders/WelcomePageExtender.php. This class should implement the __invoke() method, whose return value will be rendered at the specified anchor point.

Here's an example of our newly created class:

namespace App\BladeExtenders;

use Illuminate\Contracts\Support\Renderable;
use Kanuni\LaravelBladeAnchor\Contracts\AnchorExtender;

class WelcomePageExtender implements AnchorExtender
{
    public function __invoke(?array $variables): string|Renderable|null
    {
        return '<p>This string will be injected at anchor point.</p>';
    }
}

The __invoke() method can return a string or a View and accepts an optional array of variables available in your Blade template. If returning a Blade view, you can pass the variables to your view like this:

public function __invoke(?array $variables): string|Renderable|null
{
    return view('my-custom-blade-view', $variables);
}

It's also possible to inject any dependency classes into your extender's __construct() method:

class WelcomePageExtender implements AnchorExtender
{
    public function __construct(
        protected YourService $service
    )
    {}

    public function __invoke(?array $variables): string|Renderable|null
    {
        return "<p>This are the results of your service: {$this->service->getResults()}</p>";
    }
}

Attaching the Extender to the Anchor

Register your Blade extender in the boot() method of app/Providers/AppServiceProvider class using LaravelBladeAnchor facade. To do this, call the registerExtender method and provide the view name, anchor name, and extender class.

use Kanuni\LaravelBladeAnchor\Facades\LaravelBladeAnchor;
use App\BladeExtenders\WelcomePageExtender;

public function boot(): void
{
    LaravelBladeAnchor::registerExtender(
        view: 'welcome',
        anchor: 'begin.body',
        extenderClass: WelcomePageExtender::class,
    );
}

As demonstrated, anchor names are unique within each view. This means you can have anchors with the same name across two different views without any conflict.

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Credits

License

The MIT License (MIT). Please see License File for more information.

laravel-blade-anchor's People

Contributors

tjodalv avatar

Stargazers

 avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.