Laravel + Flowbite (ou tailwind) com blade components

Esse post nao é nenhum texto grande nao, só uma ideia pra quem estiver pesquisando no futuro.

Flowbite é uma lib de components em tailwind, mas nao possui classes proprias igual o DaisyUi por exemplo. Mas se tu nao quiser ficar enfiando a mesma linha tailwind em tudo, pra isso tu pode usar um component blade, segue abaixo como eu faço os meus

@props([
    'coloring' => 'primary',
    'href' => '#',
])

@php
    $colorClasses = [
        'primary' => "text-white bg-blue-700 hover:bg-blue-800 focus:ring-4 focus:ring-blue-300 font-medium rounded-lg text-sm px-5 py-2.5 me-2 mb-2 dark:bg-blue-600 dark:hover:bg-blue-700 focus:outline-none dark:focus:ring-blue-800",
        'alternative' => 'py-2.5 px-5 me-2 mb-2 text-sm font-medium text-gray-900 focus:outline-none bg-white rounded-lg border border-gray-200 hover:bg-gray-100 hover:text-blue-700 focus:z-10 focus:ring-4 focus:ring-gray-100 dark:focus:ring-gray-700 dark:bg-gray-800 dark:text-gray-400 dark:border-gray-600 dark:hover:text-white dark:hover:bg-gray-700',
        'dark' => "text-white bg-gray-800 hover:bg-gray-900 focus:outline-none focus:ring-4 focus:ring-gray-300 font-medium rounded-lg text-sm px-5 py-2.5 me-2 mb-2 dark:bg-gray-800 dark:hover:bg-gray-700 dark:focus:ring-gray-700 dark:border-gray-700",
        'light' => 'text-gray-900 bg-white border border-gray-300 focus:outline-none hover:bg-gray-100 focus:ring-4 focus:ring-gray-100 font-medium rounded-lg text-sm px-5 py-2.5 me-2 mb-2 dark:bg-gray-800 dark:text-white dark:border-gray-600 dark:hover:bg-gray-700 dark:hover:border-gray-600 dark:focus:ring-gray-700',
        'green' => 'focus:outline-none text-white bg-green-700 hover:bg-green-800 focus:ring-4 focus:ring-green-300 font-medium rounded-lg text-sm px-5 py-2.5 me-2 mb-2 dark:bg-green-600 dark:hover:bg-green-700 dark:focus:ring-green-800',
        'red' => 'focus:outline-none text-white bg-red-700 hover:bg-red-800 focus:ring-4 focus:ring-red-300 font-medium rounded-lg text-sm px-5 py-2.5 me-2 mb-2 dark:bg-red-600 dark:hover:bg-red-700 dark:focus:ring-red-900',
        'yellow' => 'focus:outline-none text-white bg-yellow-400 hover:bg-yellow-500 focus:ring-4 focus:ring-yellow-300 font-medium rounded-lg text-sm px-5 py-2.5 me-2 mb-2 dark:focus:ring-yellow-900',
        'purple' => 'focus:outline-none text-white bg-purple-700 hover:bg-purple-800 focus:ring-4 focus:ring-purple-300 font-medium rounded-lg text-sm px-5 py-2.5 mb-2 dark:bg-purple-600 dark:hover:bg-purple-700 dark:focus:ring-purple-900',
    ];

    $type = $colorClasses[$coloring];
@endphp

<button {{ $attributes->merge([
    "class" => "cursor-pointer $type",
    ]) }}

    onclick="window.location.href = '{{ $href }}';"
    >

    {{ $slot }}
</button>

A utilização deles fica bem simples:

<x-anchor-btn class="!font-bold uppercase" coloring="primary" href="/rent-a-space">
    Conheça nosso espaço.
</x-anchor-btn>

Eu trabalho com laravel, mais não trocaria o talwind, quanto menos lib você usar em projetos é melhor, não fica preso.

concordo, por isso a lib que eu uso basicamente te da os snippets em tailwind pra voce alterar como preferir, a melhor combinação entre nao precisar rescrever o mesmo bg-blue-600 em todo lugar mas tambem nao ficar preso ao btn btn-primary