2024-05-09 06:02:42 -05:00
|
|
|
// import { Banner, IconInfo32, Link, Textbox } from '@create-figma-plugin/ui';
|
|
|
|
import { Banner, IconInfo32, Textbox } from '@create-figma-plugin/ui';
|
2024-05-09 05:56:45 -05:00
|
|
|
import { Controller, useFormContext } from 'react-hook-form';
|
|
|
|
|
|
|
|
import { Stack } from './Stack';
|
2024-05-03 06:43:07 -05:00
|
|
|
|
|
|
|
type MissingFontsSectionProps = {
|
|
|
|
fonts?: string[];
|
|
|
|
};
|
|
|
|
|
|
|
|
export const MissingFontsSection = ({ fonts }: MissingFontsSectionProps) => {
|
2024-05-09 05:56:45 -05:00
|
|
|
if (!fonts || !fonts.length) return null;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Stack space="small">
|
|
|
|
<Stack space="xsmall">
|
|
|
|
<Banner icon={<IconInfo32 />}>
|
|
|
|
{fonts.length} custom font{fonts.length > 1 ? 's' : ''} detected
|
|
|
|
</Banner>
|
|
|
|
<span>To export your file with custom fonts, please follow these steps:</span>
|
|
|
|
<Stack as="ol" space="xsmall" style={{ paddingLeft: '1rem' }}>
|
|
|
|
<li>
|
|
|
|
Upload your local fonts in Penpot.
|
2024-05-09 06:02:42 -05:00
|
|
|
{/* <br />
|
2024-05-09 05:56:45 -05:00
|
|
|
<Link href="https://www.google.com" target="_blank" rel="noreferrer">
|
|
|
|
Learn how to do it.
|
2024-05-09 06:02:42 -05:00
|
|
|
</Link> */}
|
2024-05-09 05:56:45 -05:00
|
|
|
</li>
|
|
|
|
<li>Copy and paste the font IDs from Penpot below.</li>
|
|
|
|
</Stack>
|
|
|
|
</Stack>
|
|
|
|
{fonts.map(font => (
|
|
|
|
<Stack space="2xsmall" key={font}>
|
|
|
|
<ControlledTextbox name={font} placeholder="Paste font ID from Penpot" />
|
|
|
|
<span>{font}</span>
|
|
|
|
</Stack>
|
|
|
|
))}
|
|
|
|
</Stack>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
type ControlledTextboxProps = { name: string; placeholder: string };
|
2024-05-03 06:43:07 -05:00
|
|
|
|
2024-05-09 05:56:45 -05:00
|
|
|
const ControlledTextbox = ({ name, placeholder }: ControlledTextboxProps) => {
|
|
|
|
const { control } = useFormContext();
|
2024-05-03 06:43:07 -05:00
|
|
|
|
|
|
|
return (
|
2024-05-09 05:56:45 -05:00
|
|
|
<Controller
|
|
|
|
control={control}
|
|
|
|
name={name}
|
|
|
|
render={({ field: { onChange, onBlur, value } }) => (
|
|
|
|
<Textbox
|
|
|
|
onChange={onChange}
|
|
|
|
onBlur={onBlur}
|
|
|
|
value={value}
|
|
|
|
placeholder={placeholder}
|
|
|
|
variant="border"
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
/>
|
2024-05-03 06:43:07 -05:00
|
|
|
);
|
|
|
|
};
|