import React from 'react'; import { StyleSheet, View } from 'react-native'; import { requireNativeViewManager } from '@unimodules/core'; type Props = { colors: number[]; locations?: number[] | null; startPoint?: Point | null; endPoint?: Point | null; } & React.ComponentProps; type Point = [number, number]; export default class NativeLinearGradient extends React.Component { render() { let { colors, locations, startPoint, endPoint, children, style, ...props } = this.props; // TODO: revisit whether we need to inherit the container's borderRadius since this issue has // been resolved: https://github.com/facebook/react-native/issues/3198 let flatStyle = StyleSheet.flatten(style) || {}; let borderRadius = flatStyle.borderRadius || 0; // This is the format from: // https://developer.android.com/reference/android/graphics/Path.html#addRoundRect(android.graphics.RectF,%20float[],%20android.graphics.Path.Direction) let borderRadiiPerCorner = [ flatStyle.borderTopLeftRadius || borderRadius, flatStyle.borderTopLeftRadius || borderRadius, flatStyle.borderTopRightRadius || borderRadius, flatStyle.borderTopRightRadius || borderRadius, flatStyle.borderBottomRightRadius || borderRadius, flatStyle.borderBottomRightRadius || borderRadius, flatStyle.borderBottomLeftRadius || borderRadius, flatStyle.borderBottomLeftRadius || borderRadius, ]; return ( {children} ); } } const BaseNativeLinearGradient = requireNativeViewManager('ExpoLinearGradient');