Skip to content

maxcore25/test-task-crypto-exchange

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

test-task-crypto-exchange

Инструкция

  1. Скопируйте файл .env.example и переименуйте в .env
  2. Перейдите по ссылке ТЗ: https://telegra.ph/TZ-Frontend-dev-react-12-14
  3. Скопируйте API key
  4. Вставьте скопированный API key в переменную VITE_API_KEY в файле .env

Запуск (без Docker)

  1. Скачайте зависимости
pnpm i
  1. Запустите проект командой
pnpm dev
  1. Перейдите по ссылке: http://localhost:5173

Запуск (с Docker)

  1. Запустите проект командой
docker-compose up -d --build
  1. Перейдите по ссылке: http://localhost

Storybook

  1. Запустите Storybook командой
pnpm sb
  1. Перейдите по ссылке: http://localhost:6006

Тесты

  1. Запустите тесты в терминале командой
pnpm test
  1. Запустите тесты в веб-интерфейсе командой
pnpm test:ui
  1. Перейдите по ссылке: http://localhost:51204/__vitest__/#/

E2E-тесты

  1. Запустите e2e-тесты в терминале командой
pnpm test:e2e
  1. Запустите e2e-тесты в веб-интерфейсе командой
pnpm test:e2e-ui

Playwright команды

# Runs the end-to-end tests
pnpm exec playwright test

# Starts the interactive UI mode
pnpm exec playwright test --ui

# Runs the tests only on Desktop Chrome
pnpm exec playwright test --project=chromium

# Runs the tests in a specific file
pnpm exec playwright test example

# Runs the tests in debug mode
pnpm exec playwright test --debug

# Auto generate tests with Codegen
pnpm exec playwright codegen

ТЗ

Ссылка: https://telegra.ph/TZ-Frontend-dev-react-12-14

Есть API: https://documenter.getpostman.com/view/8180765/SVfTPnM8?version=latest#intro

API key: в файле .env.

Из этого API использовать только методы:

  • List of available currencies;
  • Minimal exchange amount;
  • Estimated exchange amount.

Нужно реализовать виджет для создания обмена (только фронт, реакт):

  1. Из API берется список всех валют (не использовать метод API get_all_pairs, делать виджет для всех возможных пар);
  2. В виджете можно выбрать левую и правую валюты;
  3. При выборе валют, выставлять в левом инпуте минимальную сумму обмена;
  4. В правый инпут считается и подставляется значение estimated для выбранных валют и суммы в левом инпуте;
  5. Если сумма меньше, чем минимальная, то в правый инпут пишется прочерк и выводится ошибка;
  6. Если для estimated или для min для выбранных валют API возвращает null, выводить ошибку this pair is disabled now.

Шрифт Arial

Макет: https://www.figma.com/file/fzcnpN2Pm9YY8CIpWbP3NE/Frontend-Test?node-id=0%3A1

Цвета:

  • brand color #137E6E
  • dark gray #282828
  • light gray #A7A7A7
  • background #F4F4F4

Состояния кнопок, адаптив, расстояния — на свое усмотрение.

Поддержка — последние версии основных браузеров.

Дополнительно (необязательно): реализация поиска.