Skip to content
This repository has been archived by the owner on Aug 14, 2024. It is now read-only.

Latest commit

 

History

History
126 lines (100 loc) · 3.48 KB

README.md

File metadata and controls

126 lines (100 loc) · 3.48 KB

Fibonacci Calculator

The app should be available here:

 

Steps to work with the app locally:

  • Clone the github repo:
git clone https://github.com/angel-langdon/react-fibonacci-calculator.git
  • Change into directory, install packages and start application
cd react-fibonacci-calculator
npm install
npm start

 

App Requirements:

[X] The app will have a main component centered on the page both horizontal and vertical

  • For this requirement I have created a div with these css styles and inside the div is all the app content
.App-container {
  display: flex;
  width: 100vw;
  height: 100vh;
  text-align: center;
  justify-content: center;
  align-items: center;
}

[X] The component will display an input field, a button and an empty div where we will display some information

  • For this requirement I have created different React components:
    • NaturalNumberInput
    • CalculationResults

[X] The input field should allow only numeric values

  • For this requirement I have added text validation in the NaturalNumberInput component

[X] When you click the button, the app should get the value from the input, send it to a function that will run some calculations and then display the result inside the empty div

  • For this requirement I had to create React state variables using useState hook in the Appcomponent
  const [inputValue, setInputValue] = useState("");
  const [result, setResult] = useState(undefined);

[X] The function will receive just one numeric parameter and will return the value of the Fibonacci sequence for that position. We will assume the Fibonacci sequence starts with 1. Example:

  • Fibonacci(0) = 0
  • Fibonacci(1) = 1
  • Fibonacci(5) = 5
  • Fibonacci(6) = 8
  • Fibonacci(10) = 55

I have created a module fibonacci.js that handles all the calculations.

[X] Unit test are optional

  • I have made unit tests for all components and utils and also three integration tests.

[X] CSS, design and any other addition to the app are optional as well but feel free to add whatever you want here if you feel the need

  • I have modified CSS to make the app look good.

Folder structure:

react-fibonacci-calculator
├── LICENSE
├── README.md
├── coverage.png
├── jsconfig.json
├── package-lock.json
├── package.json
├── public
│   ├── favicon.ico
│   ├── index.html
│   ├── manifest.json
│   └── robots.txt
└── src
    ├── components
    │   ├── App
    │   │   ├── App.css
    │   │   ├── App.js
    │   │   └── App.test.js
    │   ├── CalculationResult
    │   │   ├── CalculationResult.css
    │   │   ├── CalculationResult.js
    │   │   └── CalculationResult.test.js
    │   └── NaturalNumberInput
    │       ├── NaturalNumberInput.css
    │       ├── NaturalNumberInput.js
    │       └── NaturalNumberInput.test.js
    ├── index.css
    ├── index.js
    ├── index.test.js
    ├── setupTests.js
    └── utils
        ├── fibonacci.js
        ├── fibonacci.test.js
        ├── string-utils.js
        └── string-utils.test.js

 

 

App screenshots:

 

 

Tests coverage:

Test coverage