react-image-diff
Zero-dependency React component providing different modes for diffing or comparing images. The image format is the same as that generated by jest-image-snapshot
, a three part image with the order old-diff-new. All styles are inline for maximum portability.
Four image comparison modes
split
Drag a handle to view a split of old vs new
data:image/s3,"s3://crabby-images/6eef7/6eef7d84c0aba4971bcea110c374f2486a8141a5" alt="split"
blend
Using a native input
slider, fade the new image over the old
data:image/s3,"s3://crabby-images/3ded0/3ded0e73ca65c4194a9c76bedcaad080bc5752c4" alt="blend"
pixel-diff
Show the diff image directly
data:image/s3,"s3://crabby-images/38c78/38c788d9342df1a0d4ddb9e865257d87e88b6efd" alt="pixel diff"
side-by-size
Display both image side-by-size
data:image/s3,"s3://crabby-images/dbeae/dbeaec125c9ef4be0ab09c0f19d4b2442f839efb" alt="side-by-side"
Configuration
showOverlay
Generate a magenta overlay to highlight small changes.
data:image/s3,"s3://crabby-images/3a408/3a4087b22e484fe3658c29cf316a43463bae76f7" alt="overlay"
showFullSize
By default the component will responsively fit the image into the container size. Set showFullSize
to true
to display the image at its full size.
data:image/s3,"s3://crabby-images/2c6a8/2c6a8a825aaf05b0938599d93286762adefa16c6" alt="full size"
showDivider
Defaults to true. Shows an orange divider line between the old and new images in split
mode. Set to false
to hide.
data:image/s3,"s3://crabby-images/14f27/14f2762ba5f4baca88971ed1e593c70461992831" alt="no divider"
hasPadding
Defaults to false. Adds padding around the images with a standard checkerboard pattern. Makes it easier to see the edges of the images.
data:image/s3,"s3://crabby-images/64ba0/64ba0b477ef223a40c9db069ab4fd4e444d3d4eb" alt="padding"
Building
npm run build
Demo
Since ImageDiff
does not include any configuration controls, the demo is a simple showcase of the modes and options.
npm run demo:watch
npm run demo:serve