2025-03-10 11:53:56 +05:30

307 lines
32 KiB
TypeScript

"use client";
import React, { useEffect, useRef } from 'react';
import Navbar from '@/components/Navbar/navbar';
import Footer from "@/components/footer";
import { HoverEffect } from '@/components/ui/card-hover-effect';
import { Marquee } from '@/components/ui/marquee';
import { TextGenerateEffect } from "@/components/ui/text-generate-effect";
import { FaListUl, FaSearch, FaArrowsAlt, FaPlug, FaPaste, FaRegFileAlt } from 'react-icons/fa';
import { motion } from 'framer-motion';
const heading = "Series - Create awesome workflows and connect them to AI without a single line of code"
const description = "Help in defining, managing, and improving processes. can make any kind of flow"
const videoSrc = "https://res.cloudinary.com/zapier-media/video/upload/q_auto:best/f_auto/v1726860625/Homepage%20%E2%80%94%20Sept%202024/sc03_HP_240917_Power-with-AI_v02_supxar.mp4"
const features = [
{
head: "Connect the apps you already love",
desc: "Everyday supports over 100 apps, so you can tame the chaos and turn your tools into processes all in one place.",
button: "Explore all apps",
link: "/tools" // Updated link
},
{
head: "Start quickly with these pre-built templates from other Everyday users",
desc: "Automate your tasks in just a few minutes to reclaim countless hours of your time.",
button: "Explore more",
link: "/template" // Updated link
}
]
const brandLogos = [
"",
"",
"",
"",
"",
"",
];
const contents = [
{
title: "List",
description:
"With our drag and drop feature, anyone in your enterprise can build AI products effortlessly. Make AI an integral part of your business operations, irrespective of technical expertise.",
link: "https://stripe.com",
icon: FaListUl,
},
{
title: "Search and Discovery",
description:
"Users can search for series based on keywords, categories, or tags making it way easier to manage all your creations and looking for them is not a hassle at all.",
link: "https://netflix.com",
icon: FaSearch,
},
{
title: "Drag and drop",
description:
"Certainly! 'Drag and drop' refers to a user interface interaction where a person can click on an item, drag it to a different location, and then release it to drop it there. This action is commonly used in various applications and websites to allow users to rearrange or manipulate content more intuitively.",
link: "https://enterprise.everydayseries.com/",
icon: FaArrowsAlt,
},
{
title: "Integration",
description:
"User can integrate own apis. When we talk about users integrating their own APIs, we're referring to the ability for users to incorporate their own custom Application Programming Interfaces (APIs) into a software application or system.",
link: "https://meta.com",
icon: FaPlug,
},
{
title: "Copy and Paste",
description:
"Users have the capability to duplicate the flow or item and then paste it elsewhere within the system. No need to create the same thing twice",
link: "https://amazon.com",
icon: FaPaste,
},
{
title: "Template",
description:
"User can save any flow as template and can reuse it later. Don't be limited by your series. this feature enables users to save a sequence of actions or steps as a template for future use.",
link: "https://microsoft.com",
icon: FaRegFileAlt,
},
];
const alternatingFeatures = [
{
title: "Create Series using Drag and Drop",
description: "Organize, connect, and track your goals using the GoalGrid. Stay aligned and in sync with your strategic objectives.",
imgSrc: "https://res.cloudinary.com/dezd109fz/image/upload/v1737595526/Screenshot_2025-01-23_065418_xo3ezn.png",
direction: "left"
},
{
title: "Built for Enterprises",
description: "Everyday platform ensures enterprise-grade deployment, security, and data governance, all with the simplicity of one centrally managed platform.",
imgSrc: "https://res.cloudinary.com/dezd109fz/image/upload/v1737595526/Screenshot_2025-01-23_065356_gbkov8.png",
direction: "right"
},
{
title: "Integrate your Workflows",
description: "Connect Everyday to your existing tools, integrate important business processes, and build more powerful applications.",
imgSrc: "https://res.cloudinary.com/dezd109fz/image/upload/v1737595526/Screenshot_2025-01-23_065455_whfipm.png",
direction: "left"
},
];
const testimonialText = `This features allows even non tech guys to figure out the platform and create awesome workflows. Now that's mind-blowing.`
export default function Series() {
return (
<div className="min-h-screen bg-[#080E12] dark text-white overflow-x-hidden">
<Navbar />
{/* Hero Section */}
<div className='h-screen py-10 px-24 flex flex-col items-start justify-center'>
<h1 className="text-8xl mb-10">{heading}</h1>
<h2 className='text-4xl'>{description}</h2>
</div>
<div className="max-w-7xl mx-auto ">
{/* Video Section */}
<section className="my-16 md:my-24 lg:my-32 px-6 md:px-16 lg:px-24">
<div className="relative rounded-2xl overflow-hidden shadow-2xl shadow-violet-700/20 border border-violet-800/30">
<video
src={videoSrc}
autoPlay
loop
muted
className="w-full h-full object-cover rounded-2xl"
/>
<div className="absolute inset-0 bg-gradient-to-tr from-purple-900/30 to-transparent"></div>
</div>
</section>
{/* Features Section */}
<div className="flex flex-col text-white pb-20 space-y-32">
{features.map((item, index) => (
<div key={index} className="p-6 text-center space-y-10 relative">
{/* Feature Heading and Description */}
<motion.h2
initial={{ opacity: 0, y: 30 }}
whileInView={{ opacity: 1, y: 0 }}
transition={{ duration: 0.6 }}
viewport={{ once: true }}
className="text-3xl md:text-4xl lg:text-5xl mb-6 mx-auto max-w-3xl bg-clip-text text-transparent bg-gradient-to-r from-white to-violet-300"
>
{item.head}
</motion.h2>
<motion.p
initial={{ opacity: 0, y: 30 }}
whileInView={{ opacity: 1, y: 0 }}
transition={{ duration: 0.6, delay: 0.2 }}
viewport={{ once: true }}
className="md:w-2/3 mx-auto text-gray-300 text-lg"
>
{item.desc}
</motion.p>
<motion.a
initial={{ opacity: 0, y: 30 }}
whileInView={{ opacity: 1, y: 0 }}
transition={{ duration: 0.6, delay: 0.3 }}
viewport={{ once: true }}
href={item.link}
className="bg-violet-600 hover:bg-violet-500 font-medium px-6 py-3 rounded-lg inline-block transition-all shadow-lg hover:shadow-violet-500/40"
>
{item.button}
</motion.a>
{/* Conditional Rendering for Marquee After First Feature */}
{index === 0 && (
<div className="relative mt-24 overflow-hidden">
<Marquee className="[--duration:40s]">
<div className="flex space-x-12">
{brandLogos.map((img, i) => (
<div key={i} className="relative overflow-hidden bg-white/5 p-4 rounded-xl backdrop-blur-sm border border-white/10 transition-all hover:border-violet-500/50 hover:bg-white/10">
<img
src={img}
alt={`Brand logo ${i + 1}`}
className="h-20 w-20 object-contain"
/>
</div>
))}
</div>
</Marquee>
<Marquee reverse className="[--duration:30s] mt-6">
<div className="flex space-x-12">
{brandLogos.reverse().map((img, i) => (
<div key={i} className="relative overflow-hidden bg-white/5 p-4 rounded-xl backdrop-blur-sm border border-white/10 transition-all hover:border-violet-500/50 hover:bg-white/10">
<img
src={img}
alt={`Brand logo ${i + 1}`}
className="h-20 w-20 object-contain"
/>
</div>
))}
</div>
</Marquee>
{/* Gradient effects */}
<div className="pointer-events-none absolute inset-y-0 left-0 w-1/3 bg-gradient-to-r from-[#080E12] to-transparent"></div>
<div className="pointer-events-none absolute inset-y-0 right-0 w-1/3 bg-gradient-to-l from-[#080E12] to-transparent"></div>
</div>
)}
{/* Conditional Rendering for GIF After Second Feature */}
{index === 1 && (
<motion.div
initial={{ opacity: 0, y: 40 }}
whileInView={{ opacity: 1, y: 0 }}
transition={{ duration: 0.8 }}
viewport={{ once: true }}
className="mt-20 flex justify-center"
>
<div className="relative rounded-xl overflow-hidden shadow-2xl shadow-violet-700/20 border border-violet-800/30 w-full md:w-[70%] lg:w-[60%]">
<img
src="https://cdn.dribbble.com/users/695342/screenshots/3782293/dashboard-gif-ok.gif"
alt="Workflow GIF"
className="w-full object-cover"
/>
<div className="absolute inset-0 bg-gradient-to-tr from-purple-900/30 to-transparent pointer-events-none"></div>
</div>
</motion.div>
)}
</div>
))}
</div>
{/* Hover Cards Section */}
<section className="py-16 px-4 md:px-8">
<motion.div
initial={{ opacity: 0, y: 30 }}
whileInView={{ opacity: 1, y: 0 }}
transition={{ duration: 0.6 }}
viewport={{ once: true }}
className="max-w-7xl mx-auto"
>
<h2 className="text-3xl md:text-4xl mb-12 text-center bg-clip-text text-transparent bg-gradient-to-r from-white to-violet-300">
Powerful Features at Your Fingertips
</h2>
<HoverEffect items={contents} />
</motion.div>
</section>
{/* Alternating Feature Sections (Replace Features Component) */}
<section className="py-16 md:py-24 px-6 md:px-10 lg:px-16">
<h2 className="text-3xl md:text-4xl mb-20 text-center bg-clip-text text-transparent bg-gradient-to-r from-white to-violet-300">
The All-in-One Workflow Solution
</h2>
{alternatingFeatures.map((feature, index) => (
<motion.div
key={index}
initial={{ opacity: 0, x: index % 2 === 0 ? -50 : 50 }}
whileInView={{ opacity: 1, x: 0 }}
transition={{ duration: 0.6, type: 'spring', stiffness: 100 }}
viewport={{ once: true }}
className={`flex flex-col-reverse md:flex-${index === 1 ? 'row-reverse' : 'row'} items-center gap-10`}
>
<div className="w-full md:w-1/2">
<h3 className="text-2xl md:text-3xl mb-4 text-white">{feature.title}</h3>
<p className="text-gray-300 text-lg mb-4">{feature.description}</p>
</div>
<motion.img
src={feature.imgSrc}
alt={feature.title}
className="w-full md:w-1/2 rounded-lg shadow-lg"
initial={{ opacity: 0, scale: 0.8 }}
whileInView={{ opacity: 1, scale: 1 }}
transition={{ duration: 0.6 }}
/>
</motion.div>
))}
</section>
{/* Testimonial Section */}
<section className="px-6 md:px-10 lg:px-16 my-20">
<motion.div
initial={{ opacity: 0, y: 40 }}
whileInView={{ opacity: 1, y: 0 }}
transition={{ duration: 0.6 }}
viewport={{ once: true }}
className="bg-gradient-to-br from-white/5 to-white/2 backdrop-blur-sm rounded-2xl shadow-xl border border-white/10 px-8 md:px-12 py-16 mx-auto max-w-5xl"
>
<div className="text-yellow-400 text-center text-2xl mb-8">
</div>
<p className="text-white text-2xl md:text-3xl lg:text-4xl text-center mb-8 font-light">
<span className="font-semibold bg-clip-text text-transparent bg-gradient-to-r from-violet-400 to-violet-200">Magic Button:</span> Simply press the magic button to instantly generate your series automatically.
</p>
<div className="max-w-3xl mx-auto">
<TextGenerateEffect words={testimonialText} />
</div>
<div className="mt-12 flex justify-center">
<button className="bg-gradient-to-r from-violet-600 to-purple-600 hover:from-violet-500 hover:to-purple-500 font-medium px-8 py-4 rounded-xl transition-all shadow-lg hover:shadow-violet-500/40 text-lg">
Try Magic Button
</button>
</div>
</motion.div>
</section>
</div>
<Footer />
</div>
);
}