85 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
| /* eslint react/no-multi-comp:0, no-console:0 */
 | |
| 
 | |
| import BaseMixin from '../../_util/BaseMixin'
 | |
| import createDOMForm from '../src/createDOMForm'
 | |
| import { Modal } from 'vue-antd-ui'
 | |
| import { regionStyle, errorStyle } from './styles'
 | |
| 
 | |
| const Form = {
 | |
|   mixins: [BaseMixin],
 | |
|   props: {
 | |
|     form: Object,
 | |
|   },
 | |
| 
 | |
|   data () {
 | |
|     return {
 | |
|       visible: false,
 | |
|     }
 | |
|   },
 | |
|   methods: {
 | |
|     onSubmit (e) {
 | |
|       e.preventDefault()
 | |
|       this.form.validateFieldsAndScroll((error, values) => {
 | |
|         if (!error) {
 | |
|           console.log('ok', values)
 | |
|         } else {
 | |
|           console.log('error', error, values)
 | |
|         }
 | |
|       })
 | |
|     },
 | |
| 
 | |
|     onCancel () {
 | |
|       this.setState({
 | |
|         visible: false,
 | |
|       })
 | |
|     },
 | |
| 
 | |
|     open () {
 | |
|       this.setState({
 | |
|         visible: true,
 | |
|       })
 | |
|     },
 | |
|   },
 | |
| 
 | |
|   render () {
 | |
|     const { getFieldProps, getFieldError } = this.form
 | |
|     return (<div style={{ margin: '20px' }}>
 | |
|       <h2>modal</h2>
 | |
|       <Modal
 | |
|         visible={this.visible}
 | |
|         bodyStyle={{
 | |
|           height: '200px',
 | |
|           overflow: 'auto',
 | |
|         }}
 | |
|         onCancel={this.onCancel}
 | |
|         title='modal'
 | |
|       >
 | |
|         <div ref='dialogContent'>
 | |
|           <form onSubmit={this.onSubmit}>
 | |
|             <input
 | |
|               {...getFieldProps('required', {
 | |
|                 rules: [{
 | |
|                   required: true,
 | |
|                   message: 'ๅฟ
ๅกซ',
 | |
|                 }],
 | |
|               })}
 | |
|             />
 | |
|             <div style={errorStyle}>
 | |
|               {getFieldError('required') ? getFieldError('required').join(',')
 | |
|                 : <b style={{ visibility: 'hidden' }}>1</b>}
 | |
|             </div>
 | |
|             <div style={{ marginTop: '300px' }}>
 | |
|               <button>submit</button>
 | |
|             </div>
 | |
|           </form>
 | |
|         </div>
 | |
|       </Modal>
 | |
|       <div style={ regionStyle }>
 | |
|         <button onClick={this.open}>open</button>
 | |
|       </div>
 | |
|     </div>)
 | |
|   },
 | |
| }
 | |
| 
 | |
| export default createDOMForm()(Form)
 |