Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tedjenkler/arch-studio-scss-portfolio
Project by Teodor Jenkler for Frontend Mentor's challenge is a multi-page website for Arch Studio built with React and SCSS. It showcases a fully responsive design, optimized for various screen sizes, interactive hover states, and robust form validation. This project highlights my skills in converting Figma designs into code
https://github.com/tedjenkler/arch-studio-scss-portfolio
figma formik framer-motion leaflet react react-router scss vite yup-validation
Last synced: 17 days ago
JSON representation
Project by Teodor Jenkler for Frontend Mentor's challenge is a multi-page website for Arch Studio built with React and SCSS. It showcases a fully responsive design, optimized for various screen sizes, interactive hover states, and robust form validation. This project highlights my skills in converting Figma designs into code
- Host: GitHub
- URL: https://github.com/tedjenkler/arch-studio-scss-portfolio
- Owner: TedJenkler
- Created: 2024-08-18T17:44:01.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-08-24T23:23:48.000Z (5 months ago)
- Last Synced: 2024-11-10T16:21:59.329Z (about 2 months ago)
- Topics: figma, formik, framer-motion, leaflet, react, react-router, scss, vite, yup-validation
- Language: SCSS
- Homepage: https://portfolio-scss-tedjenkler.netlify.app
- Size: 21.6 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Frontend Mentor - Arch Studio multi-page website solution
This is a solution to the [Arch Studio multi-page website challenge on Frontend Mentor](https://www.frontendmentor.io/challenges/arch-studio-multipage-website-wNIbOFYR6). Frontend Mentor challenges help you improve your coding skills by building realistic projects.
## Table of contents
- [Overview](#overview)
- [The challenge](#the-challenge)
- [Screenshot](#screenshot)
- [Links](#links)
- [My process](#my-process)
- [Built with](#built-with)
- [What I learned](#what-i-learned)
- [Continued development](#continued-development)
- [Useful resources](#useful-resources)
- [Author](#author)
- [Acknowledgments](#acknowledgments)## Overview
### The challenge
Users should be able to:
- View the optimal layout for each page depending on their device's screen size.
- See hover states for all interactive elements throughout the site.
- Receive an error message when the contact form is submitted if:
- The `Name`, `Email`, or `Message` fields are empty should show "Can't be empty".
- The `Email` is not formatted correctly should show "Please use a valid email address".
- **Bonus**: View actual locations on the contact page map. The addresses we have on the design are fictional, so you'll need to add real addresses for this bonus task.### Screenshot
![Screenshot of the Arch Studio Multi-page Website](./screenshot.png)
### Links
- Solution URL: [GitHub Repository](https://github.com/TedJenkler/Arch-Studio-SCSS-Portfolio)
- Live Site URL: [Live Demo](https://portfolio-scss-tedjenkler.netlify.app/)## My process
### Built with
- [Vite](https://vitejs.dev/) - A frontend build tool for fast development with a modern workflow.
- [React](https://reactjs.org/) - A JavaScript library for building user interfaces.
- [SCSS](https://sass-lang.com/documentation) - For advanced styling and creating flexible, maintainable stylesheets.
- [Formik](https://formik.org/) - For managing form state and validation with ease.
- [Framer Motion](https://www.framer.com/api/motion/) - For creating smooth and interactive animations.
- [React Router v6](https://reactrouter.com/) - For handling routing in a React application.
- [Leaflet](https://leafletjs.com/) - For interactive maps.
- [Yup](https://github.com/jquense/yup) - For schema validation and form validation logic.### What I learned
During this project, I gained more experience in the following areas:
- **SCSS:** Enhanced understanding of SCSS features like mixins, maps, variables, and responsive design.
- **CSS Overlays:** Learned how to use CSS to create overlays for darkening content.
- **Formik:** Improved skills in managing form state and validation using Formik.
- **Framer Motion:** Gained experience in creating smooth and interactive animations with Framer Motion.### Continued Development
- Plan to make the site fully responsive on all devices.
- Add more animations and improve existing ones.### Useful resources
- [SCSS Documentation](https://sass-lang.com/documentation) - For comprehensive details on SCSS syntax and features.
- [Formik Documentation](https://formik.org/docs) - For learning how to use Formik for form management and validation.
- [Framer Motion Documentation](https://www.framer.com/api/motion/) - For creating animations in React.
- [React Router v6 Documentation](https://reactrouter.com/) - For handling routing in React applications.
- [Leaflet Documentation](https://leafletjs.com/) - For integrating interactive maps.## Author
- Frontend Mentor - [@TedJenkler](https://www.frontendmentor.io/profile/TedJenkler)
- LinkedIn - [Teodor Jenkler](https://www.linkedin.com/in/tedjenklerwebdeveloper/)
- X - [@TJenkler](https://x.com/TJenkler)
- Discord - [TedJenkler](https://discord.com/users/TedJenkler)
- YouTube - [WebDevwithTed](https://www.youtube.com/@WebDevwithTed)## Acknowledgments
- Special thanks to ChatGPT for assisting with writing comments for my commits. (Would love feedback on if it is good or bad)