import React from "react";
import gql from "graphql-tag";
import { useQuery } from "@apollo/client";
import OutfitThumbnail, {
outfitThumbnailFragment,
getOutfitThumbnailRenderSize,
} from "../components/OutfitThumbnail";
import OutfitPreview from "../components/OutfitPreview";
function WardrobeOutfitPreview({
isLoading,
outfitState,
onChangeHasAnimations,
}) {
return (
}
/>
);
}
/**
* OutfitThumbnailIfCached will render an OutfitThumbnail as a placeholder for
* the outfit preview... but only if we already have the data to generate the
* thumbnail stored in our local Apollo GraphQL cache.
*
* This means that, when you come from the Your Outfits page, we can show the
* outfit thumbnail instantly while everything else loads. But on direct
* navigation, this does nothing, and we just wait for the preview to load in
* like usual!
*
* We even use it as our "backdrop", so the thumbnail actually _always_ renders
* if possible. This makes loading look even smoother, by letting individual
* layers load in on top of the thumbnail.
* TODO: Can this become a perf problem on WIP outfits?
*/
function OutfitThumbnailIfCached({ outfitId }) {
const { data } = useQuery(
gql`
query OutfitThumbnailIfCached($outfitId: ID!, $size: LayerImageSize!) {
outfit(id: $outfitId) {
id
...OutfitThumbnailFragment
}
}
${outfitThumbnailFragment}
`,
{
variables: {
outfitId,
// NOTE: This parameter is used inside `OutfitThumbnailFragment`!
size: "SIZE_" + getOutfitThumbnailRenderSize(),
},
fetchPolicy: "cache-only",
}
);
if (!data?.outfit) {
return null;
}
return (
);
}
export default WardrobeOutfitPreview;