My projects

Blade Component Scopes

Scope attributes to specific elements within your Blade components.

Blade Component Scopes's cover image View the project

This package allows you to scope attributes to specific elements within your Blade components.

Installation

Requires php 8.2+ and Laravel 10+

First, install Blade Component Scopes via [composer](https://getcomposer.org/):

composer require abdelhamiderrahmouni/blade-component-scopes

Usage

This package adds a scope() macro to Laravel's ComponentAttributeBag,

allowing you to namespace your component attributes for different elements of your component.

Basic Example

<x-forms.input name="first_name"
               :label="__('Hello')"
               label:class="flex flex-col"
               label:for="#name-input"
               input:id="name-input"
               container:id="name-input-container" />

In your component view, access scoped attributes using the scope() method:

// forms.input.blade.php
<div {{ $attributes->scope('container')->merge(['class' => 'flex gap-y-2']) }}>
    @if($label)
        <label {{ $attributes->scope('label')->merge(['class' => 'text-gray-500']) }}>
            {{ $label }}
        </label>
    @endif
    <input {{ $attributes->scope('input')->merge(['class' => 'border-b']) }} />
</div>

How It Works

The scope() method filters attributes based on the prefix. For example:

- The label's class in label:class="font-bold" becomes available when using $attributes->scope('label')

- The input's ID in input:id="first-name-input" becomes available when using $attributes->scope('input')

- The container's class in container:class="mt-4" becomes available when using $attributes->scope('container')

This allows you to:

1. Organize attributes for different elements/parts of your component

2. Create more intuitive component interfaces

3. Maintain cleaner component templates

Benefits

- 🎯 Better organization of component attributes

- 🔍 More explicit attribute targeting

- 🧩 Cleaner components with less clutter

- 💪 Fully compatible with Laravel's existing attribute merging

> If you want to benifit from the scope method in your Blade views without installing this package, here is the magic sauce:

Add the following code to your AppServiceProvider:

// AppServiceProvider.php
use Illuminate\View\ComponentAttributeBag;
public function register(): void
{
    ComponentAttributeBag::macro('scope', function (string $scope): ComponentAttributeBag {
        $prefix = $scope . ':';
        $prefixLength = strlen($prefix);
        $scopedAttributes = [];
        foreach ($this->getAttributes() as $key => $value) {
            if (str_starts_with($key, $prefix)) {
                $scopedAttributes[substr($key, $prefixLength)] = $value;
            }
        }
        return new ComponentAttributeBag($scopedAttributes);
    });
}

Blade Component Scopes is an open-sourced software licensed under the MIT license

View the project

Start your project journey with me today!

I'm a software developer, I love building web applications and solve problems. I'm always looking for new challenges and opportunities to learn and grow.

Book a meet

Let's start your project journey together.

You can contact me anytime on

©2025 Errahmouni Space, All rights reserved.