Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update Setup article #123

Merged
merged 10 commits into from
Mar 19, 2024
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
81 changes: 47 additions & 34 deletions docs/setup-guide.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -2,53 +2,66 @@
title: Setup Guide
---

:::note
This guide assumes you know how to use the command line. You can find tutorials on YouTube for [Windows](https://www.youtube.com/watch?v=FiTZgpRpWv0) or [MacOS](https://www.youtube.com/watch?v=aKRYQsKR46I).
:::info[Prerequisites]
- Familiarity with the command line. You can find tutorials on YouTube for [Windows](https://www.youtube.com/watch?v=FiTZgpRpWv0) or [MacOS](https://www.youtube.com/watch?v=aKRYQsKR46I)
- [NodeJS 18+](https://nodejs.org/)
- A code editor such as [VSCode](https://code.visualstudio.com/)
- [Rojo 7+](https://rojo.space/) which can be installed through the [Rojo VSCode plugin](https://marketplace.visualstudio.com/items?itemName=evaera.vscode-rojo).
:::

## Before You Begin

In order to start using roblox-ts, you'll need to have the following software already installed:
- [NodeJS 14+](https://nodejs.org/)
- A code editor. We recommend [VSCode](https://code.visualstudio.com/).
- [Rojo 6+](https://rojo.space/). The easiest way to install it is through the [Rojo VSCode plugin](https://marketplace.visualstudio.com/items?itemName=evaera.vscode-rojo).

## Project Setup

To start using roblox-ts to create a game project, follow these steps:

<!-- Unfortunately, we need to explicitly number these steps because there are images between them :( -->

1. Create a new folder and give it a name. The folder name cannot contain spaces. We are going to name ours `my-project`.

<center><img src={require("../static/img/setup-guide/new-folder.png").default} /></center>

2. Open the folder using your code editor (or your command line if your code editor does not have one integrated).

<center><img src={require("../static/img/setup-guide/open-with-vscode.png").default} /></center>

3. Run `npm init roblox-ts` in your command line to start the interactive project setup.

:::caution PowerShell
If you're using PowerShell for the first time, you may get an error about "running scripts is disabled on this system". You can fix this by running the following in PowerShell as an administrator:

`Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser`

[More info here](./articles/powershell)
[More info here](./articles/powershell.mdx)
:::

## Project Setup

In this guide, we will introduce how to create a roblox-ts game.

Make sure you have an up-to-date version of Node.js installed and your current working directory is an empty folder that you intend to create your project in. Run the following command in your command line:

```bash title="Terminal"
npm init roblox-ts
```

The tool will guide you through some questions to set up your project:
1. `Project directory` - Since you're already in the directory you want to create a project in, just enter a period (`.`) to select your current directory and press `Enter`.
2. `Select template` - What type of roblox-ts project is this? roblox-ts can be used to build plugins and packages too, but in this case we want to make a game, so press `Enter` once.
3. `Configure Git` - Do you want to use [Git](https://git-scm.com/) for version control? Press `Y` or `N` to make your choise.
4. `Configure ESLint` - Do you want to use [ESLint](https://eslint.org/) to check your code for correctness?
5. `Configure Prettier` - Do you want to use [Prettier](https://prettier.io/) to format your code?
6. `Configure VSCode Project Settings` - Do you want the tool to create a `.vscode` folder with settings optimized for roblox-ts development? If you're using VSCode to write code, you should use this.
7. `Multiple package managers detected. Select package manager:` - Which package manager do you want to use with this project? roblox-ts works best with `npm` and support for alternative package managers is not guaranteed. (If you don't have other package managers installed, this step won't appear!)

LouieK22 marked this conversation as resolved.
Show resolved Hide resolved
:::tip
Many of the tools used here can be directly integrated into VSCode with extensions. We highly recommend the roblox-ts extension to improve your editing experience. The roblox-ts extension not only provides extra diagnostic information, but also lets you build your code with one click.
- [roblox-ts VSCode extension](https://marketplace.visualstudio.com/items?itemName=Roblox-TS.vscode-roblox-ts)
- [ESLint VSCode extension](https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint)
- [Prettier VSCode extension](https://marketplace.visualstudio.com/items?itemName=esbenp.prettier-vscode)
LouieK22 marked this conversation as resolved.
Show resolved Hide resolved
- [Rojo VSCode extension](https://marketplace.visualstudio.com/items?itemName=evaera.vscode-rojo)
:::

4. Start roblox-ts in watch mode via `npx rbxtsc -w`. You can exit watch mode later by clicking on the command line and pressing `Ctrl+C` on your keyboard.
Then, open your project in your code editor of choice, such as VSCode:

5. Next, start up a Rojo server. If you are using the Rojo VSCode extension, simply hit `Ctrl+Shift+P` and select `Rojo: Start Server`.
```bash title="Terminal"
code project-name
```

<center><img src={require("../static/img/setup-guide/rojo-extension.png").default} /></center>
## Running Your Code

Otherwise, open a new terminal with the same working directory and start Rojo via `rojo serve`. In VSCode a new terminal can be opened by pressing the `+` button.
roblox-ts has a feature called "watch mode" where it will continuously build your code as you write it. You can start watch mode from the [VSCode extension](https://marketplace.visualstudio.com/items?itemName=Roblox-TS.vscode-roblox-ts) or via the command line:

<center><img src={require("../static/img/setup-guide/rojo-serve.png").default} /></center>
```bash title="Terminal"
npm run watch
```

6. Open a new place in Roblox Studio where you wish to sync your compiled code into. Open up the Rojo plugin in Studio and hit `Connect`.
Once roblox-ts is running, you need to start Rojo to start syncing your code into Roblox studio you can do this from the [VSCode extension](https://marketplace.visualstudio.com/items?itemName=evaera.vscode-rojo) or via the command line:

<center><img src={require("../static/img/setup-guide/rojo-plugin.png").default} /></center>
```bash title="Terminal"
rojo serve
```

7. Write code! :tada:
You're all set up, go write some code :tada:
2 changes: 2 additions & 0 deletions docusaurus.config.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
/* eslint-disable @typescript-eslint/no-require-imports */
LouieK22 marked this conversation as resolved.
Show resolved Hide resolved

import type * as Preset from "@docusaurus/preset-classic";
import type { Config } from "@docusaurus/types";
import { themes as prismThemes } from "prism-react-renderer";
Expand Down
Binary file removed static/img/setup-guide/new-folder.png
Binary file not shown.
Binary file removed static/img/setup-guide/open-with-vscode.png
Binary file not shown.
Binary file removed static/img/setup-guide/rojo-extension.png
Binary file not shown.
Binary file removed static/img/setup-guide/rojo-plugin.png
Binary file not shown.
Binary file removed static/img/setup-guide/rojo-serve.png
Binary file not shown.
Loading