import * as React from 'react'; import { Platform, processColor, View } from 'react-native'; import NativeLinearGradient from './NativeLinearGradient'; import { NativeLinearGradientPoint } from './NativeLinearGradient.types'; export type LinearGradientPoint = { x: number; y: number } | NativeLinearGradientPoint; export type LinearGradientProps = { /** * An array of colors that represent stops in the gradient. At least two colors are required * (for a single-color background, use the `style.backgroundColor` prop on a `View` component). */ colors: string[]; /** * An array that contains `number`s ranging from 0 to 1, inclusive, and is the same length as the `colors` property. * Each number indicates a color-stop location where each respective color should be located. * * For example, `[0.5, 0.8]` would render: * - the first color, solid, from the beginning of the gradient view to 50% through (the middle); * - a gradient from the first color to the second from the 50% point to the 80% point; and * - the second color, solid, from the 80% point to the end of the gradient view. * * The color-stop locations must be ascending from least to greatest. */ locations?: number[] | null; /** * An object `{ x: number; y: number }` or array `[x, y]` that represents the point * at which the gradient starts, as a fraction of the overall size of the gradient ranging from 0 to 1, inclusive. * * For example, `{ x: 0.1, y: 0.2 }` means that the gradient will start `10%` from the left and `20%` from the top. * * **On web**, this only changes the angle of the gradient because CSS gradients don't support changing the starting position. */ start?: LinearGradientPoint | null; /** * An object `{ x: number; y: number }` or array `[x, y]` that represents the point * at which the gradient ends, as a fraction of the overall size of the gradient ranging from 0 to 1, inclusive. * * For example, `{ x: 0.1, y: 0.2 }` means that the gradient will end `10%` from the left and `20%` from the bottom. * * **On web**, this only changes the angle of the gradient because CSS gradients don't support changing the end position. */ end?: LinearGradientPoint | null; } & React.ComponentProps; /** * Renders a native view that transitions between multiple colors in a linear direction. */ export class LinearGradient extends React.Component { render() { const { colors, locations, start, end, ...props } = this.props; let resolvedLocations = locations; if (locations && colors.length !== locations.length) { console.warn('LinearGradient colors and locations props should be arrays of the same length'); resolvedLocations = locations.slice(0, colors.length); } return ( ); } } function _normalizePoint( point: LinearGradientPoint | null | undefined ): [number, number] | undefined { if (!point) { return undefined; } if (Array.isArray(point) && point.length !== 2) { console.warn('start and end props for LinearGradient must be of the format [x,y] or {x, y}'); return undefined; } return Array.isArray(point) ? point : [point.x, point.y]; }