Rename .js/.jsx to .ts/.tsx
This commit is contained in:
		
							parent
							
								
									257162e5b6
								
							
						
					
					
						commit
						c60d0e7392
					
				
					 151 changed files with 0 additions and 0 deletions
				
			
		
							
								
								
									
										63
									
								
								src/settings/components/form/BlacklistForm.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								src/settings/components/form/BlacklistForm.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,63 @@ | |||
| import './BlacklistForm.scss'; | ||||
| import AddButton from '../ui/AddButton'; | ||||
| import DeleteButton from '../ui/DeleteButton'; | ||||
| import React from 'react'; | ||||
| import PropTypes from 'prop-types'; | ||||
| 
 | ||||
| class BlacklistForm extends React.Component { | ||||
| 
 | ||||
|   render() { | ||||
|     return <div className='form-blacklist-form'> | ||||
|       { | ||||
|         this.props.value.map((url, index) => { | ||||
|           return <div key={index} className='form-blacklist-form-row'> | ||||
|             <input data-index={index} type='text' name='url' | ||||
|               className='column-url' value={url} | ||||
|               onChange={this.bindValue.bind(this)} | ||||
|               onBlur={this.props.onBlur} | ||||
|             /> | ||||
|             <DeleteButton data-index={index} name='delete' | ||||
|               onClick={this.bindValue.bind(this)} | ||||
|               onBlur={this.props.onBlur} | ||||
|             /> | ||||
|           </div>; | ||||
|         }) | ||||
|       } | ||||
|       <AddButton name='add' style={{ float: 'right' }} | ||||
|         onClick={this.bindValue.bind(this)} /> | ||||
|     </div>; | ||||
|   } | ||||
| 
 | ||||
|   bindValue(e) { | ||||
|     let name = e.target.name; | ||||
|     let index = e.target.getAttribute('data-index'); | ||||
|     let next = this.props.value ? this.props.value.slice() : []; | ||||
| 
 | ||||
|     if (name === 'url') { | ||||
|       next[index] = e.target.value; | ||||
|     } else if (name === 'add') { | ||||
|       next.push(''); | ||||
|     } else if (name === 'delete') { | ||||
|       next.splice(index, 1); | ||||
|     } | ||||
| 
 | ||||
|     this.props.onChange(next); | ||||
|     if (name === 'delete') { | ||||
|       this.props.onBlur(); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| BlacklistForm.propTypes = { | ||||
|   value: PropTypes.arrayOf(PropTypes.string), | ||||
|   onChange: PropTypes.func, | ||||
|   onBlur: PropTypes.func, | ||||
| }; | ||||
| 
 | ||||
| BlacklistForm.defaultProps = { | ||||
|   value: [], | ||||
|   onChange: () => {}, | ||||
|   onBlur: () => {}, | ||||
| }; | ||||
| 
 | ||||
| export default BlacklistForm; | ||||
		Reference in a new issue