Skip to content
Snippets Groups Projects
router.js 2.04 KiB
Newer Older
syuilo's avatar
:v:
syuilo committed
/**
 * Desktop App Router
 */

syuilo's avatar
syuilo committed
import * as riot from 'riot';
syuilo's avatar
:v:
syuilo committed
const route = require('page');
let page = null;

syuilo's avatar
syuilo committed
export default me => {
syuilo's avatar
syuilo committed
	route('/',                       index);
	route('/selectdrive',            selectDrive);
	route('/i/drive',                drive);
	route('/i/drive/folder/:folder', drive);
	route('/i/mentions',             mentions);
	route('/post::post',             post);
	route('/search::query',          search);
	route('/:user',                  user.bind(null, 'home'));
	route('/:user/graphs',           user.bind(null, 'graphs'));
	route('/:user/:post',            post);
	route('*',                       notFound);
syuilo's avatar
:v:
syuilo committed

	function index() {
		me ? home() : entrance();
	}

	function home() {
		mount(document.createElement('mk-home-page'));
	}

	function entrance() {
		mount(document.createElement('mk-entrance'));
		document.documentElement.setAttribute('data-page', 'entrance');
	}

	function mentions() {
		const el = document.createElement('mk-home-page');
		el.setAttribute('mode', 'mentions');
		mount(el);
	}

	function search(ctx) {
		const el = document.createElement('mk-search-page');
		el.setAttribute('query', ctx.params.query);
		mount(el);
	}

	function user(page, ctx) {
		const el = document.createElement('mk-user-page');
		el.setAttribute('user', ctx.params.user);
		el.setAttribute('page', page);
		mount(el);
	}

	function post(ctx) {
		const el = document.createElement('mk-post-page');
		el.setAttribute('post', ctx.params.post);
		mount(el);
	}

syuilo's avatar
syuilo committed
	function selectDrive() {
		mount(document.createElement('mk-selectdrive-page'));
	}

syuilo's avatar
syuilo committed
	function drive(ctx) {
		const el = document.createElement('mk-drive-page');
		if (ctx.params.folder) el.setAttribute('folder', ctx.params.folder);
		mount(el);
	}

syuilo's avatar
:v:
syuilo committed
	function notFound() {
		mount(document.createElement('mk-not-found'));
	}

	riot.mixin('page', {
		page: route
	});

	// EXEC
	route();
};

function mount(content) {
	document.documentElement.removeAttribute('data-page');
	if (page) page.unmount();
	const body = document.getElementById('app');
	page = riot.mount(body.appendChild(content))[0];
}