Zrealizowany projekt to aplikacja webowa działająca w przeglądarce, bez potrzeby instalacji. Jest to quiz sprawdzający znajomość uniwersum Gwiezdnych Wojen. Projekt jest tworzony w ramach udziału w CodersCamp 2020, wykorzystujący takie technologie jak HTML, CSS oraz JavaScript. Działanie projektu zostało pokryte testami jednostkowymi.
Zespół, którego mentorem był Krystian wspólnie pracował nad pisaniem kodu, natomiast w ramach dodatkowych odpowiedzialności zajmowaliśmy się także sprawdzaniem poprawności i stylu kodu, a także wewnętrznym zarządzaniem projektem. Spis dodatkowych ról:
- Justyna (Code Review)
- Julia (Code Review)
- Robert (Development Manager)
- Filip (Product Owner)
- Ireneusz (Code Review)
- Konrad (Code Review)
W skład repozytorium projektu wchodzą:
index.html
,index.js
- pliki wyjściowe projektu- folder
src
- zawiera pliki z funkcjonalnościami na stronie, podzielony na podfoldery:src/app/apiconnection
- zawiera pliki z łączeniem się z zewnętrznym APIsrc/app/logic
- zawiera pliki z kodem logiki quizusrc/app/uicomponents
- zawiera pliki komponentów (zwracająHTMLElement
) oraz style CSS.
- folder
test
- zawiera pliki z testami jednostkowymi dla funkcjonalności na stronie - folder
styles
- zawiera pliki z głównymi stylami strony głównej - folder
static
- zawiera pliki graficzne wykorzystywane na stronie oraz przez StarWars API
Na stronie głównej można wybrać jeden z trzech trybów quizu: People, Vehicles, Spaceships. W zależności od trybu zmienia się opis, zdjęcie i same pytania wykorzystywane w quizie, zwiazane z wybranym trybem. Po rozpoczęciu gry (kliknięciu buttona Play the Game) rozpoczyna się odliczanie czasu. Gracz musi odpowiedzieć poprawnie w ciągu 2 minut na jak najwięcej pytań. Po zaznaczeniu odpowiedzi przez sekundę pojawia się informacja (kolor buttonu) czy odpowiedź, którą gracz wybrał była poprawna (button na zielono) czy niepoprawna (button na czerwono). Po skończonym czasie wynik uzyskany przez gracza zapisywany jest do rankingu w LocalStorage danej przeglądarki, do którego można dostać się ze strony głównej.
Zadaniem gracza jest rozpoznanie, co lub kogo przedstawia zdjęcie i wybranie poprawnej odpowiedzi. Pytania do quizu generowane są w zależności od wybranego trybu gry. Na jego podstawie pobierany jest zasób ze StarWars API (https://swapi.co/api/), wybierane są losowo cztery odpowiedzi z czego jedna jest poprawna (dla niej wybierane jest również zdjęcie, wyświetlane po lewej stronie). Poprawność odpowiedzi sprawdzana jest na podstawie algorytmu opisanego TUTAJ.
W momencie wystartowania quizu na dole strony pojawia się informacja o czasie, jaki pozostał graczowi na odpowiedzi. Czas wyświetlany jest w formie tekstowej oraz w formie graficznej - miecz świetlny, który zmniejsza się wraz z upływem czasu.
W trakcie rozpoczęcia gry gracz konkuruje również z komputerem. Może zdecydować o trybie gry z komputerem, tj. komputer może wybierać odpowiedzi losowo lub z wykorzystaniem rozpoznawania obrazu (Google Vision API, pod warunkiem że gracz poda API Key) .
W celu uzyskania odpowiedzi do Google Vision API wysyłany jest obrazek w postaci stringa base64. Algorytm zwraca jedną odpowiedź najbardziej odnoszącą się do przekazanego zdjęcia (tryb WEB_DETECTION
). Przekazana odpowiedź jest porównywana do poprawnej odpowiedzi na podstawie stworzonego algorytmu sprawdzania poprawności odpowiedzi.
Gracz przed rozpoczęciem gry w ustawieniach może wybrać jak odpowiedzi ma wybierać komputer (losowo czy przez rozpoznawanie obrazu - Google Vision API - pod warunkiem że gracz poda API Key). Dodatkowo na stronie głównej jest możliwość sprawdzenia rankingu dla danego trybu gry, który jest przechowywany w LocalStorage przeglądarki.
W projekcie stworzono komponenty, które mogą być w łatwy sposób tworzone i dodawane do DOMu. Komponenty napisane w ten sposób są później łatwiejsze w użyciu, gdy interakcje użytkownika oraz upływający czas zmieniają to, co użytkownik widzi w przeglądarce.
Każda funkcjonalność użyta w projekcie została przetestowana testami jednostkowymi.
- JavaScript
- HTML
- CSS (a także SASS)
- Star Wars API
- Google Vision API
W projekcie można znaleźć przykłady zastosowania wszystkich tych zagadnień: zmienne, operatory porównania, pętle, obiekty, atrybuty, warunki, funkcje, operatory logiczne, tablice, iteracja i/lub rekurencja, console, return, === vs ==, integracja z zewnętrznym REST API, interakcja z domem, odwoływanie się do elementów DOM z JavaScript, zmiana stylów z poziomu JSa, zmiana zawartości HTML z poziomu JSa, animacje, zewnętrzne biblioteki, async await i/lub Promise, funkcje callback, metody HTTP, pisanie testów jednostkowych.
Aby uruchomić aplikację na lokalnej maszynie, wykonaj następujące kroki:
- Zainstaluj zależności za pomocą komendy:
npm install
- Wystartuj serwer developerski
npm run start:dev
- Aplikacja będzie dostępna pod adresem
localhost:8765/index.html
Aby uruchomić testy aplikacji, wykonaj następujące kroki:
- Zainstaluj zależności za pomocą komendy:
npm install
(jeśli nie zrobiłeś już tego wcześniej). - Uruchom testy, wykonując komendę:
npm run test
.