Mixonomer/src/js/Playlist/NewPlaylist.js

128 lines
4.1 KiB
JavaScript
Raw Normal View History

2019-07-31 20:31:01 +01:00
import React, { Component } from "react";
import { BrowserRouter as Redirect } from "react-router-dom";
2019-07-31 20:31:01 +01:00
const axios = require('axios');
2019-08-05 22:55:07 +01:00
import showMessage from "../Toast.js"
2019-07-31 20:31:01 +01:00
class NewPlaylist extends Component {
constructor(props) {
super(props);
this.state = {
name: '',
type: 'default',
description: ''
2019-07-31 20:31:01 +01:00
}
this.handleInputChange = this.handleInputChange.bind(this);
this.handleSubmit = this.handleSubmit.bind(this);
}
componentDidMount(){
this.setDescription('default');
}
setDescription(value){
switch(value){
case 'default':
this.setState({
description: 'Merge playlists as-is with deduplication by spotify id'
})
break;
case 'recents':
this.setState({
description: "Select songs from playlists which have been added since a variable number of days"
})
break;
}
}
2019-07-31 20:31:01 +01:00
handleInputChange(event){
this.setState({
[event.target.name]: event.target.value
});
this.setDescription(event.target.value);
2019-07-31 20:31:01 +01:00
}
handleSubmit(event){
var name = this.state.name;
this.setState({
name: ''
});
2019-08-07 16:22:31 +01:00
if(name.length != 0){
axios.get('/api/playlists')
.then((response) => {
2019-08-07 16:22:31 +01:00
var names = response.data.playlists.map(entry => entry.name)
var sameName = names.includes(this.state.name);
if(sameName == false){
axios.put('/api/playlist', {
name: name,
parts: [],
playlist_references: [],
shuffle: false,
type: this.state.type,
}).then((response) => {
showMessage(`${this.state.name} Created`);
}).catch((error) => {
showMessage(`Error Creating Playlist (${error.response.status})`);
});
}else{
showMessage('Named Playlist Already Exists');
}
})
.catch((error) => {
showMessage(`Error Getting Playlists (${error.response.status})`);
});
}else{
showMessage('Enter Name');
}
2019-07-31 20:31:01 +01:00
}
render(){
return (
<table className="app-table max-width">
2019-07-31 20:31:01 +01:00
<thead>
<tr>
<th colSpan="2">
<h1 className="ui-text center-text text-no-select">New Playlist</h1>
2019-07-31 20:31:01 +01:00
</th>
</tr>
</thead>
<tbody>
<tr>
<td>
<select className="full-width" name="type" onChange={this.handleInputChange}>
<option value="default">Default</option>
<option value="recents">Recents</option>
2019-07-31 20:31:01 +01:00
</select>
</td>
<td>
<input
className="full-width"
name="name"
type="text"
value={this.state.name}
onChange={this.handleInputChange}
placeholder="Name"/>
2019-07-31 20:31:01 +01:00
</td>
</tr>
<tr>
<td colSpan="2">
<input type="submit" className="button full-width" onClick={this.handleSubmit} value="Create" />
2019-07-31 20:31:01 +01:00
</td>
</tr>
<tr>
<td colSpan="2" className="ui-text text-no-select center-text">
<br></br>{this.state.description}
</td>
</tr>
2019-07-31 20:31:01 +01:00
</tbody>
</table>
);
}
}
export default NewPlaylist;