In this blog post, we will walk through the creation of a feature-rich cloud storage website using React. The site, inspired by Fylo, offers sections such as Home, Features, How It Works, Testimonials, and a Footer. Along the way, we will discuss the structure, components, and styling used to build this fully responsive website.
This project consists of multiple sections aimed at showcasing a cloud storage service. Each section is built with React components for modularity and ease of maintenance. We will cover the following sections:
fylo-cloud-storage-website/ │ ├── public/ │ ├── index.html │ ├── src/ │ ├── assets/ │ │ ├── images/ │ │ │ ├── icon-access-anywhere.svg │ │ │ ├── icon-security.svg │ │ │ ├── illustration-intro.png │ │ │ └── ... │ ├── components/ │ │ ├── Navbar.js │ │ ├── Home.js │ │ ├── Features.js │ │ ├── Working.js │ │ ├── Testimonials.js │ │ └── Footer.js │ ├── App.js │ ├── App.css │ └── index.js
git clone https://github.com/abhishekgurjar-in/fylo-cloud-storage.git
cd fylo-cloud-storage-website npm install
npm start
The website will be available on http://localhost:3000/.
This is the root component that imports and renders all the other components (Navbar, Home, Features, Working, Testimonials, Footer).
import "./App.css" import Navbar from "./components/Navbar"; import Home from "./components/Home"; import Features from "./components/Features"; import Working from "./components/Working"; import Testimonials from "./components/Testimonials"; import Footer from "./components/Footer"; const App = () => { return ( <> <Navbar /> <Home /> <Features /> <Working /> <Testimonials /> <Footer /> </> ); }; export default App;
The navigation bar contains the logo and three clickable links: Features, Team, and Sign In.
import logo from "../assets/images/logo.svg"; const Navbar = () => { return ( <div className="navbar"> <div className="logo"> <img src={logo} alt="" /> </div> <div className="header"> <a href="">Features</a> <a href="">Team</a> <a href="">Sign In</a> </div> </div> ); }; export default Navbar;
The Home section introduces the service with an eye-catching background image and a "Get Started" button.
import bgHome from "../assets/images/illustration-intro.png"; const Home = () => { return ( <div className="home"> <div className="home-image"> <img src={bgHome} alt="" /> </div> <div className="home-text"> <h1>All your files in one secure location, accessible anywhere.</h1> <p> Fylo stores all your most important files in one secure location. Access them wherever you need, share and collaborate with friends family, and co-workers. </p> <div className="button"> <h4>Get Started</h4> </div> </div> </div> ); }; export default Home;
This component highlights four key features of the cloud service, with corresponding icons and descriptions.
import AccessImage from "../assets/images/icon-access-anywhere.svg"; import SecurityImage from "../assets/images/icon-security.svg" import collaborationImage from "../assets/images/icon-collaboration.svg" import storageImage from "../assets/images/icon-any-file.svg" const Features = () => { return ( <div className="features"> <div className="cards"> <div className="card"> <img src={AccessImage} alt="" /> <h1>Access your files, anywhere</h1> <p> The ability to use a smartphone, tablet, or computer to access your account means your files follow you everywhere. </p> </div> <div className="card"> <img src={SecurityImage} alt="" /> <h1>Security you can trust</h1> <p> 2-factor authentication and user-controlled encryption are just a couple of the security features we allow to help secure your files. </p> </div> </div> <div className="cards"> <div className="card"> <img src={collaborationImage} alt="" /> <h1>Real-time collaboration</h1> <p> Securely share files and folders with friends, family and colleagues for live collaboration. No email attachments required. </p> </div> <div className="card"> <img src={storageImage} alt="" /> <h1>Store any type of file</h1> <p> Whether you're sharing holidays photos or work documents, Fylo has you covered allowing for all file types to be securely stored and shared. </p> </div> </div> </div> ); }; export default Features;
This section includes feedback from satisfied users along with their profile images.
import satish from "../assets/images/profile-1.jpg"; import Bruce from "../assets/images/profile-2.jpg"; import Iva from "../assets/images/profile-3.jpg" const Testimonials = () => { return ( <div className="testimonials"> <div className="t-cards"> <div className="t-card"> <h4> Fylo has improved our team productivity by an order of magnitude. Since making the switch our team has become a well-oiled collaboration machine. </h4> <div className="profile"> <div className="profile-image"> <img src={satish} alt="" /> </div> <div className="profile-text"> <h1>Satish Patel</h1> <p>Satish Patel Founder & CEO, Huddle</p> </div> </div> </div> <div className="t-card"> <h4> Fylo has improved our team productivity by an order of magnitude. Since making the switch our team has become a well-oiled collaboration machine. </h4> <div className="profile"> <div className="profile-image"> <img src={Bruce} alt="" /> </div> <div className="profile-text"> <h1>Bruce McKenzie</h1> <p>Bruce McKenzie Founder & CEO, Huddle</p> </div> </div> </div> <div className="t-card"> <h4> Fylo has improved our team productivity by an order of magnitude. Since making the switch our team has become a well-oiled collaboration machine. </h4> <div className="profile"> <div className="profile-image"> <img src={Iva} alt="" /> </div> <div className="profile-text"> <h1>Iva Boyd</h1> <p>Iva Boyd Founder & CEO, Huddle</p> </div> </div> </div> </div> <div className="contact-card"> <h1>Get early access today</h1> <p>It only takes a minute to sign up and our free starter tier is extremely generous. If you have any questions, our support team would be happy to help you.</p> <div className="input-section"> <div className="input-box"> <input type="text" placeholder=" email@example.com" /> </div> <div className="submit-button"> <p>Get Started For Free </p> </div> </div> </div> </div> ); }; export default Testimonials;
The footer contains contact information, social links, and site navigation.
import Logo from "../assets/images/logo.svg" import Location from "../assets/images/icon-location.svg" import phone from "../assets/images/icon-phone.svg" import email from '../assets/images/icon-email.svg' const Footer = () => { return ( <div className="footer"> <div className="sec-1"> <div className="logo"> <img src={Logo} alt="" /> </div> <div className="location"> <img src={Location} alt="" /> <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua</p> </div> </div> <div className="sec-2"> <div className="phone"> <img src={phone} alt="" /> <p>+1-543-123-4567</p> </div> <div className="email"> <img src={email} alt="" /> <p>example@fylo.com</p> <p>Made with ❤️ by Abhishek Gurjar</p> </div> </div> <div className="sec-3"> <p>About Us</p> <p>Jobs</p> <p>Pres</p> <p>Blog</p> </div> <div className="sec-4"> <p>Contact Us</p> <p>Terms</p> <p>Privacy</p> </div> </div> ) } export default Footer
You can check out the live demo of this project here.
In this post, we created a feature-rich, responsive website using React, showcasing a cloud storage service. We covered how to structure the project, break down the components, and style them using CSS. This modular approach makes it easy to add or update features as needed.
This project is inspired by the Fylo cloud storage service design.
Abhishek Gurjar is a dedicated web developer passionate about creating practical and functional web applications. Check out more of his projects on GitHub.
The above is the detailed content of Building a Fylo Cloud Storage Website with React. For more information, please follow other related articles on the PHP Chinese website!