43 lines
1.3 KiB
TypeScript
43 lines
1.3 KiB
TypeScript
import { createInertiaApp } from '@inertiajs/vue3';
|
|
import { initializeTheme } from '@/composables/useAppearance';
|
|
import AppLayout from '@/layouts/AppLayout.vue';
|
|
import AuthLayout from '@/layouts/AuthLayout.vue';
|
|
import SettingsLayout from '@/layouts/settings/Layout.vue';
|
|
import { initializeFlashToast } from '@/lib/flashToast';
|
|
import { configureEcho } from '@laravel/echo-vue';
|
|
|
|
configureEcho({
|
|
broadcaster: 'reverb',
|
|
key: import.meta.env.VITE_REVERB_APP_KEY,
|
|
host: import.meta.env.VITE_REVERB_HOST,
|
|
port: import.meta.env.VITE_REVERB_PORT,
|
|
scheme: import.meta.env.VITE_REVERB_SCHEME,
|
|
});
|
|
|
|
const appName = import.meta.env.VITE_APP_NAME || 'Laravel';
|
|
|
|
createInertiaApp({
|
|
title: (title) => (title ? `${title} - ${appName}` : appName),
|
|
layout: (name) => {
|
|
switch (true) {
|
|
case name === 'Welcome':
|
|
return null;
|
|
case name.startsWith('auth/'):
|
|
return AuthLayout;
|
|
case name.startsWith('settings/'):
|
|
return [AppLayout, SettingsLayout];
|
|
default:
|
|
return AppLayout;
|
|
}
|
|
},
|
|
progress: {
|
|
color: '#4B5563',
|
|
},
|
|
});
|
|
|
|
// This will set light / dark mode on page load...
|
|
initializeTheme();
|
|
|
|
// This will listen for flash toast data from the server...
|
|
initializeFlashToast();
|