-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcontent.js
More file actions
39 lines (35 loc) · 960 Bytes
/
content.js
File metadata and controls
39 lines (35 loc) · 960 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
'use strict';
import React, { Component } from 'react';
import DefaultContent from './default-content';
export default class Content extends Component {
constructor() {
super();
this.state = {
view: DefaultContent
};
}
componentDidMount() {
window.addEventListener('hashchange', (() => {
const routes = {
'#about'() {
require.ensure(['./split-content'], ((require) => {
const SplitContent = require('./split-content').default;
this.setState({ view: SplitContent });
}).bind(this));
},
default: this.setState.bind(this, { view: DefaultContent })
};
const action = routes[window.location.hash] || routes.default;
action.call(this);
}).bind(this), false);
}
render() {
return (
<div id="main">
<a href="#">home</a> : <a href="#about">about</a>
<hr />
<this.state.view />
</div>
);
}
}