Skip to content

Commit

Permalink
hide create option after closing menu
Browse files Browse the repository at this point in the history
  • Loading branch information
andreme committed Oct 15, 2016
1 parent 4487ca7 commit 1ff6c57
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 16 deletions.
32 changes: 19 additions & 13 deletions src/Select.js
Original file line number Diff line number Diff line change
Expand Up @@ -395,13 +395,12 @@ const Select = React.createClass({
this.setState({
isOpen: false,
isPseudoFocused: this.state.isFocused && !this.props.multi,
inputValue: ''
inputValue: this.handleInputValueChange('')
});
} else {
this.setState({
isOpen: false,
isPseudoFocused: this.state.isFocused && !this.props.multi,
inputValue: this.state.inputValue
isPseudoFocused: this.state.isFocused && !this.props.multi
});
}
this.hasScrolledToOption = false;
Expand Down Expand Up @@ -436,20 +435,16 @@ const Select = React.createClass({
isPseudoFocused: false,
};
if (this.props.onBlurResetsInput) {
onBlurredState.inputValue = '';
onBlurredState.inputValue = this.handleInputValueChange('');
}
this.setState(onBlurredState);
},

handleInputChange (event) {
let newInputValue = event.target.value;

if (this.state.inputValue !== event.target.value && this.props.onInputChange) {
let nextState = this.props.onInputChange(newInputValue);
// Note: != used deliberately here to catch undefined and null
if (nextState != null && typeof nextState !== 'object') {
newInputValue = '' + nextState;
}
if (this.state.inputValue !== event.target.value) {
newInputValue = this.handleInputValueChange(newInputValue);
}

this.setState({
Expand All @@ -459,6 +454,17 @@ const Select = React.createClass({
});
},

handleInputValueChange(newValue) {
if (this.props.onInputChange) {
let nextState = this.props.onInputChange(newValue);
// Note: != used deliberately here to catch undefined and null
if (nextState != null && typeof nextState !== 'object') {
newValue = '' + nextState;
}
}
return newValue;
},

handleKeyDown (event) {
if (this.props.disabled) return;

Expand Down Expand Up @@ -603,15 +609,15 @@ const Select = React.createClass({
this.hasScrolledToOption = false;
if (this.props.multi) {
this.setState({
inputValue: '',
inputValue: this.handleInputValueChange(''),
focusedIndex: null
}, () => {
this.addValue(value);
});
} else {
this.setState({
isOpen: false,
inputValue: '',
inputValue: this.handleInputValueChange(''),
isPseudoFocused: this.state.isFocused,
}, () => {
this.setValue(value);
Expand Down Expand Up @@ -648,7 +654,7 @@ const Select = React.createClass({
this.setValue(this.getResetValue());
this.setState({
isOpen: false,
inputValue: '',
inputValue: this.handleInputValueChange(''),
}, this.focus);
},

Expand Down
34 changes: 31 additions & 3 deletions test/Creatable-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ var TestUtils = require('react-addons-test-utils');
var Select = require('../src/Select');

describe('Creatable', () => {
let creatableInstance, creatableNode, filterInputNode, innserSelectInstance, renderer;
let creatableInstance, creatableNode, filterInputNode, innerSelectInstance, renderer;

beforeEach(() => renderer = TestUtils.createRenderer());

Expand All @@ -36,7 +36,7 @@ describe('Creatable', () => {
<Select.Creatable {...props} />
);
creatableNode = ReactDOM.findDOMNode(creatableInstance);
innserSelectInstance = creatableInstance.select;
innerSelectInstance = creatableInstance.select;
findAndFocusInputControl();
};

Expand Down Expand Up @@ -106,7 +106,7 @@ describe('Creatable', () => {
createControl({
filterOptions: () => null
});
typeSearchText('test');;
typeSearchText('test');
});

it('should not show a "create..." prompt if current filter text is not a valid option (as determined by :isValidNewOption prop)', () => {
Expand Down Expand Up @@ -158,6 +158,34 @@ describe('Creatable', () => {
expect(options, 'to have length', 1);
});

it('should remove the new option after closing on selecting option', () => {
createControl({
shouldKeyDownEventCreateNewOption: ({ keyCode }) => keyCode === 13
});
typeSearchText('9');
TestUtils.Simulate.keyDown(filterInputNode, { keyCode: 40, key: 'ArrowDown' });
TestUtils.Simulate.keyDown(filterInputNode, { keyCode: 13 });
expect(creatableInstance.inputValue, 'to equal', '');
});

it('should remove the new option after closing on escape', () => {
createControl({
shouldKeyDownEventCreateNewOption: ({ keyCode }) => keyCode === 13
});
typeSearchText('9');
TestUtils.Simulate.keyDown(filterInputNode, { keyCode: 27 });
expect(creatableInstance.inputValue, 'to equal', '');
});

it('should remove the new option after closing on blur', () => {
createControl({
shouldKeyDownEventCreateNewOption: ({ keyCode }) => keyCode === 13
});
typeSearchText('9');
TestUtils.Simulate.blur(filterInputNode);
expect(creatableInstance.inputValue, 'to equal', '');
});

it('should allow a custom select type to be rendered via the :children property', () => {
let childProps;
createControl({
Expand Down

0 comments on commit 1ff6c57

Please sign in to comment.