Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

changed tweet style from grid to carousel #68

Merged
merged 23 commits into from
Jan 22, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 37 additions & 0 deletions components/Marquee.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
interface MarqueeProps {
className?: string;
reverse?: boolean;
pauseOnHover?: boolean;
children?: React.ReactNode;
vertical?: boolean;
repeat?: number;
[key: string]: any;
}

export function Marquee({
className,
reverse,
pauseOnHover = false,
children,
vertical = false,
repeat = 4,
...props
}: MarqueeProps) {
return (
<div
{...props}
className={`group flex overflow-hidden p-2 [--duration:40s] [--gap:1rem] [gap:var(--gap)] ${vertical ? 'flex-col' : 'flex-row'} ${className}`}
>
{Array(repeat)
.fill(0)
.map((_, i) => (
<div
key={i}
className={`flex shrink-0 justify-around [gap:var(--gap)] ${vertical ? 'animate-marquee-vertical flex-col' : 'animate-marquee flex-row'} ${pauseOnHover ? 'group-hover:[animation-play-state:paused]' : ''} ${reverse ? '[animation-direction:reverse]' : ''}`}
>
{children}
</div>
))}
</div>
);
}
222 changes: 57 additions & 165 deletions components/testimonials.tsx
Original file line number Diff line number Diff line change
@@ -1,175 +1,67 @@
import React from "react";
import Tweet from "./tweets";
import { Marquee } from "./Marquee";
import Tweets from "../services/Tweets";
const firstRow = Tweets.slice(0, Tweets.length / 2);
const secondRow = Tweets.slice(Tweets.length / 2);

const Testimonials = () => {
const ReviewCard = ({
avatar,
name,
id,
content,
post,
}: {
avatar: string;
name: string;
post: string;
id: string;
content: string;
}) => {
return (
<>
<div className="mt-2 mb-8">
<h3 className="text-center lg:text-left bg-gradient-to-r from-orange-200 to-orange-100 bg-[length:100%_20px] bg-no-repeat bg-left-bottom w-max mb-6 text-3xl lg:text-4xl heading1 md:text-4xl font-bold tracking-tighter leading-tight mt-16">
What our community thinks
</h3>
<div className="flex flex-row max-lg:flex-col">
<a href={post} target="_blank" className="lg:mx-2">
<figure className="relative w-80 cursor-pointer overflow-hidden rounded-xl border p-4 border-gray-950/[.1] bg-gray-950/[.01] hover:bg-gray-950/[.05]">
<div className="flex flex-row items-center gap-2">
<img
className="rounded-full"
width="32"
height="32"
alt=""
src={avatar}
/>
<div className="flex flex-col">
<Tweet
avatar={
"https://pbs.twimg.com/profile_images/837573171427487744/IGQLsM55_400x400.jpg"
}
name={"やまもと@視力2.0"}
id={"yamamoto_febc"}
post={
"https://x.com/yamamoto_febc/status/1755802346188390531?s=20"
}
content={
"It is quite easy to create normal tests. On the other hand, abnormal systems may be a little difficult. I think it's okay to use it only for normal systems."
}
/>

<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1653250498127089665/x5RJbLq5_400x400.jpg"
}
name={"きょん/kyong"}
id={"kyongshiii06"}
post={
"https://x.com/kyongshiii06/status/1753030333128495470?s=20"
}
content={
"I tried keploy, but it was amazing. Just wrap and start docker, and then just hit the API with curl or the client and you'll be able to test more and more. This is the golden test."
}
/>

<Tweet
avatar="https://pbs.twimg.com/profile_images/1741543460115812352/8x4aAI9k_400x400.jpg"
name={"Shivam Sourav Jha"}
id={"ShivamSouravJha"}
post={
"https://x.com/ShivamSouravJha/status/1747517726749286713?s=20"
}
content={
"Why do I like keploy so much? Literally I see many tools and so hard to integrate. I mean update VScode , use the sdk , make this change make that change. With Keploy, don't worry buddy just run your application, we will literally do everything for you. You need to 0 efforts."
}
/>

<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1653250498127089665/x5RJbLq5_400x400.jpg"
}
name={"きょん/kyong"}
id={"kyongshiii06"}
post={
"https://x.com/kyongshiii06/status/1746532217336250821?s=20"
}
content={
"Keploy can record and replay complex, distributed API flows as mocks and stubs. It's like having a time machine for your tests—saving you tons of time."
}
/>
</div>
<div className="flex flex-col">
<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1422864637532332033/mC1Nx0vj_400x400.jpg"
}
name={"matsuu@充電期間"}
id={"matsuu"}
post={"https://x.com/matsuu/status/1747448928575099236?s=20"}
content={
"Based on the communication trace information that can be obtained using eBPF, it is possible to generate a test and a stub server to be used when executing the test.” / “The automated testing tool “Keploy” using eBPF is amazing."
}
/>

<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1604797450124144640/6G7KytX8_400x400.jpg"
}
name={"あんどーぼんばー"}
id={"AndooBomber"}
post={"https://x.com/AndooBomber/status/1747663021747691808?s=20"}
content={
"I tried Keploy, but it might be a god tool. The automated testing tool “Keploy” using eBPF is amazing"
}
/>

<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1569793803313201154/Lso5fu1j_400x400.jpg"
}
name={"Jay Vasant"}
id={"__alter123"}
post={"https://x.com/__alter123/status/1731985031521014236?s=20"}
content={
"The point being, maintaining unit tests is terribly difficult, and in general requires more efforts than the actual development itself. I've hardly seen any startups even at good scale able to manage unit tests. If you really think it's a requirement you can try tools like Keploy. But I feel even if you honestly think, manual testing should be always feasible"
}
/>

<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1213737438830452736/5_5zXtXN_400x400.jpg"
}
name={"mugi"}
id={"mugi_uno"}
post={"https://x.com/mugi_uno/status/1745726154924003502?s=20"}
content={
"I want to try this. I think the problem with mock data is that it is difficult to maintain, so if it makes it easier, I think it would be a good idea. The automated testing tool “Keploy” using eBPF is amazing"
}
/>
</div>
<div className="flex flex-col">
<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1482259385959464960/1pQMXwj7_400x400.jpg"
}
name={"yadon"}
id={"Seipann11"}
post={"https://x.com/Seipann11/status/1755989987039064103?s=20"}
content={
"Keploy is seriously amazing, a genius Indian is crushing issues at lightning speed."
}
/>

<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1860933223108452352/7AvlUHlk_400x400.jpg"
}
name={"Akash Singh"}
id={"Kind_Of_Akash"}
post={
"https://x.com/Kind_Of_Akash/status/1754207010470736165?s=20"
}
content={
"Hey people, I wanted to share about my first month as an open source contributor at Keploy -Picked up 10 issues including bugs, features, documentation and opened 3 issues. -Submitted 8 PR's, out of which 2 have been merged and rest are on review"
}
/>

<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1712175220176355329/sLXbk_PZ_400x400.jpg"
}
name={"TadasG"}
id={"JustADude404"}
post={
"https://x.com/JustADude404/status/1746888711491424681?s=20"
}
content={
"Keploy is a tool which can automatically generate tests based on data from your running app. It simply attaches to your app, reads the data being passed through, and generates tests with real data. Pretty cool, huh?"
}
/>

<Tweet
avatar={
"https://pbs.twimg.com/profile_images/1701251291861712897/PiTZ0UO7_400x400.jpg"
}
name={"Junichi.Y🐼@休職中"}
id={"ymnk_8752"}
post={"https://x.com/ymnk_8752/status/1745458928698450057?s=20"}
content={
"Looks amazing. I hear about eBPF a lot, but I don't know what it is. The automated testing tool “Keploy” using eBPF is amazing"
}
/>
<figcaption className="text-sm font-bold">{name}</figcaption>
<p className="text-xs font-medium ">{id}</p>
</div>
</div>
<blockquote className="mt-2 text-sm">{content}</blockquote>
</figure>
</a>
);
};

const TwitterTestimonials = () => {
return (
<div className="">
<h3 className="text-center lg:text-left bg-gradient-to-r from-orange-200 to-orange-100 bg-[length:100%_20px] bg-no-repeat bg-left-bottom w-max mb-6 text-3xl lg:text-4xl heading1 md:text-4xl font-bold tracking-tighter leading-tight mt-16">
What our community thinks
</h3>
<div className="relative flex mb-8 h-[700px] w-full flex-col items-center justify-center overflow-hidden rounded-lg border ">

<Marquee pauseOnHover className="[--duration:20s]">
{firstRow.map((tweet) => (
<ReviewCard key={tweet.id} {...tweet} />
))}
</Marquee>
<Marquee reverse pauseOnHover className="[--duration:20s]">
{secondRow.map((tweet) => (
<ReviewCard key={tweet.id} {...tweet} />
))}
</Marquee>
<div className="pointer-events-none absolute inset-y-0 left-0 w-1/3 bg-gradient-to-r from-neutral-100 dark:from-background"></div>
<div className="pointer-events-none absolute inset-y-0 right-0 w-1/3 bg-gradient-to-l from-neutral-100 dark:from-background"></div>
</div>
</>
</div>
);
};

export default Testimonials;
export default TwitterTestimonials;
11 changes: 11 additions & 0 deletions package-lock.json

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

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
"react": "^18.2.0",
"react-dom": "^18.2.0",
"react-icons": "^5.0.1",
"tailwind-merge": "^2.5.5",
"typescript": "^4.7.4"
},
"devDependencies": {
Expand Down
Loading
Loading