Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yurisldk/realworld-react-fsd
A social blogging site powered by React, Zustand, React-Query on FSD (Feature-Sliced Design) architectural methodology.
https://github.com/yurisldk/realworld-react-fsd
axios crud feature-based feature-sliced feature-sliced-design feature-slices jwt-authentication react react-hook-form react-query react-router realworld-application realworld-frontend typescript vertical-slices zustand
Last synced: 5 days ago
JSON representation
A social blogging site powered by React, Zustand, React-Query on FSD (Feature-Sliced Design) architectural methodology.
- Host: GitHub
- URL: https://github.com/yurisldk/realworld-react-fsd
- Owner: yurisldk
- License: mit
- Created: 2023-05-27T20:46:51.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2025-01-12T19:08:11.000Z (26 days ago)
- Last Synced: 2025-01-26T14:01:42.643Z (12 days ago)
- Topics: axios, crud, feature-based, feature-sliced, feature-sliced-design, feature-slices, jwt-authentication, react, react-hook-form, react-query, react-router, realworld-application, realworld-frontend, typescript, vertical-slices, zustand
- Language: TypeScript
- Homepage:
- Size: 2.91 MB
- Stars: 370
- Watchers: 6
- Forks: 66
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 🙌 RealWorld example app 🍰 Feature-Sliced Design
This codebase containing real world examples (CRUD, auth, advanced patterns, etc) that adheres to the [RealWorld](https://github.com/gothinkster/realworld) spec and API. Powered by [FSD (Feature-Sliced Design)](https://feature-sliced.design) architectural methodology.
![Realworld example app](./logo.gif)
---
[![Feature-Sliced Design][shields-fsd-domain]](https://feature-sliced.design/)
[![Vite][shields-vite-domain]](https://vitejs.dev/)
[![React][shields-react-domain]](https://react.dev/)
[![React Router][shields-react-router-domain]](https://reactrouter.com/)
[![React Query][shields-react-query-domain]](https://tanstack.com/query/v4/)
[![Zustand][shields-zustand-domain]](https://zustand-demo.pmnd.rs/)
[![TypeScript][shields-typescript-domain]](https://www.typescriptlang.org/)## Backend Solution for RealWorld API Challenges
As part of the solution to the issues caused by recent changes to the [RealWorld API specifications](https://github.com/gothinkster/realworld/issues/1611), I’ve forked an backend and created a fully compatible alternative with **[RealWorld Express + Prisma](https://github.com/yurisldk/realworld-express-prisma)**.
This fork addresses the challenges caused by the deletion of the official API server and demo deployment, and it implements the updated API specifications to keep the project running smoothly.
To get the backend up and running, you can find instructions on how to install and set it up in the [RealWorld Express + Prisma repository](https://github.com/yurisldk/realworld-express-prisma).
Feel free to contribute or reach out if you have any questions or suggestions!
## Features
The example application is a social blogging site (i.e. a Medium.com clone) called "Conduit". It uses a custom API for all requests, including authentication.
![Dependency Graph][dependency-graph-domain]
**General functionality:**
- 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**The general page breakdown:**
- 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: /login, /register )
- Uses JWT (store the token in localStorage)
- Authentication can be easily switched to session/cookie based
- Settings page (URL: /settings )
- Editor page to create/edit articles (URL: /editor, /editor/article-slug-here )
- Article page (URL: /article/article-slug-here )
- 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, /profile/:username/favorites)
- Show basic user info
- List of articles populated from author's created articles or author's favorited articles## Getting started
This project was bootstrapped with [Create Vite](https://vitejs.dev/guide/#getting-started)
To get the frontend running locally:
1. Clone this repo
2. `yarn install` to install all the dependencies defined in a `package.json` file.
3. `yarn dev` to start Vite dev server.## Scripts
- `yarn dev` - start a development server with hot reload.
- `yarn build` - build for production. The generated files will be on the dist folder.
- `yarn preview` - locally preview the production build.
- `yarn lint` - run ESLint.
- `yarn lint:perf` - run ESLint and track the performance of individual rules.
- `yarn prettier` - run Prettier on changed files.
- `yarn prettier:all` - run Prettier on all files.
- `yarn test:run` - run all test suites.
- `yarn test:watch` - run all test suites but watch for changes and rerun tests when they change.
- `yarn test:coverage` - run all test suites and enable coverage report.
- `yarn test:coverage:open` - run all test suites and enable coverage report then open coverage report in browser.
- `yarn dep-cruiser:preview` - create a graph of the dependencies[^1][^1]:
This assumes the GraphViz `dot` command is available - on most linux and
comparable systems this will be. In case it's not, see
[GraphViz' download page](https://www.graphviz.org/download/) for instructions
on how to get it on your machine.[shields-react-router-domain]: https://img.shields.io/badge/React_Router-CA4245?style=for-the-badge&logo=react-router&logoColor=white
[shields-react-query-domain]: https://img.shields.io/badge/-React%20Query-FF4154?style=for-the-badge&logo=react%20query&logoColor=white
[shields-zustand-domain]: https://img.shields.io/badge/zustand-%2320232a.svg?style=for-the-badge&logo=react&logoColor=%2361DAFB
[shields-typescript-domain]: https://img.shields.io/badge/typescript-%23007ACC.svg?style=for-the-badge&logo=typescript&logoColor=white
[shields-fsd-domain]: https://img.shields.io/badge/Feature--Sliced-Design?style=for-the-badge&color=F2F2F2&labelColor=262224&logoWidth=10&logo=
[shields-vite-domain]: https://img.shields.io/badge/vite-%23646CFF.svg?style=for-the-badge&logo=vite&logoColor=white
[shields-react-domain]: https://img.shields.io/badge/react-%2320232a.svg?style=for-the-badge&logo=react&logoColor=%2361DAFB
[netlify-domain]: https://api.netlify.com/api/v1/badges/5d5013c3-ec61-4496-8f48-caa7145fb166/deploy-status
[dependency-graph-domain]: ./dependency-graph-preview.svg
[build-domain]: https://github.com/sldk-yuri/realworld-react-fsd/actions/workflows/build.yml/badge.svg
[codecov-domain]: https://codecov.io/gh/sldk-yuri/realworld-react-fsd/branch/master/graph/badge.svg?token=IXE2YRPYK5
[prettier-domain]: https://img.shields.io/badge/code_style-prettier-ff69b4.svg
[license-domain]: https://img.shields.io/badge/license-MIT-green.svg