Search code examples
tailwind-cssinertiajslaravel-10flowbite

Flowbite is not working with inertia Laravel App


I am currently using Laravel version 10 along with Vite, Tailwind, and Inertia.js for my project. Previously, when I was not using Inertia.js, I was able to install and use Flowbite in my project by using the command "npm install flowbite" and importing it with the statement "import 'flowbite';" in my app.js file. However, I have encountered an issue where Flowbite is not working anymore since I started using Inertia.js in Laravel.

Could you please assist me in resolving this issue?

Here is my App.js code:

`import './bootstrap';
import '../css/app.css';

import { createApp, h } from 'vue';
import { createInertiaApp } from '@inertiajs/vue3';
import { resolvePageComponent } from 'laravel-vite-plugin/inertia-helpers';
import { ZiggyVue } from '../../vendor/tightenco/ziggy/dist/vue.m';
import 'flowbite';
const appName = window.document.getElementsByTagName('title')[0]?.innerText || 'Laravel';

createInertiaApp({
    title: (title) => `${title} - ${appName}`,
    resolve: (name) => resolvePageComponent(`./Pages/${name}.vue`, import.meta.glob('./Pages/**/*.vue')),
    setup({ el, App, props, plugin }) {
        return createApp({ render: () => h(App, props) })
            .use(plugin)
            .use(ZiggyVue, Ziggy)
            .mount(el);
    },
    progress: {
        color: '#4B5563',
    },
});

` even its not working if i try to add cdn links in app.blade.php

`<!DOCTYPE html>
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1">

        <title inertia>{{ config('app.name', 'Bathinda Chemicals') }}</title>

        <!-- Fonts -->
        <link rel="preconnect" href="https://fonts.bunny.net">
        <link href="https://fonts.bunny.net/css?family=figtree:400,500,600&display=swap" rel="stylesheet" />
        <link href="https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;500;600;700&display=swap" rel="stylesheet">
        <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"/>
        <!-- Scripts -->
        @routes
        @vite('resources/js/app.js')

        @inertiaHead
        <link rel="stylesheet" href="https://unpkg.com/[email protected]/dist/flowbite.min.css" />

    </head>
    {{-- <body class="font-sans antialiased">

    </body> --}}
    <body class="m-0 font-sans antialiased font-normal dark:bg-slate-900 text-base leading-default bg-gray-50 text-slate-500">

        <div class="absolute w-full bg-indigo-500 dark:hidden h-80"></div>
        <div class="min-h-screen bg-gray-100">
            @inertia
            <script src="https://unpkg.com/[email protected]/dist/flowbite.js"></script>

        </div>
    </body>
</html>

`

I tried Adding This code too..

`module.exports = {
    content: [
      "./resources/**/*.blade.php",
      "./resources/**/*.js",
      "./resources/**/*.vue",
      "./node_modules/flowbite/**/*.js"
    ],
    theme: {
      extend: {},
    },
    plugins: [
        require('flowbite/plugin')
    ],
  }`

Solution

  • I came across this issue before and in my case, I had to initialize Flowbite in the Vue file with one of the lifecycle methods.

    Try this in your Vue file:

    <script>
    import { initFlowbite } from "flowbite";
    
    export default {
    
        mounted() {
            initFlowbite(); // Initialize Flowbite on mount of the Vue component
        },
    }
    </script>
    

    With this, all of the Flowbite components will be you use will be initialized. In my case, I used Popovers and it didn't work until I used the initFlowbite() function.

    You can read more about it here.

    Also, the above example I provided was with Vue's Options API. If you're using the Composition API it can be done like this:

    <script setup>
    import { onMounted } from 'vue'
    import { initFlowbite } from 'flowbite'
    
    // initialize components based on data attribute selectors
    onMounted(() => {
        initFlowbite();
    })
    </script>
    

    Hope this helps!