mirror of
				https://github.com/vector-im/element-web.git
				synced 2025-10-26 22:01:25 +01:00 
			
		
		
		
	Swap old login for new
This commit is contained in:
		
							parent
							
								
									58472b8251
								
							
						
					
					
						commit
						726afd30bb
					
				| @ -86,8 +86,7 @@ skin['organisms.UserSettings'] = require('./views/organisms/UserSettings'); | |||||||
| skin['organisms.ViewSource'] = require('./views/organisms/ViewSource'); | skin['organisms.ViewSource'] = require('./views/organisms/ViewSource'); | ||||||
| skin['pages.CompatibilityPage'] = require('./views/pages/CompatibilityPage'); | skin['pages.CompatibilityPage'] = require('./views/pages/CompatibilityPage'); | ||||||
| skin['pages.MatrixChat'] = require('./views/pages/MatrixChat'); | skin['pages.MatrixChat'] = require('./views/pages/MatrixChat'); | ||||||
| skin['pages.LoginPage'] = require('./views/pages/LoginPage'); | skin['pages.Login'] = require('./views/pages/Login'); | ||||||
| skin['templates.Login'] = require('./views/templates/Login'); |  | ||||||
| skin['templates.Register'] = require('./views/templates/Register'); | skin['templates.Register'] = require('./views/templates/Register'); | ||||||
| 
 | 
 | ||||||
| module.exports = skin; | module.exports = skin; | ||||||
| @ -26,7 +26,7 @@ var CasLogin = require("matrix-react-sdk/lib/components/CasLogin"); | |||||||
| /** | /** | ||||||
|  * A wire component which glues together login UI components and Signup logic |  * A wire component which glues together login UI components and Signup logic | ||||||
|  */ |  */ | ||||||
| module.exports = React.createClass({displayName: 'LoginPage', | module.exports = React.createClass({displayName: 'Login', | ||||||
|     propTypes: { |     propTypes: { | ||||||
|         onLoggedIn: React.PropTypes.func.isRequired, |         onLoggedIn: React.PropTypes.func.isRequired, | ||||||
|         homeserverUrl: React.PropTypes.string, |         homeserverUrl: React.PropTypes.string, | ||||||
| @ -97,7 +97,6 @@ module.exports = React.createClass({ | |||||||
|         var LeftPanel = sdk.getComponent('organisms.LeftPanel'); |         var LeftPanel = sdk.getComponent('organisms.LeftPanel'); | ||||||
|         var RoomView = sdk.getComponent('organisms.RoomView'); |         var RoomView = sdk.getComponent('organisms.RoomView'); | ||||||
|         var RightPanel = sdk.getComponent('organisms.RightPanel'); |         var RightPanel = sdk.getComponent('organisms.RightPanel'); | ||||||
|         var Login = sdk.getComponent('templates.Login'); |  | ||||||
|         var UserSettings = sdk.getComponent('organisms.UserSettings'); |         var UserSettings = sdk.getComponent('organisms.UserSettings'); | ||||||
|         var Register = sdk.getComponent('templates.Register'); |         var Register = sdk.getComponent('templates.Register'); | ||||||
|         var CreateRoom = sdk.getComponent('organisms.CreateRoom'); |         var CreateRoom = sdk.getComponent('organisms.CreateRoom'); | ||||||
| @ -168,9 +167,9 @@ module.exports = React.createClass({ | |||||||
|                 /> |                 /> | ||||||
|             ); |             ); | ||||||
|         } else { |         } else { | ||||||
|             var LoginPage = sdk.getComponent("pages.LoginPage"); |             var Login = sdk.getComponent("pages.Login"); | ||||||
|             return ( |             return ( | ||||||
|                 <LoginPage onLoggedIn={this.onLoggedIn} onRegisterClick={this.onRegisterClick} /> |                 <Login onLoggedIn={this.onLoggedIn} onRegisterClick={this.onRegisterClick} /> | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -1,219 +0,0 @@ | |||||||
| /* |  | ||||||
| Copyright 2015 OpenMarket Ltd |  | ||||||
| 
 |  | ||||||
| Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| you may not use this file except in compliance with the License. |  | ||||||
| You may obtain a copy of the License at |  | ||||||
| 
 |  | ||||||
|     http://www.apache.org/licenses/LICENSE-2.0
 |  | ||||||
| 
 |  | ||||||
| Unless required by applicable law or agreed to in writing, software |  | ||||||
| distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| See the License for the specific language governing permissions and |  | ||||||
| limitations under the License. |  | ||||||
| */ |  | ||||||
| 
 |  | ||||||
| 'use strict'; |  | ||||||
| 
 |  | ||||||
| var React = require('react'); |  | ||||||
| var ReactDOM = require('react-dom'); |  | ||||||
| 
 |  | ||||||
| var sdk = require('matrix-react-sdk') |  | ||||||
| var MatrixClientPeg = require('matrix-react-sdk/lib/MatrixClientPeg'); |  | ||||||
| 
 |  | ||||||
| var LoginController = require('matrix-react-sdk/lib/controllers/templates/Login') |  | ||||||
| 
 |  | ||||||
| var config = require('../../../../../config.json'); |  | ||||||
| 
 |  | ||||||
| module.exports = React.createClass({ |  | ||||||
|     displayName: 'Login', |  | ||||||
|     mixins: [LoginController], |  | ||||||
| 
 |  | ||||||
|     getInitialState: function() { |  | ||||||
|         // TODO: factor out all localstorage stuff into its own home.
 |  | ||||||
|         // This is common to Login, Register and MatrixClientPeg
 |  | ||||||
|         var localStorage = window.localStorage; |  | ||||||
|         var hs_url, is_url; |  | ||||||
|         if (localStorage) { |  | ||||||
|             hs_url = localStorage.getItem("mx_hs_url"); |  | ||||||
|             is_url = localStorage.getItem("mx_is_url"); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         return { |  | ||||||
|             customHsUrl: hs_url || config.default_hs_url, |  | ||||||
|             customIsUrl: is_url || config.default_is_url, |  | ||||||
|             serverConfigVisible: (hs_url && hs_url !== config.default_hs_url || |  | ||||||
|                                   is_url && is_url !== config.default_is_url) |  | ||||||
|         }; |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     componentDidMount: function() { |  | ||||||
|         this.onHSChosen(); |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     componentDidUpdate: function() { |  | ||||||
|         if (!this.state.focusFired && this.refs.user) { |  | ||||||
|             this.refs.user.focus(); |  | ||||||
|             this.setState({ focusFired: true }); |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     getHsUrl: function() { |  | ||||||
|         if (this.state.serverConfigVisible) { |  | ||||||
|             return this.state.customHsUrl; |  | ||||||
|         } else { |  | ||||||
|             return config.default_hs_url; |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     getIsUrl: function() { |  | ||||||
|         if (this.state.serverConfigVisible) { |  | ||||||
|             return this.state.customIsUrl; |  | ||||||
|         } else { |  | ||||||
|             return config.default_is_url; |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     onServerConfigVisibleChange: function(ev) { |  | ||||||
|         this.setState({ |  | ||||||
|             serverConfigVisible: ev.target.checked |  | ||||||
|         }, this.onHSChosen); |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Gets the form field values for the current login stage |  | ||||||
|      */ |  | ||||||
|     getFormVals: function() { |  | ||||||
|         return { |  | ||||||
|             'username': this.refs.user.value.trim(), |  | ||||||
|             'password': this.refs.pass.value.trim() |  | ||||||
|         }; |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     onHsUrlChanged: function() { |  | ||||||
|         var newHsUrl = this.refs.serverConfig.getHsUrl().trim(); |  | ||||||
|         var newIsUrl = this.refs.serverConfig.getIsUrl().trim(); |  | ||||||
| 
 |  | ||||||
|         if (newHsUrl == this.state.customHsUrl && |  | ||||||
|             newIsUrl == this.state.customIsUrl) |  | ||||||
|         { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             this.setState({ |  | ||||||
|                 customHsUrl: newHsUrl, |  | ||||||
|                 customIsUrl: newIsUrl, |  | ||||||
|             }); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // XXX: why are we replacing the MatrixClientPeg here when we're about
 |  | ||||||
|         // to do it again 1s later in the setTimeout to onHSChosen? -- matthew
 |  | ||||||
|         // Commenting it out for now to see what breaks.
 |  | ||||||
|         /* |  | ||||||
|         MatrixClientPeg.replaceUsingUrls( |  | ||||||
|             this.getHsUrl(), |  | ||||||
|             this.getIsUrl() |  | ||||||
|         ); |  | ||||||
|         this.setState({ |  | ||||||
|             hs_url: this.getHsUrl(), |  | ||||||
|             is_url: this.getIsUrl() |  | ||||||
|         }); |  | ||||||
|         */ |  | ||||||
| 
 |  | ||||||
|         // XXX: HSes do not have to offer password auth, so we
 |  | ||||||
|         // need to update and maybe show a different component
 |  | ||||||
|         // when a new HS is entered.
 |  | ||||||
|         if (this.updateHsTimeout) { |  | ||||||
|             clearTimeout(this.updateHsTimeout); |  | ||||||
|         } |  | ||||||
|         var self = this; |  | ||||||
|         this.updateHsTimeout = setTimeout(function() { |  | ||||||
|             self.onHSChosen(); |  | ||||||
|         }, 1000); |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     componentForStep: function(step) { |  | ||||||
|         switch (step) { |  | ||||||
|             case 'choose_hs': |  | ||||||
|             case 'fetch_stages': |  | ||||||
|                 var serverConfigStyle = {}; |  | ||||||
|                 serverConfigStyle.display = this.state.serverConfigVisible ? 'block' : 'none'; |  | ||||||
|                 var ServerConfig = sdk.getComponent("molecules.ServerConfig"); |  | ||||||
| 
 |  | ||||||
|                 return ( |  | ||||||
|                     <div> |  | ||||||
|                         <input className="mx_Login_checkbox" id="advanced" type="checkbox" checked={this.state.serverConfigVisible} onChange={this.onServerConfigVisibleChange} /> |  | ||||||
|                         <label className="mx_Login_label" htmlFor="advanced">Use custom server options (advanced)</label> |  | ||||||
|                         <div style={serverConfigStyle}> |  | ||||||
|                             <ServerConfig ref="serverConfig" |  | ||||||
|                                 defaultHsUrl={this.state.customHsUrl} defaultIsUrl={this.state.customIsUrl} |  | ||||||
|                                 onHsUrlChanged={this.onHsUrlChanged} |  | ||||||
|                             /> |  | ||||||
|                         </div> |  | ||||||
|                     </div> |  | ||||||
|                 ); |  | ||||||
|             // XXX: clearly these should be separate organisms
 |  | ||||||
|             case 'stage_m.login.password': |  | ||||||
|                 return ( |  | ||||||
|                     <div> |  | ||||||
|                         <form onSubmit={this.onUserPassEntered}> |  | ||||||
|                         <input className="mx_Login_field" ref="user" type="text" value={this.state.username} onChange={this.onUsernameChanged} placeholder="Email or user name" /><br /> |  | ||||||
|                         <input className="mx_Login_field" ref="pass" type="password" value={this.state.password} onChange={this.onPasswordChanged} placeholder="Password" /><br /> |  | ||||||
|                         { this.componentForStep('choose_hs') } |  | ||||||
|                         <input className="mx_Login_submit" type="submit" value="Log in" /> |  | ||||||
|                         </form> |  | ||||||
|                     </div> |  | ||||||
|                 ); |  | ||||||
|             case 'stage_m.login.cas': |  | ||||||
|                 var CasLogin = sdk.getComponent('organisms.CasLogin'); |  | ||||||
|                 return ( |  | ||||||
|                     <CasLogin /> |  | ||||||
|                 ); |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     onUsernameChanged: function(ev) { |  | ||||||
|         this.setState({username: ev.target.value}); |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     onPasswordChanged: function(ev) { |  | ||||||
|         this.setState({password: ev.target.value}); |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     loginContent: function() { |  | ||||||
|         var Loader = sdk.getComponent("atoms.Spinner"); |  | ||||||
|         var loader = this.state.busy ? <div className="mx_Login_loader"><Loader /></div> : null; |  | ||||||
|         return ( |  | ||||||
|             <div> |  | ||||||
|                 <h2>Sign in</h2> |  | ||||||
|                 {this.componentForStep(this.state.step)} |  | ||||||
|                 <div className="mx_Login_error"> |  | ||||||
|                         { loader } |  | ||||||
|                         {this.state.errorText} |  | ||||||
|                 </div> |  | ||||||
|                 <a className="mx_Login_create" onClick={this.showRegister} href="#">Create a new account</a> |  | ||||||
|                 <br/> |  | ||||||
|                 <div className="mx_Login_links"> |  | ||||||
|                     <a href="https://medium.com/@Vector">blog</a>  ·   |  | ||||||
|                     <a href="https://twitter.com/@VectorCo">twitter</a>  ·   |  | ||||||
|                     <a href="https://github.com/vector-im/vector-web">github</a>  ·   |  | ||||||
|                     <a href="https://matrix.org">powered by Matrix</a> |  | ||||||
|                 </div> |  | ||||||
|             </div> |  | ||||||
|         ); |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     render: function() { |  | ||||||
|         return ( |  | ||||||
|             <div className="mx_Login"> |  | ||||||
|                 <div className="mx_Login_box"> |  | ||||||
|                     <div className="mx_Login_logo"> |  | ||||||
|                         <img  src="img/logo.png" width="249" height="78" alt="vector"/> |  | ||||||
|                     </div> |  | ||||||
|                     {this.loginContent()} |  | ||||||
|                 </div> |  | ||||||
|             </div> |  | ||||||
|         ); |  | ||||||
|     } |  | ||||||
| }); |  | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user