Skip to content

Commit

Permalink
Merge pull request #2091 from JedWatson/dekelb-feature/rtl_support
Browse files Browse the repository at this point in the history
Resolved merge conflicts and nit in #1613
  • Loading branch information
gwyneplaine authored Oct 25, 2017
2 parents 8fed74b + c0133e5 commit 6ad485c
Show file tree
Hide file tree
Showing 8 changed files with 97 additions and 10 deletions.
11 changes: 11 additions & 0 deletions examples/src/components/Multiselect.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ var MultiSelectField = createClass({
crazy: false,
stayOpen: false,
value: [],
rtl: false,
};
},
handleSelectChange (value) {
Expand All @@ -38,6 +39,11 @@ var MultiSelectField = createClass({
[e.target.name]: e.target.checked,
});
},
toggleRtl (e) {
let rtl = e.target.checked;
this.setState({ rtl });
},

render () {
const { crazy, disabled, stayOpen, value } = this.state;
const options = crazy ? WHY_WOULD_YOU : FLAVOURS;
Expand All @@ -51,6 +57,7 @@ var MultiSelectField = createClass({
onChange={this.handleSelectChange}
options={options}
placeholder="Select your favourite(s)"
rtl={this.state.rtl}
simpleValue
value={value}
/>
Expand All @@ -68,6 +75,10 @@ var MultiSelectField = createClass({
<input type="checkbox" className="checkbox-control" name="stayOpen" checked={stayOpen} onChange={this.toggleCheckbox}/>
<span className="checkbox-label">Stay open when an Option is selected</span>
</label>
<label className="checkbox">
<input type="checkbox" className="checkbox-control" name="rtl" checked={this.state.rtl} onChange={this.toggleCheckbox} />
<span className="checkbox-label">rtl</span>
</label>
</div>
</div>
);
Expand Down
32 changes: 24 additions & 8 deletions examples/src/components/States.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,18 +24,17 @@ var StatesField = createClass({
searchable: this.props.searchable,
selectValue: 'new-south-wales',
clearable: true,
rtl: false,
};
},
switchCountry (e) {
var newCountry = e.target.value;
console.log('Country changed to ' + newCountry);
this.setState({
country: newCountry,
selectValue: null,
});
},
updateValue (newValue) {
console.log('State changed to ' + newValue);
this.setState({
selectValue: newValue,
});
Expand All @@ -53,22 +52,39 @@ var StatesField = createClass({
return (
<div className="section">
<h3 className="section-heading">{this.props.label} <a href="https://github.com/JedWatson/react-select/tree/master/examples/src/components/States.js">(Source)</a></h3>
<Select id="state-select" ref="stateSelect" autoFocus options={options} simpleValue clearable={this.state.clearable} name="selected-state" disabled={this.state.disabled} value={this.state.selectValue} onChange={this.updateValue} searchable={this.state.searchable} />
<Select
id="state-select"
ref="stateSelect"
autoFocus
options={options}
simpleValue
clearable={this.state.clearable}
name="selected-state"
disabled={this.state.disabled}
value={this.state.selectValue}
onChange={this.updateValue}
rtl={this.state.rtl}
searchable={this.state.searchable}
/>
<button style={{ marginTop: '15px' }} type="button" onClick={this.focusStateSelect}>Focus Select</button>
<div className="checkbox-list">

<div style={{ marginTop: 14 }}>
<button type="button" onClick={this.focusStateSelect}>Focus Select</button>
<label className="checkbox" style={{ marginLeft: 10 }}>
<label className="checkbox">
<input type="checkbox" className="checkbox-control" name="searchable" checked={this.state.searchable} onChange={this.toggleCheckbox}/>
<span className="checkbox-label">Searchable</span>
</label>
<label className="checkbox" style={{ marginLeft: 10 }}>
<label className="checkbox">
<input type="checkbox" className="checkbox-control" name="disabled" checked={this.state.disabled} onChange={this.toggleCheckbox}/>
<span className="checkbox-label">Disabled</span>
</label>
<label className="checkbox" style={{ marginLeft: 10 }}>
<label className="checkbox">
<input type="checkbox" className="checkbox-control" name="clearable" checked={this.state.clearable} onChange={this.toggleCheckbox}/>
<span className="checkbox-label">Clearable</span>
</label>
<label className="checkbox">
<input type="checkbox" className="checkbox-control" name="rtl" checked={this.state.rtl} onChange={this.toggleCheckbox}/>
<span className="checkbox-label">rtl</span>
</label>
</div>
<div className="checkbox-list">
<label className="checkbox">
Expand Down
10 changes: 10 additions & 0 deletions less/control.less
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,10 @@
.Select-arrow-zone:hover > .Select-arrow {
border-top-color: @select-arrow-color-hover;
}
&.Select--rtl {
direction: rtl;
text-align: right;
}
}

// base
Expand Down Expand Up @@ -255,6 +259,12 @@
text-align: center;
vertical-align: middle;
width: (@select-arrow-width * 5);
padding-right: @select-arrow-width;

.Select--rtl & {
padding-right: 0;
padding-left: @select-arrow-width;
}
}

.Select-arrow {
Expand Down
16 changes: 15 additions & 1 deletion less/multi.less
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,10 @@
margin-left: @select-padding-horizontal;
padding: 0;
}
&.Select--rtl .Select-input {
margin-left: 0;
margin-right: @select-padding-horizontal;
}

// reduce margin once there is value
&.has-value .Select-input {
Expand Down Expand Up @@ -80,7 +84,17 @@
background-color: @select-item-border-color;
}
}

&.Select--rtl {
.Select-value {
margin-left: 0;
margin-right: @select-item-gutter;
}
.Select-value-icon {
border-right: none;
border-left: 1px solid @select-item-border-color-fb; /* Fallback color for IE 8 */
border-left: 1px solid @select-item-border-color;
}
}
}

.Select--multi.is-disabled {
Expand Down
9 changes: 9 additions & 0 deletions scss/control.scss
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,10 @@
.Select-arrow-zone:hover > .Select-arrow {
border-top-color: $select-arrow-color-hover;
}
&.Select--rtl {
direction: rtl;
text-align: right;
}
}

// base
Expand Down Expand Up @@ -251,6 +255,11 @@
vertical-align: middle;
width: ($select-arrow-width * 5);
padding-right: $select-arrow-width;

.Select--rtl & {
padding-right: 0;
padding-left: $select-arrow-width;
}
}

.Select-arrow {
Expand Down
14 changes: 14 additions & 0 deletions scss/multi.scss
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,10 @@
margin-left: $select-padding-horizontal;
padding: 0;
}
&.Select--rtl .Select-input {
margin-left: 0;
margin-right: $select-padding-horizontal;
}

// reduce margin once there is value
&.has-value .Select-input {
Expand Down Expand Up @@ -75,6 +79,16 @@
}
}

&.Select--rtl {
.Select-value {
margin-left: 0;
margin-right: $select-item-gutter;
}
.Select-value-icon {
border-right: none;
border-left: 1px solid $select-item-border-color;
}
}
}

.Select--multi.is-disabled {
Expand Down
5 changes: 4 additions & 1 deletion src/Select.js
Original file line number Diff line number Diff line change
Expand Up @@ -781,7 +781,7 @@ class Select extends React.Component {
[this._instancePrefix + '-list']: isOpen,
});
return (

<div
{...divProps}
role="combobox"
Expand Down Expand Up @@ -1005,6 +1005,7 @@ class Select extends React.Component {
'is-pseudo-focused': this.state.isPseudoFocused,
'is-searchable': this.props.searchable,
'has-value': valueArray.length,
'Select--rtl': this.props.rtl,
});

let removeMessage = null;
Expand Down Expand Up @@ -1113,6 +1114,7 @@ Select.propTypes = {
placeholder: stringOrNode, // field placeholder, displayed when there's no value
required: PropTypes.bool, // applies HTML5 required attribute when needed
resetValue: PropTypes.any, // value to use when you clear the control
rtl: PropTypes.bool, // set to true in order to use react-select in right-to-left direction
scrollMenuIntoView: PropTypes.bool, // boolean to enable the viewport to shift so that the full menu fully visible when engaged
searchable: PropTypes.bool, // whether to enable searching feature or not
simpleValue: PropTypes.bool, // pass the value to onChange as a simple value (legacy pre 1.0 mode), defaults to false
Expand Down Expand Up @@ -1162,6 +1164,7 @@ Select.defaultProps = {
pageSize: 5,
placeholder: 'Select...',
required: false,
rtl: false,
scrollMenuIntoView: true,
searchable: true,
simpleValue: false,
Expand Down
10 changes: 10 additions & 0 deletions test/Select-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -4060,4 +4060,14 @@ describe('Select', () => {
expect(warn, 'was called once');
});
});
describe('rtl', () => {
describe('className', () => {
it('assigns the className Select--rtl to the outer-most element', () => {
var instance = createControl({ rtl: true });
expect(ReactDOM.findDOMNode(instance), 'to have attributes', {
class: 'Select--rtl'
});
});
});
});
});

0 comments on commit 6ad485c

Please sign in to comment.