Skip to content

css-for-js/character-creator-v2

Repository files navigation

Character Creation Workshop

In this workshop, you'll build a Sims-style character creation screen.

Mockups

Desktop:

Desktop-sized screenshot of the character creation screen

For this workshop, we're only targeting desktops (although if you're so inclined, creating a mobile variant would make a great stretch goal!).

Protip: If you're reading this in VS Code, open the Command Palette (Cmd + Shift + P) and select “Markdown: Open Preview to the Side”. That way, you can see all the images in this document!

Setup Instructions

This project uses a build tool called Vite. We’ll need to run some terminal commands to get ourselves set up.

Start by installing dependencies:

npm install

Next, boot up a dev server:

npm run dev

You should see a message like this:

VITE v6.0.3  ready in 111 ms

➜  Local:   http://localhost:5173/
➜  Network: use --host to expose
➜  press h + enter to show help

This shows that a development server is running! We can view the project in-browser by following that URL. In this case, it’s http://localhost:5173/, but you should use the URL shown in your terminal.

Troubleshooting

If you run into problems running a local development server, check out our Troubleshooting Guide on the course platform.

The first thing you should check, if you encounter an error, is that you’re using an up-to-date version of Node.js. This project requires Node 18+. You can find more information in the Troubleshooting Guide.

Project structure and context

This project is built with React.

All of the functionality has already been built. Your job is to add the CSS. You're also allowed to tweak the JSX (HTML) as-needed. But you shouldn't need to fuss with any advanced React stuff.

This project uses CSS Modules. CSS modules are very similar to vanilla CSS, but the classes are applied in JS. Here's an example:

/* Something.module.css */
.wrapper {
  width: 500px;
}
/* Something.js */
import styles from './Something.module.css';

function Something() {
  return <div className={styles.wrapper}>I'll be 500px wide!</div>;
}

Additionally, a few global styles can be found in src/index.css.

Exercises

Exercise 1: Fix footer links

Let's start with a small detail: The footer links are unreadable:

Side-by-side comparison of the current footer vs. the ideal one

Exercise 2: Layout adjustments

Next, let's tackle the biggest visual issue: the layout.

We have a MaxWidthWrapper constraining the max width, but everything is super wide within it.

Our header should be 65% of the available width, and our control-panel column should be 50%.

Annotated mockup showing the overall width at 1024px, the header occupying 65%, and the control panels occupying 50%

The character (the big illustration) should use fixed positioning, and it should occupy the space cleared by the above width tweaks.

Give the character a minimum height of 500px. On smaller windows, this means the character won't fit in the viewport:

Screenshot of a shorter Chrome window, with the character truncated at the knees

NOTE: If you notice at some point that the character SVG disappears, it's likely because it needs to be given an explicit width/height. This is discussed in more depth on the “Solution” page, https://courses.joshwcomeau.com/css-for-js/02-rendering-logic-2/20-character-workshop-solution#collapsed-svgs

Exercise 3: Overflow

Each control panel features a number of customizations. For control panels with too many options, a horizontal scrollbar should be introduced:

Close-up screen recording of the overflow area in the control-panel

Exercise 4: Perspective decoration

To help add a bit of perspective, a light gray bar should extend across the bottom 40% of the screen:

Screenshot of the mockup, showing the light gray bar

It should sit behind the avatar (and both the perspective bar and the character should sit below the footer):

Screen recording, showing how the character and stripe don't move as the page is scrolled

You can use the background color hsl(195deg, 20%, 86%).

For bonus points, solve this challenge without setting any z-indexes.

Exercise 5 (Stretch): Implement a mobile variant

On mobile devices, the cards should stack horizontally, and sit near the bottom of the screen, underneath the character:

Screen recording, showing a mobile variant of the application

NOTE: This is a challenging stretch goal! It may require some CSS features we haven't covered yet. This is meant as an extra challenge for advanced students. Feel free to skip it!

Submissions

Workshops are submitted through the course platform. Commit your changes, push them to your fork, and submit the link by clicking the "Complete lesson" button on the workshop page.

If you're not comfortable with Git, you can upload a .zip file using Dropbox or Google Drive, and paste a link to the public file instead.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages