diff --git a/src/App.tsx b/src/App.tsx index a3f0c53..ac5d31d 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -1,10 +1,22 @@ -import { ChakraProvider } from '@chakra-ui/react' +import { ChakraProvider } from "@chakra-ui/react"; import { NotesPage } from "./pages"; const App = () => { return ( - +
+ +
+ {"Made with ❤️ by "} + + Cyril Gourgouillon + +
+
); }; diff --git a/src/config/constants/index.ts b/src/config/constants/index.ts new file mode 100644 index 0000000..0329d15 --- /dev/null +++ b/src/config/constants/index.ts @@ -0,0 +1 @@ +export * from './notes'; diff --git a/src/config/constants/notes.ts b/src/config/constants/notes.ts new file mode 100644 index 0000000..dbc1bb2 --- /dev/null +++ b/src/config/constants/notes.ts @@ -0,0 +1,3 @@ +export const DEFAULT_NUMBER_OF_NOTE = 7; +export const NOTES_LIST_MAX = 7; +export const NOTES_LIST_MIN = 1; diff --git a/src/pages/NotesPage.tsx b/src/pages/NotesPage.tsx index eb425ba..e410f29 100644 --- a/src/pages/NotesPage.tsx +++ b/src/pages/NotesPage.tsx @@ -1,20 +1,27 @@ import { useState } from "react"; -import { Button } from "@chakra-ui/react"; +import { Button, IconButton } from "@chakra-ui/react"; + import { MdBuild } from "react-icons/md"; -import { TbArrowsRandom } from "react-icons/tb"; +import { FaPlus, FaMinus } from "react-icons/fa"; import { GuitarString, Note } from "../config"; import { NotesList } from "../components"; -import { getListOfRandomNotes, getRandomString } from "../services"; +import { getListOfRandomNotes, getRandomString, isValidCountList } from "../services"; +import { DEFAULT_NUMBER_OF_NOTE, NOTES_LIST_MAX, NOTES_LIST_MIN } from "../config/constants"; export const NotesPage = () => { - const [notes, setNotes] = useState(getListOfRandomNotes()); + const [notes, setNotes] = useState(getListOfRandomNotes(DEFAULT_NUMBER_OF_NOTE)); const [isStringVisible, setIsStringVisible] = useState(false); - const [guitarString, setGuitarString] = useState(getRandomString()); + const [guitarString, setGuitarString] = useState( + getRandomString() + ); + const [numberOfNoteDisplayed, setNumberOfNoteDisplayed] = useState( + DEFAULT_NUMBER_OF_NOTE + ); const handleGetRandomNoteOnClick = () => { - setNotes(getListOfRandomNotes()); + setNotes(getListOfRandomNotes(numberOfNoteDisplayed)); setGuitarString(getRandomString()); }; @@ -22,6 +29,16 @@ export const NotesPage = () => { setIsStringVisible((prevState: boolean) => !prevState); }; + const handleChangeNumberOfNoteDisplayed = (step: number) => { + setNumberOfNoteDisplayed((prevState: number) => { + const value = prevState + step; + if (isValidCountList(value)) { + return value; + } + return prevState; + }); + }; + const GuitarStringDecorator: React.ReactNode = (
{guitarString} @@ -29,8 +46,8 @@ export const NotesPage = () => { ); return ( -
-
RANDOM NOTES GENERATOR
+
+
RANDOM NOTES GENERATOR
{ GuitarStringDecorator={GuitarStringDecorator} />
- +
+ } + variant="outline" + onClick={() => handleChangeNumberOfNoteDisplayed(-1)} + disabled={numberOfNoteDisplayed === NOTES_LIST_MIN} + /> + + } + variant="outline" + onClick={() => handleChangeNumberOfNoteDisplayed(1)} + disabled={numberOfNoteDisplayed === NOTES_LIST_MAX} + /> +
-
- {"Made with ❤️ by "} - - Cyril Gourgouillon - -
); }; diff --git a/src/services/noteService.ts b/src/services/noteService.ts index 032afb6..612cf6b 100644 --- a/src/services/noteService.ts +++ b/src/services/noteService.ts @@ -1,8 +1,13 @@ import { Note, notes } from "../config"; +import { NOTES_LIST_MAX, NOTES_LIST_MIN } from "../config/constants"; import { shuffle } from "../utils/shuffle"; -export const getListOfRandomNotes = (): Note[] => { +export const getListOfRandomNotes = (count: number): Note[] => { const randomNotes = shuffle(notes); - return randomNotes.slice(undefined, 7); + return randomNotes.slice(undefined, count); }; + +export const isValidCountList = (count: number): boolean => { + return count >= NOTES_LIST_MIN && count <= NOTES_LIST_MAX +}