UNPKG

react-native-svg

Version:
65 lines (58 loc) 1.85 kB
import React, { Component } from "react"; import { requireNativeComponent } from "react-native"; import units from "../lib/units"; import extractTransform from "../lib/extract/extractTransform"; import extractViewBox from "../lib/extract/extractViewBox"; export default class extends Component { static displayName = "Pattern"; setNativeProps = props => { this.root.setNativeProps(props); }; render() { const { props } = this; const { patternTransform, transform, id, x, y, width, height, patternUnits, patternContentUnits, children, viewBox, preserveAspectRatio, } = props; let extractedTransform; if (patternTransform) { extractedTransform = extractTransform(patternTransform); } else if (transform) { extractedTransform = extractTransform(transform); } else { extractedTransform = extractTransform(props); } return ( <RNSVGPattern ref={ele => { this.root = ele; }} name={id} x={x} y={y} width={width} height={height} matrix={extractedTransform} patternTransform={extractedTransform} patternUnits={units[patternUnits] || 0} patternContentUnits={ patternContentUnits ? units[patternContentUnits] : 1 } {...extractViewBox({ viewBox, preserveAspectRatio })} > {children} </RNSVGPattern> ); } } const RNSVGPattern = requireNativeComponent("RNSVGPattern");