From 2aec5fbd603633a88d92dbfacf2b60d058783524 Mon Sep 17 00:00:00 2001 From: Lior Keren Date: Wed, 26 Oct 2022 18:36:09 +0300 Subject: [PATCH] Added Guitar Gallery This Component presents the guitars gotten from the server. It contains a sub-component: GuitarInfo which is a GalleryItem In addition this commit removes the unecessary files regarding Users.js --- .ruby-version | 2 +- app/controllers/guitars_controller.rb | 24 ++++++++++++ app/controllers/user_controller.rb | 7 ---- app/javascript/components/GuitarGallery.js | 45 ++++++++++++++++++++++ app/javascript/components/GuitarInfo.js | 38 ++++++++++++++++++ app/javascript/components/Users.js | 31 --------------- app/javascript/packs/hello_react.jsx | 4 +- app/views/guitar_gallery/index.html.erb | 2 + app/views/user/index.html.erb | 2 - config/routes.rb | 2 +- 10 files changed, 113 insertions(+), 44 deletions(-) create mode 100644 app/controllers/guitars_controller.rb delete mode 100644 app/controllers/user_controller.rb create mode 100644 app/javascript/components/GuitarGallery.js create mode 100644 app/javascript/components/GuitarInfo.js delete mode 100644 app/javascript/components/Users.js create mode 100644 app/views/guitar_gallery/index.html.erb delete mode 100644 app/views/user/index.html.erb diff --git a/.ruby-version b/.ruby-version index 4560fb9..49cdd66 100644 --- a/.ruby-version +++ b/.ruby-version @@ -1 +1 @@ -ruby-2.6.3 +2.7.6 diff --git a/app/controllers/guitars_controller.rb b/app/controllers/guitars_controller.rb new file mode 100644 index 0000000..92e9a6e --- /dev/null +++ b/app/controllers/guitars_controller.rb @@ -0,0 +1,24 @@ +class GuitarsController < ApplicationController + def index + render :json => [ + { + 'name':'guitar1', + 'url':'https://rukminim1.flixcart.com/image/416/416/acoustic-guitar/x/8/w/topaz-blue-signature-original-imaefec7uhypjdr9.jpeg?q=70', + 'price':'100', + 'description':'blablabla 1' + }, + { + 'name':'guitar2', + 'url':'https://shop.brianmayguitars.co.uk/user/special/content/Antique%20Cherry%20a.jpg', + 'price':'200', + 'description':'blablabla 2' + }, + { + 'name':'guitar3', + 'url':'https://cdn.mos.cms.futurecdn.net/Yh6r74b8CAj2jbdf2FAhq4-970-80.jpg.webp', + 'price':'300', + 'description':'blablabla 3' + } + ] + end + end diff --git a/app/controllers/user_controller.rb b/app/controllers/user_controller.rb deleted file mode 100644 index d1af404..0000000 --- a/app/controllers/user_controller.rb +++ /dev/null @@ -1,7 +0,0 @@ -class UserController < ApplicationController - def index - render :json => [ - 'admin', 'guest' - ] - end -end diff --git a/app/javascript/components/GuitarGallery.js b/app/javascript/components/GuitarGallery.js new file mode 100644 index 0000000..c7677d6 --- /dev/null +++ b/app/javascript/components/GuitarGallery.js @@ -0,0 +1,45 @@ +import React, { useEffect, useState } from 'react'; +import axios from 'axios'; +import { Title, TitleSizes, Gallery } from '@patternfly/react-core'; +import GuitarInfo from './GuitarInfo'; + +// Loading the data from the server: + +export const GuitarGallery = () => { + const getGuitars = async () => { + try { + const response = await axios.get('/guitars'); + if (response.data) { + setGuitars(response.data); + } + } catch (error) { + console.error(error); + } + }; + + const [guitars, setGuitars] = useState([]); + + useEffect(() => { + getGuitars(); + }, []); + + return ( +
+ + Guitars For Sale: + + + {guitars.map(({ name, url, price, description }) => ( + + ))} + +
+ ); +}; diff --git a/app/javascript/components/GuitarInfo.js b/app/javascript/components/GuitarInfo.js new file mode 100644 index 0000000..3706d64 --- /dev/null +++ b/app/javascript/components/GuitarInfo.js @@ -0,0 +1,38 @@ +import React from 'react'; +import PropTypes from 'prop-types'; +import { + GalleryItem, + Grid, + GridItem, + Card, + CardTitle, + CardBody, + CardFooter +} from '@patternfly/react-core'; + +const GuitarInfo = ({ name, url, price, description }) => { + return ( + + + + + Guitar Image + + + {name} + Price: {price} + Description: {description} + + + + + ); +}; +GuitarInfo.propTypes = { + name: PropTypes.string.isRequired, + url: PropTypes.string.isRequired, + price: PropTypes.string.isRequired, + description: PropTypes.string.isRequired +}; + +export default GuitarInfo; diff --git a/app/javascript/components/Users.js b/app/javascript/components/Users.js deleted file mode 100644 index e267a4c..0000000 --- a/app/javascript/components/Users.js +++ /dev/null @@ -1,31 +0,0 @@ -import React, { useEffect, useState } from 'react'; -import axios from 'axios'; -import { Title, TitleSizes, List, ListItem } from '@patternfly/react-core'; - -export const Users = () => { - const [users, setUsers] = useState([]); - useEffect(() => { - const getUser = async () => { - try { - const response = await axios.get('/user'); - setUsers(response.data || []); - } catch (error) { - console.error(error); - } - }; - getUser(); - }, []); - - return ( -
- - Users: - - - {users.map((user, index) => ( - {user} - ))} - -
- ); -}; diff --git a/app/javascript/packs/hello_react.jsx b/app/javascript/packs/hello_react.jsx index 35a0215..5c7d640 100644 --- a/app/javascript/packs/hello_react.jsx +++ b/app/javascript/packs/hello_react.jsx @@ -3,9 +3,9 @@ // of the page. import React from 'react'; import ReactDOM from 'react-dom'; -import { Users } from '../components/Users'; +import { GuitarGallery } from '../components/GuitarGallery'; import './fonts.css'; document.addEventListener('DOMContentLoaded', () => { - ReactDOM.render(, document.body.appendChild(document.createElement('div'))); + ReactDOM.render(, document.body.appendChild(document.createElement('div'))); }); diff --git a/app/views/guitar_gallery/index.html.erb b/app/views/guitar_gallery/index.html.erb new file mode 100644 index 0000000..f861ea2 --- /dev/null +++ b/app/views/guitar_gallery/index.html.erb @@ -0,0 +1,2 @@ +

Guitars#index

+

Find me in app/views/guitars/index.html.erb

diff --git a/app/views/user/index.html.erb b/app/views/user/index.html.erb deleted file mode 100644 index c825aaf..0000000 --- a/app/views/user/index.html.erb +++ /dev/null @@ -1,2 +0,0 @@ -

User#index

-

Find me in app/views/user/index.html.erb

diff --git a/config/routes.rb b/config/routes.rb index 8c9f741..db1f8fc 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -1,5 +1,5 @@ Rails.application.routes.draw do root 'home#index' - get '/user', to: 'user#index' + get '/guitars', to: 'guitars#index' # For details on the DSL available within this file, see https://guides.rubyonrails.org/routing.html end