mirror of
https://github.com/status-im/react-native.git
synced 2025-02-26 08:05:34 +00:00
Added support for styling the PickerIOS
Summary: - PickerIOS accepts now a new prop: style - this prop modifies the native style of the RCTPicker allowing to modify the font size of the items (fontSize), color of the items (color, only 6 char HEX values for now) and alignment of the items (textAlign) Closes https://github.com/facebook/react-native/pull/4490 Reviewed By: svcscm Differential Revision: D2723190 Pulled By: nicklockwood fb-gh-sync-id: ab9188192f1d0d087787dfed8c128073bfaa3235
This commit is contained in:
parent
e7a4b20d75
commit
e2c35dddba
@ -87,24 +87,21 @@ var PickerExample = React.createClass({
|
|||||||
key={carMake}
|
key={carMake}
|
||||||
value={carMake}
|
value={carMake}
|
||||||
label={CAR_MAKES_AND_MODELS[carMake].name}
|
label={CAR_MAKES_AND_MODELS[carMake].name}
|
||||||
/>
|
/>
|
||||||
)
|
))}
|
||||||
)}
|
|
||||||
</PickerIOS>
|
</PickerIOS>
|
||||||
<Text>Please choose a model of {make.name}:</Text>
|
<Text>Please choose a model of {make.name}:</Text>
|
||||||
<PickerIOS
|
<PickerIOS
|
||||||
selectedValue={this.state.modelIndex}
|
selectedValue={this.state.modelIndex}
|
||||||
key={this.state.carMake}
|
key={this.state.carMake}
|
||||||
onValueChange={(modelIndex) => this.setState({modelIndex})}>
|
onValueChange={(modelIndex) => this.setState({modelIndex})}>
|
||||||
{CAR_MAKES_AND_MODELS[this.state.carMake].models.map(
|
{CAR_MAKES_AND_MODELS[this.state.carMake].models.map((modelName, modelIndex) => (
|
||||||
(modelName, modelIndex) => (
|
<PickerItemIOS
|
||||||
<PickerItemIOS
|
key={this.state.carMake + '_' + modelIndex}
|
||||||
key={this.state.carMake + '_' + modelIndex}
|
value={modelIndex}
|
||||||
value={modelIndex}
|
label={modelName}
|
||||||
label={modelName}
|
/>
|
||||||
/>
|
))}
|
||||||
))
|
|
||||||
}
|
|
||||||
</PickerIOS>
|
</PickerIOS>
|
||||||
<Text>You selected: {selectionString}</Text>
|
<Text>You selected: {selectionString}</Text>
|
||||||
</View>
|
</View>
|
||||||
@ -112,6 +109,33 @@ var PickerExample = React.createClass({
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
var PickerStyleExample = React.createClass({
|
||||||
|
getInitialState: function() {
|
||||||
|
return {
|
||||||
|
carMake: 'cadillac',
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
render: function() {
|
||||||
|
var make = CAR_MAKES_AND_MODELS[this.state.carMake];
|
||||||
|
var selectionString = make.name + ' ' + make.models[this.state.modelIndex];
|
||||||
|
return (
|
||||||
|
<PickerIOS
|
||||||
|
itemStyle={{fontSize: 25, color: 'red', textAlign: 'left', fontWeight: 'bold'}}
|
||||||
|
selectedValue={this.state.carMake}
|
||||||
|
onValueChange={(carMake) => this.setState({carMake, modelIndex: 0})}>
|
||||||
|
{Object.keys(CAR_MAKES_AND_MODELS).map((carMake) => (
|
||||||
|
<PickerItemIOS
|
||||||
|
key={carMake}
|
||||||
|
value={carMake}
|
||||||
|
label={CAR_MAKES_AND_MODELS[carMake].name}
|
||||||
|
/>
|
||||||
|
))}
|
||||||
|
</PickerIOS>
|
||||||
|
);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
exports.displayName = (undefined: ?string);
|
exports.displayName = (undefined: ?string);
|
||||||
exports.title = '<PickerIOS>';
|
exports.title = '<PickerIOS>';
|
||||||
exports.description = 'Render lists of selectable options with UIPickerView.';
|
exports.description = 'Render lists of selectable options with UIPickerView.';
|
||||||
@ -121,4 +145,10 @@ exports.examples = [
|
|||||||
render: function(): ReactElement {
|
render: function(): ReactElement {
|
||||||
return <PickerExample />;
|
return <PickerExample />;
|
||||||
},
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '<PickerIOS> with custom styling',
|
||||||
|
render: function(): ReactElement {
|
||||||
|
return <PickerStyleExample />;
|
||||||
|
},
|
||||||
}];
|
}];
|
||||||
|
@ -17,8 +17,11 @@ var React = require('React');
|
|||||||
var ReactChildren = require('ReactChildren');
|
var ReactChildren = require('ReactChildren');
|
||||||
var RCTPickerIOSConsts = require('NativeModules').UIManager.RCTPicker.Constants;
|
var RCTPickerIOSConsts = require('NativeModules').UIManager.RCTPicker.Constants;
|
||||||
var StyleSheet = require('StyleSheet');
|
var StyleSheet = require('StyleSheet');
|
||||||
|
var StyleSheetPropType = require('StyleSheetPropType');
|
||||||
|
var TextStylePropTypes = require('TextStylePropTypes');
|
||||||
var View = require('View');
|
var View = require('View');
|
||||||
|
|
||||||
|
var itemStylePropType = StyleSheetPropType(TextStylePropTypes);
|
||||||
var requireNativeComponent = require('requireNativeComponent');
|
var requireNativeComponent = require('requireNativeComponent');
|
||||||
|
|
||||||
var PickerIOS = React.createClass({
|
var PickerIOS = React.createClass({
|
||||||
@ -26,6 +29,7 @@ var PickerIOS = React.createClass({
|
|||||||
|
|
||||||
propTypes: {
|
propTypes: {
|
||||||
...View.propTypes,
|
...View.propTypes,
|
||||||
|
itemStyle: itemStylePropType,
|
||||||
onValueChange: React.PropTypes.func,
|
onValueChange: React.PropTypes.func,
|
||||||
selectedValue: React.PropTypes.any, // string or integer basically
|
selectedValue: React.PropTypes.any, // string or integer basically
|
||||||
},
|
},
|
||||||
@ -50,13 +54,13 @@ var PickerIOS = React.createClass({
|
|||||||
});
|
});
|
||||||
return {selectedIndex, items};
|
return {selectedIndex, items};
|
||||||
},
|
},
|
||||||
|
|
||||||
render: function() {
|
render: function() {
|
||||||
return (
|
return (
|
||||||
<View style={this.props.style}>
|
<View style={this.props.style}>
|
||||||
<RCTPickerIOS
|
<RCTPickerIOS
|
||||||
ref={ picker => this._picker = picker }
|
ref={picker => this._picker = picker}
|
||||||
style={styles.pickerIOS}
|
style={[styles.pickerIOS, this.props.itemStyle]}
|
||||||
items={this.state.items}
|
items={this.state.items}
|
||||||
selectedIndex={this.state.selectedIndex}
|
selectedIndex={this.state.selectedIndex}
|
||||||
onChange={this._onChange}
|
onChange={this._onChange}
|
||||||
@ -108,7 +112,11 @@ var styles = StyleSheet.create({
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
var RCTPickerIOS = requireNativeComponent('RCTPicker', PickerIOS, {
|
var RCTPickerIOS = requireNativeComponent('RCTPicker', {
|
||||||
|
propTypes: {
|
||||||
|
style: itemStylePropType,
|
||||||
|
},
|
||||||
|
}, {
|
||||||
nativeOnly: {
|
nativeOnly: {
|
||||||
items: true,
|
items: true,
|
||||||
onChange: true,
|
onChange: true,
|
||||||
|
@ -15,6 +15,11 @@
|
|||||||
|
|
||||||
@property (nonatomic, copy) NSArray<NSDictionary *> *items;
|
@property (nonatomic, copy) NSArray<NSDictionary *> *items;
|
||||||
@property (nonatomic, assign) NSInteger selectedIndex;
|
@property (nonatomic, assign) NSInteger selectedIndex;
|
||||||
|
|
||||||
|
@property (nonatomic, strong) UIColor *color;
|
||||||
|
@property (nonatomic, strong) UIFont *font;
|
||||||
|
@property (nonatomic, assign) NSTextAlignment textAlign;
|
||||||
|
|
||||||
@property (nonatomic, copy) RCTBubblingEventBlock onChange;
|
@property (nonatomic, copy) RCTBubblingEventBlock onChange;
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
|
|
||||||
#import "RCTPicker.h"
|
#import "RCTPicker.h"
|
||||||
|
|
||||||
|
#import "RCTConvert.h"
|
||||||
#import "RCTUtils.h"
|
#import "RCTUtils.h"
|
||||||
|
|
||||||
@interface RCTPicker() <UIPickerViewDataSource, UIPickerViewDelegate>
|
@interface RCTPicker() <UIPickerViewDataSource, UIPickerViewDelegate>
|
||||||
@ -19,7 +20,10 @@
|
|||||||
- (instancetype)initWithFrame:(CGRect)frame
|
- (instancetype)initWithFrame:(CGRect)frame
|
||||||
{
|
{
|
||||||
if ((self = [super initWithFrame:frame])) {
|
if ((self = [super initWithFrame:frame])) {
|
||||||
|
_color = [UIColor blackColor];
|
||||||
|
_font = [UIFont systemFontOfSize:21]; // TODO: selected title default should be 23.5
|
||||||
_selectedIndex = NSNotFound;
|
_selectedIndex = NSNotFound;
|
||||||
|
_textAlign = NSTextAlignmentCenter;
|
||||||
self.delegate = self;
|
self.delegate = self;
|
||||||
}
|
}
|
||||||
return self;
|
return self;
|
||||||
@ -59,20 +63,33 @@ numberOfRowsInComponent:(__unused NSInteger)component
|
|||||||
|
|
||||||
#pragma mark - UIPickerViewDelegate methods
|
#pragma mark - UIPickerViewDelegate methods
|
||||||
|
|
||||||
- (NSDictionary *)itemForRow:(NSInteger)row
|
|
||||||
{
|
|
||||||
return _items[row];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (id)valueForRow:(NSInteger)row
|
|
||||||
{
|
|
||||||
return [self itemForRow:row][@"value"];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (NSString *)pickerView:(__unused UIPickerView *)pickerView
|
- (NSString *)pickerView:(__unused UIPickerView *)pickerView
|
||||||
titleForRow:(NSInteger)row forComponent:(__unused NSInteger)component
|
titleForRow:(NSInteger)row
|
||||||
|
forComponent:(__unused NSInteger)component
|
||||||
{
|
{
|
||||||
return [self itemForRow:row][@"label"];
|
return [RCTConvert NSString:_items[row][@"label"]];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (UIView *)pickerView:(UIPickerView *)pickerView
|
||||||
|
viewForRow:(NSInteger)row
|
||||||
|
forComponent:(NSInteger)component
|
||||||
|
reusingView:(UILabel *)label
|
||||||
|
{
|
||||||
|
if (!label) {
|
||||||
|
label = [[UILabel alloc] initWithFrame:(CGRect){
|
||||||
|
CGPointZero,
|
||||||
|
{
|
||||||
|
[pickerView rowSizeForComponent:component].width,
|
||||||
|
[pickerView rowSizeForComponent:component].height,
|
||||||
|
}
|
||||||
|
}];
|
||||||
|
}
|
||||||
|
|
||||||
|
label.font = _font;
|
||||||
|
label.textColor = _color;
|
||||||
|
label.textAlignment = _textAlign;
|
||||||
|
label.text = [self pickerView:pickerView titleForRow:row forComponent:component];
|
||||||
|
return label;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)pickerView:(__unused UIPickerView *)pickerView
|
- (void)pickerView:(__unused UIPickerView *)pickerView
|
||||||
@ -82,7 +99,7 @@ numberOfRowsInComponent:(__unused NSInteger)component
|
|||||||
if (_onChange) {
|
if (_onChange) {
|
||||||
_onChange(@{
|
_onChange(@{
|
||||||
@"newIndex": @(row),
|
@"newIndex": @(row),
|
||||||
@"newValue": [self valueForRow:row]
|
@"newValue": RCTNullIfNil(_items[row][@"value"]),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,24 @@ RCT_EXPORT_MODULE()
|
|||||||
RCT_EXPORT_VIEW_PROPERTY(items, NSDictionaryArray)
|
RCT_EXPORT_VIEW_PROPERTY(items, NSDictionaryArray)
|
||||||
RCT_EXPORT_VIEW_PROPERTY(selectedIndex, NSInteger)
|
RCT_EXPORT_VIEW_PROPERTY(selectedIndex, NSInteger)
|
||||||
RCT_EXPORT_VIEW_PROPERTY(onChange, RCTBubblingEventBlock)
|
RCT_EXPORT_VIEW_PROPERTY(onChange, RCTBubblingEventBlock)
|
||||||
|
RCT_EXPORT_VIEW_PROPERTY(color, UIColor)
|
||||||
|
RCT_EXPORT_VIEW_PROPERTY(textAlign, NSTextAlignment)
|
||||||
|
RCT_CUSTOM_VIEW_PROPERTY(fontSize, CGFloat, RCTPicker)
|
||||||
|
{
|
||||||
|
view.font = [RCTConvert UIFont:view.font withSize:json ?: @(defaultView.font.pointSize)];
|
||||||
|
}
|
||||||
|
RCT_CUSTOM_VIEW_PROPERTY(fontWeight, NSString, __unused RCTPicker)
|
||||||
|
{
|
||||||
|
view.font = [RCTConvert UIFont:view.font withWeight:json]; // defaults to normal
|
||||||
|
}
|
||||||
|
RCT_CUSTOM_VIEW_PROPERTY(fontStyle, NSString, __unused RCTPicker)
|
||||||
|
{
|
||||||
|
view.font = [RCTConvert UIFont:view.font withStyle:json]; // defaults to normal
|
||||||
|
}
|
||||||
|
RCT_CUSTOM_VIEW_PROPERTY(fontFamily, NSString, RCTPicker)
|
||||||
|
{
|
||||||
|
view.font = [RCTConvert UIFont:view.font withFamily:json ?: defaultView.font.familyName];
|
||||||
|
}
|
||||||
|
|
||||||
- (NSDictionary<NSString *, id> *)constantsToExport
|
- (NSDictionary<NSString *, id> *)constantsToExport
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user