Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Add new image resolvers #27443

Merged
merged 174 commits into from
Oct 29, 2020
Merged
Show file tree
Hide file tree
Changes from 155 commits
Commits
Show all changes
174 commits
Select commit Hold shift + click to select a range
4814d60
Add static image plugin
ascorbic Sep 16, 2020
5509d90
Parse static image files
ascorbic Sep 16, 2020
6585d84
Fix package.json
ascorbic Sep 16, 2020
83b0321
Better static analysis
ascorbic Sep 17, 2020
b430e5a
Use jsx utils package
ascorbic Sep 18, 2020
96df1b8
Fix typings
ascorbic Sep 18, 2020
f98f56a
Typecheck fix
ascorbic Sep 18, 2020
e48da0a
Fix repo fields
ascorbic Sep 21, 2020
c11c2a4
Helpful warning
ascorbic Sep 21, 2020
7f16e80
Re-enable duotone
ascorbic Sep 22, 2020
146bd6e
Update readme
ascorbic Sep 22, 2020
f46f3e0
Improve typings
ascorbic Sep 22, 2020
65d06a4
Merge branch 'master' into feat/static-image-babel
ascorbic Sep 29, 2020
45a223f
wip fixed image fields for tracedSVG and webP
gillkyle Sep 30, 2020
836fe1d
handle fluid images as well
gillkyle Sep 30, 2020
97a5b77
Use require rather than JSON import
ascorbic Oct 1, 2020
46e5807
Watch files for changes, and use relative paths
ascorbic Oct 1, 2020
0d66f40
Merge branch 'add-missing-static-image-fields' into feat/static-image…
ascorbic Oct 1, 2020
5e41c30
Improve types
ascorbic Oct 1, 2020
0ebbf06
Add type
ascorbic Oct 2, 2020
41a3cce
Merge branch 'master' into feat/static-image-babel
ascorbic Oct 2, 2020
12597fa
Update yarn.lock
ascorbic Oct 2, 2020
4036bb3
Add lots of comments and remove unused stuff
ascorbic Oct 2, 2020
b548429
Create and watch our own nodes
ascorbic Oct 2, 2020
3242599
Update readme
ascorbic Oct 2, 2020
935e91a
Merge remote-tracking branch 'origin/master' into feat/static-image-b…
ascorbic Oct 2, 2020
70616e2
Update deps
ascorbic Oct 2, 2020
67ea9ef
Only watch in develop
ascorbic Oct 2, 2020
4f68363
Rename to gatsby-plugin-image
ascorbic Oct 5, 2020
f5dc9f7
Rearrange, ready for merger
ascorbic Oct 5, 2020
13e1ca8
Import @wardpeet 's gatsby-image-netxtgen
ascorbic Oct 5, 2020
6569d06
Update typings and further merge packages
ascorbic Oct 5, 2020
f3598f0
Build babel plugin
ascorbic Oct 5, 2020
94e4b7e
More merging
ascorbic Oct 5, 2020
7635d59
Add server/browser static image variants
ascorbic Oct 5, 2020
5060df6
include webpack changes
Oct 5, 2020
812ab51
change error message to use gatsby-plugin-image
Oct 5, 2020
80c9155
Merge remote-tracking branch 'origin/master' into feat/static-image-b…
ascorbic Oct 6, 2020
5f1aa5a
Fix compat compilation
ascorbic Oct 6, 2020
4f8824e
Fix SSR
ascorbic Oct 6, 2020
5155374
Merge readmes
ascorbic Oct 6, 2020
e93480f
Build browser bundle
ascorbic Oct 6, 2020
e581396
Export correctly from browser entry point
ascorbic Oct 6, 2020
f6e1156
Remove hook import
ascorbic Oct 6, 2020
24ffaa2
Apply suggestions from code review
ascorbic Oct 6, 2020
ff4d0a9
Merge branch 'feat/static-image-babel' of github.com:gatsbyjs/gatsby …
ascorbic Oct 6, 2020
ea4bf65
Changes from review
ascorbic Oct 6, 2020
2e5912f
add path prefix, static image do e2e test
Oct 6, 2020
aee3dc9
Add prepare script
ascorbic Oct 7, 2020
9ecea93
Apply README suggestions from code review
ascorbic Oct 7, 2020
284d34c
Fix image component in e2e test
ascorbic Oct 7, 2020
8badae4
Better error messages
ascorbic Oct 7, 2020
121e344
Merge branch 'feat/static-image-babel' of github.com:gatsbyjs/gatsby …
ascorbic Oct 7, 2020
618bd75
Prefer svg over base64. Warn for unsupported art direction
ascorbic Oct 7, 2020
e2d84d8
Fix type
ascorbic Oct 7, 2020
f84853f
Use "layout" instead of fixed/fluid
ascorbic Oct 7, 2020
31b8594
add static images to production runtime site
Oct 7, 2020
cc7c571
add path prefix tests
Oct 7, 2020
5426dcf
Reorg types. Change private prop name
ascorbic Oct 7, 2020
a3305a9
Merge branch 'feat/static-image-babel' of github.com:gatsbyjs/gatsby …
ascorbic Oct 7, 2020
a80fa20
initial gatsby static image tests
Oct 7, 2020
3f15544
add test suite to circle ci
Oct 7, 2020
d891b8d
add test suite to circle ci
Oct 7, 2020
0a19484
add test suite to circle ci
Oct 7, 2020
c97041c
remove unused imports, use valid fluid setting
Oct 7, 2020
1c2c89e
Use new fluid props syntax
ascorbic Oct 8, 2020
127840e
Better var name
ascorbic Oct 8, 2020
8e93857
update tests
Oct 8, 2020
8125d34
remove tests that no longer match the expected DOM
Oct 8, 2020
a76ea81
Merge branch 'feat/static-image-babel' of github.com:gatsbyjs/gatsby …
ascorbic Oct 8, 2020
5aa7ec6
Merge remote-tracking branch 'origin/master' into feat/static-image-b…
ascorbic Oct 9, 2020
f999a45
More compat-fixes
ascorbic Oct 9, 2020
81e7ee7
Change classname to match old version
ascorbic Oct 9, 2020
df2e14b
Compat improvements
ascorbic Oct 9, 2020
a4d991e
Update tests to match new classname
ascorbic Oct 9, 2020
2a8d141
Merge remote-tracking branch 'upstream/master' into feat/static-image…
Oct 9, 2020
6d05bc1
Merge remote-tracking branch 'origin/master' into feat/static-image-b…
ascorbic Oct 13, 2020
46f33b7
v0.0.1
ascorbic Oct 13, 2020
b2620c7
Add readme caveat
ascorbic Oct 13, 2020
870ceff
Update version in packages
ascorbic Oct 13, 2020
5db8d30
Remove forcewrapper
ascorbic Oct 13, 2020
c095f4b
wip
ascorbic Oct 13, 2020
02e6495
have static image use gatsbyImageProps function
Oct 13, 2020
4de8330
Merge remote-tracking branch 'origin/master' into feat/image-resolvers
ascorbic Oct 14, 2020
683b57a
Upgrade sharp
ascorbic Oct 14, 2020
559b571
Fix static image type
ascorbic Oct 14, 2020
d52c4a0
First steps to update API
ascorbic Oct 14, 2020
13e3423
Add descriptions
ascorbic Oct 14, 2020
1d440ce
Merge remote-tracking branch 'origin/master' into feat/static-image-b…
ascorbic Oct 14, 2020
03e894a
Merge branch 'feat/static-image-babel' into feat/image-resolvers
ascorbic Oct 14, 2020
60d554f
TypeScript fixes
ascorbic Oct 14, 2020
d5b1f1a
Compile ts
ascorbic Oct 14, 2020
f78bb88
Merge remote-tracking branch 'origin/master' into feat/image-resolvers
ascorbic Oct 15, 2020
6a0c0b0
Add @gillkyle's calculateImageSizes util funciton
ascorbic Oct 15, 2020
86f9af0
remove unused file
Oct 15, 2020
9e1f556
unbump sharp until sharp PR is merged
Oct 15, 2020
ffddd6f
comment out import
Oct 15, 2020
70cdb59
update snapshots
Oct 15, 2020
c1558f2
change JSX to take image prop
Oct 15, 2020
3127a0a
static image uses new image props
Oct 15, 2020
4a31afb
Rename all the things
ascorbic Oct 15, 2020
4b57129
Turns out it wasn't all of them
ascorbic Oct 15, 2020
a1d967d
Update schema
ascorbic Oct 15, 2020
b601e9d
fix intrinsic issue 1px problem, still doesn't seem to reach the corr…
Oct 15, 2020
a5ba190
Fix layout
ascorbic Oct 16, 2020
1e1dba6
Update readme
ascorbic Oct 16, 2020
e1b3b62
Merge remote-tracking branch 'origin/master' into feat/image-resolvers
ascorbic Oct 16, 2020
edb5a7a
Fix dep
ascorbic Oct 16, 2020
8449710
Shouldn;t be in this
ascorbic Oct 16, 2020
1888a2f
Fix sharp function name
ascorbic Oct 16, 2020
8568329
Version
ascorbic Oct 16, 2020
483adb8
Merge remote-tracking branch 'origin/master' into feat/image-resolvers
ascorbic Oct 16, 2020
6abf47d
What is this snapshot out of date?
ascorbic Oct 16, 2020
f30d823
Add a helper funciton
ascorbic Oct 16, 2020
abd9052
Make backgroundColor work
ascorbic Oct 16, 2020
b0e1a39
update layout for images
Oct 16, 2020
dc905ac
no longer using base64 so remove that test
Oct 16, 2020
6307d9b
placeholder not getting passed from static, so this is still busted
Oct 16, 2020
cde4d27
Fix passing of props
ascorbic Oct 16, 2020
267af4d
Merge branch 'feat/image-resolvers' of github.com:gatsbyjs/gatsby int…
ascorbic Oct 16, 2020
a02fadb
Add TODO comments
ascorbic Oct 16, 2020
03e26e8
Merge remote-tracking branch 'origin/master' into feat/image-resolvers
ascorbic Oct 19, 2020
2a78089
Merge remote-tracking branch 'origin/master' into feat/image-resolvers
ascorbic Oct 19, 2020
087d792
Export batch queue function
ascorbic Oct 19, 2020
48ffac8
Handle the default sizes elsewhere, as it depends on layout
ascorbic Oct 19, 2020
99d5c77
feat(gatsby-plugin-sharp): create image sizes helper (#27554)
gillkyle Oct 20, 2020
dd903e7
Use passed-in reporter
ascorbic Oct 20, 2020
6f96517
Use shared function to handle fit calculation
ascorbic Oct 20, 2020
b048019
Return presentationW/H and aspect ratio from sizes function
ascorbic Oct 20, 2020
0924270
Round sizes
ascorbic Oct 20, 2020
050450d
Use new resizing functions
ascorbic Oct 20, 2020
b49e8c8
default layout wasn't passed to createImageSizes
Oct 20, 2020
0809801
add fixed width default and round calculated height
Oct 20, 2020
f65ed05
reversed logic for aspect ratio calculations
gillkyle Oct 20, 2020
2a08433
Merge remote-tracking branch 'origin' into feat/image-resolvers
ascorbic Oct 21, 2020
ee0f51a
Correct description for outputPixelDensities resolver
ascorbic Oct 21, 2020
22f4e8a
Remove log
ascorbic Oct 21, 2020
9523fc3
Handle null image in SSR
ascorbic Oct 21, 2020
d6c0b3b
Version fix
ascorbic Oct 21, 2020
59ee72c
fix(gatsby-plugin-utils): skip libcheck during typegen
ascorbic Oct 21, 2020
046a614
Remove unused func
ascorbic Oct 21, 2020
35df109
Remove dominantColor from fixed and fluid
ascorbic Oct 22, 2020
0108c2c
sizing code for KG to drive refactor
Oct 22, 2020
130ba02
remove isSmaller
gillkyle Oct 22, 2020
8fbca1d
fix tests
gillkyle Oct 22, 2020
3c264eb
Merge remote-tracking branch 'origin' into feat/image-resolvers
ascorbic Oct 23, 2020
838b01a
Fix sizes and srcset generation
ascorbic Oct 23, 2020
781af53
Merge branch 'feat/image-resolvers' of github.com:gatsbyjs/gatsby int…
ascorbic Oct 23, 2020
92768e1
Add object-fit
ascorbic Oct 23, 2020
72645ad
rename placeholder function for consistency
Oct 23, 2020
2f73b31
Update readme
ascorbic Oct 23, 2020
d7d8617
Merge branch 'feat/image-resolvers' of github.com:gatsbyjs/gatsby int…
ascorbic Oct 23, 2020
abda06a
fix path prefix images
Oct 23, 2020
a086ef7
Merge branch 'feat/image-resolvers' of https://github.com/gatsbyjs/ga…
Oct 23, 2020
2a9b0fe
fix sizing when larger image dimensions are requested, fix warning as…
Oct 23, 2020
f3e114a
rename file to match constrained naming
Oct 23, 2020
b5c546a
Changes from review
ascorbic Oct 26, 2020
89764a8
Merge remote-tracking branch 'origin' into feat/image-resolvers
ascorbic Oct 26, 2020
950b131
Add alpha warning
ascorbic Oct 26, 2020
2568f00
Change from review
ascorbic Oct 26, 2020
43bb48b
fix placeholder opacity
Oct 26, 2020
fb616c3
fix placeholder bug
Oct 26, 2020
3508808
only change placeholder size for background color div
Oct 26, 2020
d66f3b2
tests: Add visual regression tests (#27619)
ascorbic Oct 27, 2020
9c3b7cb
Fix e2e test
ascorbic Oct 27, 2020
d0ff2c8
Merge branch 'feat/image-resolvers' of github.com:gatsbyjs/gatsby int…
ascorbic Oct 27, 2020
f9e36bb
Merge remote-tracking branch 'origin' into feat/image-resolvers
ascorbic Oct 27, 2020
4cfc7c3
Merge remote-tracking branch 'origin' into feat/image-resolvers
ascorbic Oct 27, 2020
de6c6a1
dont flash placeholder image when removing opacity
gillkyle Oct 27, 2020
b0c27ec
Merge branch 'feat/image-resolvers' of github.com:gatsbyjs/gatsby int…
gillkyle Oct 27, 2020
d8675ce
Fix dependency
ascorbic Oct 27, 2020
96118ca
add analagous tests for static image
gillkyle Oct 28, 2020
a33d4f6
Add width to constrained images and update snapshots
ascorbic Oct 29, 2020
b4a8e60
Use float
ascorbic Oct 29, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 0 additions & 8 deletions e2e-tests/gatsby-static-image/cypress/integration/image.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,12 +31,4 @@ describe(`Production gatsby-image`, () => {
})
})

describe(`fallback image`, () => {
it(`renders base-64 src`, () => {
cy.getTestElement(fluidTestId)
.find(`.gatsby-image-wrapper > img`)
.should(`have.attr`, `src`)
.and(`contains`, `base64`)
})
})
})
8 changes: 4 additions & 4 deletions e2e-tests/gatsby-static-image/src/pages/fluid.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,26 +8,26 @@ const FluidPage = () => (
<div data-testid="image-fluid">
<StaticImage
src="../images/citrus-fruits.jpg"
layout="responsive"
layout="fluid"
alt="Citrus fruits"
/>
</div>
<div data-testid="image-fluid-png">
<StaticImage
src="../images/gatsby-icon.png"
layout="responsive"
layout="fluid"
alt="Gatsby icon"
/>
</div>
<div data-testid="image-fluid-relative">
<StaticImage
src="../../content/relative.jpg"
layout="responsive"
layout="fluid"
alt="Citrus fruits"
/>
</div>
<div data-testid="invalid-image">
<StaticImage src="./does-not-exist.jpg" layout="responsive" />
<StaticImage src="./does-not-exist.jpg" layout="fluid" />
</div>
</Layout>
)
Expand Down
8 changes: 4 additions & 4 deletions e2e-tests/gatsby-static-image/src/pages/intrinsic.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,26 +8,26 @@ const FluidPage = () => (
<div data-testid="image-fluid">
<StaticImage
src="../images/citrus-fruits.jpg"
layout="intrinsic"
laurieontech marked this conversation as resolved.
Show resolved Hide resolved
layout="constrained"
alt="Citrus fruits"
/>
</div>
<div data-testid="image-fluid-png">
<StaticImage
src="../images/gatsby-icon.png"
layout="intrinsic"
layout="constrained"
alt="Gatsby icon"
/>
</div>
<div data-testid="image-fluid-relative">
<StaticImage
src="../../content/relative.jpg"
layout="intrinsic"
layout="constrained"
alt="Citrus fruits"
/>
</div>
<div data-testid="invalid-image">
<StaticImage src="./does-not-exist.jpg" layout="intrinsic" />
<StaticImage src="./does-not-exist.jpg" layout="constrained" />
</div>
</Layout>
)
Expand Down
6 changes: 3 additions & 3 deletions e2e-tests/gatsby-static-image/src/pages/traced.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,21 +8,21 @@ const FluidPage = () => (
<div data-testid="image-traced">
<StaticImage
src="../images/citrus-fruits.jpg"
tracedSVG
placeholder="tracedSVG"
alt="Citrus fruits"
/>
</div>
<div data-testid="image-traced-png">
<StaticImage
src="../images/gatsby-icon.png"
tracedSVG
placeholder="tracedSVG"
alt="Gatsby icon"
/>
</div>
<div data-testid="image-traced-relative">
<StaticImage
src="../../content/relative.jpg"
tracedSVG
placeholder="tracedSVG"
alt="Citrus fruits"
/>
</div>
Expand Down
156 changes: 83 additions & 73 deletions packages/gatsby-plugin-image/README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# Experimental image plugin

This plugin is a replacement for gatsby-image. It adds [static images](#static-images), and a [new higher-performance gatsby-image component](#gatsby-image-next-generation).
It also adds [a new GraphQL resolver](#graphql-resolver) to gatsby-transformer-sharp

This package is in alpha, and the API will change. It is not ready for production use yet, but feedback would be great.

Expand All @@ -12,7 +13,7 @@ Install `gatsby-plugin-image` and `gatsby-plugin-sharp`, then add them to your `

This plugin is a proof of concept for a simpler way to use Gatsby's image processing tools and components without needing to write GraphQL queries. It is designed for static images such as logos rather than ones loaded dynamically from a CMS.

The current way to do this is with `useStaticQuery`:
The old way to do this is with `useStaticQuery`:

```js
import React from "react"
Expand Down Expand Up @@ -57,7 +58,8 @@ import { StaticImage } from "gatsby-plugin-image"
export const Dino = () => (
<StaticImage
src="trex.png"
base64={false}
placeholder="none"
layout="fluid"
grayscale
maxWidth={200}
alt="T-Rex"
Expand Down Expand Up @@ -169,9 +171,7 @@ Note: gatsby-image is not a drop-in replacement for <img />. It's optimized for
- [Solution](#solution)
- [Install](#install)
- [How to use](#how-to-use)
- [Types of Responsive Images](#two-types-of-responsive-images)
- [Fixed Queries](#fixed-queries)
- [Fluid Queries](#fluid-queries)
- [Types of Responsive Images](#three-types-of-responsive-images)
- [Gatsby Image Props](#gatsby-plugin-image-props)

## Problem
Expand Down Expand Up @@ -261,51 +261,31 @@ module.exports = {
This is what a component using `gatsby-plugin-image` looks like:

```jsx
// TODO We don't have proper Fragments yet so this isn't user friendly yet
import * as React from "react"
import { graphql } from "gatsby"
import { GatsbyImage } from "gatsby-plugin-image"

export default ({ data }) => (
<div>
<h1>Hello gatsby-image</h1>
<GatsbyImage
placeholder={{ fallback: data.file.childImageSharp.fixed.fallback }}
images={{
fallback: {
src: data.file.childImageSharp.fixed.src,
srcSet: data.file.childImageSharp.fixed.srcSet,
},
sources: [
{
src: data.file.childImageSharp.fixed.srcWebp,
srcSet: data.file.childImageSharp.fixed.srcSetWebp,
type: "image/webp",
},
],
}}
width={data.file.childImageSharp.fixed.width}
height={data.file.childImageSharp.fixed.height}
layout="fixed"
alt="my gatsby image"
/>
</div>
)
import { GatsbyImage, getImage } from "gatsby-plugin-image"

export default ({ data }) => {
// You can use the helper function `getImage`, which is equivalent to:
// const imageData = data.file.childImageSharp.gatsbyImage.imageData
const imageData = getImage(data.file)

return (
<div>
<h1>Hello gatsby-image</h1>
<GatsbyImage image={imageData} alt="my gatsby image" />
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So good

</div>
)
}

export const query = graphql`
query {
file(relativePath: { eq: "blog/avatars/kyle-mathews.jpeg" }) {
childImageSharp {
# Specify the image processing specifications right in the query.
# Makes it trivial to update as your page's design changes.
fixed(width: 125, height: 125) {
fallback: base64
width
height
src
srcSet
srcWebp
srcSetWebp
gatsbyImage(layout: FIXED, width: 125, height: 125) {
imageData
}
}
}
Expand Down Expand Up @@ -344,46 +324,76 @@ export const query = graphql`
`
```

## Two types of responsive images
## Three types of responsive images

There are two types of responsive images supported by gatsby-image.
There are three types of responsive images supported by gatsby-image.

1. Images that have a _fixed_ width and height
1. Images that stretch across a _fluid_ container
1. Images that stretch across a container but are _constrained_ to a maximum width

In the first scenario, you want to vary the image's size for different screen
resolutions -- in other words, create retina images.

For the second scenario, you want to create multiple sizes of thumbnails for
For the second and third scenario, you want to create multiple sizes of thumbnails for
devices with widths stretching from smartphone to wide desktop monitors.

To decide between the two, ask yourself: "do I know what the exact size of this image
will be?" If yes, it's the first type. If no and its width and/or height need to
vary depending on the size of the screen, then it's the second type.

In Gatsby's GraphQL implementation, you query for the first type by querying a
child object of an image called `fixed` — which you can see in the sample
component above. For the second type, you do a similar query but for a child
object called `fluid`.

## `gatsby-plugin-image` props

| Name | Type | Description |
| ----------------------- | --------------- | ----------------------------------------------------------- |
| placeholder | object | Object holding the placeholder image |
| placeholder.fallback | string | Source for the image |
| images | array | List of different image sources (WebP, ...) |
| images.fallback | object | |
| images.fallback.src | string | The image src if srcset is not supported |
| images.fallback.srcSet | string | |
| images.fallback.sizes | string | |
| images.sources | array | List of different image sources (WebP, ...) |
| images.sources[].srcSet | string | |
| images.sources[].sizes | string | |
| images.sources[].type | string | |
| images.sources[].media | string | |
| layout | string | "fixed", "responsive" or "intrinsic" are values for layout. |
| alt | string | Passed to the `img` element. Defaults to an empty string |
| width | number | Width of the image |
| height | number | Height of the image |
| as | React Component | The component that wraps the Gatsby Image. |
will be?" If yes, it's "fixed". If no and its width and/or height need to
vary depending on the size of the screen, then it's "fluid". If you want it to shrink
to fit on smaller screens, but not to expand larger than a maximum, then use "constrained"

In Gatsby's GraphQL implementation, you specify the type of image with the `layout` argument

## `GatsbyImage` props

| Name | Type | Description |
| ----- | --------------- | -------------------------------------------------------------------------------------------------------------------------- |
| image | object | The image data object returned from a GraphQL query |
| alt | string | Passed to the `img` element. Defaults to an empty string |
| sizes | string | An HTML "sizes" argument, which is passed-though to the image. Can be left blank, when it will be calculated automatically |
| as | React Component | The component that wraps the Gatsby Image. Default is `div` |

# GraphQL resolver

We have added a new resolver to the `ImageSharp` node, with a single field `imageData`. Unlike the existing `fixed` and `fluid` resolvers, this returns a
JSON type, meaning you don't specify the individual fields, but are instead given the whole object. This is because the object is then passed in to the `<GatsbyImage>` component. The API is like this:

```graphql
coverImage: file(relativePath: { eq: "plant.jpg" }) {
childImageSharp {
gatsbyImage(maxWidth: 720, layout: FLUID, placeholder: TRACED_SVG) {
imageData
}
}
}
```

```jsx
import { GatsbyImage, getImage } from "gatsby-plugin-image"

export function Plant({ data }) {
const imageData = getImage(data.coverImage)
return <GatsbyImage image={imageData} />
}
```

The helper function `getImage` takes a file node and returns `file?.childImageSharp?.gatsbyImage?.imageData`

Because this no longer uses fragments to specify which fields to return, it instead uses arguments passed to the resolver. These include:

- `placeholder`: Format of generated placeholder image.
DOMINANT*COLOR: a solid color, calculated from the dominant color of the image. (default) \_Currently disabled until sharp is updated*
BLURRED: a blurred, low resolution image, encoded as a base64 data URI
TRACED_SVG: a low-resolution traced SVG of the image.
NONE: no placeholder. Set "background" to use a fixed background color.
- `layout`: The layout for the image.
FIXED: A static image sized, that does not resize according to the screen width
FLUID: The image resizes to fit its container. Pass a "sizes" option if it isn't going to be the full width of the screen.
CONSTRAINED: Resizes to fit its container, up to a maximum width, at which point it will remain fixed in size.
- `outputPixelDensities`: A list of image pixel densities to generate, for high-resolution (retina) screens. It will never generate images larger than the source, and will always a 1x image.
Default is [ 0.25, 0.5, 1, 2 ], for fluid/constrained images, and [ 1, 2 ] for fixed. In this case, an image with a fluid layout and maxWidth = 400 would generate images at 100, 200, 400 and 800px wide

- `sizes`: The "sizes" property, passed to the img tag. This describes the display size of the image.
This does not affect the generated images, but is used by the browser to decide which images to download. You can leave this blank for fixed images, or if the responsive image
container will be the full width of the screen. In these cases we will generate an appropriate value.
21 changes: 14 additions & 7 deletions packages/gatsby-plugin-image/src/babel-helpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@ import { getAttributeValues } from "babel-jsx-utils"

export const SHARP_ATTRIBUTES = new Set([
`src`,
`layout`,
pvdz marked this conversation as resolved.
Show resolved Hide resolved
`maxWidth`,
`maxHeight`,
`quality`,
`jpegQuality`,
`pngQuality`,
Expand All @@ -15,16 +18,20 @@ export const SHARP_ATTRIBUTES = new Set([
`pngCompressionSpeed`,
`rotate`,
`duotone`,
`layout`,
`maxWidth`,
`maxHeight`,
`srcSetBreakpoints`,
`fit`,
`background`,
`width`,
`height`,
`tracedSVG`,
`placeholder`,
`tracedSVGOptions`,
`webP`,
`outputPixelDensities`,
`sizes`,
`fit`,
`background`,
`base64Width`,
`jpegProgressive`,
`toFormatBase64`,
`trim`,
`srcSetBreakpoints`,
])

export function evaluateImageAttributes(
Expand Down
Loading