Conduit is a social blogging site (i.e. a Medium.com clone). It uses a custom API for all requests, including authentication. This codebase was created to demonstrate a frontend application built with Next.js and TypeScript including CRUD operations, authentication, routing, pagination, and more.
For more information on how to this works with other frontends/backends, head over to the RealWorld repo.
- Authenticate users via JWT (login/signup pages + logout button on settings page)
- CRU- users (sign up & settings page - no deleting required)
- CRUD Articles
- CR-D Comments on articles (no updating required)
- GET and display paginated lists of articles
- Favorite articles
- Follow other users
- Home page (URL:'/'):
- List of tags
- List of articles pulled from either Feed, Global, or by Tag
- Pagination for list of articles
- Sign in/Sign up pages (URL: /auth/login, /auth/register):
- Uses JWT (store the token in localStorage)
- Authentication can be easily switched to session/cookie based
- Settings page (URL: /auth/settings)
- Editor page to create/edit articles:
- Create articles (URL: /editor/new)
- Edit articles (URL: /editor/slug)
- Article page (URL: /article/slug):
- Delete article button (only shown to article's author)
- Render markdown from server client side
- Comments section at bottom of page
- Delete comment button (only shown to comment's author)
- Profile page (URL: /profile/:username)
- Get authenticated user info and profile (URL: /auth/me)
- Show basic user info
- Frontend: React, TypeScript, Next.js, Tailwind CSS
- State Management: React Query, Zustand
- Form Management: React Hook Form
- Testing: Jest, Cypress, React Testing Library
- CI/CD: GitHub Actions
-
Clone the repository:
git clone https://github.com/nina1012/realworld-app.git cd realworld-app
-
Install dependencies:
npm install
-
Set up environment variables:
Command goes here... TO DO!!!
-
Run the development server:
npm run dev
To explore the app without registering, use the following demo account credentials:
- Email: [email protected]
- Password: password123
Simply log in with these credentials to start using the application. 🚀
Please note: The app may not render or function correctly if the API (https://api.realworld.io/api/) is down or experiencing issues. This could affect features such as user authentication, data fetching, and any dynamic content relying on the backend. To demonstrate the functionality of the application, I have included several demo Articles and Tags. These are designed to showcase the core features of the app, even if the API is not working properly or is unavailable.
If you encounter problems:
- Try refreshing the page.
- Check if the API service is available.
I apologize for any inconvenience this may cause.
Additional Note: dashboard.cy.ts
tests have been temporarily commented out in the workflow due to their dependency on the API, which is currently unstable (as of October 26th). This allows other tests to proceed until the API is reliable.