From dec9484d3ccde64d13263975509e623fd8f772fe Mon Sep 17 00:00:00 2001 From: GokaPek Date: Mon, 25 Dec 2023 16:08:33 +0400 Subject: [PATCH] 5_5 --- .../src/components/directions/Direction.jsx | 29 ++++++++++ .../src/components/directions/Directions.jsx | 45 +++++++++++++++ .../src/components/directions/TableDirect.jsx | 27 +++++++++ Lab5/Bookfill/src/pages/Search.jsx | 56 ++----------------- 4 files changed, 106 insertions(+), 51 deletions(-) create mode 100644 Lab5/Bookfill/src/components/directions/Direction.jsx create mode 100644 Lab5/Bookfill/src/components/directions/Directions.jsx create mode 100644 Lab5/Bookfill/src/components/directions/TableDirect.jsx diff --git a/Lab5/Bookfill/src/components/directions/Direction.jsx b/Lab5/Bookfill/src/components/directions/Direction.jsx new file mode 100644 index 0000000..1756c19 --- /dev/null +++ b/Lab5/Bookfill/src/components/directions/Direction.jsx @@ -0,0 +1,29 @@ +import PropTypes from 'prop-types'; +import { Heart } from 'react-bootstrap-icons'; +import '../lines/table/LinesTableRow.css'; + +const Direction = ({ index, line, onAddCart }) => { + const handleAnchorClick = (event, action) => { + event.preventDefault(); + action(); + }; + return ( + + {index + 1} + {line.book_name} + {line.type.name} + {line.author_name} + {parseFloat(line.price).toFixed(2)} + {line.book_name} + handleAnchorClick(event, onAddCart)}> + + ); +}; + +Direction.propTypes = { + index: PropTypes.number, + line: PropTypes.object, + onAddCart: PropTypes.func, +}; + +export default Direction; diff --git a/Lab5/Bookfill/src/components/directions/Directions.jsx b/Lab5/Bookfill/src/components/directions/Directions.jsx new file mode 100644 index 0000000..5c69f28 --- /dev/null +++ b/Lab5/Bookfill/src/components/directions/Directions.jsx @@ -0,0 +1,45 @@ +import { useState } from 'react'; +import TableDirect from './TableDirect.jsx'; +import Select from '../input/Select.jsx'; +import Direction from './Direction.jsx'; +import useLines from '../lines/hooks/LinesHook'; +import useCart from '../cart/CartHook'; +import Input from '../input/Input.jsx'; +import useTypeFilter from '../lines/hooks/LinesFilterHook'; + +const Directions = () => { + const { types, currentFilter, handleFilterChange } = useTypeFilter(); + const { lines } = useLines(currentFilter); + const [searchValue, setSearchValue] = useState(''); + const { addToCart } = useCart(); + + return ( + <> +
+ setSearchValue(e.target.value)} + type='text' required /> +