136 lines
3.4 KiB
JavaScript
136 lines
3.4 KiB
JavaScript
import { createRouter, createWebHistory } from 'vue-router';
|
|
import Layout from '../shared/components/layout/Layout.vue';
|
|
import HomePage from '../domain/manga/presentation/pages/HomePage.vue';
|
|
|
|
// Placeholder component for new routes
|
|
const PlaceholderComponent = {
|
|
props: {
|
|
title: {
|
|
type: String,
|
|
required: true
|
|
}
|
|
},
|
|
template: `
|
|
<div class="container mx-auto px-4 py-8">
|
|
<h1 class="text-2xl font-bold mb-4">{{ title }}</h1>
|
|
<p class="text-gray-600">Cette fonctionnalité sera bientôt disponible.</p>
|
|
</div>
|
|
`
|
|
};
|
|
|
|
const routes = [
|
|
{
|
|
path: '/',
|
|
component: Layout,
|
|
children: [
|
|
{
|
|
path: '',
|
|
name: 'home',
|
|
component: HomePage
|
|
},
|
|
{
|
|
path: '/manga/:id',
|
|
name: 'manga-details',
|
|
component: () => import('../domain/manga/presentation/pages/MangaDetails.vue')
|
|
},
|
|
{
|
|
path: '/add',
|
|
name: 'add-manga',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Ajouter un manga' }
|
|
},
|
|
{
|
|
path: '/reader/:chapterId',
|
|
name: 'reader',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Lecteur' }
|
|
},
|
|
// Pages placeholder avec chargement différé
|
|
{
|
|
path: '/import',
|
|
name: 'import',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Import de bibliothèque' }
|
|
},
|
|
{
|
|
path: '/discover',
|
|
name: 'discover',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Découvrir' }
|
|
},
|
|
{
|
|
path: '/convert',
|
|
name: 'convert',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Convertir CBR en CBZ' }
|
|
},
|
|
{
|
|
path: '/calendar',
|
|
name: 'calendar',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Calendrier' }
|
|
},
|
|
{
|
|
path: '/activity',
|
|
name: 'activity',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Activité' }
|
|
},
|
|
// Paramètres
|
|
{
|
|
path: '/settings/general',
|
|
name: 'settings-general',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Paramètres généraux' }
|
|
},
|
|
{
|
|
path: '/settings/folders',
|
|
name: 'settings-folders',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Gestion des dossiers' }
|
|
},
|
|
{
|
|
path: '/settings/scrappers',
|
|
name: 'settings-scrappers',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Configuration des scrappers' }
|
|
},
|
|
{
|
|
path: '/settings/ui',
|
|
name: 'settings-ui',
|
|
component: PlaceholderComponent,
|
|
props: { title: "Paramètres de l'interface" }
|
|
},
|
|
// Système
|
|
{
|
|
path: '/system/status',
|
|
name: 'system-status',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Status du système' }
|
|
},
|
|
{
|
|
path: '/system/backup',
|
|
name: 'system-backup',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Sauvegarde' }
|
|
},
|
|
{
|
|
path: '/system/logs',
|
|
name: 'system-logs',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Journaux système' }
|
|
},
|
|
{
|
|
path: '/system/updates',
|
|
name: 'system-updates',
|
|
component: PlaceholderComponent,
|
|
props: { title: 'Mises à jour' }
|
|
}
|
|
]
|
|
}
|
|
];
|
|
|
|
export const router = createRouter({
|
|
history: createWebHistory('/vue/'),
|
|
routes
|
|
});
|