Skip to content

gegebe/vue-components-training

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

logo_ironhack_blue 7

LAB | Vue3 Training

This exercise allows you to practice and apply the concepts and techniques taught in class. This is a free adaptation from this exercise so some errors may be expected.

Upon completion of this exercise, you will be able to:

  • Create and render components with multiple props.
  • Use props to pass data to components and display the data received through props within the components
  • Use inline styles to modify the appearance of components
  • Use operators ? and && to conditionally render content
  • Use the ref function to create references to elements.
  • Use the reactive function to create reactive objects and the toRefs function to extract refs.
  • Create event handler functions to handle user interactions and browser events.
  • Create controlled components to manage the form inputs.
  • Apply the "Lifting State Up" approach to share the state between components.
  • Pass functions as props from a parent component to a child component.

Introduction

The purpose of this exercise is to practice the core React concepts such as: creating components, passing data through props, working with state, rendering lists, and working with forms (controlled components).

To see the expected result for each iteration, refer to the solution example: React Training - solution.

Setup

  • Fork this repo
  • Clone this repo
$ cd vue-components-training
$ npm install
$ npm run dev

Submission

  • Upon completion, run the following commands:

    git add .
    git commit -m "done"
    git push origin master
    

Instructions

Iteration 0 | Components folder

Inside of the src/ folder, create a new folder named components.

Use the components folder to store all the components that you create in the following iterations.


Iteration 1 | Component: IdCard

Create and render an IdCard component with 6 props:

  • lastName: A string
  • firstName: A string
  • gender: A string, 'male' or 'female'
  • height: A number
  • birth: A date
  • picture: A string

Example:

<IdCard
  last-name='Doe'
  first-name='John'
  gender='male'
  :height="178"
  :birth='new Date("1992-07-14")'
  picture="https://randomuser.me/api/portraits/men/44.jpg"
/>

<IdCard
  last-name='Delores '
  first-name='Obrien'
  gender='female'
  :height="172"
  :birth='new Date("1988-05-11")'
  picture="https://randomuser.me/api/portraits/women/44.jpg"
/>

Expected Output:

image

This component is partially implemented. Help - Components and passing props Help - Passing different prop types


Iteration 2 | Component: Random

Create a Random component with 2 props:

  • min: A number
  • max: A number

The component should display a random integer in the range between the min and the max number.

Example:

<Random :min="1" :max="6"/>
<Random :min="1" :max="100"/>

Expected Output:

image


Iteration 3 | Component: BoxColor

Create a BoxColor component that displays a rectangle with a background color based on props. For this, you will need to add inline styles (documentation).

The component should take 3 props:

  • r: A number between 0 and 255 representing the amount of red
  • g: A number between 0 and 255 representing the amount of green
  • b: A number between 0 and 255 representing the amount of blue

Example:

    <BoxColor :r="255" :g="0" :b="0" />
    <BoxColor :r="128" :g="255" :b="0" />

Expected Output:

image

As a bonus, you can also display the hex values of the color (e.g., #ff0000 for red).


Iteration 4 | Component: CreditCard

Create a CreditCard component that displays a rectangle with the information coming from the props.

The component should take 8 props:

  • type: A string that can be "Visa" or "Master Card"
  • number: A string that is the number of the credit card. For security reasons, you should only display the 4 last digits 😉
  • expirationMonth: A number that represents the month, between 1 and 12
  • expirationYear: A number that represents the year
  • bank: A string that represents the name of the bank
  • owner: A string that represents the name of the owner
  • bgColor: A string for the background color of the card
  • color: A string for the text color of the card

Take your time to make the component look as close to the expected output as possible. You'll probably want to use flexbox.

Example:

    <CreditCard
      type="Visa"
      number="0123456789018845"
      :expiration-month="3"
      :expiration-year="2021"
      bank="BNP"
      owner="Maxence Bouret"
      bg-color="#11aa99"
      color="white"
    />

    <CreditCard
      type="Master Card"
      number="0123456789010995"
      :expiration-month="3"
      :expiration-year="2021"
      bank="N26"
      owner="Maxence Bouret"
      bg-color="#eeeeee"
      color="#222222"
    />

    <CreditCard
      type="Visa"
      number="0123456789016984"
      :expiration-month="12"
      :expiration-year="2019"
      bank="Name of the Bank"
      owner="Firstname Lastname"
      bg-color="#ddbb55"
      color="white"
    />

Expected Output:

image


Iteration 5 | Component: Greetings

Create a Greetings component with 1 props:

  • lang: A string that can have values: "de", "en", "es" or "fr"

You must also pass the text between the <Greetings> tags. That's called Slots

The component should display a greeting text in the chosen language.

Example:

<Greetings lang="de"><span style="color: yellow">Ludwig</span></Greetings>
<Greetings lang="fr"><strong>François</strong></Greetings>

Expected Output:

Important: This is not the exact output. You should see the color of the text of Ludwing in yellow, whereas François should be between strong tags.

image


Iteration 6 | Component: Rating

Create a Rating component that displays 5 stars. Depending on the value received, some stars should be empty (☆), and some should be filled (★).

Example:

    <Rating :rate="0" />
    <Rating :rate="1.49" />
    <Rating :rate="1.5" />
    <Rating :rate="3" />
    <Rating :rate="4" />
    <Rating :rate="5" />

Expected Output:

image


Iteration 7 | Component: DriverCard

Create a DriverCard component that displays a rectangle with content based on the received props.

The component should take 4 props:

  • name: A string
  • rating: A number between 0 and 5. The value can be a floating point number.
  • img: A string
  • car: An object with properties model and licensePlate.

Notice that you can use the component created in Iteration 6 in this Driver Card component.

Example

  <DriverCard
      name="Travis Kalanick"
      :rating="4.2"
      img="https://si.wsj.net/public/resources/images/BN-TY647_37gql_OR_20170621052140.jpg?width=620&height=428"
      :car="{ model: 'Toyota Corolla Altis', licensePlate: 'CO42DE' }"
    />

    <DriverCard
      name="Dara Khosrowshahi"
      :rating="4.9"
      img="https://ubernewsroomapi.10upcdn.com/wp-content/uploads/2017/09/Dara_ELT_Newsroom_1000px.jpg"
      :car="{ model: 'Audi A3', licensePlate: 'BE33ER' }"
    />
  </div>

Expected Output:

image


Iteration 8 | State: LikeButton

Create a LikeButton component that displays a button with the initial text "0 Likes". With each click, the number of Likes should increase.

As a bonus, implement the background color change on each click. You can use the following array of colors: ['purple','blue','green','yellow','orange','red']

Example:

<LikeButton />

Expected Output:


Iteration 9: State: ClickablePicture

Create a ClickablePicture component that displays a picture. On each click, the picture should toggle between the two images passed through the props.

Example:

<ClickablePicture img="maxence.png" img-clicked="maxence-glasses.png" />

Expected Output:

PS: If you want to use your picture instead, you can create it using this picture: http://www.stickpng.com/assets/images/584999937b7d4d76317f5ffd.png 😎


Iteration 10 | State: Dice

Create a Dice component that displays a picture with the random dice value (example: '../assets/images/dice3.png').

Every time the user clicks on the component, it should:

  • First, display an empty picture ('../assets/images/dice-empty.png')
  • 1 second later, display a new random picture (example: '../assets/images/dice6.png').

Example:

<Dice />

Expected Output before the click:

image

Expected Output immediately after the click:

image

Expected Output 1 second after the click:

image


Iteration 11 | State: Carousel

Create a Carousel component that displays an image and two buttons (Left and Right), which change the picture on each click, respectively.

The component should take 1 prop:

  • images: An array of strings. Each string should be an image URL.

Example:

<Carousel
  images={[
    "https://randomuser.me/api/portraits/women/1.jpg",
    "https://randomuser.me/api/portraits/men/1.jpg",
    "https://randomuser.me/api/portraits/women/2.jpg",
    "https://randomuser.me/api/portraits/men/2.jpg",
  ]}
/>

Expected Output:


Iteration 12 | List and Keys | NumbersTable

Create a NumbersTable component that displays a list of numbers between 1 and the limit. Even numbers must be colored in red.

The component should take 1 prop:

  • limit: A number.

Example:

<NumbersTable :limit={12} />

Expected Output:

image


Iteration 13 | List and Keys - FaceBook (Simple)

Create a FaceBook component that displays the list of all profiles coming from the file src/data/berlin.json. Remember to import the json data in the component:

import profiles from "./data/berlin.json";

Example:

<FaceBook />

Expected Output: (you should see about 28 profiles)

image


Iteration 14 | List and Keys - FaceBook (Advanced)

Update your FaceBook component and add a button for each country the students come from; Each student object has a country property. When the user clicks on the button with the country name (example: USA), add a blue background to all the profiles where the country is the one selected.

Example:

<FaceBook />

Expected Output: (note: part of the content in the screenshot was cropped)

image

Bonus:

  • By default, only display the picture. Then, when a user clicks on a picture, display more information
  • Add sort buttons
  • Add a search input

Iteration 15 | Form - SignupPage

Create a SignupPage component with the following elements:

  • An input of type "email" (bonus: make the input green/red when the email is valid/invalid)

  • An input of type "password" (bonus: make the input green/red when the password is strong/weak)

  • A select input, used for selecting a nationality, with possible options/values: "en", "de", "fr"

  • A paragraph displaying "Hello", "Hallo" or "Bonjour" based on the selected nationality

  • A text "Your email is john@doe.com"

For this, you will need 3 state variables:

  • email
  • password
  • nationality

Try installing Bootstrao or PicoCSS to markup easily the form.

Example

<SignupPage />

Output

image


Iteration 16 | Lifting State Up - RGBColorPicker

Create 2 components:

  • The RGBColorPicker component, that displays a square with an rgb color coming from the state. The component should have the following state variables:

    • rValue: A number between 0 and 255, representing the amount of red

    • gValue: A number between 0 and 255, representing the amount of green

    • bValue: A number between 0 and 255, representing the amount of blue

  • The SingleColorPicker component should have an input field of type "number", and allow the user to select a number between 0 and 255.

    The component should take 3 props:

    • color: A string that is either "r", "g" or "b"
    • value: A number between 0 and 255
    • onChange: A method that is triggered when the input is changed

The RGBColorPicker should render 3 SingleColorPicker components and send the state values to them.

Example:

 <SingleColorPicker color="r" :value="rValue" @change="updateColor('r', $event)" />
    <SingleColorPicker color="g" :value="gValue" @change="updateColor('g', $event)" />
    <SingleColorPicker color="b" :value="bValue" @change="updateColor('b', $event)" />

Expected Output

image

Happy coding! ❤️

Recommended IDE Setup

VSCode + Volar (and disable Vetur) + TypeScript Vue Plugin (Volar).

Customize configuration

See Vite Configuration Reference.

Project Setup

npm install

Compile and Hot-Reload for Development

npm run dev

Compile and Minify for Production

npm run build

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • CSS 48.4%
  • Vue 36.8%
  • JavaScript 8.2%
  • HTML 6.6%