Text gradient for React-Native
npm install react-native-text-gradient



React-Native text gradient component for iOS & Android.
$ npm install react-native-text-gradient --save
$ react-native link react-native-text-gradient
> If you are using Cocoapods you need to follow the manual installation guide.
- Component works as drop-in replacement for standard Text component and it is possible to have nested gradients.
- React-Native:
- with rn >= 0.59.0 use latest version and patch;
- with rn >= 0.56.0 use 0.0.17 and patch;
- with rn >= 0.55.0 use 0.0.9;
- with rn >= 0.54.0 use 0.0.7;
- with rn >= 0.53.1 use 0.0.4;
- rn 0.53.0 is not supported;
- with rn >= 0.50.0 use 0.0.3.
``javascript
import { LinearTextGradient } from "react-native-text-gradient";
locations={[0, 1]}
colors={["red", "blue"]}
start={{ x: 0, y: 0 }}
end={{ x: 1, y: 0 }}
>
THIS IS TEXT GRADIENT
;
`
| iOS | Android |
| :-----------------------------------------------: | :----------------------------------------------------: |
|
|
|
Interface is similar to Text & LinearGradient
#### colors
An array of at least two color values that represent gradient colors. Example: ['red', 'blue'] sets gradient from red to blue.
#### start
An optional object of the following type: { x: number, y: number }. Coordinates declare the position that the gradient starts at, as a fraction of the overall size of the gradient, starting from the top left corner. Example: { x: 0.1, y: 0.1 } means that the gradient will start 10% from the top and 10% from the left.
#### end
Same as start, but for the end of the gradient.
#### locations
An optional array of numbers defining the location of each gradient color stop, mapping to the color with the same index in colors prop. Example: [0.1, 0.75, 1] means that first color will take 0% - 10%, second color will take 10% - 75% and finally third color will occupy 75% - 100%.
#### useViewFrame
Optional. If true gradient will be calculated for text view background frame rather than text frame.
`javascript`
useViewFrame={true}
locations={[0.5, 0.95]}
// note colors like '#FF000000' are used for seamless transition to transparent
colors={["#FF0000", "#FF000000"]}
start={{ x: 0, y: 0 }}
end={{ x: 1, y: 0 }}
>
%%%%%%%%%%%%%%%%%%%%%%

Wait until https://github.com/facebook/react/pull/13211 will be merged or patch react-native to remove failing invariant checks
$ node node_modules/react-native-text-gradient/patch-rn.js
When mixing several text gradients and Texts top component always should be text gradient.
`javascript``
qwerty
This is necessary because only top text component is 'mapped' to actual native node and its children are 'virtual' from the native perspective.