77 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
| /*
 | |
| Copyright 2015, 2016 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.
 | |
| */
 | |
| 
 | |
| /*
 | |
|  * Usage:
 | |
|  * Modal.createDialog(ErrorDialog, {
 | |
|  *   title: "some text", (default: "Error")
 | |
|  *   description: "some more text",
 | |
|  *   button: "Button Text",
 | |
|  *   onFinished: someFunction,
 | |
|  *   focus: true|false (default: true)
 | |
|  * });
 | |
|  */
 | |
| 
 | |
| import React from 'react';
 | |
| import sdk from '../../../index';
 | |
| import { _t } from '../../../languageHandler';
 | |
| 
 | |
| export default React.createClass({
 | |
|     displayName: 'ErrorDialog',
 | |
|     propTypes: {
 | |
|         title: React.PropTypes.string,
 | |
|         description: React.PropTypes.oneOfType([
 | |
|             React.PropTypes.element,
 | |
|             React.PropTypes.string,
 | |
|         ]),
 | |
|         button: React.PropTypes.string,
 | |
|         focus: React.PropTypes.bool,
 | |
|         onFinished: React.PropTypes.func.isRequired,
 | |
|     },
 | |
| 
 | |
|     getDefaultProps: function() {
 | |
|         return {
 | |
|             focus: true,
 | |
|             title: null,
 | |
|             description: null,
 | |
|             button: null,
 | |
|         };
 | |
|     },
 | |
| 
 | |
|     componentDidMount: function() {
 | |
|         if (this.props.focus) {
 | |
|             this.refs.button.focus();
 | |
|         }
 | |
|     },
 | |
| 
 | |
|     render: function() {
 | |
|         const BaseDialog = sdk.getComponent('views.dialogs.BaseDialog');
 | |
|         return (
 | |
|             <BaseDialog className="mx_ErrorDialog" onFinished={this.props.onFinished}
 | |
|                     title={this.props.title || _t('Error')}>
 | |
|                 <div className="mx_Dialog_content">
 | |
|                     {this.props.description || _t('An error has occurred.')}
 | |
|                 </div>
 | |
|                 <div className="mx_Dialog_buttons">
 | |
|                     <button ref="button" className="mx_Dialog_primary" onClick={this.props.onFinished}>
 | |
|                         {this.props.button || _t('OK')}
 | |
|                     </button>
 | |
|                 </div>
 | |
|             </BaseDialog>
 | |
|         );
 | |
|     },
 | |
| });
 |