@uiw/react-native
Version:
UIW for React Native
185 lines (153 loc) • 16.7 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireDefault(require("react"));
var _reactNative = require("react-native");
var _utils = require("../utils");
var _Div = _interopRequireDefault(require("../Typography/Div"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
class ButtonView extends _react.default.Component {
render() {
const {
children,
style,
textStyle: childStyle,
rounded,
bordered,
color: buttonColor,
type,
size,
disabled,
loading,
...restProps
} = this.props;
let backgroundColor, textColor, borderColor, borderWidth, borderRadius;
switch (type) {
case 'warning':
backgroundColor = _utils.colors.yellow;
break;
case 'primary':
backgroundColor = _utils.colors.blue;
break;
case 'success':
backgroundColor = _utils.colors.green;
break;
case 'danger':
backgroundColor = _utils.colors.red;
break;
case 'light':
backgroundColor = _utils.colors.white;
break;
case 'dark':
backgroundColor = _utils.colors.black;
break;
default:
break;
}
if (backgroundColor) {
backgroundColor = (0, _utils.color)(backgroundColor).rgb().string();
}
if (type) {
textColor = (0, _utils.color)(backgroundColor).isLight() ? (0, _utils.color)(_utils.colors.black).rgb().string() : (0, _utils.color)(_utils.colors.white).rgb().string();
}
if (!type) {
borderColor = (0, _utils.color)(_utils.colors.black).alpha(0.32).rgb().string();
borderWidth = 1;
}
if (disabled) {
textColor = (0, _utils.color)(textColor).alpha(0.3).rgb().string();
}
if (buttonColor) {
backgroundColor = (0, _utils.color)(buttonColor).rgb().string();
textColor = (0, _utils.color)(buttonColor).isLight() ? (0, _utils.color)(buttonColor).darken(0.9).string() : (0, _utils.color)(buttonColor).lighten(0.9).string();
}
if (rounded && typeof rounded === 'number') {
borderRadius = rounded;
}
if (backgroundColor) {
borderColor = (0, _utils.color)(backgroundColor).darken(0.2).string();
borderWidth = 1;
}
if (!bordered) {
borderWidth = 0;
}
const buttonStyle = {
backgroundColor,
borderColor,
borderWidth,
borderRadius
};
const textStyle = {
color: textColor
};
let sizeStyle = {};
if (size && styles[size]) {
sizeStyle = styles[size];
}
let boxStyle = {};
const stylKey = `${size}Box`;
if (size && styles[stylKey]) {
boxStyle = styles[stylKey];
}
if (!children) {
return null;
}
return <_reactNative.TouchableOpacity style={[styles.button, styles.content, buttonStyle, boxStyle, style]} disabled={disabled} {...restProps}>
{loading && <_reactNative.ActivityIndicator size={16} color={textColor} style={styles.icon} />}
{_react.default.Children.toArray(children).map((child, idx) => {
return <_Div.default key={idx} style={[sizeStyle, styles.label, textStyle, childStyle]}>
{child}
</_Div.default>;
})}
</_reactNative.TouchableOpacity>;
}
}
exports.default = ButtonView;
ButtonView.defaultProps = {
activeOpacity: 0.5,
rounded: 5,
bordered: true,
size: 'default'
};
const styles = _reactNative.StyleSheet.create({
button: {
borderStyle: 'solid',
display: 'flex'
},
content: {
flexDirection: 'row',
alignItems: 'center',
justifyContent: 'center'
},
icon: {
width: 16,
marginRight: 4
},
label: {// textAlign: 'center',
},
smallBox: {
paddingHorizontal: 3
},
defaultBox: {
paddingHorizontal: 8
},
largeBox: {
paddingHorizontal: 10
},
small: {
marginVertical: 4,
fontSize: 14
},
default: {
marginVertical: 8,
fontSize: 16
},
large: {
marginVertical: 10,
fontSize: 18
}
});
module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Button/index.tsx"],"names":["ButtonView","React","Component","render","children","style","textStyle","childStyle","rounded","bordered","color","buttonColor","type","size","disabled","loading","restProps","props","backgroundColor","textColor","borderColor","borderWidth","borderRadius","colors","yellow","blue","green","red","white","black","rgb","string","isLight","alpha","darken","lighten","buttonStyle","sizeStyle","styles","boxStyle","stylKey","button","content","icon","Children","toArray","map","child","idx","label","defaultProps","activeOpacity","StyleSheet","create","borderStyle","display","flexDirection","alignItems","justifyContent","width","marginRight","smallBox","paddingHorizontal","defaultBox","largeBox","small","marginVertical","fontSize","default","large"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { StyleSheet, TextProps, TouchableOpacity, ActivityIndicator, TouchableOpacityProps } from 'react-native';\nimport { color, colors } from '../utils';\nimport Div from '../Typography/Div';\n\nexport interface ButtonProps extends TouchableOpacityProps {\n  color?: string;\n  /**\n   * 如果子节点是文本，修改文本样式\n   */\n  textStyle?: TextProps['style'];\n  /**\n   * 设置禁用\n   */\n  disabled?: boolean;\n  /**\n   * 加载状态\n   */\n  loading?: boolean;\n  /**\n   * 按钮类型，可选值为\n   */\n  type?: 'primary' | 'success' | 'warning' | 'danger' | 'light' | 'dark';\n  /**\n   * 按钮尺寸\n   */\n  size?: 'small' | 'default' | 'large';\n  /**\n   * 设置按钮圆角\n   */\n  rounded?: boolean | number;\n  /**\n   * 设置是否显示边框\n   */\n  bordered?: boolean;\n}\n\nexport default class ButtonView<T> extends React.Component<ButtonProps> {\n  static defaultProps: ButtonProps = {\n    activeOpacity: 0.5,\n    rounded: 5,\n    bordered: true,\n    size: 'default',\n  };\n  render() {\n    const {\n      children,\n      style,\n      textStyle: childStyle,\n      rounded,\n      bordered,\n      color: buttonColor,\n      type,\n      size,\n      disabled,\n      loading,\n      ...restProps\n    } = this.props;\n    let backgroundColor, textColor, borderColor, borderWidth, borderRadius;\n\n    switch (type) {\n      case 'warning':\n        backgroundColor = colors.yellow;\n        break;\n      case 'primary':\n        backgroundColor = colors.blue;\n        break;\n      case 'success':\n        backgroundColor = colors.green;\n        break;\n      case 'danger':\n        backgroundColor = colors.red;\n        break;\n      case 'light':\n        backgroundColor = colors.white;\n        break;\n      case 'dark':\n        backgroundColor = colors.black;\n        break;\n      default:\n        break;\n    }\n    if (backgroundColor) {\n      backgroundColor = color(backgroundColor).rgb().string();\n    }\n    if (type) {\n      textColor = color(backgroundColor).isLight()\n        ? color(colors.black).rgb().string()\n        : color(colors.white).rgb().string();\n    }\n    if (!type) {\n      borderColor = color(colors.black).alpha(0.32).rgb().string();\n      borderWidth = 1;\n    }\n    if (disabled) {\n      textColor = color(textColor).alpha(0.3).rgb().string();\n    }\n    if (buttonColor) {\n      backgroundColor = color(buttonColor).rgb().string();\n      textColor = color(buttonColor).isLight()\n        ? color(buttonColor).darken(0.9).string()\n        : color(buttonColor).lighten(0.9).string();\n    }\n    if (rounded && typeof rounded === 'number') {\n      borderRadius = rounded;\n    }\n    if (backgroundColor) {\n      borderColor = color(backgroundColor).darken(0.2).string();\n      borderWidth = 1;\n    }\n    if (!bordered) {\n      borderWidth = 0;\n    }\n    const buttonStyle = {\n      backgroundColor,\n      borderColor,\n      borderWidth,\n      borderRadius,\n    };\n    const textStyle = { color: textColor };\n    let sizeStyle = {};\n    if (size && styles[size]) {\n      sizeStyle = styles[size];\n    }\n    let boxStyle = {};\n    const stylKey = `${size}Box` as keyof typeof styles;\n    if (size && styles[stylKey]) {\n      boxStyle = styles[stylKey];\n    }\n    if (!children) {\n      return null;\n    }\n    return (\n      <TouchableOpacity\n        style={[styles.button, styles.content, buttonStyle, boxStyle, style]}\n        disabled={disabled}\n        {...restProps}\n      >\n        {loading && <ActivityIndicator size={16} color={textColor} style={styles.icon} />}\n        {React.Children.toArray(children).map((child: any, idx) => {\n          return (\n            <Div key={idx} style={[sizeStyle, styles.label, textStyle, childStyle]}>\n              {child}\n            </Div>\n          );\n        })}\n      </TouchableOpacity>\n    );\n  }\n}\n\nconst styles = StyleSheet.create({\n  button: {\n    borderStyle: 'solid',\n    display: 'flex',\n  },\n  content: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'center',\n  },\n  icon: {\n    width: 16,\n    marginRight: 4,\n  },\n  label: {\n    // textAlign: 'center',\n  },\n  smallBox: {\n    paddingHorizontal: 3,\n  },\n  defaultBox: {\n    paddingHorizontal: 8,\n  },\n  largeBox: {\n    paddingHorizontal: 10,\n  },\n  small: {\n    marginVertical: 4,\n    fontSize: 14,\n  },\n  default: {\n    marginVertical: 8,\n    fontSize: 16,\n  },\n  large: {\n    marginVertical: 10,\n    fontSize: 18,\n  },\n});\n"]}