diff options
author | Shin'ya Ueoka <ueokande@i-beam.org> | 2019-04-29 10:31:58 +0900 |
---|---|---|
committer | Shin'ya Ueoka <ueokande@i-beam.org> | 2019-04-29 16:06:07 +0900 |
commit | 25111f9de4b7959cdd97b51bfdd2f1c2a7124e48 (patch) | |
tree | c1140f9a68c803c5ea9c6cdbf72d5ac89b7afb98 /src/console | |
parent | 46228c6b184a662b3b8398b6d5604c177f0c158e (diff) |
Declare component prop types on console
Diffstat (limited to 'src/console')
-rw-r--r-- | src/console/components/Console.jsx (renamed from src/console/components/console.jsx) | 21 | ||||
-rw-r--r-- | src/console/components/console/Completion.jsx (renamed from src/console/components/console/completion.jsx) | 49 | ||||
-rw-r--r-- | src/console/components/console/CompletionItem.jsx | 28 | ||||
-rw-r--r-- | src/console/components/console/CompletionTitle.jsx | 14 | ||||
-rw-r--r-- | src/console/components/console/Input.jsx (renamed from src/console/components/console/input.jsx) | 13 | ||||
-rw-r--r-- | src/console/components/console/Message.jsx (renamed from src/console/components/console/message.jsx) | 11 | ||||
-rw-r--r-- | src/console/index.jsx | 2 |
7 files changed, 103 insertions, 35 deletions
diff --git a/src/console/components/console.jsx b/src/console/components/Console.jsx index b792088..6a9cebd 100644 --- a/src/console/components/console.jsx +++ b/src/console/components/Console.jsx @@ -1,14 +1,15 @@ import './console.scss'; import { connect } from 'react-redux'; import React from 'react'; -import Input from './console/input'; -import Completion from './console/completion'; -import Message from './console/message'; +import PropTypes from 'prop-types'; +import Input from './console/Input'; +import Completion from './console/Completion'; +import Message from './console/Message'; import * as consoleActions from '../../console/actions/console'; const COMPLETION_MAX_ITEMS = 33; -class ConsoleComponent extends React.Component { +class Console extends React.Component { onBlur() { if (this.props.mode === 'command' || this.props.mode === 'find') { return this.props.dispatch(consoleActions.hideCommand()); @@ -137,5 +138,15 @@ class ConsoleComponent extends React.Component { } } +Console.propTypes = { + mode: PropTypes.string, + onBlur: PropTypes.func, + onKeyDown: PropTypes.func, + onInput: PropTypes.func, + consoleText: PropTypes.string, + messageText: PropTypes.string, + children: PropTypes.string, +}; + const mapStateToProps = state => state; -export default connect(mapStateToProps)(ConsoleComponent); +export default connect(mapStateToProps)(Console); diff --git a/src/console/components/console/completion.jsx b/src/console/components/console/Completion.jsx index 5d248a0..5477cb6 100644 --- a/src/console/components/console/completion.jsx +++ b/src/console/components/console/Completion.jsx @@ -1,29 +1,9 @@ import React from 'react'; +import PropTypes from 'prop-types'; +import CompletionItem from './CompletionItem'; +import CompletionTitle from './CompletionTitle'; -const CompletionTitle = (props) => { - return <li className='vimvixen-console-completion-title' >{props.title}</li>; -}; - -const CompletionItem = (props) => { - let className = 'vimvixen-console-completion-item'; - if (props.highlight) { - className += ' vimvixen-completion-selected'; - } - return <li - className={className} - style={{ backgroundImage: 'url(' + props.icon + ')' }} - > - <span - className='vimvixen-console-completion-item-caption' - >{props.caption}</span> - <span - className='vimvixen-console-completion-item-url' - >{props.url}</span> - </li>; -}; - - -class CompletionComponent extends React.Component { +class Completion extends React.Component { constructor() { super(); this.state = { viewOffset: 0, select: -1 }; @@ -63,9 +43,13 @@ class CompletionComponent extends React.Component { let index = 0; for (let group of this.props.completions) { - eles.push(<CompletionTitle title={ group.name }/>); + eles.push(<CompletionTitle + key={`group-${index}`} + title={ group.name } + />); for (let item of group.items) { eles.push(<CompletionItem + key={`item-${index}`} icon={item.icon} caption={item.caption} url={item.url} @@ -86,4 +70,17 @@ class CompletionComponent extends React.Component { } } -export default CompletionComponent; +Completion.propTypes = { + select: PropTypes.number, + size: PropTypes.number, + completions: PropTypes.arrayOf(PropTypes.shape({ + name: PropTypes.string, + items: PropTypes.arrayOf(PropTypes.shape({ + icon: PropTypes.string, + caption: PropTypes.string, + url: PropTypes.string, + })), + })), +}; + +export default Completion; diff --git a/src/console/components/console/CompletionItem.jsx b/src/console/components/console/CompletionItem.jsx new file mode 100644 index 0000000..3dc552b --- /dev/null +++ b/src/console/components/console/CompletionItem.jsx @@ -0,0 +1,28 @@ +import React from 'react'; +import PropTypes from 'prop-types'; + +const CompletionItem = (props) => { + let className = 'vimvixen-console-completion-item'; + if (props.highlight) { + className += ' vimvixen-completion-selected'; + } + return <li + className={className} + style={{ backgroundImage: 'url(' + props.icon + ')' }} + > + <span + className='vimvixen-console-completion-item-caption' + >{props.caption}</span> + <span + className='vimvixen-console-completion-item-url' + >{props.url}</span> + </li>; +}; + +CompletionItem.propTypes = { + highlight: PropTypes.bool, + caption: PropTypes.string, + url: PropTypes.string, +}; + +export default CompletionItem; diff --git a/src/console/components/console/CompletionTitle.jsx b/src/console/components/console/CompletionTitle.jsx new file mode 100644 index 0000000..4fcba3f --- /dev/null +++ b/src/console/components/console/CompletionTitle.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import PropTypes from 'prop-types'; + +const CompletionTitle = (props) => { + return <li className='vimvixen-console-completion-title'> + {props.title} + </li>; +}; + +CompletionTitle.propTypes = { + title: PropTypes.string, +}; + +export default CompletionTitle; diff --git a/src/console/components/console/input.jsx b/src/console/components/console/Input.jsx index 3ac075e..c85d252 100644 --- a/src/console/components/console/input.jsx +++ b/src/console/components/console/Input.jsx @@ -1,6 +1,7 @@ import React from 'react'; +import PropTypes from 'prop-types'; -export default class InputComponent extends React.Component { +class Input extends React.Component { focus() { this.input.focus(); } @@ -30,3 +31,13 @@ export default class InputComponent extends React.Component { ); } } + +Input.propTypes = { + mode: PropTypes.string, + value: PropTypes.string, + onBlur: PropTypes.func, + onKeyDown: PropTypes.func, + onInput: PropTypes.func, +}; + +export default Input; diff --git a/src/console/components/console/message.jsx b/src/console/components/console/Message.jsx index 6c8297f..dd96248 100644 --- a/src/console/components/console/message.jsx +++ b/src/console/components/console/Message.jsx @@ -1,6 +1,7 @@ import React from 'react'; +import PropTypes from 'prop-types'; -export default function Message(props) { +const Message = (props) => { switch (props.mode) { case 'error': return ( @@ -15,4 +16,10 @@ export default function Message(props) { </p> ); } -} +}; + +Message.propTypes = { + children: PropTypes.string, +}; + +export default Message; diff --git a/src/console/index.jsx b/src/console/index.jsx index 0d0a8b9..3190a9a 100644 --- a/src/console/index.jsx +++ b/src/console/index.jsx @@ -4,7 +4,7 @@ import { createStore, applyMiddleware } from 'redux'; import promise from 'redux-promise'; import * as consoleActions from 'console/actions/console'; import { Provider } from 'react-redux'; -import Console from './components/console'; +import Console from './components/Console'; import React from 'react'; import ReactDOM from 'react-dom'; |