This commit is contained in:
AllenFang 2018-09-29 13:26:44 +08:00
parent 7a1ed67847
commit db19e7dd9b
3 changed files with 15 additions and 7 deletions

View File

@ -24,6 +24,7 @@ export default (_, onStartEdit) =>
onUpdate: PropTypes.func.isRequired, onUpdate: PropTypes.func.isRequired,
onEscape: PropTypes.func.isRequired, onEscape: PropTypes.func.isRequired,
timeToCloseMessage: PropTypes.number, timeToCloseMessage: PropTypes.number,
autoSelectText: PropTypes.bool,
className: PropTypes.string, className: PropTypes.string,
style: PropTypes.object style: PropTypes.object
} }
@ -31,6 +32,7 @@ export default (_, onStartEdit) =>
static defaultProps = { static defaultProps = {
timeToCloseMessage: TIME_TO_CLOSE_MESSAGE, timeToCloseMessage: TIME_TO_CLOSE_MESSAGE,
className: null, className: null,
autoSelectText: false,
style: {} style: {}
} }
@ -121,7 +123,7 @@ export default (_, onStartEdit) =>
render() { render() {
let editor; let editor;
const { row, column, className, style, rowIndex, columnIndex } = this.props; const { row, column, className, style, rowIndex, columnIndex, autoSelectText } = this.props;
const { dataField } = column; const { dataField } = column;
const value = _.get(row, dataField); const value = _.get(row, dataField);
@ -174,13 +176,13 @@ export default (_, onStartEdit) =>
} else if (isDefaultEditorDefined && column.editor.type === EDITTYPE.SELECT) { } else if (isDefaultEditorDefined && column.editor.type === EDITTYPE.SELECT) {
editor = <DropdownEditor { ...editorProps } />; editor = <DropdownEditor { ...editorProps } />;
} else if (isDefaultEditorDefined && column.editor.type === EDITTYPE.TEXTAREA) { } else if (isDefaultEditorDefined && column.editor.type === EDITTYPE.TEXTAREA) {
editor = <TextAreaEditor { ...editorProps } />; editor = <TextAreaEditor { ...editorProps } autoSelectText={ autoSelectText } />;
} else if (isDefaultEditorDefined && column.editor.type === EDITTYPE.CHECKBOX) { } else if (isDefaultEditorDefined && column.editor.type === EDITTYPE.CHECKBOX) {
editor = <CheckBoxEditor { ...editorProps } />; editor = <CheckBoxEditor { ...editorProps } />;
} else if (isDefaultEditorDefined && column.editor.type === EDITTYPE.DATE) { } else if (isDefaultEditorDefined && column.editor.type === EDITTYPE.DATE) {
editor = <DateEditor { ...editorProps } />; editor = <DateEditor { ...editorProps } />;
} else { } else {
editor = <TextEditor { ...editorProps } />; editor = <TextEditor { ...editorProps } autoSelectText={ autoSelectText } />;
} }
return ( return (

View File

@ -5,9 +5,10 @@ import PropTypes from 'prop-types';
class TextEditor extends Component { class TextEditor extends Component {
componentDidMount() { componentDidMount() {
const { defaultValue, didMount } = this.props; const { defaultValue, didMount, autoSelectText } = this.props;
this.text.value = defaultValue; this.text.value = defaultValue;
this.text.focus(); this.text.focus();
if (autoSelectText) this.text.select();
if (didMount) didMount(); if (didMount) didMount();
} }
@ -16,7 +17,7 @@ class TextEditor extends Component {
} }
render() { render() {
const { defaultValue, didMount, className, ...rest } = this.props; const { defaultValue, didMount, className, autoSelectText, ...rest } = this.props;
const editorClass = cs('form-control editor edit-text', className); const editorClass = cs('form-control editor edit-text', className);
return ( return (
<input <input
@ -38,11 +39,13 @@ TextEditor.propTypes = {
PropTypes.string, PropTypes.string,
PropTypes.number PropTypes.number
]), ]),
autoSelectText: PropTypes.bool,
didMount: PropTypes.func didMount: PropTypes.func
}; };
TextEditor.defaultProps = { TextEditor.defaultProps = {
className: null, className: null,
defaultValue: '', defaultValue: '',
autoSelectText: false,
didMount: undefined didMount: undefined
}; };
export default TextEditor; export default TextEditor;

View File

@ -10,9 +10,10 @@ class TextAreaEditor extends Component {
} }
componentDidMount() { componentDidMount() {
const { defaultValue, didMount } = this.props; const { defaultValue, didMount, autoSelectText } = this.props;
this.text.value = defaultValue; this.text.value = defaultValue;
this.text.focus(); this.text.focus();
if (autoSelectText) this.text.select();
if (didMount) didMount(); if (didMount) didMount();
} }
@ -28,7 +29,7 @@ class TextAreaEditor extends Component {
} }
render() { render() {
const { defaultValue, didMount, className, ...rest } = this.props; const { defaultValue, didMount, className, autoSelectText, ...rest } = this.props;
const editorClass = cs('form-control editor edit-textarea', className); const editorClass = cs('form-control editor edit-textarea', className);
return ( return (
<textarea <textarea
@ -52,11 +53,13 @@ TextAreaEditor.propTypes = {
PropTypes.number PropTypes.number
]), ]),
onKeyDown: PropTypes.func, onKeyDown: PropTypes.func,
autoSelectText: PropTypes.bool,
didMount: PropTypes.func didMount: PropTypes.func
}; };
TextAreaEditor.defaultProps = { TextAreaEditor.defaultProps = {
className: '', className: '',
defaultValue: '', defaultValue: '',
autoSelectText: false,
onKeyDown: undefined, onKeyDown: undefined,
didMount: undefined didMount: undefined
}; };