2018-01-05 22:59:25 +01:00
|
|
|
import React from 'react';
|
2018-01-10 20:26:01 +01:00
|
|
|
import {connect} from 'react-redux';
|
2018-01-11 20:41:12 +01:00
|
|
|
import {updateLoggedInChannel} from '../actions/index';
|
2018-01-10 03:49:26 +01:00
|
|
|
import { makeGetRequest, makePostRequest } from '../utils/xhr.js';
|
2018-01-10 20:26:01 +01:00
|
|
|
import { setUserCookies } from '../utils/cookies.js';
|
2018-01-12 19:21:40 +01:00
|
|
|
import { replaceChannelSelectionInNavBar } from '../utils/page.js';
|
2018-01-05 22:59:25 +01:00
|
|
|
|
|
|
|
class ChannelCreateForm extends React.Component {
|
|
|
|
constructor (props) {
|
|
|
|
super(props);
|
|
|
|
this.state = {
|
|
|
|
error : null,
|
2018-01-11 20:41:12 +01:00
|
|
|
channel : '',
|
|
|
|
password: '',
|
2018-01-05 22:59:25 +01:00
|
|
|
status : null,
|
|
|
|
};
|
2018-01-10 20:26:01 +01:00
|
|
|
this.cleanseChannelInput = this.cleanseChannelInput.bind(this);
|
2018-01-05 22:59:25 +01:00
|
|
|
this.handleChannelInput = this.handleChannelInput.bind(this);
|
|
|
|
this.handleInput = this.handleInput.bind(this);
|
2018-01-12 21:48:24 +01:00
|
|
|
this.updateIsChannelAvailable = this.updateIsChannelAvailable.bind(this);
|
|
|
|
this.checkIsChannelAvailable = this.checkIsChannelAvailable.bind(this);
|
|
|
|
this.checkIsPasswordProvided = this.checkIsPasswordProvided.bind(this);
|
2018-01-05 22:59:25 +01:00
|
|
|
this.createChannel = this.createChannel.bind(this);
|
|
|
|
}
|
2018-01-10 20:26:01 +01:00
|
|
|
cleanseChannelInput (input) {
|
|
|
|
input = input.replace(/\s+/g, '-'); // replace spaces with dashes
|
|
|
|
input = input.replace(/[^A-Za-z0-9-]/g, ''); // remove all characters that are not A-Z, a-z, 0-9, or '-'
|
|
|
|
return input;
|
|
|
|
}
|
2018-01-05 22:59:25 +01:00
|
|
|
handleChannelInput (event) {
|
|
|
|
event.preventDefault();
|
|
|
|
let value = event.target.value;
|
2018-01-10 20:26:01 +01:00
|
|
|
value = this.cleanseChannelInput(value);
|
|
|
|
this.setState({channel: value});
|
2018-01-12 21:48:24 +01:00
|
|
|
if (value) {
|
|
|
|
this.updateIsChannelAvailable(value);
|
|
|
|
} else {
|
|
|
|
this.setState({error: 'Please enter a channel name'});
|
|
|
|
}
|
|
|
|
console.log('end of handlechannelinput');
|
2018-01-05 22:59:25 +01:00
|
|
|
}
|
|
|
|
handleInput (event) {
|
|
|
|
event.preventDefault();
|
|
|
|
const name = event.target.name;
|
|
|
|
const value = event.target.value;
|
|
|
|
this.setState({[name]: value});
|
|
|
|
}
|
2018-01-12 21:48:24 +01:00
|
|
|
updateIsChannelAvailable (channel) {
|
2018-01-05 22:59:25 +01:00
|
|
|
const that = this;
|
2018-01-12 21:48:24 +01:00
|
|
|
const channelWithAtSymbol = `@${channel}`
|
|
|
|
makeGetRequest(`/api/channel-is-available/${channelWithAtSymbol}`)
|
|
|
|
.then(isAvailable => {
|
|
|
|
if (isAvailable) {
|
|
|
|
that.setState({'error': null});
|
|
|
|
} else {
|
|
|
|
that.setState({'error': 'That channel has already been claimed'});
|
|
|
|
}
|
2018-01-05 22:59:25 +01:00
|
|
|
})
|
|
|
|
.catch((error) => {
|
2018-01-12 21:48:24 +01:00
|
|
|
that.setState({'error': error.message});
|
2018-01-05 22:59:25 +01:00
|
|
|
});
|
|
|
|
}
|
2018-01-12 21:48:24 +01:00
|
|
|
checkIsChannelAvailable (channel) {
|
|
|
|
const channelWithAtSymbol = `@${channel}`;
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
makeGetRequest(`/api/channel-is-available/${channelWithAtSymbol}`)
|
|
|
|
.then(isAvailable => {
|
|
|
|
if (!isAvailable) {
|
|
|
|
console.log('channel is not available');
|
|
|
|
return reject(new Error('That channel has already been claimed'));
|
|
|
|
}
|
|
|
|
console.log('channel is available');
|
|
|
|
resolve();
|
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
reject(error);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
checkIsPasswordProvided () {
|
|
|
|
const password = this.state.password;
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
if (!password || password.length < 1) {
|
|
|
|
console.log('password not provided');
|
|
|
|
return reject(new Error('Please provide a password'));
|
|
|
|
}
|
|
|
|
console.log('password provided');
|
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
makeCreateChannelRequest (channel, password) {
|
|
|
|
const params = `username=${channel}&password=${password}`;
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
makePostRequest('/signup', params)
|
|
|
|
.then(result => {
|
|
|
|
resolve(result);
|
|
|
|
})
|
|
|
|
.catch(error => {
|
|
|
|
console.log('create channel request failed:', error);
|
|
|
|
reject(new Error('Unfortunately, we encountered an error while creating your channel. Please let us know in Discord!'));
|
|
|
|
});
|
|
|
|
});
|
2018-01-06 01:47:55 +01:00
|
|
|
}
|
2018-01-05 22:59:25 +01:00
|
|
|
createChannel (event) {
|
|
|
|
event.preventDefault();
|
2018-01-06 01:47:55 +01:00
|
|
|
const that = this;
|
2018-01-12 21:48:24 +01:00
|
|
|
this.checkIsPasswordProvided()
|
|
|
|
.then(() => {
|
|
|
|
return that.checkIsChannelAvailable(that.state.channel, that.state.password);
|
|
|
|
})
|
|
|
|
.then(() => {
|
|
|
|
that.setState({status: 'We are publishing your new channel. Sit tight...'});
|
|
|
|
return that.makeCreateChannelRequest();
|
|
|
|
})
|
2018-01-06 01:47:55 +01:00
|
|
|
.then(result => {
|
2018-01-12 21:48:24 +01:00
|
|
|
that.setState({status: null});
|
2018-01-10 20:26:01 +01:00
|
|
|
setUserCookies(result.channelName, result.shortChannelId, result.channelClaimId);
|
|
|
|
replaceChannelSelectionInNavBar(result.channelName);
|
2018-01-12 21:48:24 +01:00
|
|
|
that.props.onChannelLogin(result.channelName, result.shortChannelId, result.channelClaimId);
|
2018-01-06 01:47:55 +01:00
|
|
|
})
|
2018-01-12 21:48:24 +01:00
|
|
|
.catch((error) => {
|
|
|
|
that.setState({'error': error.message, status: null});
|
2018-01-06 01:47:55 +01:00
|
|
|
});
|
2018-01-05 22:59:25 +01:00
|
|
|
}
|
|
|
|
render () {
|
|
|
|
return (
|
2018-01-06 01:47:55 +01:00
|
|
|
<div>
|
|
|
|
{ !this.state.status ? (
|
|
|
|
<form id="publish-channel-form">
|
|
|
|
<p id="input-error-channel-name" className="info-message-placeholder info-message--failure">{this.state.error}</p>
|
|
|
|
<div className="row row--wide row--short">
|
|
|
|
<div className="column column--3 column--sml-10">
|
|
|
|
<label className="label" htmlFor="new-channel-name">Name:</label>
|
|
|
|
</div><div className="column column--6 column--sml-10">
|
2018-01-12 21:48:24 +01:00
|
|
|
<div className="input-text--primary flex-container--row flex-container--left-bottom">
|
|
|
|
<span>@</span>
|
|
|
|
<input type="text" name="channel" id="new-channel-name" className="input-text" placeholder="exampleChannelName" value={this.state.channel} onChange={this.handleChannelInput} />
|
|
|
|
<span id="input-success-channel-name" className="info-message--success">{'\u2713'}</span>
|
|
|
|
</div>
|
2018-01-06 01:47:55 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div className="row row--wide row--short">
|
|
|
|
<div className="column column--3 column--sml-10">
|
|
|
|
<label className="label" htmlFor="new-channel-password">Password:</label>
|
|
|
|
</div><div className="column column--6 column--sml-10">
|
2018-01-12 21:48:24 +01:00
|
|
|
<div className="input-text--primary">
|
|
|
|
<input type="password" name="password" id="new-channel-password" className="input-text" placeholder="" value={this.state.password} onChange={this.handleInput} />
|
|
|
|
</div>
|
2018-01-06 01:47:55 +01:00
|
|
|
</div>
|
2018-01-05 22:59:25 +01:00
|
|
|
</div>
|
|
|
|
|
2018-01-06 01:47:55 +01:00
|
|
|
<div className="row row--wide">
|
2018-01-10 20:26:01 +01:00
|
|
|
<button className="button--primary" onClick={this.createChannel}>Create Channel</button>
|
2018-01-06 01:47:55 +01:00
|
|
|
</div>
|
|
|
|
</form>
|
|
|
|
) : (
|
2018-01-12 21:48:24 +01:00
|
|
|
<p className="label">{this.state.status}</p>
|
2018-01-06 01:47:55 +01:00
|
|
|
)}
|
|
|
|
</div>
|
2018-01-05 22:59:25 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-01-10 20:26:01 +01:00
|
|
|
const mapDispatchToProps = dispatch => {
|
|
|
|
return {
|
|
|
|
onChannelLogin: (name, shortId, longId) => {
|
|
|
|
dispatch(updateLoggedInChannel(name, shortId, longId));
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export default connect(null, mapDispatchToProps)(ChannelCreateForm);
|