From d3701ba28ae007f65eb29cc54554d55e84f81030 Mon Sep 17 00:00:00 2001 From: yude Date: Mon, 22 Jan 2024 17:08:22 +0900 Subject: [PATCH] Improve card hiding --- src/App.tsx | 117 +++++++++++++++++----------------------------------- 1 file changed, 37 insertions(+), 80 deletions(-) diff --git a/src/App.tsx b/src/App.tsx index fe9063c..5b7feb3 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -1,106 +1,63 @@ import Card from "./components/Card" +import Profile from "./components/Profile" +import Works from "./components/Works" -import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' -import { faChevronDown } from '@fortawesome/free-solid-svg-icons' - -import React, { useState, useEffect } from 'react'; +import { useState, useEffect } from 'react'; export default function App() { - const [scrollPercentage, setScrollPercentage] = useState(0); const [cardY, setCardY] = useState(0); const [contentY, setContentY] = useState(0); + + const cardElm = document.getElementById("card"); + const contentElm = document.getElementById("content"); + const [cardOpacity, setCardOpacity] = useState(1.0); const handleScroll = () => { + const card = Math.max((window.innerHeight / 2) - window.scrollY, 0); setCardY(card); - - const windowHeight = window.innerHeight; - const fullHeight = document.documentElement.scrollHeight; - const currentPosition = window.scrollY; - - const scrollPercentage = (currentPosition / (fullHeight - windowHeight)); - - setScrollPercentage(scrollPercentage); setContentY(card + (window.innerHeight / 2)); - console.log(scrollPercentage) + }; + useEffect(() => { + const a = cardElm?.getBoundingClientRect().bottom + const b = contentElm?.getBoundingClientRect().top + if (a && b) { + if (a - b > 0 && a - b < 100) { + setCardOpacity((100 - (a - b)) / 100) + } else if (a - b < 0) { + setCardOpacity(100) + } else { + setCardOpacity(0) + } + } + }, [cardY, contentY]) + useEffect(() => { handleScroll(); window.addEventListener('scroll', handleScroll); - return () => { window.removeEventListener('scroll', handleScroll); }; }, []); - useEffect(() => { - handleScroll(); - window.addEventListener('scroll', handleScroll, { passive: true }); - return () => { - window.removeEventListener('scroll', handleScroll); - }; - }, []); - return ( -
-
-
- -

{document.documentElement.clientHeight}, {(window.innerHeight / 2) - window.scrollY}

-
-
- -
-
-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

-

AAAAAAAAAA

+ <> +
+
+
-
- + +
+
+ + +
+ +
© 2024 yude
+
+ ) }