Cryptocurrency app is an application that allows tracking cryptocurrency data and provides access to the latest news from the world of cryptocurrencies. With this app, users can easily monitor their favorite cryptocurrencies, view price charts, check rankings, and stay up to date with the most important information from the world of cryptocurrencies.
-
Registration and login
The app enables users to register and log in to their accounts. After logging in, they have access to personalized features and data.
-
Favorite cryptocurrencies
After logging in, users can add their favorite cryptocurrencies to a favorites list. These selected cryptocurrencies will be displayed on the main dashboard, allowing for quick and easy tracking of their prices and statistics.
-
Price charts
The app provides interactive price charts for the selected cryptocurrency. Users can view price history over different time periods, analyze market trends, and make informed investment decisions.
-
Cryptocurrency rankings
The app provides cryptocurrency rankings based on their market positions. Users can see which cryptocurrencies have the highest market capitalization and are most significant in the world of cryptocurrencies.
-
Cryptocurrency news
The app gathers the latest news and information from the world of cryptocurrencies. Users can browse various articles, market analyses, and updates related to their favorite cryptocurrencies. This allows them to stay up to date and make informed investment decisions.
The application is fully responsive. It was designed and programmed in accordance with the mobile first principle. Below are screenshots of the desktop version:
![Screenshot 2023-05-26 at 21 06 02](https://private-user-images.githubusercontent.com/81325472/241532078-b11ef245-a477-44e6-95f0-d47f09c12dab.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MjE5MjI1OTEsIm5iZiI6MTcyMTkyMjI5MSwicGF0aCI6Ii84MTMyNTQ3Mi8yNDE1MzIwNzgtYjExZWYyNDUtYTQ3Ny00NGU2LTk1ZjAtZDQ3ZjA5YzEyZGFiLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNDA3MjUlMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjQwNzI1VDE1NDQ1MVomWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPTI4MzBiM2U0NmExMzIxZDcyYTE3YTRlYzU2N2I2YjYwZGM0MGRiM2JlYjZmNzBiNTdlMzA1Y2Y2ODNiODZiY2ImWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0JmFjdG9yX2lkPTAma2V5X2lkPTAmcmVwb19pZD0wIn0.O6UBKPm8CQCNb2xTfBB5k1rGTtZtdMTRzXJmrP1tjXE)
![Screenshot 2023-05-26 at 21 26 57](https://private-user-images.githubusercontent.com/81325472/241533045-93acd4dc-3924-4906-9d6c-3b22ddd50789.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MjE5MjI1OTEsIm5iZiI6MTcyMTkyMjI5MSwicGF0aCI6Ii84MTMyNTQ3Mi8yNDE1MzMwNDUtOTNhY2Q0ZGMtMzkyNC00OTA2LTlkNmMtM2IyMmRkZDUwNzg5LnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNDA3MjUlMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjQwNzI1VDE1NDQ1MVomWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPWZhOThkOWU0MjYzYWNlYTRiMTU4YWJlYTliNWUyMzc2ZGI1ZTY1Yjc0YWJmMjY4YTNlZjNkNmEzYTMxMTQ4NTcmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0JmFjdG9yX2lkPTAma2V5X2lkPTAmcmVwb19pZD0wIn0.IHjQ8EleHlAUzden1sa4mOyj5IPpGGW6XDdMmdg21Yo)
![Screenshot 2023-05-26 at 21 27 04](https://private-user-images.githubusercontent.com/81325472/241532094-89901fea-ef20-4f8d-b022-236e44c5334f.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MjE5MjI1OTEsIm5iZiI6MTcyMTkyMjI5MSwicGF0aCI6Ii84MTMyNTQ3Mi8yNDE1MzIwOTQtODk5MDFmZWEtZWYyMC00ZjhkLWIwMjItMjM2ZTQ0YzUzMzRmLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNDA3MjUlMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjQwNzI1VDE1NDQ1MVomWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPTRmZGMyNjIxNTZkNjZlMWM4OTg3ZTE4NTNhMDkyYzNkNjI4NjNhYTUzZGIzODNiMjA2YTI3MTY1YWUxYTY4NGEmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0JmFjdG9yX2lkPTAma2V5X2lkPTAmcmVwb19pZD0wIn0.LHyCjg-cIPuAulkEoI733YgktCJ2iveR5xXJVX8WpAM)
![Screenshot 2023-05-26 at 21 28 07](https://private-user-images.githubusercontent.com/81325472/241532349-ae987202-50bc-4c22-a974-e32406baa5fb.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MjE5MjI1OTEsIm5iZiI6MTcyMTkyMjI5MSwicGF0aCI6Ii84MTMyNTQ3Mi8yNDE1MzIzNDktYWU5ODcyMDItNTBiYy00YzIyLWE5NzQtZTMyNDA2YmFhNWZiLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNDA3MjUlMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjQwNzI1VDE1NDQ1MVomWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPWI0Nzc2YzlkN2I5MTU4Y2FhMzlkZGUyNzVjM2UwYmIxOWZhOTQ4Mjc1YjIwYTc5MWY3ZThhYTU5Mzk0YWQwYWMmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0JmFjdG9yX2lkPTAma2V5X2lkPTAmcmVwb19pZD0wIn0.S30bmHPiuFvkS-P1bZ49FvDEx4i6KQ98Yx8VPOcAH4A)
![Screenshot 2023-05-26 at 21 27 21](https://private-user-images.githubusercontent.com/81325472/241532471-6c9f328c-2504-4618-b465-8b526fd7e043.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MjE5MjI1OTEsIm5iZiI6MTcyMTkyMjI5MSwicGF0aCI6Ii84MTMyNTQ3Mi8yNDE1MzI0NzEtNmM5ZjMyOGMtMjUwNC00NjE4LWI0NjUtOGI1MjZmZDdlMDQzLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNDA3MjUlMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjQwNzI1VDE1NDQ1MVomWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPWNjNTcxNjg3YmM4ZmZmZTA1OGRmNzg5OWRhOTM1ZmM1M2I4YmRjZmYyZTMyNzBlYmU4ZWJkN2Q0M2NhOTA5YzYmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0JmFjdG9yX2lkPTAma2V5X2lkPTAmcmVwb19pZD0wIn0.PnuzdMcj-eq5MX1r0ZFI1hHlVO35ogwOY8X66uV4WIA)
![Screenshot 2023-05-26 at 21 27 34](https://private-user-images.githubusercontent.com/81325472/241532736-7788a7f2-68c0-435e-88e4-e171a12223ca.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MjE5MjI1OTEsIm5iZiI6MTcyMTkyMjI5MSwicGF0aCI6Ii84MTMyNTQ3Mi8yNDE1MzI3MzYtNzc4OGE3ZjItNjhjMC00MzVlLTg4ZTQtZTE3MWExMjIyM2NhLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNDA3MjUlMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjQwNzI1VDE1NDQ1MVomWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPTI0ZGE0MmI4NmYzM2QwYTY3NmVhMjE4YzlmYzQ3Y2I2ZTYwNjFhZDcyYWQxN2ZmZDdiYjkyOGQ5YTM1MTQyNTkmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0JmFjdG9yX2lkPTAma2V5X2lkPTAmcmVwb19pZD0wIn0.tzyqrRlLAo6Q13dPVta1gL0Lc6CGImKnbI3fFDjLX44)
![Screenshot 2023-05-26 at 21 27 42](https://private-user-images.githubusercontent.com/81325472/241532841-990414fc-7694-4f1e-9c0b-8699ccafbe5e.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MjE5MjI1OTEsIm5iZiI6MTcyMTkyMjI5MSwicGF0aCI6Ii84MTMyNTQ3Mi8yNDE1MzI4NDEtOTkwNDE0ZmMtNzY5NC00ZjFlLTljMGItODY5OWNjYWZiZTVlLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNDA3MjUlMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjQwNzI1VDE1NDQ1MVomWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPWM5M2EzNjI4NDE2NTNjMWQ0Y2VkMjQyYjk5ZTNjOTlhYmJlYzUzOTMyNThkY2Q4YmJkZjY0NjAzYjk4NjY3NmEmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0JmFjdG9yX2lkPTAma2V5X2lkPTAmcmVwb19pZD0wIn0.bkyf0aq-q6GCr3NY6Tds_go2WpfchdvueUBZQO1E9Uk)
Frontend: React, TypeScript, Vite, SCSS, React Query, Context API
Backend: Nest.js, Typescript, MongoDB, Mongoose, JWT for authentication, GRPC for communication between microservices
-
Clone the repository
git clone https://github.com/kacperbylicki/cryptocurrency-viewer
-
Navigate to the project directory
cd cryptocurrency-viewer
-
Install Turbo
yarn global add turbo
-
Install and build the project dependencies using Turbo
yarn install && yarn build
-
Fill .env file with the required environment variables
cp .env.example .env
-
Build and run the Docker-Compose setup
docker-compose build && docker-compose up -d
You should now be able to access the frontend app at http://localhost:8080.
To run the tests, use the following command:
yarn test:ci