Skip to content

Commit

Permalink
Merge branch 'main' into feat/cookie-consent-legal-texts
Browse files Browse the repository at this point in the history
  • Loading branch information
virus-rpi authored Nov 28, 2024
2 parents f47e312 + b1e6063 commit 4d52429
Showing 1 changed file with 45 additions and 41 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import React, { useEffect, useState } from 'react';
import styled, { keyframes } from 'styled-components';
import styled, { css, keyframes } from 'styled-components';

interface RaindropProps {
color: string;
Expand All @@ -13,7 +13,6 @@ interface RaindropProps {
interface SnowflakeProps {
fallDuration: number;
size: number;
animation: any;
blur: number;
transparency: number;
left: number;
Expand Down Expand Up @@ -50,47 +49,55 @@ interface SplashData {
}

const fallAnimation = keyframes`
0% {
transform: translateY(-75px);
opacity: 0;
}
100% {
transform: translateY(150vh);
opacity: 1;
}
0% {
transform: translateY(-75px);
opacity: 0;
}
100% {
transform: translateY(150vh);
opacity: 1;
}
`;

const splashAnimation = keyframes`
0% {
opacity: 1;
transform: scale(0);
}
80% {
opacity: 1;
transform: scale(0);
}
90% {
opacity: 0.5;
transform: scale(1);
}
100% {
opacity: 0;
transform: scale(1.5);
}
0% {
opacity: 1;
transform: scale(0);
}
80% {
opacity: 1;
transform: scale(0);
}
90% {
opacity: 0.5;
transform: scale(1);
}
100% {
opacity: 0;
transform: scale(1.5);
}
`;

const generateSwayAnimation = (initialX: number, range: number) => keyframes`
0% {
transform: translateX(0);
}
50% {
transform: translateX(${initialX + Math.random() * range - range / 2}px);
}
100% {
transform: translateX(${
initialX + (Math.random() * range) / 2 - range / 4
}px);
}
0% {
transform: translateX(0);
}
50% {
transform: translateX(${initialX + Math.random() * range - range / 2}px);
}
100% {
transform: translateX(${
initialX + (Math.random() * range) / 2 - range / 4
}px);
}
`;

const swayAnimation = (snowflake: {
left: number;
fallDuration: number;
}) => css`
${generateSwayAnimation(snowflake.left, 400)} ${snowflake.fallDuration /
3}s ease-in-out infinite alternate;
`;

const Splash = styled.div<SplashProps>`
Expand Down Expand Up @@ -128,8 +135,7 @@ const Snowflake = styled.div<SnowflakeProps>`
width: ${(props) => props.size}px;
height: ${(props) => props.size}px;
border-radius: 150%;
animation: ${(props) => props.animation} ${(props) => props.fallDuration / 3}s
ease-in-out infinite alternate;
animation: ${swayAnimation};
background: radial-gradient(
50% 50% at 50% 50%,
rgba(255, 255, 255, ${(props) => props.transparency}) 0%,
Expand Down Expand Up @@ -222,7 +228,6 @@ const PrecipitationEffect = ({
return (
<>
{snowflakes.map((snowflake) => {
const swayAnimation = generateSwayAnimation(snowflake.left, 400);
return (
<SnowflakeContainer
key={snowflake.id}
Expand All @@ -238,7 +243,6 @@ const PrecipitationEffect = ({
(snowflake.fallDuration * 5 - snowflake.fallDuration * 3) *
1.5
}
animation={swayAnimation}
left={snowflake.left}
top={-75}
animation_delay={snowflake.delay}
Expand Down

0 comments on commit 4d52429

Please sign in to comment.