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')
],
}`
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!