Skip to content

Commit

Permalink
improv: footer and responsiveness
Browse files Browse the repository at this point in the history
  • Loading branch information
pranavvraja committed Oct 4, 2024
1 parent cb5aa80 commit 182072e
Show file tree
Hide file tree
Showing 5 changed files with 124 additions and 97 deletions.
3 changes: 2 additions & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 7 additions & 6 deletions src/components/Footer.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import Link from "next/link";
import React from "react";
import TextGlitch from "./edil-ozi/text-glitch";

type Props = {};

Expand All @@ -26,8 +27,8 @@ const Footer = (props: Props) => {
</div>
<div className="flex flex-col mt-8">
<div className="flex flex-col mx-8">
<h1 className="text-2xl font-bold my-4">Contact</h1>
<p>
<h1 className="text-xl font-bold my-4">Contact</h1>
<p className="text-lg">
Dr. Binu K G :{" "}
<a href="tel:+91-9739866947" className="text-red-600">
+91-9739866947
Expand All @@ -40,19 +41,19 @@ const Footer = (props: Props) => {
</h1>
<Link
href={"https://instagram.com/tedxsjec"}
className="underline hover:decoration-4 transition-all decoration-red-600 my-2"
className=" my-2 text-xl"
rel="noopener noreferrer"
target="_blank"
>
Instagram
<TextGlitch text="Instagram" />
</Link>
<Link
href={"https://www.linkedin.com/company/tedxsjec"}
className="underline hover:decoration-4 transition-all decoration-red-600"
className="text-xl"
rel="noopener noreferrer"
target="_blank"
>
LinkedIn
<TextGlitch text="LinkedIn" />
</Link>
</div>
</div>
Expand Down
178 changes: 90 additions & 88 deletions src/components/HorizontalScrollCarousel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,109 +3,111 @@ import { motion, useTransform, useScroll } from "framer-motion";
import { useRef } from "react";

const HorizontalScroll = () => {
return (
<div className="bg-transparent">
<HorizontalScrollCarousel />
</div>
);
return (
<div className="bg-transparent">
<HorizontalScrollCarousel />
</div>
);
};

const HorizontalScrollCarousel = () => {
const targetRef = useRef<HTMLDivElement | null>(null);
const { scrollYProgress } = useScroll({
target: targetRef,
});
const targetRef = useRef<HTMLDivElement | null>(null);
const { scrollYProgress } = useScroll({
target: targetRef,
});

const x = useTransform(scrollYProgress, [0, 1], ["5%", "-50%"]);
const x = useTransform(scrollYProgress, [0, 1], ["5%", "-50%"]);

return (
<section ref={targetRef} className="relative h-[300vh] ">
<div className="sticky top-0 flex h-screen items-center overflow-hidden">
<motion.div style={{ x }} className="flex gap-4">
<h1 className="text-7xl ml-5 uppercase text-[#ff0000] font-extrabold mb-0">The Team</h1>
{cards.map((card) => {
return <Card card={card} key={card.id} />;
})}
</motion.div>
</div>
</section>
);
return (
<section ref={targetRef} className="relative h-[300vh] ">
<div className="sticky top-0 flex h-screen items-center overflow-hidden">
<motion.div style={{ x }} className="flex gap-4">
<h1 className="text-7xl ml-5 uppercase text-[#ff0000] font-extrabold mb-0">
The Team
</h1>
{cards.map((card) => {
return <Card card={card} key={card.id} />;
})}
</motion.div>
</div>
</section>
);
};

const Card = ({ card }: { card: CardType }) => {
return (
<div
key={card.id}
className="group relative h-[450px] w-[450px] rounded-3xl mr-4 overflow-hidden bg-neutral-200"
>
<div
style={{
backgroundImage: `url(${card.url})`,
backgroundSize: "cover",
backgroundPosition: "center",
}}
className="absolute inset-0 z-0 transition-transform duration-300 group-hover:scale-110"
></div>
<div className="absolute bottom-0 w-full z-10 grid place-content-left">
<div className="bg-gradient-to-b w-full from-black/0 to-black/30 p-8 py-4 text-5xl font-black uppercase text-white ">
<p className=" text-3xl f">{card.name}</p>
<p className="b text-xl ">{card.title}</p>
</div>
</div>
return (
<div
key={card.id}
className="group relative md:h-[450px] md:w-[450px] h-[300px] w-[400px] rounded-3xl mr-4 overflow-hidden bg-neutral-200"
>
<div
style={{
backgroundImage: `url(${card.url})`,
backgroundSize: "cover",
backgroundPosition: "center",
}}
className="absolute inset-0 z-0 transition-transform duration-300 group-hover:scale-110"
></div>
<div className="absolute bottom-0 w-full z-10 grid place-content-left">
<div className="bg-gradient-to-b w-full from-black/0 to-black/30 p-8 py-4 text-5xl font-black uppercase text-white ">
<p className=" text-3xl f">{card.name}</p>
<p className="b text-xl ">{card.title}</p>
</div>
);
</div>
</div>
);
};

export default HorizontalScroll;

type CardType = {
url: string;
title: string;
id: number;
name: string;
url: string;
title: string;
id: number;
name: string;
};

const cards: CardType[] = [
// {
// url: "https://tedx-sjec.github.io/website-assets/team/dr-binu-k-g.avif",
// title: "Faculty Co-Ordinator",
// name: "Binu K G",
// id: 1,
// },
{
url: `${tedxsjecAssetsPrefix}/team/sharon.avif`,
title: "Licensee & Organizer",
id: 2,
name: "Sharon Tyana Menezes",
},
{
url: "/imgs/abstract/3.jpg",
title: "Co-Organizer",
id: 3,
name: "Sasha Sajith",
},
{
url: "/imgs/abstract/4.jpg",
title: "Curation Head",
id: 4,
name: "Vyasa M Nayak",
},
{
url: "/imgs/abstract/5.jpg",
title: "Technical Head",
id: 5,
name: "Hanniel Andrede",
},
{
url: "/imgs/abstract/6.jpg",
title: "Design Head",
id: 6,
name: "Lawrence Robert D'Souza",
},
// {
// url: "/imgs/abstract/7.jpg",
// title: "Title 7",
// id: 7,
// name: "Binu K G",
// },
// {
// url: "https://tedx-sjec.github.io/website-assets/team/dr-binu-k-g.avif",
// title: "Faculty Co-Ordinator",
// name: "Binu K G",
// id: 1,
// },
{
url: `${tedxsjecAssetsPrefix}/team/sharon.avif`,
title: "Licensee & Organizer",
id: 2,
name: "Sharon Tyana Menezes",
},
{
url: "/imgs/abstract/3.jpg",
title: "Co-Organizer",
id: 3,
name: "Sasha Sajith",
},
{
url: "/imgs/abstract/4.jpg",
title: "Curation Head",
id: 4,
name: "Vyasa M Nayak",
},
{
url: "/imgs/abstract/5.jpg",
title: "Technical Head",
id: 5,
name: "Hanniel Andrede",
},
{
url: "/imgs/abstract/6.jpg",
title: "Design Head",
id: 6,
name: "Lawrence Robert D'Souza",
},
// {
// url: "/imgs/abstract/7.jpg",
// title: "Title 7",
// id: 7,
// name: "Binu K G",
// },
];
23 changes: 23 additions & 0 deletions src/components/edil-ozi/text-glitch.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
"use client";
import { FC } from "react";

interface Props {
text: string;
}

const TextGlitch: FC<Props> = ({ text }) => {
text;
return (
<div className="group relative inline-block overflow-hidden">
<span className="invisible">Text Glitch Effect</span>
<span className="absolute left-0 top-0 text-white transition duration-300 ease-in-out group-hover:-translate-y-full ">
{text}
</span>
<span className="absolute left-0 top-0 translate-y-full transition duration-300 ease-in-out group-hover:translate-y-0 text-red-600">
tedxsjec
</span>
</div>
);
};

export default TextGlitch;
4 changes: 2 additions & 2 deletions src/components/ui/text-reveal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -32,11 +32,11 @@ export const TextRevealByWord: FC<TextRevealByWordProps> = ({
<div ref={targetRef} className={cn("relative z-0 h-[200vh]", className)}>
<div
className={
"sticky top-0 mx-auto flex h-[50%] max-w-8xl justify-center items-start flex-col bg-transparent md:py-[1rem]"
"sticky top-0 mx-auto flex h-[50%] max-w-8xl justify-center items-start flex-col bg-transparent px-[7rem] md:py-[1rem]"
}
>
<motion.h1
className="md:text-8xl text-5xl md:text-start text-center font-extrabold uppercase text-[#ff0000]"
className="md:text-8xl text-5xl md:text-start text-center px-12 font-extrabold uppercase text-[#ff0000]"
// ref={ref}
initial={{ opacity: 1, y: -30 }}
// animate={isInView ? { opacity: 1, y: 0 } : {}}
Expand Down

0 comments on commit 182072e

Please sign in to comment.