Ensure original size is included if any widths are larger and !allowUpscale
#190
+25
−10
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Change
Image.getValidWidths()
logic to ensure original width is included if any larger-than-original widths are requested in the!allowUpscale
case.Added test to cover this scenario.
Fixes #184
From a "what do you expect" standpoint, there are cases where you ask for a specific list of widths (like [300, 1200]), and you might get a width not on that list ([300, 840]). This already happens, though, when upscaling is disabled and you ask only for widths larger than the original. This effectively enables the list of widths to include both a thumbnail width and a maximum width at the same time, ensuring that images narrower than the maximum don't result in only the thumbnail size. (This is useful in photo gallery/lightbox scenarios.)