Skip to content
8 changes: 4 additions & 4 deletions src/content/docs/en/tutorial/2-pages/4.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,7 @@ The Astro `<style>` tag can also reference any variables from your frontmatter s
const finished = false;
const goal = 3;

const skillColor = "navy";
const skillColor = "crimson";
---
```

Expand All @@ -129,7 +129,7 @@ The Astro `<style>` tag can also reference any variables from your frontmatter s
</style>
```

3. Check your About page in your browser preview. You should see that the skills are now navy blue, as set by the `skillColor` variable passed to the `define:vars` directive.
3. Check your About page in your browser preview. You should see that the skills are now crimson red, as set by the `skillColor` variable passed to the `define:vars` directive.
</Steps>

<Box icon="puzzle-piece">
Expand All @@ -154,7 +154,7 @@ The Astro `<style>` tag can also reference any variables from your frontmatter s
```

2. Add any missing variable definitions in your frontmatter script so that your new `<style>` tag successfully applies these styles to your list of skills:
- The text color is navy blue
- The text color is crimson red
- The text is bold
- The list items are in all-caps (all uppercase letters)
</Steps>
Expand All @@ -178,7 +178,7 @@ const happy = true;
const finished = false;
const goal = 3;

const skillColor = "navy";
const skillColor = "crimson";
const fontWeight = "bold";
const textCase = "uppercase";
---
Expand Down
2 changes: 1 addition & 1 deletion src/content/docs/en/tutorial/2-pages/5.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ There are a few ways to define styles **globally** in Astro, but in this tutoria
const finished = false;
const goal = 3;

const skillColor = "navy";
const skillColor = "crimson";
const fontWeight = "bold";
const textCase = "uppercase";
---
Expand Down
20 changes: 4 additions & 16 deletions src/content/docs/en/tutorial/3-components/3.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -49,9 +49,6 @@ Since your site will be viewed on different devices, it's time to create a page

</Box>




<Box icon="puzzle-piece">

## Try it yourself - Update your pages
Expand Down Expand Up @@ -95,12 +92,12 @@ Since your site will be viewed on different devices, it's time to create a page
## Add responsive styles

<Steps>
1. Update `Navigation.astro` with the CSS class to control your navigation links. Wrap the existing navigation links in a `<div>` with the class `nav-links`.
1. Update `Navigation.astro` with the CSS class to control your navigation links. Wrap the existing navigation links in a `<div>` with the class `nav-links` and the id attribute set to `main-menu`.

```astro title="src/components/Navigation.astro" ins={3,7}
---
---
<div class="nav-links">
<div id="main-menu" class="nav-links">
<a href="/">Home</a>
<a href="/about">About</a>
<a href="/blog">Blog</a>
Expand All @@ -117,7 +114,7 @@ Since your site will be viewed on different devices, it's time to create a page
Start by defining what should happen on small screen sizes first! Smaller screen sizes require simpler layouts. Then, adjust your styles to accommodate larger devices. If you design the complicated case first, then you have to work to try to make it simple again.
:::

```css title="src/styles/global.css" ins={23-100}
```css title="src/styles/global.css" ins={23-60}
html {
background-color: #f1f5f9;
font-family: sans-serif;
Expand All @@ -144,9 +141,6 @@ Since your site will be viewed on different devices, it's time to create a page

.nav-links {
width: 100%;
top: 5rem;
left: 48px;
background-color: #ff9776;
display: none;
margin: 0;
}
Expand All @@ -159,17 +153,14 @@ Since your site will be viewed on different devices, it's time to create a page
font-size: 1.2rem;
font-weight: bold;
text-transform: uppercase;
color: #0d0950;
}

.nav-links a:hover,
.nav-links a:focus {
background-color: #ff9776;
}

.expanded {
display: unset;
}

@media screen and (min-width: 636px) {
.nav-links {
margin-left: 5em;
Expand All @@ -183,15 +174,12 @@ Since your site will be viewed on different devices, it's time to create a page
display: inline-block;
padding: 15px 20px;
}

}
```
</Steps>

Resize your window and look for different styles being applied at different screen widths. Your header is now **responsive** to screen size through the use of `@media` queries.



<Box icon="check-list">

## Checklist
Expand Down
90 changes: 46 additions & 44 deletions src/content/docs/en/tutorial/3-components/4.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -16,75 +16,66 @@ import Option from '~/components/tutorial/Option.astro';
import PreCheck from '~/components/tutorial/PreCheck.astro';
import { Steps } from '@astrojs/starlight/components';

Let's add a hamburger menu to open and close your links on mobile screen sizes, requiring some client-side interactivity!
Let's add a button to open and close your navigation menu on mobile screen sizes, requiring some client-side interactivity!

<PreCheck>
- Create a hamburger menu component
- Create a menu component
- Write a `<script>` to allow your site visitors to open and close the navigation menu
- Move your JavaScript to its `.js` file
</PreCheck>

## Build a Hamburger component
## Build a Menu component

Create a `<Hamburger />` component to open and close your mobile menu.
Create a `<Menu />` component to open and close your mobile menu.

<Steps>
1. Create a file named `Hamburger.astro` in `src/components/`
1. Create a file named `Menu.astro` in `src/components/`


2. Copy the following code into your component. This will represent your 3-line "hamburger" menu to open and close your navigation links on mobile. (You will add the new CSS styles to `global.css` later.)
2. Copy the following code into your component. It creates a button that will be used to toggle the visibility of the navigation links on mobile devices. (You will add the new CSS styles to `global.css` later.)

```astro title="src/components/Hamburger.astro"
```astro title="src/components/Menu.astro"
---
---
<div class="hamburger">
<span class="line"></span>
<span class="line"></span>
<span class="line"></span>
</div>
<button aria-expanded="false" aria-controls="main-menu" class="menu">
Menu
</button>
```

3. Place this new `<Hamburger />` component just before your `<Navigation />` component in `Header.astro`.
3. Place this new `<Menu />` component just before your `<Navigation />` component in `Header.astro`.

<details>
<summary>Show me the code!</summary>

```astro title="src/components/Header.astro" ins={2,7}
---
import Hamburger from './Hamburger.astro';
import Menu from './Menu.astro';
import Navigation from './Navigation.astro';
---
<header>
<nav>
<Hamburger />
<Menu />
<Navigation />
</nav>
</header>
```
</details>

4. Add the following styles for your Hamburger component:
4. Add the following styles for your Menu component, including some responsive styles:

```css title="src/styles/global.css" ins={2-13, 56-58}
```css title="src/styles/global.css" ins={2-9, 33-35, 51-53}
/* nav styles */
.hamburger {
padding-right: 20px;
cursor: pointer;
}

.hamburger .line {
display: block;
width: 40px;
height: 5px;
margin-bottom: 10px;
background-color: #ff9776;
.menu {
background-color: #0d0950;
border: none;
color: #fff;
font-size: 1.2rem;
font-weight: bold;
padding: 5px 10px;
}

.nav-links {
width: 100%;
top: 5rem;
left: 48px;
background-color: #ff9776;
display: none;
margin: 0;
}
Expand All @@ -97,13 +88,15 @@ Create a `<Hamburger />` component to open and close your mobile menu.
font-size: 1.2rem;
font-weight: bold;
text-transform: uppercase;
color: #0d0950;
}

.nav-links a:hover, a:focus {
.nav-links a:hover,
.nav-links a:focus{
background-color: #ff9776;
}

.expanded {
:has(.menu[aria-expanded="true"]) .nav-links {
display: unset;
}

Expand All @@ -121,7 +114,7 @@ Create a `<Hamburger />` component to open and close your mobile menu.
padding: 15px 20px;
}

.hamburger {
.menu {
display: none;
}
}
Expand All @@ -131,18 +124,21 @@ Create a `<Hamburger />` component to open and close your mobile menu.

## Write your first script tag

Your header is not yet **interactive** because it can't respond to user input, like clicking on the hamburger menu to show or hide the navigation links.
Your header is not yet **interactive** because it can't respond to user input, like clicking on the menu to show or hide the navigation links.

Adding a `<script>` tag provides client-side JavaScript to "listen" for a user event and then respond accordingly.

<Steps>
1. Add the following `<script>` tag to `index.astro`, just before the closing `</body>` tag.

```astro title="src/pages/index.astro" ins={2-6}
```astro title="src/pages/index.astro" ins={2-9}
<Footer />
<script>
document.querySelector('.hamburger')?.addEventListener('click', () => {
document.querySelector('.nav-links')?.classList.toggle('expanded');
const menu = document.querySelector('.menu');

menu.addEventListener('click', () => {
const isExpanded = menu.getAttribute('aria-expanded') === 'true';
menu.setAttribute('aria-expanded', !isExpanded);
});
</script>
</body>
Expand All @@ -159,26 +155,32 @@ Instead of writing your JavaScript directly on each page, you can move the conte
1. Create `src/scripts/menu.js` (you will have to create a new `/scripts/` folder) and move your JavaScript into it.

```js title="src/scripts/menu.js"
document.querySelector('.hamburger').addEventListener('click', () => {
document.querySelector('.nav-links').classList.toggle('expanded');
const menu = document.querySelector('.menu');

menu.addEventListener('click', () => {
const isExpanded = menu.getAttribute('aria-expanded') === 'true';
menu.setAttribute('aria-expanded', !isExpanded);
});
```

2. Replace the contents of the `<script>` tag on `index.astro` with the following file import:

```astro title="src/pages/index.astro" ins={7} del={3-5}
```astro title="src/pages/index.astro" ins={10} del={3-8}
<Footer />
<script>
document.querySelector('.hamburger')?.addEventListener('click', () => {
document.querySelector('.nav-links')?.classList.toggle('expanded');
const menu = document.querySelector('.menu');

menu.addEventListener('click', () => {
const isExpanded = menu.getAttribute('aria-expanded') === 'true';
menu.setAttribute('aria-expanded', !isExpanded);
});

import "../scripts/menu.js";
</script>
</body>
```

3. Check your browser preview again at a smaller size and verify that the hamburger menu still opens and closes your navigation links.
3. Check your browser preview again at a smaller size and verify that the menu still opens and closes your navigation links.


4. Add the same `<script>` with import to your other two pages, `about.astro` and `blog.astro` and verify that you have a responsive, interactive header on each page.
Expand Down
2 changes: 1 addition & 1 deletion src/content/docs/en/tutorial/3-components/index.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ You'll build:
- A Navigation component that presents a menu of links to your pages
- A Footer component to include at the bottom of each page
- A Social Media component, used in the Footer, that links to profile pages
- An interactive Hamburger component to toggle the Navigation on mobile
- An interactive Menu component to toggle the Navigation on mobile

Along the way, you'll use CSS and JavaScript to build a responsive design that reacts to screen sizes and user input.

Expand Down
Loading