Before starting the setup, check that your hardware, operating system and account is compatible:
Make sure that your machine has at least 8GB RAM
Make sure that you're running Windows 10 or later - earlier versions such as Windows 7 or 8.1 are not supported
Open the Start menu and type "cmd" and click on "Command Prompt". When PowerShell starts, type in echo %USERPROFILE%
. It should display something like C:\Users\Karl
(without any spaces).
If you see spaces in the path (eg. C:\Users\Karl Horky
) then you should create a new Windows account:
- Start menu -> Settings -> Accounts -> Family & other users -> Add other user -> Add account
- Enter a name without spaces in the user name (the box beneath the question "Who's going to use this PC?")
- Once you create the new account, log in to the new account and try the command above again
Make sure to use an account without spaces in the user name for the course.
With those compatibility things out of the way, you're ready to start the system setup:
-
Open the Start menu, type "Windows Update" and click on the result named Windows Update. Make sure that you have all of the latest updates.
-
Open the Start menu and type "powershell". Right-click on the item "Windows PowerShell" that appears and choose "Run as administrator":
This will run Powershell as an administrator user -
Copy the following text (be sure you select all of it, it's very long) and right-click in the blue middle part of the PowerShell window to paste the text. Hit enter.
Set-ExecutionPolicy AllSigned -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1'))
This will install Chocolatey, a package manager which will allow us to install and uninstall programs from the command line.
-
The installer will take a bit of time and then show a message that "Chocolatey is ready", signaling that it is done:
-
Close PowerShell and open it again as administrator (like in step 2)
-
Copy the following text and right-click in the blue middle part of the PowerShell window to paste the text. Hit enter.
choco install git nodejs-lts vscode hyper httpie flyctl --yes
This uses Chocolatey to install Git, Node.js, Visual Studio Code, Hyper, HTTPie and
flyctl
.If you don't have Zoom installed yet, run this to install it:
choco install zoom --yes
If you don't have Slack installed yet, run this to install it:
choco install slack --yes
-
Close PowerShell and open it again as administrator (like in step 2). Copy the following text and right-click in the blue middle part of the PowerShell window to paste the text. Hit enter.
corepack enable corepack prepare pnpm@latest --activate Set-ExecutionPolicy -Scope Process -ExecutionPolicy Bypass -Force pnpm setup
Close PowerShell and open it again as administrator (like in step 2). This uses Corepack to install
pnpm
, and configurespnpm
's global bin directory.
Install@upleveled/preflight
, a program we will use in the course, to verify that the previous commands were successful: copy the following text, paste it in the terminal and hit return.pnpm add --global @upleveled/preflight
Verify that your output looks similar to the "Successful" output below. You can ignore any differences in version numbers and package names - the important part is "Done in ..." on the last line.
If your output looks very different (either like the "Failing" output below or like some other different output), repeat the pnpm installation commands at the start of this step.
Successful Failing (ERR_PNPM_NO_GLOBAL_BIN_DIR) WARN 6 deprecated subdependencies found: @oclif/[email protected], [email protected], [email protected], [email protected], [email protected], [email protected] Packages: +21 -32 +++++++++++++++++-------------------------- Progress: resolved 773, reused 772, downloaded 1, added 21, done /Users/k/Library/pnpm/global/5: + @upleveled/preflight 7.0.8 Done in 3.3s
ERR_PNPM_NO_GLOBAL_BIN_DIR Unable to find the global bin directory Run "pnpm setup" to create it automatically, or set the global-bin-dir setting, or the PNPM_HOME env variable. The global bin directory should be in the PATH.
-
Copy the following text, right-click in the blue middle part of the PowerShell window to paste the text and hit enter.
choco install python visualstudio2022-workload-vctools --yes
This may take some time (possibly up to 15-20 minutes). This uses Chocolatey to install Python and Visual Studio build tools, which are required for installing Node.js native modules.
-
Copy each line in the following text, right-click in the blue middle part of the PowerShell window to paste the text and hit enter.
code --install-extension bradlc.vscode-tailwindcss code --install-extension Cardinal90.multi-cursor-case-preserve code --install-extension dbaeumer.vscode-eslint code --install-extension dozerg.tsimportsorter code --install-extension esbenp.prettier-vscode code --install-extension frigus02.vscode-sql-tagged-template-literals-syntax-only code --install-extension kumar-harsh.graphql-for-vscode code --install-extension mattpocock.ts-error-translator code --install-extension meganrogge.template-string-converter code --install-extension styled-components.vscode-styled-components code --install-extension stylelint.vscode-stylelint code --install-extension sysoev.vscode-open-in-github code --install-extension tamasfe.even-better-toml code --install-extension unional.vscode-sort-package-json code --install-extension viijay-kr.react-ts-css code --install-extension vitaliymaz.vscode-svg-previewer code --install-extension vunguyentuan.vscode-css-variables code --install-extension wix.glean
This installs some VS Code extensions we will need.
-
We recommend installing and using Chrome so that you have the same DevTools as others.
If you don't have Chrome installed yet, you can install it with Chocolatey. To do this, copy the following text and right-click in the blue middle part of the PowerShell window to paste the text. Hit enter.choco install googlechrome --yes
This uses Chocolatey to install Chrome.
-
Install the following Chrome Extensions:
-
Next we will configure VS Code.
Open VS Code and then press the keys Ctrl-Shift-P. Type in "Settings" and select the item that saysPreferences: Open User Settings (JSON)
:
Once the settings file is open, we will want to add the settings below.
First of all, identify whether your settings file is empty or not. This is what an empty file looks like:
If your file is not empty (if there is more text within the curly brackets), then we will need to do something extra - add a comma on the second to last line:
Now in both cases you will want to paste the following settings before the closing curly bracket (before the}
):"editor.wordWrap": "on", "editor.minimap.enabled": false, "editor.linkedEditing": true, "editor.tabSize": 2, "workbench.editor.tabSizing": "shrink", "workbench.editor.closeEmptyGroups": false, "workbench.tree.enableStickyScroll": true, "terminal.integrated.stickyScroll.enabled": true, "terminal.integrated.defaultProfile.windows": "Git Bash", "files.insertFinalNewline": true, "files.trimFinalNewlines": true, "files.trimTrailingWhitespace": true, "[markdown]": { "files.trimTrailingWhitespace": false }, "files.autoSave": "onFocusChange", "editor.formatOnSave": true, "editor.codeActionsOnSave": [ // Sort package.json keys with https://marketplace.visualstudio.com/items?itemName=unional.vscode-sort-package-json "source.sortPackageJson" ], "tsImportSorter.configuration.groupRules": ["^node:", {}, "^[.]"], "tsImportSorter.configuration.keepUnused": [".*"], "tsImportSorter.configuration.emptyLinesBetweenGroups": 0, "tsImportSorter.configuration.wrappingStyle": "prettier", "editor.defaultFormatter": "esbenp.prettier-vscode", "[html]": { "editor.defaultFormatter": "esbenp.prettier-vscode" }, "[javascript]": { "editor.defaultFormatter": "esbenp.prettier-vscode" }, "[javascriptreact]": { "editor.defaultFormatter": "esbenp.prettier-vscode" }, "[typescript]": { "editor.defaultFormatter": "esbenp.prettier-vscode" }, "[typescriptreact]": { "editor.defaultFormatter": "esbenp.prettier-vscode" }, "[json]": { "editor.defaultFormatter": "esbenp.prettier-vscode" }, "[jsonc]": { "editor.defaultFormatter": "esbenp.prettier-vscode" }, "prettier.singleQuote": true, "prettier.trailingComma": "all", "prettier.documentSelectors": [ // Enable prettier-vscode to format *.sql files (eg. with prettier-plugin.sql) // https://github.com/prettier/prettier-vscode/issues/3248#issuecomment-1956209714 "**/*.sql" ], "eslint.runtime": "node", "totalTypeScript.hideAllTips": true,
After you have pasted the settings, save the file with
File
->Save
in the top menu.
If you had any previous settings beforehand, you may notice that some text above will be underlined by a squiggly yellow line. This is a warning because we pasted some duplicate properties from the code above.
If you have any of these warnings, we should fix them. For each one of these lines with the warnings on them, delete the full line, including the comma at the end. We usually like to select from the start of the first"
to just before the next"
on the next line:
If you made any further changes to the file, save the file again withFile
->Save
in the top menu. -
To verify that the VS Code configuration was successful, select
Terminal
->New Terminal
in the top menu:
Once the terminal appears, copy the following text, paste it into the terminal and hit return:
echo -e "VS Code Config:\n Shell: $SHELL\n Terminal: $TERM"
This should display the following output on Windows:
VS Code Config: Shell: /usr/bin/bash Terminal: xterm-256color
Check your output carefully - if line 2 (
Shell: ...
) and line 3 (Terminal: ...
) on your screen aren't exactly the same as the output above, return to the previous step and check if everything was completed fully. -
Now we will configure Hyper.
Open Hyper and then select Edit -> Preferences, which will open a text file in an editor:
In this file, we will do three things:- Find
shell: '',
and replace it withshell: 'C:\\Program Files\\Git\\bin\\bash.exe',
- Find
env: {},
and replace it withenv: { TERM: 'cygwin' },
Then save the file and close and restart Hyper.
- Find
-
To verify that the Hyper configuration was successful, copy the following text, paste it into Hyper and hit return:
echo -e "Hyper Config:\n Shell: $SHELL\n Terminal: $TERM"
This should display the following output:
Hyper Config: Shell: /usr/bin/bash Terminal: cygwin
Check your output carefully - if line 2 (
Shell: ...
) and line 3 (Terminal: ...
) on your screen aren't exactly the same as the output above, return to the previous step and check if everything was completed fully. -
We will now install PostgreSQL. Search for Hyper in the start menu, then right click on it and choose "Run as Administrator".
Copy the following text, paste it in Hyper and hit return.
choco install postgresql17 --yes --params '/Password:postgres'
This will install PostgreSQL and create a default user of
postgres
and a password ofpostgres
. Remember this password and use it any time it asks from now on.After the installation is complete, close Hyper and reopen it (just as a normal user - not as an administrator).
Now let's set an environment variable to tell PostgreSQL where to find the programs and where to put the data. Copy and run each of these lines separately in Hyper:
echo -e "\nexport PATH=\$PATH:\"/c/Program Files/PostgreSQL/17/bin\"" >> ~/.bash_profile echo "export PGDATA=\"/c/Program Files/PostgreSQL/17/data\"" >> ~/.bash_profile echo "export PSQL_PAGER=\"less --chop-long-lines --header 1\"" >> ~/.bash_profile echo "export LANG=en_US.UTF-8" >> ~/.bash_profile source ~/.bash_profile perl -i -pe "s/^[#\s]*(timezone|log_timezone)\s*=.+$/\1 = 'UTC'/" "$PGDATA/postgresql.conf" perl -i -pe "s/^logging_collector = on/logging_collector = off/" "$PGDATA/postgresql.conf"
We can now test whether PostgreSQL has been correctly installed by starting the database. To do this, we can run the following command:
postgres
If it worked, it should print out some messages and end with the rectangular cursor on the left side of the screen:
You will need to run this every time you want to use your database.
When you want to stop PostgreSQL again, just stop it like any other command line program using the shortcut control-C.
Now we will connect to PostgreSQL using a tool called
psql
and add a new table, to make sure everything is working with the connection.Open a new tab in Hyper using control-shift-T and run the following command:
psql -U postgres
It will ask you for a password - enter
postgres
(the password will not be visible). Now it should look like this:If your screen looks like the above screenshot, type in or copy and paste the following query (this is a language called SQL):
CREATE TABLE users( id serial PRIMARY KEY, first_name VARCHAR (100) NOT NULL, last_name VARCHAR (100) NOT NULL );
It should print
CREATE TABLE
on the line after running the query. Your screen should look like this:Now let's check that the table has been created. Run this query:
\dt
This will show the tables that you have, including the newly-created
users
table. Your screen should look like this (although the owner may bepostgres
on your screen):Finally, let's delete the table again to clean up. Exit the table view by typing q on your keyboard and then run this query:
DROP TABLE users;
It should print
DROP TABLE
on the line after running the query. Your screen should look like this:Great, PostgreSQL is set up! 🚀 Now you can exit from
psql
again by writingexit
and hitting return:exit
It should exit and send you back to the command line. Your screen should look similar to this (the last line will not be exactly the same):
Now close the new tab in Hyper with control-W, and stop PostgreSQL again using control-C. PostgreSQL should shut down - your screen should look similar to this (the last line will not be exactly the same):
-
Option A - Windows 10/11 Pro:
-
Search for Hyper in the start menu, then right click on it and choose "Run as Administrator".
-
Copy the following text and paste it into Hyper. Hit enter.
choco install wsl2 --yes choco install wsl-ubuntu-2004 --yes choco install docker-desktop --yes
-
Open start menu and search for "Docker Desktop". Run it. This will set up and start Docker.
You will need to run this every time you want to work with Docker after you restart.
Option B - Windows 10/11 Home:
-
Windows 10 only: Click on the start menu, type in "winver" to the search and verify you have at least Windows 10 version 1903. If your number is lower than 1903, run Windows Update.
-
Search for Hyper in the start menu, then right click on it and choose "Run as Administrator".
-
Copy the following text and paste it into Hyper. Hit enter.
choco install wsl2 --yes choco install wsl-ubuntu-2004 --yes choco install docker-desktop --yes
-
Open the start menu and search for "Ubuntu". Start it - it should ask you to create a user with a password. This will be your user to log in to your Ubuntu Linux Subsystem - note down the username and password somewhere secure to make sure you do not forget it.
-
Open the start menu and search for "Docker Desktop". Start it and go to the Settings. Under the General tab, you will find an option called "Use WSL 2 based engine". Make sure this is checked.
When opening Docker Desktop during Option A or Option B, an error message
Docker Desktop - Windows Hypervisor is not present
may appear:If this appears for you, follow the next steps to enable virtualization on your machine (if you don't receive the error, you can skip to the Docker testing step).
-
Close PowerShell and open it again as administrator (like in step 2). Copy the following text and right-click in the blue middle part of the PowerShell window to paste the text. Hit enter.
Get-ComputerInfo -Property HyperVRequirementVMMonitorModeExtensions,HyperVRequirementVirtualizationFirmwareEnabled | Format-List
This should display the following output:
HyperVRequirementVMMonitorModeExtensions: True HyperVRequirementVirtualizationFirmwareEnabled: False
The output indicates that your machine supports virtualization, but it is not enabled. Ensure that your output is the same before proceeding with the steps below to enable virtualization.
-
Restart your machine
-
As soon as the monitor turns black during restart, press the BIOS key or UEFI key for your machine repeatedly. If you're not sure what that key is, either try to read the key on the screen quickly as your machine restarts or refer to BIOS key documentation online eg. the guide by the University of Wisconson-Madison (common keys are Delete, Esc, F1, F2, F9, F10 or F12)
-
On some machines, you will need to find and select the option to enter the BIOS / UEFI after hitting the hotkey
-
Find the virtualization option for your machine and enable it. If you're not sure what the option is called, refer to the virtualization options here (often in
Advanced
settings, common names areVirtualization
,VMX
,VT-x
,VT-d
,AMD-V
, orSVM
) -
Find and select the option to save changes and exit the BIOS / UEFI
-
Open Docker Desktop again (as instructed in Option A or Option B) to verify that the error has been resolved
-
-
Test if Docker is installed by running the following command on the command line:
docker run hello-world
-
We will now install EAS CLI for React Native. Search for Hyper in the start menu, then right click on it and choose "Run as Administrator".
Copy the following text, paste it in Hyper and hit return.
pnpm add --global eas-cli
You can ignore the lines marked
WARN
- these do not indicate problems:Lastly, we'll install Expo on your phone, so that you can also test on a real device.
On your phone, go to the app store and install Expo on your phone (Android, iOS). Create an account and log in.
-
Next we will set up some dependencies for Expo and React Native.
Copy each line in the following text, paste it in Hyper and hit return.
choco install androidstudio --yes echo "export PATH=$HOME/AppData/Local/Android/Sdk/platform-tools:\$PATH" >> ~/.bash_profile source ~/.bash_profile
This will install Android Studio, for creating and running Android virtual devices in an emulator.
Open Android Studio by finding it using the Start menu.
If it asks to import Android Studio Settings, choose Do not import settings.
When prompted, choose a Custom install:
Leave the default JDK installation location as-is and click Next:
Uncheck the box next to Android Virtual Device (we will install our own manually):
For each of the licenses with red stars next to them, click on the license name and then accept the agreement, finally clicking on Finish when you have accepted all agreements:
This will download components, which may take a few minutes:
Next will be getting a virtual device installed. Click on More Actions and select Virtual Device Manager:
Click on the Create device button on the top left of the window:
Select the Pixel 3a as the hardware device.
Under the Recommended tab (the default tab), locate the system image named S (API level 31) and click on the downward arrow icon (download button) next to it. In the window that pops up, accept the license agreement and click Next:
Once the download completes, select the image you just downloaded and click on Next through the rest of the steps until the virtual device has been created:
The device will now show up in the Device Manager. Click on the triangular play button to launch the virtual device in the emulator. An emulator window will appear showing the screen of the virtual device:
If a message pops up in the virtual device that the "System UI isn't responding" at any point during these steps, you can click on "Wait".
Before running the first Expo app, test that the Android Studio
adb
(Android Debug Bridge) program has been set up properly, by running the following in a new Hyper command line (open a new tab):adb
It should print the version and help information:
-
To verify that Expo is working with the Android Studio virtual device copy and run each of these lines separately in Hyper:
cd ~ mkdir -p projects cd projects pnpm create expo-app@latest --template blank-typescript expo-test cd expo-test pnpm start --android
This will create a new Expo demo app and start it.
If this step doesn't work, it's possible that you may not have the emulator running - check the last part of the previous step to see how to launch the emulator.
The first thing that you will see is the installation of Expo Go on the virtual device:
Next, the Metro bundler will bundle the JavaScript for the device, which may take some time. You will see a loading bar in the command line and a loading screen on the virtual device:
After the bundling has completed, the simple app should show up in the virtual device, with the words "Open up App.js to start working on your app!" (if it instead says "Universal React with Expo", this is also ok):
Click on the small
x
at the top right of the virtual device frame to stop the virtual device - this will save a snapshot to make starting the virtual device faster in the future. -
If you don't have one yet, create a Google account here. Make a note of the email address associated with this account for usage in later steps.
-
If you don't have one yet, create a GitHub account here. Make sure to set a name.
If you already have a GitHub account and you haven't set a name on GitHub yet, go to the GitHub Profile Settings and add a name:
We will use this name in the next step. -
For this step, we'll need to edit some of the information in the commands by adding our own information.
First of all, we will set our name, which will be the same name as on our GitHub profile:
Copy your name from your profile, add it in quotes in the command (replaceMona Lisa Octocat
) and run the command:git config --global user.name "Mona Lisa Octocat"
You can test whether the name was set correctly with the next command (if it worked, it will print the name on the next line):
git config --global user.name
For running the next command, add your email in quotes:git config --global user.email "[email protected]"
You can test whether the email was set correctly with with the next command (if it worked, it will print the email on the next line):
git config --global user.email
This prepares
git
so that your work is attributed correctly to you.
- Copy the following text, paste it in Hyper and hit return.
This step will change the default Git branch fromgit config --global init.defaultBranch main
master
tomain
(see https://github.com/github/renaming). - Copy and run each of these lines separately in Hyper.
This step will improve line breaks compatibility on Windows.git config --global core.autocrlf false git config --global core.eol lf
- Go back to GitHub, and go to your profile page by clicking on your avatar at the top right and selecting Your profile
Copy thegithub.com/...
URL in the address bar of your browser, for use in the next step. - Open the Start menu and start Slack. Log in to the UpLeveled Slack. Send your GitHub profile URL to Lukas. Also send your Google Account email address to Lukas (if you haven't already).
- Open the start menu, type "Settings" and open the app (or click on the cog on the left). Select "System" and "About". Under "Device specifications", click the Copy button and paste this to Lukas. Under "Windows specifications", click the Copy button and paste this to Lukas.
- On your phone, go to the app store and install Slack on your phone. Log in to the UpLeveled Slack.
-
If you would like to check the spelling of all code you write in VS Code, try out Code Spell Checker. You can install on the command line with this command:
code --install-extension streetsidesoftware.code-spell-checker
-
If you want to easily capture screenshots and draw and write on them, try Flameshot:
choco install flameshot --yes
-
If you need to record mp4 videos of your screen with sound, try out Loom.
An alternative without the limitations of Loom is Screen to Gif (however, it does not record audio):
choco install screentogif --yes
-
If you need a clipboard manager to keep a history of things that you have copied, this is an awesome option:
choco install ditto --yes
-
To simultaneously test your web design in multiple mobile viewports, try Responsively App:
choco install responsively --yes
-
To remove secrets, large files or other undesirable files from your Git repository, try BFG Repo-Cleaner:
choco install bfg-repo-cleaner --yes
-
If you're running out of space on your computer, you can use WinDirStat to analyze your hard drive and show a chart of which items are taking up how much space:
choco install windirstat --yes
-
To add an assortment of new features to Windows such as "pinning" a window to stay on top of all others, quickly renaming or resizing multiple files, splitting your running apps into regions of the screen and more, try Microsoft PowerToys:
choco install powertoys --yes
Most software upgrades can be performed with choco upgrade <package name>
, but some software upgrades require additional steps:
- Node.js with pnpm
choco upgrade nodejs-lts --yes corepack disable corepack enable corepack prepare pnpm@latest --activate