From 56e74239d6b34df8f30ef046f0b0ff4ff0866a71 Mon Sep 17 00:00:00 2001 From: =Corey Hulen Date: Sun, 14 Jun 2015 23:53:32 -0800 Subject: first commit --- web/react/components/rename_channel_modal.jsx | 142 ++++++++++++++++++++++++++ 1 file changed, 142 insertions(+) create mode 100644 web/react/components/rename_channel_modal.jsx (limited to 'web/react/components/rename_channel_modal.jsx') diff --git a/web/react/components/rename_channel_modal.jsx b/web/react/components/rename_channel_modal.jsx new file mode 100644 index 000000000..b4ccb2937 --- /dev/null +++ b/web/react/components/rename_channel_modal.jsx @@ -0,0 +1,142 @@ +// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved. +// See License.txt for license information. + + +var utils = require('../utils/utils.jsx'); +var Client = require('../utils/client.jsx'); +var AsyncClient = require('../utils/async_client.jsx'); +var ChannelStore = require('../stores/channel_store.jsx'); + +module.exports = React.createClass({ + handleSubmit: function(e) { + e.preventDefault(); + + if (this.state.channel_id.length !== 26) return; + + var channel = ChannelStore.get(this.state.channel_id); + var oldName = channel.name + var oldDisplayName = channel.display_name + var state = { server_error: "" }; + + channel.display_name = this.state.display_name.trim(); + if (!channel.display_name) { + state.display_name_error = "This field is required"; + state.inValid = true; + } + else if (channel.display_name.length > 22) { + state.display_name_error = "This field must be less than 22 characters"; + state.inValid = true; + } + else { + state.display_name_error = ""; + } + + channel.name = this.state.channel_name.trim(); + if (!channel.name) { + state.name_error = "This field is required"; + state.inValid = true; + } + else if(channel.name.length > 22){ + state.name_error = "This field must be less than 22 characters"; + state.inValid = true; + } + else { + var cleaned_name = utils.cleanUpUrlable(channel.name); + if (cleaned_name != channel.name) { + state.name_error = "Must be lowercase alphanumeric characters"; + state.inValid = true; + } + else { + state.name_error = ""; + } + } + + this.setState(state); + + if (state.inValid) + return; + + if (oldName == channel.name && oldDisplayName == channel.display_name) + return; + + Client.updateChannel(channel, + function(data) { + this.refs.display_name.getDOMNode().value = ""; + this.refs.channel_name.getDOMNode().value = ""; + + $('#' + this.props.modalId).modal('hide'); + window.location.href = '/channels/' + this.state.channel_name; + AsyncClient.getChannels(true); + }.bind(this), + function(err) { + state.server_error = err.message; + state.inValid = true; + this.setState(state); + }.bind(this) + ); + }, + onNameChange: function() { + this.setState({ channel_name: this.refs.channel_name.getDOMNode().value }) + }, + onDisplayNameChange: function() { + this.setState({ display_name: this.refs.display_name.getDOMNode().value }) + }, + displayNameKeyUp: function(e) { + var display_name = this.refs.display_name.getDOMNode().value.trim(); + var channel_name = utils.cleanUpUrlable(display_name); + this.refs.channel_name.getDOMNode().value = channel_name; + this.setState({ channel_name: channel_name }) + }, + componentDidMount: function() { + var self = this; + $(this.refs.modal.getDOMNode()).on('show.bs.modal', function(e) { + var button = $(e.relatedTarget); + self.setState({ display_name: button.attr('data-display'), title: button.attr('data-name'), channel_id: button.attr('data-channelid') }); + }); + }, + getInitialState: function() { + return { display_name: "", channel_name: "", channel_id: "" }; + }, + render: function() { + + var display_name_error = this.state.display_name_error ? : null; + var name_error = this.state.name_error ? : null; + var server_error = this.state.server_error ?
: null; + + return ( + + ); + } +}); + -- cgit v1.2.3-1-g7c22