Skip to content

Commit

Permalink
feat(native): log unsupported components
Browse files Browse the repository at this point in the history
  • Loading branch information
gregberge committed Dec 7, 2017
1 parent 7cd92c3 commit 888d968
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 5 deletions.
2 changes: 2 additions & 0 deletions src/cli/__snapshots__/index.test.js.snap
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,8 @@ exports[`cli --native 1`] = `
"import React from \\"react\\";
import Svg, { Path } from \\"react-native-svg\\";
// SVGR has dropped some elements not supported by react-native-svg: title
const One = props => (
<Svg width={48} height={1} viewBox=\\"0 0 48 1\\" {...props}>
<Path d=\\"M0 0h48v1H0z\\" fill=\\"#063855\\" fillRule=\\"evenodd\\" />
Expand Down
5 changes: 3 additions & 2 deletions src/h2x/toReactNative.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,15 +30,16 @@ const toReactNative = () => ({
const component = elementToComponent[path.node.name]
if (component) {
path.node.name = component
state.reactNativeSvgReplacedComponents = state.reactNativeSvgReplacedComponents || new Set()
state.reactNativeSvgReplacedComponents =
state.reactNativeSvgReplacedComponents || new Set()
state.reactNativeSvgReplacedComponents.add(component)
return
}

// Remove element if not supported
if (!componentToElement[path.node.name]) {
state.unsupportedComponents = state.unsupportedComponents || new Set()
state.unsupportedComponents.add(component)
state.unsupportedComponents.add(path.node.name)
path.remove()
}
},
Expand Down
20 changes: 17 additions & 3 deletions src/transforms/wrapIntoNativeComponent.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,27 @@
const componentsToImport = components =>
const componentsToList = components =>
[...components].filter(component => component !== 'Svg').join(', ')

const logUnsupportedComponents = components => {
if (!components.size) return ''
return `
// SVGR has dropped some elements not supported by react-native-svg: ${componentsToList(
components,
)}
`
}

export default (opts = {}) => (code, state) => {
const { reactNativeSvgReplacedComponents = new Set() } = state
const {
reactNativeSvgReplacedComponents = new Set(),
unsupportedComponents = new Set(),
} = state

return `import React from 'react'
import Svg, { ${componentsToImport(
import Svg, { ${componentsToList(
reactNativeSvgReplacedComponents,
)} } from 'react-native-svg';
${logUnsupportedComponents(unsupportedComponents)}
const ${state.componentName} = (${opts.expandProps ? 'props' : ''}) => ${code}
Expand Down

0 comments on commit 888d968

Please sign in to comment.