diff --git a/src/app/components/OutfitPreview.js b/src/app/components/OutfitPreview.js
index f6d4b08..08f5605 100644
--- a/src/app/components/OutfitPreview.js
+++ b/src/app/components/OutfitPreview.js
@@ -188,7 +188,7 @@ export function OutfitLayers({
isPaused={isPaused}
/>
) : (
- tags are always allowed through CORS), but
@@ -197,30 +197,9 @@ export function OutfitLayers({
// image instead of requesting it again with crossOrigin!
crossOrigin={getBestImageUrlForLayer(layer).crossOrigin}
alt=""
- // We manage the fade-in and fade-out separately! The fade-in
- // happens here, when the finishes preloading and
- // applies the src to the underlying .
- className={cx(
- css`
- object-fit: contain;
- max-width: 100%;
- max-height: 100%;
-
- &.do-animations {
- animation: fade-in 0.2s;
- }
-
- @keyframes fade-in {
- from {
- opacity: 0;
- }
- to {
- opacity: 1;
- }
- }
- `,
- doTransitions && "do-animations"
- )}
+ objectFit="contain"
+ maxWidth="100%"
+ maxHeight="100%"
/>
)}
@@ -371,4 +350,22 @@ export function usePreloadLayers(layers) {
return { loading, error, loadedLayers, layersHaveAnimations };
}
+/**
+ * FadeInImage is like a , but with one extra feature: once the
+ * image loads, we fade in!
+ */
+function FadeInImage(props) {
+ const [isLoaded, setIsLoaded] = React.useState(false);
+
+ return (
+ setIsLoaded(true)}
+ />
+ );
+}
+
export default OutfitPreview;