UNPKG

@uiw/react-native

Version:
142 lines (120 loc) 17.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _reactNative = require("react-native"); var _Flex = _interopRequireDefault(require("../Flex")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function MaybeTextOrView({ children, ...otherProps }) { if (typeof children === 'string' || children && children.type.displayName === 'Text') { return <_reactNative.Text {...otherProps}>{children}</_reactNative.Text>; } return <_reactNative.View {...otherProps}>{children}</_reactNative.View>; } const styles = _reactNative.StyleSheet.create({ defalut: { backgroundColor: '#fff' }, touchWarpper: { flex: 1, width: '100%', alignItems: 'center', justifyContent: 'center' } }); class Grid extends _react.Component { render() { const { style, data, iconStyle, textStyle, itemStyle, renderItem, hasLine, columns = 4, onPress, ...otherProps } = this.props; if (!Array.isArray(data)) { return null; } const childs = []; let childItem = []; data.forEach((item, idx) => { if (idx !== 0 && idx % columns === 0) { childs.push(childItem); childItem = []; } let icon = null; if (_react.default.isValidElement(item.icon)) { icon = item.icon; } else if (item.icon) { icon = <_reactNative.Image style={[{ width: 36, height: 36 }, _reactNative.StyleSheet.flatten(iconStyle)]} source={typeof item.icon === 'number' ? item.icon : { uri: item.icon }} />; } if (renderItem && typeof renderItem === 'function') { childItem.push(renderItem(item, idx, parseInt((idx / columns).toString(), 10) + 1)); } else { const itemContent = <_react.Fragment> {icon && <MaybeTextOrView style={iconStyle}>{icon}</MaybeTextOrView>} <MaybeTextOrView style={[{ marginTop: 9, fontSize: 12 }, textStyle]}>{item.text}</MaybeTextOrView> </_react.Fragment>; childItem.push(<_Flex.default direction="column" align="center" justify="center" style={[{ height: 120 }, _reactNative.StyleSheet.flatten(itemStyle), { width: `${100 / columns}%` }]}> {onPress ? <_reactNative.TouchableOpacity style={styles.touchWarpper} onPress={onPress.bind(this, item, idx, parseInt((idx / columns).toString(), 10) + 1)}> {itemContent} </_reactNative.TouchableOpacity> : itemContent} </_Flex.default>); } if (idx === data.length - 1) { childs.push(childItem); } }); return <_reactNative.View style={[styles.defalut, style]} {...otherProps}> {childs.map((rowitem, rowidx) => <_Flex.default justify="start" key={rowidx}> {rowitem.map((item, idx) => { if (!_react.default.isValidElement(item)) { return null; } const itemBorderStyle = {}; if (hasLine) { const hairLineWidth = _reactNative.StyleSheet.hairlineWidth; itemBorderStyle.borderBottomWidth = childs.length - 1 === rowidx ? 0 : hairLineWidth; itemBorderStyle.borderRightWidth = rowitem.length - 1 === idx && rowitem.length === columns ? 0 : hairLineWidth; itemBorderStyle.borderBottomColor = '#ddd'; itemBorderStyle.borderRightColor = '#ddd'; } return _react.default.cloneElement(item, { key: idx, style: [itemBorderStyle, item.props.style] }); })} </_Flex.default>)} </_reactNative.View>; } } exports.default = Grid; Grid.defaultProps = { data: [], hasLine: true }; module.exports = exports.default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Grid/index.tsx"],"names":["MaybeTextOrView","children","otherProps","type","displayName","styles","StyleSheet","create","defalut","backgroundColor","touchWarpper","flex","width","alignItems","justifyContent","Grid","Component","render","style","data","iconStyle","textStyle","itemStyle","renderItem","hasLine","columns","onPress","props","Array","isArray","childs","childItem","forEach","item","idx","push","icon","React","isValidElement","height","flatten","uri","parseInt","toString","itemContent","marginTop","fontSize","text","bind","length","map","rowitem","rowidx","itemBorderStyle","hairLineWidth","hairlineWidth","borderBottomWidth","borderRightWidth","borderBottomColor","borderRightColor","cloneElement","key","defaultProps"],"mappings":"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","sourcesContent":["import React, { Component, Fragment } from 'react';\nimport {\n  View,\n  ViewProps,\n  ViewStyle,\n  Text,\n  TextStyle,\n  StyleProp,\n  Image,\n  ImageStyle,\n  TextProps,\n  TouchableOpacity,\n  GestureResponderEvent,\n  StyleSheet,\n} from 'react-native';\nimport Flex from '../Flex';\n\ninterface MaybeTextOrViewProps {\n  children?: React.ReactNode;\n}\n\nfunction MaybeTextOrView({ children, ...otherProps }: MaybeTextOrViewProps & TextProps & ViewProps) {\n  if (typeof children === 'string' || (children && (children as any).type.displayName === 'Text')) {\n    return <Text {...otherProps}>{children}</Text>;\n  }\n  return <View {...otherProps}>{children}</View>;\n}\n\nconst styles = StyleSheet.create({\n  defalut: {\n    backgroundColor: '#fff',\n  },\n  touchWarpper: {\n    flex: 1,\n    width: '100%',\n    alignItems: 'center',\n    justifyContent: 'center',\n  },\n});\n\ninterface ItemData {\n  icon?: React.ReactNode;\n  text?: React.ReactNode;\n}\n\nexport interface GridProps extends ViewProps {\n  data?: ItemData[];\n  columns?: number;\n  hasLine?: boolean;\n  itemStyle?: StyleProp<ViewStyle>;\n  textStyle?: StyleProp<TextStyle & ViewStyle>;\n  iconStyle?: StyleProp<ImageStyle & TextStyle & ViewStyle>;\n  renderItem?: (data: ItemData, index: number, row: number) => React.ReactNode;\n  onPress?: (data: ItemData, index: number, row: number, event: GestureResponderEvent) => void;\n}\n\nexport default class Grid extends Component<GridProps> {\n  static defaultProps: GridProps = {\n    data: [],\n    hasLine: true,\n  };\n  render() {\n    const {\n      style,\n      data,\n      iconStyle,\n      textStyle,\n      itemStyle,\n      renderItem,\n      hasLine,\n      columns = 4,\n      onPress,\n      ...otherProps\n    } = this.props;\n    if (!Array.isArray(data)) {\n      return null;\n    }\n    const childs: React.ReactNode[][] = [];\n    let childItem: React.ReactNode[] = [];\n    data.forEach((item, idx) => {\n      if (idx !== 0 && idx % columns === 0) {\n        childs.push(childItem);\n        childItem = [];\n      }\n      let icon = null;\n      if (React.isValidElement(item.icon)) {\n        icon = item.icon;\n      } else if (item.icon) {\n        icon = (\n          <Image\n            style={[{ width: 36, height: 36 }, StyleSheet.flatten(iconStyle)]}\n            source={typeof item.icon === 'number' ? item.icon : { uri: item.icon as string }}\n          />\n        );\n      }\n      if (renderItem && typeof renderItem === 'function') {\n        childItem!.push(renderItem(item, idx, parseInt((idx / columns).toString(), 10) + 1));\n      } else {\n        const itemContent = (\n          <Fragment>\n            {icon && <MaybeTextOrView style={iconStyle}>{icon}</MaybeTextOrView>}\n            <MaybeTextOrView style={[{ marginTop: 9, fontSize: 12 }, textStyle]}>{item.text}</MaybeTextOrView>\n          </Fragment>\n        );\n        childItem!.push(\n          <Flex\n            direction=\"column\"\n            align=\"center\"\n            justify=\"center\"\n            style={[{ height: 120 }, StyleSheet.flatten(itemStyle), { width: `${100 / columns}%` }]}\n          >\n            {onPress ? (\n              <TouchableOpacity\n                style={styles.touchWarpper}\n                onPress={onPress.bind(this, item, idx, parseInt((idx / columns).toString(), 10) + 1)}\n              >\n                {itemContent}\n              </TouchableOpacity>\n            ) : (\n              itemContent\n            )}\n          </Flex>,\n        );\n      }\n      if (idx === data.length - 1) {\n        childs.push(childItem);\n      }\n    });\n    return (\n      <View style={[styles.defalut, style]} {...otherProps}>\n        {childs.map((rowitem, rowidx) => (\n          <Flex justify=\"start\" key={rowidx}>\n            {rowitem.map((item, idx) => {\n              if (!React.isValidElement(item)) {\n                return null;\n              }\n              const itemBorderStyle: ViewProps['style'] = {};\n              if (hasLine) {\n                const hairLineWidth = StyleSheet.hairlineWidth;\n                itemBorderStyle.borderBottomWidth = childs.length - 1 === rowidx ? 0 : hairLineWidth;\n                itemBorderStyle.borderRightWidth =\n                  rowitem.length - 1 === idx && rowitem.length === columns ? 0 : hairLineWidth;\n                itemBorderStyle.borderBottomColor = '#ddd';\n                itemBorderStyle.borderRightColor = '#ddd';\n              }\n              return React.cloneElement(item as React.ReactElement, {\n                key: idx,\n                style: [itemBorderStyle, item.props.style],\n              });\n            })}\n          </Flex>\n        ))}\n      </View>\n    );\n  }\n}\n"]}