1
0
Fork 0
freesewing/packages/react-components/src/pattern/snippet.mjs

28 lines
962 B
JavaScript
Raw Normal View History

2023-06-07 10:06:30 -05:00
// eslint-disable-next-line no-unused-vars
import React from 'react'
import { getProps } from './utils.mjs'
export const Snippet = ({ snippet }) => {
if (!snippet?.anchor || !snippet.def) return null
const snippetProps = {
xlinkHref: '#' + snippet.def,
x: snippet.anchor.x,
y: snippet.anchor.y,
}
const scale = snippet.attributes.list['data-scale']?.[0] || false
const rotate = snippet.attributes.list['data-rotate']?.[0] || false
if (scale || rotate) {
snippetProps.transform = ''
if (scale) {
snippetProps.transform += `translate(${snippetProps.x}, ${snippetProps.y}) `
snippetProps.transform += `scale(${scale}) `
snippetProps.transform += `translate(${snippetProps.x * -1}, ${snippetProps.y * -1}) `
}
if (rotate) {
snippetProps.transform += `rotate(${rotate}, ${snippetProps.x}, ${snippetProps.y}) `
}
}
return <use {...snippetProps} {...getProps(snippet)} color="currentColor" />
}