style: updating collection loading for mobile (#5434)

This commit is contained in:
Jack Short 2022-11-29 13:36:46 -05:00 committed by GitHub
parent af2725ec25
commit 18f64d6dac
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 10 additions and 84 deletions

@ -2,7 +2,6 @@ import clsx from 'clsx'
import { getDeltaArrow } from 'components/Tokens/TokenDetails/PriceChart'
import { Box, BoxProps } from 'nft/components/Box'
import { Column, Row } from 'nft/components/Flex'
import { Marquee } from 'nft/components/layout/Marquee'
import { themeVars } from 'nft/css/sprinkles.css'
import { useIsCollectionLoading } from 'nft/hooks/useIsCollectionLoading'
import { GenieCollection, TokenType } from 'nft/types'
@ -255,14 +254,15 @@ const StatsItem = ({ children, label, shouldHide }: { children: ReactNode; label
}
const statsLoadingSkeleton = (isMobile: boolean) =>
new Array(5).fill(null).map((_, index) => (
new Array(isMobile ? 3 : 5).fill(null).map((_, index) => (
<Box
display="flex"
flexDirection={isMobile ? 'row' : 'column'}
flexDirection="column"
alignItems="baseline"
gap="2"
height="min"
key={`statsLoadingSkeleton-key-${index}`}
marginBottom={isMobile ? '12' : '0'}
>
<div className={styles.statsLabelLoading} />
<span className={styles.statsValueLoading} />
@ -334,7 +334,7 @@ const StatsRow = ({ stats, isMobile, ...props }: { stats: GenieCollection; isMob
export const CollectionStatsLoading = ({ isMobile }: { isMobile: boolean }) => {
return (
<Column marginTop={isMobile ? '20' : '0'} position="relative" width="full">
<Column position="relative" width="full">
<Box className={styles.collectionImageIsLoadingBackground} />
<Box className={styles.collectionImageIsLoading} />
<Box className={styles.statsText}>
@ -342,19 +342,18 @@ export const CollectionStatsLoading = ({ isMobile }: { isMobile: boolean }) => {
{!isMobile && (
<>
<CollectionDescriptionLoading />
<Row gap={{ sm: '20', md: '60' }} marginTop="20">
{statsLoadingSkeleton(isMobile)}
<Row gap="60" marginTop="20">
{statsLoadingSkeleton(false)}
</Row>
</>
)}
</Box>
{isMobile && (
<>
<Marquee>
<Row gap={{ sm: '20', md: '60' }} marginX="6" marginY="28">
{statsLoadingSkeleton(isMobile)}
<CollectionDescriptionLoading />
<Row gap="20" marginTop="20">
{statsLoadingSkeleton(true)}
</Row>
</Marquee>
</>
)}
</Column>

@ -1,26 +0,0 @@
import { globalKeyframes, style } from '@vanilla-extract/css'
import { sprinkles } from '../../css/sprinkles.css'
globalKeyframes('scroll', {
'0%': {
transform: 'translateX(0%)',
},
'100%': {
transform: 'translateX(-100%)',
},
})
export const marquee = style([
sprinkles({
minWidth: 'full',
zIndex: '1',
display: 'flex',
flexDirection: 'row',
alignItems: 'center',
}),
{
flex: '0 0 auto',
animation: 'scroll var(--duration) linear infinite',
},
])

@ -1,47 +0,0 @@
import { Box } from 'nft/components/Box'
import * as styles from 'nft/components/layout/Marquee.css'
import { ReactNode, useEffect, useRef, useState } from 'react'
export const Marquee = ({ children, speed = 20 }: { children: ReactNode; speed?: number }) => {
const [duration, setDuration] = useState(0)
const containerRef = useRef<HTMLDivElement | null>(null)
const marqueeRef = useRef<HTMLDivElement | null>(null)
const updateScrollDuration = () => {
let containerWidth = 0
let marqueeWidth = 0
try {
if (marqueeRef.current && containerRef.current) {
containerWidth = containerRef.current.getBoundingClientRect().width
marqueeWidth = marqueeRef.current.getBoundingClientRect().width
}
} catch (e) {}
if (marqueeWidth < containerWidth) {
setDuration(containerWidth / speed)
} else {
setDuration(marqueeWidth / speed)
}
}
useEffect(() => {
updateScrollDuration()
// Rerender on window resize
window.addEventListener('resize', updateScrollDuration)
return () => {
window.removeEventListener('resize', updateScrollDuration)
}
})
return (
<Box ref={containerRef} overflowX="hidden" display="flex" flexDirection="row" position="relative" width="full">
<div ref={marqueeRef} style={{ ['--duration' as string]: `${duration}s` }} className={styles.marquee}>
{children}
</div>
<div style={{ ['--duration' as string]: `${duration}s` }} className={styles.marquee}>
{children}
</div>
</Box>
)
}