Portfolio website written with Next.js
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
wychdev-nextjs/components/scrollme.tsx

55 lines
1.1 KiB

/* import Link from "next/link"; */
import * as React from "react";
import { SVGProps } from "react";
import styled from "styled-components";
const ScrollMeWrapper = styled.div`
position: absolute;
bottom: 2rem;
left: 50%;
color: var(--fg-faded);
@media only screen and (max-height: 490px) {
display: none;
}
:hover {
cursor: pointer;
}
svg {
width: 1.2rem;
height: auto;
}
`;
const ScrollMe = (props: SVGProps<SVGSVGElement> & { href: string }) => {
const handleScroll = () => {
const sectionRef = document.querySelector(props.href);
if (sectionRef) {
sectionRef.scrollIntoView({ behavior: "smooth" });
}
}
return (
<ScrollMeWrapper onClick={handleScroll}>
<svg
xmlns="http://www.w3.org/2000/svg"
height="1em"
viewBox="0 0 38 23"
stroke="currentColor"
fill="none"
{...props}
>
<path
strokeLinecap="round"
strokeLinejoin="round"
strokeWidth={2.8}
d="m2 2 15.77 17.369a2 2 0 0 0 2.96 0L36.5 2"
/>
</svg>
</ScrollMeWrapper>
);
};
export default ScrollMe;