]> git.r.bdr.sh - rbdr/forum/blobdiff - app/forum.svelte
Add internationalized error block
[rbdr/forum] / app / forum.svelte
index d944d8e7b5c7aa65f82dd0d2e0ced4f4f7684d66..d83438d9766056c9e893100735dccc2331a0edd0 100644 (file)
@@ -1,10 +1,61 @@
 <script>
+  import LightRouter from 'lightrouter';
+
+  // Initialize localization
+
+  import './config/i18n';
+
+  // Global components
+
   import ForumList from './components/forum_list/forum_list.svelte';
   import Header from './components/header/header.svelte';
+
+  // Routed Components
+  import Author from './components/author/author.svelte';
+  import Home from './components/home/home.svelte';
+  import InvalidRoute from './components/invalid_route/invalid_route.svelte';
+  import Post from './components/post/post.svelte';
   import Topic from './components/topic/topic.svelte';
+  import TopicIndex from './components/topic_index/topic_index.svelte';
+
+  let page;
+  let params;
+
+  // sets the route params and current page.
+
+  const setRoute = function setRoute(targetPage) {
+
+    return function (routerParams) {
+
+      params = routerParams;
+      page = targetPage;
+    };
+  };
+
+  const router = new LightRouter({
+    routes: {
+      '': () => (page = Home) && true,
+      'f/{id}': setRoute(TopicIndex),
+      'g/{id}': setRoute(TopicIndex),
+      'a/{id}': setRoute(Author),
+      't/{id}': setRoute(Topic),
+      'p/{id}': setRoute(Post),
+      '.*': setRoute(InvalidRoute)
+    }
+  });
+
+  router.run();
 
 </script>
 
 <Header />
-<Topic />
+<main>
+  <svelte:component this={ page } params={ params } />
+</main>
 <ForumList />
+
+<style>
+  main {
+    grid-column: col-start 2 / span 11;
+  }
+</style>