Skip to content

Commit

Permalink
feat: add frame param to builder
Browse files Browse the repository at this point in the history
Currently only supports a value of `1`, intended to be used
to return the first frame of an animated image.
  • Loading branch information
Jon Ruskin committed Jul 31, 2024
1 parent 0a0f297 commit 4589d66
Show file tree
Hide file tree
Showing 6 changed files with 32 additions and 2 deletions.
6 changes: 6 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -134,6 +134,12 @@ Return the url as a string.

Specify the number of pixels to pad the image.

### `frame(value)`

Specify the frame of an animated image to transform. Acceptable values:

- `1` - Returns the first frame of the animated image as a static preview of the image.

### Deprecated: `minWidth(pixels)`, `maxWidth(pixels)`, `minHeight(pixels)`, `maxHeight(pixels)`

Specifies min/max dimensions when cropping.
Expand Down
8 changes: 8 additions & 0 deletions src/builder.ts
Original file line number Diff line number Diff line change
Expand Up @@ -247,6 +247,14 @@ export class ImageUrlBuilder {
return this.withOptions({pad})
}

frame(frame: number) {
if (frame !== 1) {
throw new Error(`Invalid frame value "${frame}"`)
}

return this.withOptions({frame})
}

// Gets the url based on the submitted parameters
url() {
return urlForImage(this.options)
Expand Down
1 change: 1 addition & 0 deletions src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ export type ImageUrlBuilderOptions = Partial<SanityProjectDetails> & {
saturation?: number
auto?: AutoMode
pad?: number
frame?: number
}

export type ImageUrlBuilderOptionsWithAliases = ImageUrlBuilderOptions & {
Expand Down
1 change: 1 addition & 0 deletions src/urlForImage.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ export const SPEC_NAME_TO_URL_NAME_MAPPINGS = [
['auto', 'auto'],
['dpr', 'dpr'],
['pad', 'pad'],
['frame', 'frame']
]

export default function urlForImage(options: ImageUrlBuilderOptions): string {
Expand Down
6 changes: 4 additions & 2 deletions test/__snapshots__/builder.test.ts.snap
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`builder all hotspot/crop-compatible params 1`] = `"rect=200,300,1600,2400&flip=hv&fm=png&dl=a.png&blur=50&sharp=7&invert=true&or=90&min-h=150&max-h=300&min-w=100&max-w=200&q=50&fit=crop&auto=format&pad=40"`;
exports[`builder all hotspot/crop-compatible params 1`] = `"rect=200,300,1600,2400&flip=hv&fm=png&dl=a.png&blur=50&sharp=7&invert=true&or=90&min-h=150&max-h=300&min-w=100&max-w=200&q=50&fit=crop&auto=format&pad=40&frame=1"`;

exports[`builder all params 1`] = `"rect=10,20,30,40&bg=bf1942&fp-x=10&fp-y=20&flip=hv&fm=png&dl=a.png&blur=50&invert=true&or=90&min-h=150&max-h=300&min-w=100&max-w=200&q=50&fit=crop&crop=center&auto=format&pad=40"`;
exports[`builder all params 1`] = `"rect=10,20,30,40&bg=bf1942&fp-x=10&fp-y=20&flip=hv&fm=png&dl=a.png&blur=50&invert=true&or=90&min-h=150&max-h=300&min-w=100&max-w=200&q=50&fit=crop&crop=center&auto=format&pad=40&frame=1"`;

exports[`builder automatic format 1`] = `"auto=format"`;

Expand All @@ -24,6 +24,8 @@ exports[`builder flip horizontal 1`] = `"flip=h"`;

exports[`builder flip vertical 1`] = `"flip=v"`;

exports[`builder frame = 1 1`] = `"frame=1"`;

exports[`builder handles crop and hotspot being set to null (GraphQL) 1`] = `"https://cdn.sanity.io/images/zp7mbokg/production/Tb9Ew8CXIwaY6R1kjMvI0uRR-2000x3000.jpg"`;

exports[`builder handles crop but no hotspot 1`] = `"https://cdn.sanity.io/images/zp7mbokg/production/Tb9Ew8CXIwaY6R1kjMvI0uRR-2000x3000.jpg?rect=200,300,1600,2400"`;
Expand Down
12 changes: 12 additions & 0 deletions test/builder.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,11 @@ const cases = [
url: stripPath(urlFor.image(noHotspotImage()).pad(50).url()),
},

{
name: 'frame = 1',
url: stripPath(urlFor.image(noHotspotImage()).frame(1).url()),
},

{
name: 'automatic format',
url: stripPath(urlFor.image(noHotspotImage()).auto('format').url()),
Expand Down Expand Up @@ -176,6 +181,7 @@ const cases = [
.flipVertical()
.fit('crop')
.pad(40)
.frame(1)
.url()
),
},
Expand Down Expand Up @@ -204,6 +210,7 @@ const cases = [
.fit('crop')
.crop('center')
.pad(40)
.frame(1)
.url()
),
},
Expand All @@ -230,4 +237,9 @@ describe('builder', () => {
// @ts-ignore: Because we're throwing on invalids
expect(() => urlFor.image(croppedImage()).auto('moo')).toThrowError(/Invalid auto mode "moo"/)
})

test('should throw on invalida frame number', () => {
// @ts-ignore: Because we're throwing on invalids
expect(() => urlFor.image(croppedImage()).frame(2)).toThrowError(/Invalid frame value "2"/)
})
})

0 comments on commit 4589d66

Please sign in to comment.