From 212a7ef2251558ce7638e37c515569f07d4f188e Mon Sep 17 00:00:00 2001 From: NickOvchinnikov Date: Thu, 23 Sep 2021 14:31:58 +0300 Subject: [PATCH 1/2] Add useState example --- .../ClickCounter.test.tsx | 28 +++++++++++++++++++ .../useStateAndUseEffect/ClickCounter.tsx | 17 +++++++++++ 2 files changed, 45 insertions(+) create mode 100644 examples/useStateAndUseEffect/ClickCounter.test.tsx create mode 100644 examples/useStateAndUseEffect/ClickCounter.tsx diff --git a/examples/useStateAndUseEffect/ClickCounter.test.tsx b/examples/useStateAndUseEffect/ClickCounter.test.tsx new file mode 100644 index 0000000..3d2654b --- /dev/null +++ b/examples/useStateAndUseEffect/ClickCounter.test.tsx @@ -0,0 +1,28 @@ +import React from 'react'; +import { render, screen, fireEvent } from '@testing-library/react'; + +import { ClickCounter } from './ClickCounter'; + +describe('Test ClickCounter', () => { + it('should inc/dec counter when buttons inc/dec clicked', () => { + render(); + + const counter = screen.getByRole('heading'); + const increaseBtn = screen.getByRole('button', { name: 'Increase' }); + const decreaseBtn = screen.getByRole('button', { name: 'Decrease' }); + + expect(counter.textContent).toBe('Counter: 0'); + + fireEvent.click(increaseBtn); + expect(counter.textContent).toBe('Counter: 1'); + + fireEvent.click(increaseBtn); + expect(counter.textContent).toBe('Counter: 2'); + + fireEvent.click(decreaseBtn); + expect(counter.textContent).toBe('Counter: 1'); + + fireEvent.click(decreaseBtn); + expect(counter.textContent).toBe('Counter: 0'); + }); +}); diff --git a/examples/useStateAndUseEffect/ClickCounter.tsx b/examples/useStateAndUseEffect/ClickCounter.tsx new file mode 100644 index 0000000..b745df8 --- /dev/null +++ b/examples/useStateAndUseEffect/ClickCounter.tsx @@ -0,0 +1,17 @@ +import React, { FC, useState } from 'react'; + +interface Props { + defaultCount?: number; +} + +export const ClickCounter: FC = ({ defaultCount = 0 }) => { + const [count, setCount] = useState(defaultCount); + + return ( +
+

Counter: {count}

+ + +
+ ); +}; From aee978e97fccda920de0ba526d0c4cf4c00ca4d1 Mon Sep 17 00:00:00 2001 From: NickOvchinnikov Date: Thu, 23 Sep 2021 14:34:09 +0300 Subject: [PATCH 2/2] Refactoring readme --- README.md | 24 +++++++++++++----------- 1 file changed, 13 insertions(+), 11 deletions(-) diff --git a/README.md b/README.md index 570de39..4c549de 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ # Minesweeper -## Section 1: Introduction +## Section: Introduction ### Minesweeper presentation @@ -19,7 +19,7 @@ [Pull request](https://github.com/nickovchinnikov/minesweeper/pull/2) -## Section 2: Typescript recap +## Section: Typescript recap ### Typescript basic ### Parametric typing with generics @@ -35,7 +35,7 @@ [Pull request](https://github.com/nickovchinnikov/minesweeper/pull/4) -## Section 3: React intro +## Section: React intro ### Create React App @@ -64,7 +64,7 @@ [React intro examples pull request](https://github.com/nickovchinnikov/minesweeper/pull/10/files) -## Section 4: Jest, TDD and basic game logic +## Section: Jest, TDD and basic game logic ### Jest testing framework (TDD vs TLD) @@ -85,7 +85,7 @@ [config for vscode](https://gist.github.com/nickovchinnikov/ace62c117e6b6ff87f0fbfe96bb04164) -## Section 5: Storybook and Components Library +## Section: Storybook and Components Library ### Library Emotion for css-in-js @@ -115,10 +115,12 @@ [Pull request](https://github.com/nickovchinnikov/minesweeper/pull/14) -## Section 6: React Hooks intro +## Section: React Hooks intro ### useState +[Pull request](https://github.com/nickovchinnikov/minesweeper/pull/41) + ### Dynamic components with useState Hook [Pull request](https://github.com/nickovchinnikov/minesweeper/pull/15) @@ -153,7 +155,7 @@ [Pull request](https://github.com/nickovchinnikov/minesweeper/pull/38) -## Section 7: Code quality, app deploy and CI/CD +## Section: Code quality, app deploy and CI/CD ### Test coverage report ### Test quality tool Stryker-Mutator @@ -175,7 +177,7 @@ [Pull request3](https://github.com/nickovchinnikov/minesweeper/pull/23) -## Section 8: React hooks and react testing library +## Section: React hooks and react testing library ### Static game @@ -203,7 +205,7 @@ [Pull request](https://github.com/nickovchinnikov/minesweeper/pull/28/files) -## Section 9: Game Hook +## Section: Game Hook ### Create game over behavior by TDD @@ -217,7 +219,7 @@ [Pull request](https://github.com/nickovchinnikov/minesweeper/pull/31/files) -## Section 9: Game behavior and useEffect +## Section: Game behavior and useEffect ### Set flag action @@ -229,7 +231,7 @@ [Pull request](https://github.com/nickovchinnikov/minesweeper/pull/33/files) -## Section 10: useEffect and useCallback +## Section: useEffect and useCallback ### Game timer and useEffect