Fix images

This commit is contained in:
Marcus Blättermann 2022-12-14 23:25:27 +01:00
parent fc8c1f33bc
commit 62b9c9c6d7
No known key found for this signature in database
GPG Key ID: A1E1F04008AC450D
7 changed files with 45 additions and 12 deletions

View File

@ -122,10 +122,11 @@ export const getStaticProps: GetStaticProps<PropsPage, ParsedUrlQuery> = async (
const next = const next =
section === 'usage' section === 'usage'
? sidebarUsageFlat.find( ? sidebarUsageFlat.find((item, index) => {
(item, index) => return (
index > 0 && sidebarUsageFlat[index - 1].url === slug && item[0] === '/' index > 0 && sidebarUsageFlat[index - 1].url === slug && item.url[0] === '/'
) )
})
: undefined : undefined
return { return {

View File

@ -29,6 +29,7 @@ import tailoredPipelinesImage from '../public/images/spacy-tailored-pipelines_wi
import { nightly, legacy } from '../meta/dynamicMeta.mjs' import { nightly, legacy } from '../meta/dynamicMeta.mjs'
import Benchmarks from '../docs/usage/_benchmarks-models.mdx' import Benchmarks from '../docs/usage/_benchmarks-models.mdx'
import { ImageFill } from '../src/components/embed'
function getCodeExample(nightly) { function getCodeExample(nightly) {
return `# pip install -U ${nightly ? 'spacy-nightly --pre' : 'spacy'} return `# pip install -U ${nightly ? 'spacy-nightly --pre' : 'spacy'}
@ -113,7 +114,10 @@ const Landing = () => {
> >
<p> <p>
<Link to="https://explosion.ai/custom-solutions" hidden> <Link to="https://explosion.ai/custom-solutions" hidden>
<img src={tailoredPipelinesImage.src} alt="spaCy Tailored Pipelines" /> <ImageFill
image={tailoredPipelinesImage}
alt="spaCy Tailored Pipelines"
/>
</Link> </Link>
</p> </p>
<p> <p>
@ -159,9 +163,8 @@ const Landing = () => {
> >
<p> <p>
<Link to="https://prodi.gy" hidden> <Link to="https://prodi.gy" hidden>
{/** Update image */} <ImageFill
<img image={prodigyImage}
src={prodigyImage.src}
alt="Prodigy: Radically efficient machine teaching" alt="Prodigy: Radically efficient machine teaching"
/> />
</Link> </Link>
@ -203,7 +206,7 @@ const Landing = () => {
<LandingGrid cols={2}> <LandingGrid cols={2}>
<LandingCol> <LandingCol>
<Link to="/usage/projects" hidden> <Link to="/usage/projects" hidden>
<img src={projectsImage.src} /> <ImageFill image={projectsImage} />
</Link> </Link>
<br /> <br />
<br /> <br />
@ -259,8 +262,8 @@ const Landing = () => {
> >
<p> <p>
<Link to="https://course.spacy.io" hidden> <Link to="https://course.spacy.io" hidden>
<img <ImageFill
src={courseImage.src} image={courseImage}
alt="Advanced NLP with spaCy: A free online course" alt="Advanced NLP with spaCy: A free online course"
/> />
</Link> </Link>

View File

@ -18,6 +18,7 @@ export default function Card({ title, to, image, header, small, onClick, childre
<H5 className={classes.title}> <H5 className={classes.title}>
{image && ( {image && (
<div className={classes.image}> <div className={classes.image}>
{/* eslint-disable-next-line @next/next/no-img-element */}
<img src={image} width={35} alt="" /> <img src={image} width={35} alt="" />
</div> </div>
)} )}

View File

@ -1,6 +1,7 @@
import React, { Fragment } from 'react' import React, { Fragment } from 'react'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import classNames from 'classnames' import classNames from 'classnames'
import ImageNext from 'next/image'
import Link from './link' import Link from './link'
import Button from './button' import Button from './button'
@ -88,6 +89,7 @@ const Image = ({ src, alt, title, href, ...props }) => {
return ( return (
<figure className="gatsby-resp-image-figure"> <figure className="gatsby-resp-image-figure">
<Link className={linkClassNames} href={href ?? src} hidden forceExternal> <Link className={linkClassNames} href={href ?? src} hidden forceExternal>
{/* eslint-disable-next-line @next/next/no-img-element */}
<img className={classes.image} src={src} alt={alt} width={650} height="auto" /> <img className={classes.image} src={src} alt={alt} width={650} height="auto" />
</Link> </Link>
{title && ( {title && (
@ -99,6 +101,17 @@ const Image = ({ src, alt, title, href, ...props }) => {
) )
} }
const ImageFill = ({ image, ...props }) => {
return (
<span
class={classes['figure-fill']}
style={{ paddingBottom: `${(image.height / image.width) * 100}%` }}
>
<ImageNext src={image.src} {...props} fill />
</span>
)
}
const GoogleSheet = ({ id, link, height, button = 'View full table' }) => { const GoogleSheet = ({ id, link, height, button = 'View full table' }) => {
return ( return (
<figure className={classes.root}> <figure className={classes.root}>
@ -118,4 +131,4 @@ const GoogleSheet = ({ id, link, height, button = 'View full table' }) => {
) )
} }
export { YouTube, SoundCloud, Iframe, Image, GoogleSheet } export { YouTube, SoundCloud, Iframe, Image, ImageFill, GoogleSheet }

View File

@ -10,6 +10,7 @@ import { H1, Label, InlineList, Help } from './typography'
import Icon from './icon' import Icon from './icon'
import classes from '../styles/title.module.sass' import classes from '../styles/title.module.sass'
import Image from 'next/image'
const MetaItem = ({ label, url, children, help }) => ( const MetaItem = ({ label, url, children, help }) => (
<span> <span>
@ -50,6 +51,7 @@ export default function Title({
{image && ( {image && (
<div className={classes.image}> <div className={classes.image}>
{/* eslint-disable-next-line @next/next/no-img-element */}
<img src={image} width={100} height={100} alt="" /> <img src={image} width={100} height={100} alt="" />
</div> </div>
)} )}

View File

@ -32,6 +32,13 @@
max-width: 100% max-width: 100%
margin: 0 auto margin: 0 auto
.figure-fill
display: block
position: relative
width: 100%
img
object-fit: contain
.image-link .image-link
display: block display: block

View File

@ -20,6 +20,7 @@ import { github, MarkdownToReact } from '../components/util'
import { nightly, legacy } from '../../meta/dynamicMeta.mjs' import { nightly, legacy } from '../../meta/dynamicMeta.mjs'
import universe from '../../meta/universe.json' import universe from '../../meta/universe.json'
import Image from 'next/image'
function filterResources(resources, data) { function filterResources(resources, data) {
const sorted = resources.sort((a, b) => a.id.localeCompare(b.id)) const sorted = resources.sort((a, b) => a.id.localeCompare(b.id))
@ -80,6 +81,7 @@ const UniverseContent = ({ content = [], categories, theme, pageContext, mdxComp
} }
const url = `/universe/project/${id}` const url = `/universe/project/${id}`
const header = youtube && ( const header = youtube && (
// eslint-disable-next-line @next/next/no-img-element
<img <img
src={`https://img.youtube.com/vi/${youtube}/0.jpg`} src={`https://img.youtube.com/vi/${youtube}/0.jpg`}
alt="" alt=""
@ -92,6 +94,7 @@ const UniverseContent = ({ content = [], categories, theme, pageContext, mdxComp
return cover ? ( return cover ? (
<p key={id}> <p key={id}>
<Link key={id} to={url} hidden> <Link key={id} to={url} hidden>
{/* eslint-disable-next-line @next/next/no-img-element */}
<img src={cover} alt={title || id} /> <img src={cover} alt={title || id} />
</Link> </Link>
</p> </p>
@ -205,6 +208,7 @@ const Project = ({ data, components }) => (
`license/${data.github}.svg?style=flat-square`, `license/${data.github}.svg?style=flat-square`,
`stars/${data.github}.svg?style=social&label=Stars`, `stars/${data.github}.svg?style=social&label=Stars`,
].map((url, i) => ( ].map((url, i) => (
// eslint-disable-next-line @next/next/no-img-element
<img <img
style={{ style={{
borderRadius: '1em', borderRadius: '1em',
@ -236,6 +240,7 @@ const Project = ({ data, components }) => (
{data.cover && ( {data.cover && (
<p> <p>
{/* eslint-disable-next-line @next/next/no-img-element */}
<img src={data.cover} alt={data.title} width={250} style={{ maxWidth: '50%' }} /> <img src={data.cover} alt={data.title} width={250} style={{ maxWidth: '50%' }} />
</p> </p>
)} )}
@ -266,6 +271,7 @@ const Project = ({ data, components }) => (
{data.image && ( {data.image && (
<p> <p>
{/* eslint-disable-next-line @next/next/no-img-element */}
<img src={data.image} style={{ maxWidth: '100%' }} alt="" /> <img src={data.image} style={{ maxWidth: '100%' }} alt="" />
</p> </p>
)} )}