Livewire Component passing variable to Blade Error
Hello! I have a livewire component called Announcement and this is the code
<?php
namespace App\Http\Livewire;
use Livewire\Component;
class Announcement extends Component
{
public $message = '';
public function render()
{
return view('livewire.announcement', [
'message' => 'This is a test announcement!'
]);
}
}
This is my blade file's code in /views/livewire/announcement.blade.php
<div>
<div>
<h1>Announcement</h1>
<h1>{{ $message }}</h1>
</div>
</div>
I tried a lot of things of why the error message "Undefined variable $message" is always showing but I can't seem to find what solution is applicable.data:image/s3,"s3://crabby-images/7e16f/7e16fbd7e3865117d5600f01676820d92805d58b" alt="No description"
Solution:Jump to solution
I got it working bro, the solution is I deleted the Announcement Class and its View file and created a new livewire component.
16 Replies
try it like this:
Still Undefined variable $message
🤔
I registered the livewire in the AppServiceProvider using this code FilamentView::registerRenderHook(
PanelsRenderHook::BODY_START,
fn (): View => view('livewire.announcement'),
);
Try like this
This is now the error:
data:image/s3,"s3://crabby-images/e79b7/e79b71722fb1675efb029786d0a921241bb612db" alt="No description"
Just check out and I don't have a problem, what I did
This is my code in AppServiceProvider
<?php
namespace App\Providers;
use Illuminate\Support\ServiceProvider;
use Filament\Support\Facades\FilamentView;
use Illuminate\Contracts\View\View;
use Filament\View\PanelsRenderHook;
use Illuminate\Support\Facades\Blade;
class AppServiceProvider extends ServiceProvider
{
/**
* Register any application services.
*/
public function register(): void
{
}
/**
* Bootstrap any application services.
*/
public function boot(): void
{
FilamentView::registerRenderHook(
PanelsRenderHook::GLOBAL_SEARCH_BEFORE,
fn (): View => view('livewire.clock'),
);
FilamentView::registerRenderHook(
PanelsRenderHook::BODY_START,
fn (): string => Blade::render('@livewire(\'announcement\')'),
);
}
}
And this is the latest error code
data:image/s3,"s3://crabby-images/01214/0121470e81212441981d2b6077ae0c356c7a0704" alt="No description"
what are the versions of filament and livewire?
"filament/filament": "^3.2.71",
"hasnayeen/themes": "^3.0",
"jeffgreco13/filament-breezy": "^2.3",
"laravel/framework": "^11.0",
"laravel/tinker": "^2.9",
"livewire/livewire": "^3.5",
@Pints ^^
data:image/s3,"s3://crabby-images/61869/6186966da331779a48515264bdc3148c3f5abe7c" alt="No description"
This is the current code,
data:image/s3,"s3://crabby-images/5b35c/5b35c753e1ee694cff6b71257be15a26162cef48" alt="No description"
data:image/s3,"s3://crabby-images/99ec9/99ec9171e7f1554bee8c1835c7d8bfeb5e71224b" alt="No description"
data:image/s3,"s3://crabby-images/7ad29/7ad29d08a5dbfa5d66eec62dbf3700918dd51d26" alt="No description"
no idea now
It's okay bro, gonna find it out soon, thanks btw
Solution
I got it working bro, the solution is I deleted the Announcement Class and its View file and created a new livewire component.