Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andreynav/social-network
Social network app for programmers | React, Redux-toolkit
https://github.com/andreynav/social-network
it-kamasutra react redux-toolkit reduxjs-toolkit social-network styled-components type-application typescript
Last synced: 9 days ago
JSON representation
Social network app for programmers | React, Redux-toolkit
- Host: GitHub
- URL: https://github.com/andreynav/social-network
- Owner: andreynav
- License: apache-2.0
- Created: 2022-09-09T13:21:25.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-02-04T18:18:10.000Z (about 2 years ago)
- Last Synced: 2024-12-20T04:47:47.669Z (2 months ago)
- Topics: it-kamasutra, react, redux-toolkit, reduxjs-toolkit, social-network, styled-components, type-application, typescript
- Language: TypeScript
- Homepage: https://social-network-4geeks.vercel.app
- Size: 1.6 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/5d798/5d798386838b9eb8c19186016862816348dde8c6" alt="GitHub repo size"
data:image/s3,"s3://crabby-images/25f1d/25f1dac6621b0419075366590dcbd616c9371c4f" alt="GitHub deployments"
data:image/s3,"s3://crabby-images/820ad/820ad7b4f9a7d4475501a0a8f67211a5a5ed5237" alt="Website"# General Notes
The current project is a project of social network executed due to the React, Redux, Styled components.
The project used the API calls to back-end, possibility to set up your own user profile, set up the languages and themes.
## Demo
You can open and use the app by [social network app link](https://social-network-4geeks-git-master-andreynav.vercel.app/).
Use free account for login: **Email:** `[email protected]` **Password:** `free`.
To find an author's private profile use the endpoint `/profile/26100` inside the app 🙂
## Project structure
The project has multilayer structure:
- `public` - used to keep static content for builds
- `api` - used to keep API calls functionality
- `assets` - used to keep static content
- `components` - used to keep react components
- `App` - used to keep main App component
- `...` - rest of components
- `common` - used to keep common for whole app components
- `fonts` - used to keep fonts
- `hoc` - used to keep Higher Order Components
- `hook` - used to keep hooks
- `locales` - used to keep locales for translations
- `store` - used to keep store
- `styles` - used to keep styles
- `tests` - used to keep tests
- `types` - used to keep TypeScript common types
- `utils` - used to keep utils for helping```
.
├── public
└── src
  ├── api
  ├── assets
  ├── components
  │  ├── App
  │  ├── Captcha
  │  ├── Dialogs
  │  ├── Footer
  │  ├── FormPostMessage
  │  ├── Header
  │  ├── InputField
  │  ├── Login
  │  ├── Music
  │  ├── Navbar
  │  ├── News
  │  ├── NotFound
  │  ├── Paginator
  │  ├── PhotoSection
  │  ├── Profile
  │  │  ├── MyPosts
  │  │  └── ProfileInfo
  │  ├── Settings
  │  ├── TextAreaField
  │  ├── Users
  │  ├── common
  │  │  ├── Avatar
  │  │  ├── Button
  │  │  ├── Label
  │  │  ├── Like
  │  │  ├── Loader
  │  │  ├── Logo
  │  │  ├── Radio
  │  │  ├── Select
  │  │  └── Toggle
  ├── fonts
  ├── hoc
  ├── hook
  ├── locales
  │  ├── en
  │  └── ru
  ├── store
  ├── styles
  ├── tests
  ├── types
  └── utils
```## Dependencies
The project has the next dependencies in the [package.json](package.json) file.
data:image/s3,"s3://crabby-images/5e128/5e12845a5bd0225400a1389b1d00f109e02ef39a" alt="GitHub package.json dependency version (prod)"
data:image/s3,"s3://crabby-images/938f4/938f4d2cfbd40ec4f72a16dc4c5f3ca3a5d77dbb" alt="GitHub package.json dependency version (prod)"
data:image/s3,"s3://crabby-images/abb3a/abb3a691523750bb87959798141c5329045bcfae" alt="GitHub package.json dependency version (prod)"
data:image/s3,"s3://crabby-images/bb280/bb2804dc9b8c0e6c4496a506f8bee917770f850d" alt="GitHub package.json dependency version (prod)"
data:image/s3,"s3://crabby-images/bee71/bee7134a040410f8b42c7ba250314c259745f377" alt="GitHub package.json dependency version (prod)"
data:image/s3,"s3://crabby-images/1945e/1945efe760b506cc9fb0fe62904f59f5a387d55c" alt="GitHub package.json dependency version (prod)"
data:image/s3,"s3://crabby-images/b81ff/b81ff25357425ea0424e112d91bd2cbd2aa8b2bb" alt="GitHub package.json dependency version (prod)"## Installation
1. Clone project to your PC by the following command:
```console
git clone https://github.com/andreynav/social-network.git
```2. Open the root directory and enter the following command:
```console
yarn
```3. In the root directory create `.env` file and add inside it a row `REACT_APP_API_KEY=XXXX` where `XXXX` is your API key for getting back-end. To get API key you need to create your own account on the [Social Network API](https://social-network.samuraijs.com/) site. Also, you can add a row like `PORT=3001` to `.env` file, and run the project on the desired port.
## Running project
To run project, open the root directory and enter the following command:
```console
yarn start
```The command runs the app in the development mode.
Open [http://localhost:3001](http://localhost:3000) to view it in your browser.## Running tests
To run the tests, open the root directory and enter the following command:
```console
yarn test
```Launches the test runner in the interactive watch mode.
See the folder [tests](src/tests) for information about existing tests.## Running build
To run build, open the root directory and enter the following command:
```console
yarn build
```Builds the app for production to the `build` folder.
It correctly bundles React in production mode and optimizes the build for the best performance.
The build is minified and the filenames include the hashes.
Your app is ready to be deployed!See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.
## License
The project is open source software provided under the [Apache License 2.0](LICENSE.md).