diff --git a/package-lock.json b/package-lock.json index a7c446c..564e5b4 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,6 +10,7 @@ "license": "ISC", "dependencies": { "axios": "^1.6.7", + "bootstrap": "^5.3.3", "react": "^18.2.0", "react-cookie": "^7.0.2", "react-dom": "^18.2.0", @@ -758,6 +759,16 @@ "node": ">=16" } }, + "node_modules/@popperjs/core": { + "version": "2.11.8", + "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.8.tgz", + "integrity": "sha512-P1st0aksCrn9sGZhp8GMYwBnQsbvAWsZAX44oXNNvLHGqAOcoVxmjZiohstwQ7SqKnbR47akdNi+uleWD8+g6A==", + "peer": true, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/popperjs" + } + }, "node_modules/@remix-run/router": { "version": "1.14.2", "resolved": "https://registry.npmjs.org/@remix-run/router/-/router-1.14.2.tgz", @@ -1663,6 +1674,24 @@ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", "dev": true }, + "node_modules/bootstrap": { + "version": "5.3.3", + "resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-5.3.3.tgz", + "integrity": "sha512-8HLCdWgyoMguSO9o+aH+iuZ+aht+mzW0u3HIMzVu7Srrpv7EBBxTnrFlSCskwdY1+EOFQSm7uMJhNQHkdPcmjg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/twbs" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/bootstrap" + } + ], + "peerDependencies": { + "@popperjs/core": "^2.11.8" + } + }, "node_modules/brace-expansion": { "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", diff --git a/package.json b/package.json index 33af28b..77aeed8 100644 --- a/package.json +++ b/package.json @@ -16,6 +16,7 @@ }, "dependencies": { "axios": "^1.6.7", + "bootstrap": "^5.3.3", "react": "^18.2.0", "react-cookie": "^7.0.2", "react-dom": "^18.2.0", diff --git a/src/components/item/item.jsx b/src/components/item/item.jsx new file mode 100644 index 0000000..cda5e50 --- /dev/null +++ b/src/components/item/item.jsx @@ -0,0 +1,43 @@ +import React from 'react'; + +// Composant Image atomique +const Image = ({ src, alt }) => { + return {alt}; +}; + +// Composant Description atomique +const Description = ({ title, children }) => { + return ( +
+

{title}

+ {children} +
+ ); +}; + +// Composant Caractéristique atomique +const Characteristic = ({ label, value }) => { + return ( +
+ {label}: {value} +
+ ); +}; + +// Composant Détails du Produit (combinaison atomique) +export const ItemBox = ({ imageUrl, modelName, brandName, purchaseDate, price, onEdit }) => { + return ( +
+ Product + + + + + + + +
+ ); +}; + + diff --git a/src/pages/home.jsx b/src/pages/home.jsx index c093dce..f2746ca 100644 --- a/src/pages/home.jsx +++ b/src/pages/home.jsx @@ -1,6 +1,7 @@ import React from "react"; import { useAuth } from "../hooks"; +import { ItemBox } from "../components/item/item"; export const Home = () => { const { user } = useAuth(); @@ -9,6 +10,14 @@ export const Home = () => {

Home page

{user &&

Hello {user.user.username}

} +
); };