Can't use svg in TextColumn

What I want to achive is a column which shows an icon and when you click on it, a defined text is copied to the clipboard. The problem is, that the IconColumn has no copyable method, so I tried to use the TextColumn:
TextColumn::make("copy_column")
->getStateUsing("Copy")
->copyable()
->copyableState(fn($record) => $record->id)
TextColumn::make("copy_column")
->getStateUsing("Copy")
->copyable()
->copyableState(fn($record) => $record->id)
this works as expected and it shows the text "Copy". Now I tried to use an icon:
TextColumn::make("copy_column")
->getStateUsing(function() {
return new HtmlString(
'<svg style="width: 20px; height: 20px;" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" d="M8 5H6a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2v-1M8 5a2 2 0 002 2h2a2 2 0 002-2M8 5a2 2 0 012-2h2a2 2 0 012 2m0 0h2a2 2 0 012 2v3m2 4H10m0 0l3-3m-3 3l3 3"></path>
</svg>');
})
->html()
->copyable()
->copyableState(fn($record) => $record->id)
TextColumn::make("copy_column")
->getStateUsing(function() {
return new HtmlString(
'<svg style="width: 20px; height: 20px;" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" d="M8 5H6a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2v-1M8 5a2 2 0 002 2h2a2 2 0 002-2M8 5a2 2 0 012-2h2a2 2 0 012 2m0 0h2a2 2 0 012 2v3m2 4H10m0 0l3-3m-3 3l3 3"></path>
</svg>');
})
->html()
->copyable()
->copyableState(fn($record) => $record->id)
but the column is empty. Any ideas?
Solution:
ugly, but maybe this works ```php ->icon('heroicon-o-clipboard') ->getStateUsing(fn () => '<span></span>') ->html()...
Jump to solution
23 Replies
bernhard
bernhard5mo ago
Btw. using an (base64) image works:
TextColumn::make("copy_column")
->getStateUsing(function() {
return new HtmlString(
'<img src="">');
})
->html()
->copyable()
->copyableState(fn($record) => $record->id)
TextColumn::make("copy_column")
->getStateUsing(function() {
return new HtmlString(
'<img src="">');
})
->html()
->copyable()
->copyableState(fn($record) => $record->id)
LeandroFerreira
LeandroFerreira5mo ago
->formatStateUsing(fn () => new HtmlString(Blade::render('<x-heroicon-o-clipboard class="w-5 h-5"/>')))
->formatStateUsing(fn () => new HtmlString(Blade::render('<x-heroicon-o-clipboard class="w-5 h-5"/>')))
bernhard
bernhard5mo ago
Tried that as well, not working.
bernhard
bernhard5mo ago
Funny thing is, that the cell is empty
No description
bernhard
bernhard5mo ago
Using Blade:render and just plain return new HtmlString( '<svg style="width: 20px;...
bernhard
bernhard5mo ago
while using <img> it works
No description
Tim van Heugten
Tim van Heugten5mo ago
How about when you make it a custom icon as explained here: https://filamentphp.com/docs/3.x/support/icons
Tim van Heugten
Tim van Heugten5mo ago
Good idea for reusability anyway
bernhard
bernhard5mo ago
Why? The heroicon-o-clipboard is just fine, I don't need a custom icon.
Tim van Heugten
Tim van Heugten5mo ago
Oh sorry, thought you were looking for a custom icon.
LeandroFerreira
LeandroFerreira5mo ago
share the whole code please
awcodes
awcodes5mo ago
Html runs through symfony/html-sanitizer, it might be that svg isn’t an allowed tag.
bernhard
bernhard5mo ago
The whole code is just
TextColumn::make("copy_column")
->getStateUsing(function() {
return new HtmlString(
'<img src="">');
})
->html()
->copyable()
->copyableState(fn($record) => $record->id)
TextColumn::make("copy_column")
->getStateUsing(function() {
return new HtmlString(
'<img src="">');
})
->html()
->copyable()
->copyableState(fn($record) => $record->id)
Or not working:
TextColumn::make("copy_column")
->formatStateUsing(fn () => new HtmlString(Blade::render('<x-heroicon-o-clipboard class="w-5 h-5"/>')))
->html()
->copyable()
->copyableState(fn($record) => $record->id)
TextColumn::make("copy_column")
->formatStateUsing(fn () => new HtmlString(Blade::render('<x-heroicon-o-clipboard class="w-5 h-5"/>')))
->html()
->copyable()
->copyableState(fn($record) => $record->id)
The problem is, that it seems that svg is somehow parsed out everything else works
awcodes
awcodes5mo ago
See my message
bernhard
bernhard5mo ago
Oh. That miight be the problem 😮
LeandroFerreira
LeandroFerreira5mo ago
ahh, use getStateUsing instead of formatStateUsing probably copy_column isnt a column..
bernhard
bernhard5mo ago
Tried both Thats right, but thats irrelevant, since all other versions are working, including regular text, html and even images. @awcodes is right. SVG gets parsed out. Will make a PR to add copyable to IconColumn ;). Thanks all for your time!
awcodes
awcodes5mo ago
You could possibly bind to the HtmlSanitizerInterface and modify the settings too. Currently it’s using ->allowSafeElements() and svg isn’t considered a safe element since it’s technically executable markup outside of a code block.
Solution
LeandroFerreira
LeandroFerreira5mo ago
ugly, but maybe this works
->icon('heroicon-o-clipboard')
->getStateUsing(fn () => '<span></span>')
->html()
->icon('heroicon-o-clipboard')
->getStateUsing(fn () => '<span></span>')
->html()
bernhard
bernhard5mo ago
This works. Thanks! Didn't know there was an icon method on the TextColumn 😄
LeandroFerreira
LeandroFerreira5mo ago
yes, there is.. But it is joining with the state, and I had thought you didn't want this.
bernhard
bernhard5mo ago
In my case, this doesn't matter, since i dont need the state at all, since I get the state for the clipboard by myself copyableState. Thank you very much
LeandroFerreira
LeandroFerreira5mo ago
nice, because I didn't like this ->getStateUsing(fn () => '<span></span>') 😅