Mixonomer/src/js/PlaylistManager.js
2019-08-05 22:55:07 +01:00

87 lines
2.9 KiB
JavaScript

import React, { Component } from "react";
import { BrowserRouter as Router, Route, Link, Switch, Redirect} from "react-router-dom";
import Index from "./Index/Index.js";
import Playlists from "./Playlist/Playlists.js";
import PlaylistView from "./Playlist/PlaylistView.js";
import Settings from "./Settings/Settings.js";
import Admin from "./Admin/Admin.js";
import NotFound from "./Error/NotFound.js";
import showMessage from "./Toast.js"
const axios = require('axios');
class PlaylistManager extends Component {
constructor(props){
super(props);
this.state = {
type: null,
spotify_linked: null
}
}
componentDidMount() {
this.getUserInfo();
}
componentWillUnmount() {
this.userInfoCancelToken.cancel();
}
getUserInfo(){
this.userInfoCancelToken = axios.CancelToken.source();
var self = this;
axios.get('/api/user', {
cancelToken: this.userInfoCancelToken.token
})
.then((response) => {
self.setState({
type: response.data.type,
spotify_linked: response.data.spotify_linked
})
})
.catch((error) => {
showMessage(`error getting user info (${error.response.status})`);
});
}
render(){
return (
<Router>
<div className="card pad-12">
<table className="sidebar pad-3">
<tbody>
<tr><td><span><Link to="/app">home</Link></span></td></tr>
<tr><td><Link to="/app/playlists">playlists</Link></td></tr>
<tr><td><Link to="/app/settings">settings</Link></td></tr>
{ this.state.type == 'admin' && <tr><td><Link to="/app/admin">admin</Link></td></tr> }
<tr><td><a href="/auth/logout">logout</a></td></tr>
<tr><td><a href="https://sarsoo.xyz">sarsoo.xyz</a></td></tr>
</tbody>
</table>
<div className="pad-9">
<Switch>
<Route path="/app" exact component={Index} />
<Route path="/app/playlists" component={Playlists} />
<Route path="/app/settings" component={Settings} />
{ this.state.type == 'admin' && <Route path="/app/admin" component={Admin} /> }
<Route path='/app/playlist/:name' component={PlaylistView} />
<Route component={NotFound} />
</Switch>
</div>
</div>
<footer>
<a href="https://github.com/Sarsoo/spotify-web">view source code</a>
</footer>
</Router>
);
}
}
export default PlaylistManager;