UNPKG

react-native-svg

Version:
47 lines (42 loc) 1.32 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"; // TSpan elements are shadow components export default class TSpan extends Shape { static displayName = "TSpan"; 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 ( <RNSVGTSpan ref={ele => { this.root = ele; }} {...extractProps( { ...props, x: null, y: null, }, this, )} {...extractText(props, false, TSpan)} /> ); } } const RNSVGTSpan = requireNativeComponent("RNSVGTSpan");