UNPKG

react-native-ui-lib

Version:

UI Components Library for React Native ###### Lateset version support RN44

122 lines (71 loc) • 6.44 kB
Object.defineProperty(exports,"__esModule",{value:true});var _extends=Object.assign||function(target){for(var i=1;i<arguments.length;i++){var source=arguments[i];for(var key in source){if(Object.prototype.hasOwnProperty.call(source,key)){target[key]=source[key];}}}return target;};var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||false;descriptor.configurable=true;if("value"in descriptor)descriptor.writable=true;Object.defineProperty(target,descriptor.key,descriptor);}}return function(Constructor,protoProps,staticProps){if(protoProps)defineProperties(Constructor.prototype,protoProps);if(staticProps)defineProperties(Constructor,staticProps);return Constructor;};}();var _react=require('react');var _react2=_interopRequireDefault(_react); var _reactNative=require('react-native'); var _commons=require('../../commons'); var _helpers=require('../../helpers'); var _assets=require('../../assets');var Assets=_interopRequireWildcard(_assets); var _style=require('../../style'); var _view=require('../../components/view');var _view2=_interopRequireDefault(_view); var _button=require('../../components/button');var _button2=_interopRequireDefault(_button); var _text=require('../../components/text');var _text2=_interopRequireDefault(_text);function _interopRequireWildcard(obj){if(obj&&obj.__esModule){return obj;}else{var newObj={};if(obj!=null){for(var key in obj){if(Object.prototype.hasOwnProperty.call(obj,key))newObj[key]=obj[key];}}newObj.default=obj;return newObj;}}function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj};}function _objectWithoutProperties(obj,keys){var target={};for(var i in obj){if(keys.indexOf(i)>=0)continue;if(!Object.prototype.hasOwnProperty.call(obj,i))continue;target[i]=obj[i];}return target;}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor)){throw new TypeError("Cannot call a class as a function");}}function _possibleConstructorReturn(self,call){if(!self){throw new ReferenceError("this hasn't been initialised - super() hasn't been called");}return call&&(typeof call==="object"||typeof call==="function")?call:self;}function _inherits(subClass,superClass){if(typeof superClass!=="function"&&superClass!==null){throw new TypeError("Super expression must either be null or a function, not "+typeof superClass);}subClass.prototype=Object.create(superClass&&superClass.prototype,{constructor:{value:subClass,enumerable:false,writable:true,configurable:true}});if(superClass)Object.setPrototypeOf?Object.setPrototypeOf(subClass,superClass):subClass.__proto__=superClass;} var DEFAULT_BUTTON_PROPS={ color:_style.Colors.blue30};var TopBar=function(_BaseComponent){_inherits(TopBar,_BaseComponent);function TopBar(){_classCallCheck(this,TopBar);return _possibleConstructorReturn(this,(TopBar.__proto__||Object.getPrototypeOf(TopBar)).apply(this,arguments));}_createClass(TopBar,[{key:'generateStyles',value:function generateStyles() { this.styles=createStyles(this.props); }},{key:'renderTopBarButton',value:function renderTopBarButton(_ref) {var onPress=_ref.onPress,label=_ref.label,icon=_ref.icon,buttonProps=_ref.buttonProps; if(onPress&&(label||icon)){var iconStyle=buttonProps.iconStyle,labelStyle=buttonProps.labelStyle,otherButtonProps=_objectWithoutProperties(buttonProps,['iconStyle','labelStyle']); return( _react2.default.createElement(_button2.default,_extends({ link:true, onPress:onPress, label:label, labelStyle:[this.styles.actionLabel,labelStyle], iconSource:icon, iconStyle:[this.styles.icon,iconStyle]}, DEFAULT_BUTTON_PROPS, otherButtonProps,{ hitSlop:{top:6,bottom:6,left:6,right:6}}))); } }},{key:'renderDone',value:function renderDone() {var _props= this.props,doneButtonProps=_props.doneButtonProps,doneLabel=_props.doneLabel,doneIcon=_props.doneIcon,onDone=_props.onDone; return this.renderTopBarButton({ onPress:onDone,label:doneLabel,icon:doneIcon,buttonProps:doneButtonProps}); }},{key:'renderCancel',value:function renderCancel() {var _props2= this.props,cancelButtonProps=_props2.cancelButtonProps,cancelLabel=_props2.cancelLabel,cancelIcon=_props2.cancelIcon,onCancel=_props2.onCancel; return this.renderTopBarButton({ onPress:onCancel,label:cancelLabel,icon:cancelIcon,buttonProps:cancelButtonProps}); }},{key:'render',value:function render() {var _props3= this.props,title=_props3.title,titleStyle=_props3.titleStyle,includeStatusBar=_props3.includeStatusBar; return( _react2.default.createElement(_view2.default,null, includeStatusBar&&_react2.default.createElement(_view2.default,{style:this.styles.statusBar}), _react2.default.createElement(_view2.default,{style:this.styles.container}, _react2.default.createElement(_view2.default,{row:true,flex:true,bottom:true,'paddingL-15':true,centerV:true}, this.renderCancel()), _react2.default.createElement(_view2.default,{row:true,'flex-3':true,bottom:true,centerH:true,centerV:true}, _react2.default.createElement(_text2.default,{numberOfLines:1,text70:true,style:[this.styles.title,titleStyle]},title)), _react2.default.createElement(_view2.default,{row:true,flex:true,bottom:true,right:true,'paddingR-15':true,centerV:true}, this.renderDone())))); }}]);return TopBar;}(_commons.BaseComponent);TopBar.propTypes={title:_react.PropTypes.string,titleStyle:_react.PropTypes.object,doneButtonProps:_react.PropTypes.shape(_button2.default.propTypes),doneLabel:_react.PropTypes.string,doneIcon:_react.PropTypes.oneOfType([_react.PropTypes.object,_react.PropTypes.number]),onDone:_react.PropTypes.func,cancelButtonProps:_react.PropTypes.shape(_button2.default.propTypes),cancelLabel:_react.PropTypes.string,cancelIcon:_react.PropTypes.oneOfType([_react.PropTypes.object,_react.PropTypes.number]),onCancel:_react.PropTypes.func,includeStatusBar:_react.PropTypes.bool};TopBar.defaultProps={doneLabel:'Save',cancelIcon:Assets.icons.x,doneButtonProps:{},cancelButtonProps:{},includeStatusBar:_helpers.Constants.isIOS};exports.default=TopBar; function createStyles(){ return _reactNative.StyleSheet.create({ container:{ flexDirection:'row', height:32+_helpers.Constants.statusBarHeight}, statusBar:{ height:_helpers.Constants.statusBarHeight}, title:{ fontWeight:'500'}, actionLabel:_extends({}, _style.Typography.text70), icon:{ width:16, height:16, tintColor:_style.Colors.dark10, marginBottom:2}}); }