Skip to content
Snippets Groups Projects
index.js 1.26 KiB
Newer Older
import m from 'mithril';
Hermann's avatar
Hermann committed
import LoginScreen from './login';
import TableView from './views/tableView';
Hermann's avatar
Hermann committed
import { UserModal, UserTable, NewUser } from './userTool';
Hermann's avatar
Hermann committed
import { MembershipView } from './membershipTool';
Hermann's avatar
Hermann committed
import { EventTable, NewEvent, EventModal } from './eventTool';
import Sidebar from './sidebar';
import AnnounceTool from './announceTool';
import style from './style';

const main = document.createElement('div');
document.body.appendChild(main);
const root = main;


class Layout {
  view(vnode) {
    return m('div.wrapper-main.smooth', [
      m(Sidebar),
      m('div.wrapper-content', vnode.children),
    ]);
  }
}

function layoutWith(view) {
  return {
    view() {
      return m(Layout, m(view));
    },
  };
}

m.route(root, '/users', {
  '/users': layoutWith(UserTable),
  '/users/:id': layoutWith(UserModal),
Hermann's avatar
Hermann committed
  '/newuser': layoutWith(NewUser),
Hermann's avatar
Hermann committed
  '/groupmemberships/:id': layoutWith(MembershipView),
Hermann's avatar
Hermann committed
  '/events': layoutWith(EventTable),
  '/events/:id': layoutWith(EventModal),
Hermann's avatar
Hermann committed
  '/newevent': layoutWith(NewEvent),
  '/groups': layoutWith({
    view() {
      return m(TableView, {
        resource: 'groups',
        keys: ['name'],
      });
    },
  '/login': LoginScreen,
  '/announce': layoutWith(AnnounceTool),


//m.mount(root, layoutWith(userlist));