import '../css/app.css';

import axios from 'axios';
import { createInertiaApp, router } from '@inertiajs/vue3';
import {
    refreshPricingUpdateBanner,
    shouldRefreshPricingBannerFromResponse,
} from './composables/usePricingUpdateRefresh';
import { resolvePageComponent } from 'laravel-vite-plugin/inertia-helpers';
import type { DefineComponent } from 'vue';
import { createApp, h } from 'vue';
import { ZiggyVue } from 'ziggy-js';
import { initializeTheme } from './composables/useAppearance';
// Import Quasar & icon libraries
import { Quasar,  Dialog,Notify,Loading } from 'quasar'
import '@quasar/extras/material-icons/material-icons.css'
import '@quasar/extras/material-icons-outlined/material-icons-outlined.css'
import '@quasar/extras/material-icons-round/material-icons-round.css'
//immport material symbols
import '@quasar/extras/material-symbols-outlined/material-symbols-outlined.css'

// Import Quasar css
import 'quasar/src/css/index.sass';



const appName = import.meta.env.VITE_APP_NAME || 'Laravel';

axios.interceptors.response.use((response) => {
    if (shouldRefreshPricingBannerFromResponse(response)) {
        void refreshPricingUpdateBanner();
    }

    return response;
});

router.on('success', (event) => {
    const page = event.detail.page;
    const props = page.props as { pricingUpdate?: unknown; flash?: { refreshPricingUpdate?: boolean } };

    if (props.pricingUpdate) {
        return;
    }

    if (props.flash?.refreshPricingUpdate) {
        void refreshPricingUpdateBanner();
    }
});

createInertiaApp({
    title: (title) => (title ? `${title} - ${appName}` : appName),
    resolve: (name) => resolvePageComponent(`./pages/${name}.vue`, import.meta.glob<DefineComponent>('./pages/**/*.vue')),
    setup({ el, App, props, plugin }) {
        createApp({ render: () => h(App, props) })
            .use(plugin)
            .use(ZiggyVue)
            .use(Quasar, {
                plugins: {Dialog,Notify,Loading},
                config: {
                    brand: {
                        primary: '#000000',
                    }
                }
              })
            .mount(el);
    },
    progress: {
        color: '#4B5563',
    },
});

// This will set light / dark mode on page load...
initializeTheme();
