1
0
Fork 0
freesewing/packages/freesewing.shared/components/workbench/draft/index.js

42 lines
969 B
JavaScript
Raw Normal View History

2022-01-29 14:51:13 +01:00
import SvgWrapper from './svg-wrapper'
2022-01-28 16:57:07 +01:00
import Error from './error.js'
2022-01-25 11:22:09 +01:00
2022-01-28 16:57:07 +01:00
const LabDraft = props => {
2022-01-30 15:14:44 +01:00
const { app, draft, pattern, gist, updateGist, unsetGist } = props
if (!draft) return null
2022-01-28 16:57:07 +01:00
2022-01-30 15:14:44 +01:00
if (gist?.renderer === 'svg') {
// Render as SVG
let svg
try { svg = draft.render() }
catch(error) {
console.log('Failed to render pattern', error)
return <Error error={error} {...props} />
}
2022-01-28 16:57:07 +01:00
return <div dangerouslySetInnerHTML={{ __html: svg }} />
2022-01-30 15:14:44 +01:00
}
2022-01-28 16:57:07 +01:00
// Render as React
let patternProps = {}
2022-01-30 15:14:44 +01:00
try { patternProps = draft.draft().getRenderProps() }
2022-01-28 16:57:07 +01:00
catch(error) {
console.log('Failed to get render props for pattern', error)
2022-01-30 15:14:44 +01:00
return <Error error={error} {...props} />
2022-01-28 16:57:07 +01:00
}
2022-01-25 11:22:09 +01:00
return (
2022-01-28 16:57:07 +01:00
<div>
<SvgWrapper
2022-01-30 15:14:44 +01:00
draft={draft}
2022-01-29 14:51:13 +01:00
patternProps={patternProps}
gist={gist}
updateGist={updateGist}
unsetGist={unsetGist}
app={app}
/>
2022-01-28 16:57:07 +01:00
</div>
2022-01-25 11:22:09 +01:00
)
}
export default LabDraft