From d18997e0be42316081596e50e1f94b5af4feeb01 Mon Sep 17 00:00:00 2001 From: dtauer Date: Fri, 8 Nov 2024 15:06:23 -0600 Subject: [PATCH] added selectedPizza logic --- lessons/04-core-react-concepts/B-hooks.md | 2 ++ lessons/04-core-react-concepts/C-effects.md | 32 +++++++++++++++++++++ 2 files changed, 34 insertions(+) diff --git a/lessons/04-core-react-concepts/B-hooks.md b/lessons/04-core-react-concepts/B-hooks.md index c8ca63f..cb85309 100644 --- a/lessons/04-core-react-concepts/B-hooks.md +++ b/lessons/04-core-react-concepts/B-hooks.md @@ -104,8 +104,10 @@ Now navigate to [http://localhost:5173/]() and see that you have two inputs, one > In the recorded course, the layout is vertical because the `order-pizza` DIV was in the wrong place. Use the markup above. The layout should look like this: + ![Order Page Layout](/images/order-page-layout.webp) + Notice we're using `className` instead of `class` on the HTML element for CSS classes. This is because `class` is a reserved word in JS and JSX is still just JS. So instead they opted to use `className` which is the [name of the JS API][js-api] for interacting with class names. Like `className`, `htmlFor` is used because `for` is a reserved word in JS. diff --git a/lessons/04-core-react-concepts/C-effects.md b/lessons/04-core-react-concepts/C-effects.md index c640190..894bdc8 100644 --- a/lessons/04-core-react-concepts/C-effects.md +++ b/lessons/04-core-react-concepts/C-effects.md @@ -77,6 +77,38 @@ async function fetchPizzaTypes() { - We're using a loading flag to only display data once it's ready. We'll use TanStack Query in a bit to make this code look cleaner. But this is how you do conditional showing/hiding of components in React. - The `key` portion is an interesting one. When React renders arrays of things, it doesn't know the difference between something is new and something is just being re-ordered in the array (think like changing the sorting of a results list, like price high-to-low and then priced low-to-high). Because of this, if you don't tell React how to handle those situations, it just tears it all down and re-renders everything anew. This can cause unnecessary slowness on devices. This is what key is for. Key tells React "this is a simple identifier of what this component is". If React sees you just moved a key to a different order, it will keep the component tree. So key here is to associate the key to something unique about that component. 99/100 this is a database ID of some variety. _Don't_ use the index of the array as that just isn't right unless the array is literally is never going to change order. +### Updating the Selected Pizza & Price + +When a pizza is selected, we need to update the selected pizza and price. First, let's format the price after the `selectedPizza` state is updated: + +```javascript + if(!loading){ + selectedPizza = pizzaTypes.find((pizza) => pizzaType === pizza.id) + price = intl.format(selectedPizza.sizes[pizzaSize]) + } +``` + +When the application loads, we don't have our data yet. So we only want to render a selected pizza and price once we are done loading. Add a condition to the JSX to show "Loading..." initially, and then the selected pizza once we are done loading. Add the condition **before** the closing `` tag: + +```jsx +... + { + loading ? ( +

Loading...

+ ) : ( +
+ +

{price}

+
+ ) + } + +``` + > 🏁 [Click here to see the state of the project up until now: 05-effects][step] [step]: https://github.com/btholt/citr-v9-project/tree/master/05-effects