UNPKG

react-native-svg

Version:
48 lines (42 loc) 1.3 kB
import React from "react"; import _ from "lodash"; import { requireNativeComponent } from "react-native"; import extractText from "../lib/extract/extractText"; import extractProps from "../lib/extract/extractProps"; import extractTransform from "../lib/extract/extractTransform"; import Shape from "./Shape"; import TSpan from "./TSpan"; export default class extends Shape { static displayName = "Text"; setNativeProps = props => { const matrix = !props.matrix && extractTransform(props); if (matrix) { props.matrix = matrix; } const text = _.pickBy(extractText(props, true, TSpan), p => !_.isNil(p)); this.root.setNativeProps({ ...props, ...text, }); }; render() { const props = this.props; return ( <RNSVGText ref={ele => { this.root = ele; }} {...extractProps( { ...props, x: null, y: null, }, this, )} {...extractText(props, true, TSpan)} /> ); } } const RNSVGText = requireNativeComponent("RNSVGText");