Skip to content

Commit

Permalink
update resize and tests
Browse files Browse the repository at this point in the history
  • Loading branch information
sarahatwork committed Jan 20, 2018
1 parent 232c50d commit f9a69ea
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 70 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ exports[`contentful extend node type createUrl ignores options it doesn't unders
exports[`contentful extend node type resolveResize generates resized images 1`] = `
Object {
"aspectRatio": 0.75,
"base64": "",
"baseUrl": "//images.contentful.com/ubriaw6jfhm1/10TkaLheGeQG6qQGqWYqUI/5421d3108cbb699561acabd594fa2cb0/ryugj83mqwa1asojwtwb.jpg",
"height": 533,
"src": "//images.contentful.com/ubriaw6jfhm1/10TkaLheGeQG6qQGqWYqUI/5421d3108cbb699561acabd594fa2cb0/ryugj83mqwa1asojwtwb.jpg?w=400",
"width": 400,
Expand All @@ -17,7 +17,7 @@ Object {
exports[`contentful extend node type resolveResize generates resized images using all options 1`] = `
Object {
"aspectRatio": 1.1278195488721805,
"base64": "",
"baseUrl": "//images.contentful.com/ubriaw6jfhm1/10TkaLheGeQG6qQGqWYqUI/5421d3108cbb699561acabd594fa2cb0/ryugj83mqwa1asojwtwb.jpg",
"height": 399,
"src": "//images.contentful.com/ubriaw6jfhm1/10TkaLheGeQG6qQGqWYqUI/5421d3108cbb699561acabd594fa2cb0/ryugj83mqwa1asojwtwb.jpg?w=450&h=399&q=50&fit=fill",
"width": 450,
Expand Down
98 changes: 30 additions & 68 deletions packages/gatsby-source-contentful/src/extend-node-type.js
Original file line number Diff line number Diff line change
Expand Up @@ -72,37 +72,6 @@ const isImage = image =>
_.get(image, `file.contentType`)
)

const getBase64ImageOld = (imgUrl, args = {}) => {
const requestUrl = `https:${imgUrl}?w=20`
// TODO add caching.
return new Promise(resolve => {
base64Img.requestBase64(requestUrl, (a, b, body) => {
resolve(body)
})
})
}

const getBase64ImageAndBasicMeasurements = (image, args) =>
new Promise(resolve => {
getBase64ImageOld(image.file.url, args).then(base64Str => {
let aspectRatio
if (args.width && args.height) {
aspectRatio = args.width / args.height
} else {
aspectRatio =
image.file.details.image.width / image.file.details.image.height
}

resolve({
contentType: image.file.contentType,
base64Str,
aspectRatio,
width: image.file.details.image.width,
height: image.file.details.image.height,
})
})
})

const getBase64Image = (imageProps) => {
if (!imageProps) return null

Expand Down Expand Up @@ -312,39 +281,30 @@ exports.resolveResponsiveSizes = resolveResponsiveSizes
const resolveResize = (image, options) => {
if (!isImage(image)) return null

return new Promise(resolve => {
getBase64ImageAndBasicMeasurements(image, options).then(
({ contentType, base64Str, width, height, aspectRatio }) => {
// If the user selected a height (so cropping) and fit option
// is not set, we'll set our defaults
if (options.height) {
if (!options.resizingBehavior) {
options.resizingBehavior = `fill`
}
}

if (options.base64) {
resolve(base64Str)
return
}

const pickedWidth = options.width
let pickedHeight
if (options.height) {
pickedHeight = options.height
} else {
pickedHeight = pickedWidth / aspectRatio
}
resolve({
src: createUrl(image.file.url, options),
width: Math.round(pickedWidth),
height: Math.round(pickedHeight),
aspectRatio,
base64: base64Str,
})
}
)
})
const { baseUrl, aspectRatio } = getBasicImageProps(image, options)

// If the user selected a height (so cropping) and fit option
// is not set, we'll set our defaults
if (options.height) {
if (!options.resizingBehavior) {
options.resizingBehavior = `fill`
}
}

const pickedWidth = options.width
let pickedHeight
if (options.height) {
pickedHeight = options.height
} else {
pickedHeight = pickedWidth / aspectRatio
}
return {
src: createUrl(image.file.url, options),
width: Math.round(pickedWidth),
height: Math.round(pickedHeight),
aspectRatio,
baseUrl,
}
}

exports.resolveResize = resolveResize
Expand Down Expand Up @@ -545,6 +505,12 @@ exports.extendNodeType = ({ type }) => {
type: new GraphQLObjectType({
name: `ContentfulResize`,
fields: {
base64: {
type: GraphQLString,
resolve(imageProps) {
return getBase64Image(imageProps)
},
},
src: { type: GraphQLString },
width: { type: GraphQLInt },
height: { type: GraphQLInt },
Expand All @@ -570,10 +536,6 @@ exports.extendNodeType = ({ type }) => {
resizingBehavior: {
type: ImageResizingBehavior,
},
base64: {
type: GraphQLBoolean,
defaultValue: false,
},
toFormat: {
type: ImageFormatType,
defaultValue: ``,
Expand Down

0 comments on commit f9a69ea

Please sign in to comment.