import React, { Component } from "react"; import { BrowserRouter as Router, Route, Link, Switch, Redirect} from "react-router-dom"; import Index from "./Index/Index.js"; import Maths from "./Maths/Maths.js"; import Playlists from "./Playlist/Playlists.js"; import PlaylistView from "./Playlist/View/View.js"; import Settings from "./Settings/Settings.js"; import Admin from "./Admin/Admin.js"; import NotFound from "./Error/NotFound.js"; import showMessage from "./Toast.js" import GlobalTheme from './Theme.js'; import { Typography } from '@material-ui/core'; import { ThemeProvider } from '@material-ui/core/styles'; import AppBar from '@material-ui/core/AppBar'; import Toolbar from '@material-ui/core/Toolbar'; import IconButton from '@material-ui/core/IconButton'; import MenuIcon from '@material-ui/icons/Menu'; import Drawer from '@material-ui/core/Drawer'; import List from '@material-ui/core/List'; import Divider from '@material-ui/core/Divider'; import ChevronLeftIcon from '@material-ui/icons/ChevronLeft'; import ListItem from '@material-ui/core/ListItem'; import ListItemIcon from '@material-ui/core/ListItemIcon'; import ListItemText from '@material-ui/core/ListItemText'; import HomeIcon from '@material-ui/icons/Home'; import { Build, PieChart, QueueMusic, ExitToApp, AccountCircle, KeyboardBackspace } from '@material-ui/icons' const axios = require('axios'); class MusicTools extends Component { constructor(props){ super(props); this.state = { type: null, spotify_linked: null, drawerOpen: false } this.setOpen = this.setOpen.bind(this); } 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})`); }); } setOpen(bool){ this.setState({ drawerOpen: bool }) } render(){ return (
this.setOpen(true)}> Music Tools
this.setOpen(false)}>
{ this.state.type == 'admin' && }
{ this.state.type == 'admin' && }
); } } export default MusicTools;