Calc viewbox
Unanswered
Maltese posted this in #help-forum
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
MalteseOP
Hello! I have a problem that I can't solve. I have a logo created in Figma, and now I want to export it as an SVG and turn it into a React component. For this, I plan to use SVGR. My question is: what is the correct way to do this?
What I'm doing right now is exporting the logo, converting it into a component, but I can't see it in the viewport. I understand why this happens—it's because the logo isn't within the proportions of the viewport. To fix this, I used the viewBox attribute to define the part of the canvas where the logo is and bring it into the viewport. However, this is where I get stuck.
I'm not sure if I'm doing it correctly. I've set arbitrary values for the viewBox just to make sure it captures the logo. Could someone explain the proper way to calculate the viewBox values so I can correctly place the logo in the viewport?
React code:
What I'm doing right now is exporting the logo, converting it into a component, but I can't see it in the viewport. I understand why this happens—it's because the logo isn't within the proportions of the viewport. To fix this, I used the viewBox attribute to define the part of the canvas where the logo is and bring it into the viewport. However, this is where I get stuck.
I'm not sure if I'm doing it correctly. I've set arbitrary values for the viewBox just to make sure it captures the logo. Could someone explain the proper way to calculate the viewBox values so I can correctly place the logo in the viewport?
React code:
import * as React from 'react';
import type { SVGProps } from 'react';
import { Ref, forwardRef } from 'react';
const SvgLogo1Svg = (
props: SVGProps<SVGSVGElement>,
ref: Ref<SVGSVGElement>
) => (
<svg
xmlns="http://www.w3.org/2000/svg"
width="100%"
height="100%"
viewBox="0 0 980 428"
fill="none"
ref={ref}
{...props}
>
<path
fill="#1A2435"
d="M359.392 ..."
/>
<path
fill="#5437F4"
d="M57.02..."
/>
</svg>
);
const ForwardRef = forwardRef(SvgLogo1Svg);
export default ForwardRef;
2 Replies
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
MalteseOP
I have made some corrections in figma, should it looks like that? I mean, I removed the white space around it, is it that the correct way when working with SVGs to take only the needed space?
data:image/s3,"s3://crabby-images/ee170/ee17066a76e976e2035d42cef9a4f6c7d6e80b9d" alt="Image"
because before that, I exported is looking as that
data:image/s3,"s3://crabby-images/0a671/0a671b13de2932275ec7fa73c892609fea92cae4" alt="Image"