👋 Hey there! Please take a look at this Notion to gauge at technical findings, hurdles, and lessons I am uncovering while working on this project.
I wanted to create a baseline clone of DoorDash's home portal from an authenticated user's perspective. This challenge tested a variety of skillsets including prototyping pixel perfect, data driven, and reusable UI components.
This challenge is currently undergoing active development as of January 6th 2023, so features including SSR driven merchant pages, search functionality, and checkout will be implemented along the way. Please check Roadmap for more information!
Up-to-date builds are hosted on Vercel. Please take a look at the About
section on this repository to access the build.
Install the dependencies and start the development server
From the project root,
npm i
npx next
Open http://localhost:3000 with your browser to the application.
You can start editing the page by modifying pages/index.tsx
. The page auto-updates as you edit the file.
This project uses next/font
to automatically optimize and load local fonts.
Next.js is used as the React Framework in this rapid prototype. DoorDash requires Server Side Rendering, as the content that hydrates a merchant's page is widely dynamic.
styled-components is used as the CSS-in-JS framework used to generate dynamic styles based on component props.
TypeScript is used as the programming language in this application. With a large range of data-dependent components, it is necessary to guard data driven UI components (and their props) with explicit types.
State Management
This clone uses Redux-Toolkit to manage state. Several items are put in global store, including the cart list. Check cartSlice.tsx
to see reducers and CartOverview.tsx
to see global store consumption. #5
- Created
<Navbar />
component and<SearchBar />
,<ShoppingCartButton />
subcomponents. Completed 1/6/23 - Created
<HomeLayout />
layout components, that holds the<Navbar />
and child elements from theindex.tsx
page. Completed 1/7/23 - Created reusable & data driven
<RestaurantCarousel />
and<RestaurantCard />
components and their subcomponents. Completed 1/8/23 - Creating and Linking
<RestaurantCard />
[slug] to a new store view page. Completed 1/10/23 - Asset optimization. Images batched to webp format with 40% quality. Proper image caching, eager/lazy loading on qualified assets.
- Created
<HeroComponent />
,<CartOverview />
,<CartItem />
,<InputStepper />
, and wired them. Currently uses temporary data, needs management from global state. Completed 1/14/23 - Establish global state for CartOverview & Store Items. Completed 1/19/23 theericzhang/doordash-clone#10
- Created
<ItemOverlay />
,<ItemCustomizationPanel />
to complete add-to-cart logic. completed 1/19/23 theericzhang/doordash-clone#10 - Responsive styling for existing layouts & components when viewport width is under 1800px. Begin 1/19/23, Completed 1/26/23 theericzhang/doordash-clone#13
- a11y + accessibilty enhancements, screen reader testing. Begin 1/26/23, Completed 1/29/23 theericzhang/doordash-clone#16
- Add more restaurants and items Begin 1/31/23 Completed 2/1/23 theericzhang/doordash-clone#17
- Button visited effect remove, webkit mobile Begin 1/31/23 Completed 2/1/23 theericzhang/doordash-clone#17
- Notion updates. Begin 1/31/23
- loading state for getServerSideProps
- create API routes data - use fetch instead of instantiating data files directly
- Implement Search functionality. Start with stores, then cuisines and dishes. (backlogged until e-amuse completed)
- Checkout flow. (backlogged until e-amuse completed)
- Garner feedback.
- DoorDash Clone - Discoveries, Hurdles, Lessons (A WIP) - read about my experience thus far building this application!
- Next.js Documentation - learn about Next.js features and API.
- styled-components - learn about styled-components with an interactive button component
- DoorDash Engineering - Improving Web Page Performance at DoorDash through Server Side Rendering with Next.js - Read about DoorDash's motivation and technical decision to move to Next.js powered SSR
I'd love to hear from you! Let me know of any feedback you have; it can be pertinent to this project, tech stack, design assets, etc!
Contact | |
---|---|
@anericzhang | |
Mastodon | @anericzhang@hachyderm.io |
anericzhang@gmail.com |