---
stage: Create
group: IDE
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/product/ux/technical-writing/#assignments
---
# Web IDE **(FREE)**
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/95169) in GitLab 15.7 [with a flag](../../../administration/feature_flags.md) named `vscode_web_ide`. Disabled by default.
> - [Enabled on GitLab.com](https://gitlab.com/gitlab-org/gitlab/-/issues/371084) in GitLab 15.7.
> - [Enabled on self-managed](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/115741) in GitLab 15.11.
FLAG:
On self-managed GitLab, by default this feature is available. To hide the feature, ask an administrator to [disable the feature flag](../../../administration/feature_flags.md) named `vscode_web_ide`. On GitLab.com, this feature is available.
The Web IDE is an advanced editor with commit staging.
You can use the Web IDE to make changes to multiple files directly from the GitLab UI.
For a more basic implementation, see [Web Editor](../repository/web_editor.md).
To pair the Web IDE with a remote development environment, see [remote development](../remote_development/index.md).
## Use the Web IDE
To open the Web IDE from the GitLab UI:
1. On the top bar, select **Main menu > Projects** and find your project.
1. Use the . keyboard shortcut.
You can also open the Web IDE from:
- A file
- The repository file list
- A merge request
### From a file or the repository file list
To open the Web IDE from a file or the repository file list:
- In the upper-right corner of the page, select **Open in Web IDE**.
If **Open in Web IDE** is not visible:
1. Next to **Edit** or **Gitpod**, select the down arrow (**{chevron-lg-down}**).
1. From the dropdown list, select **Open in Web IDE**.
1. Select **Open in Web IDE**.
### From a merge request
To open the Web IDE from a merge request:
1. Go to your merge request.
1. In the upper-right corner, select **Code > Open in Web IDE**.
The Web IDE opens new and modified files in separate tabs and displays changes side by side with the original source.
To optimize loading time, only the top 10 files (by number of lines changed) are opened automatically.
In the file tree, any new or modified file in the merge request is indicated by an icon next to the filename.
To view changes to a file, right-click the filename and select **Compare with merge request base**.
## Open a file in the Web IDE
To open any file by its name:
1. Press Command+P.
1. Enter the name of your file.
![fuzzy_finder_v15_7](img/fuzzy_finder_v15_7.png)
## Search across files
You can use the Web IDE to search all files in the opened folder.
To search across files:
1. Press Shift+Command+F.
1. Enter your search term.
In the Web IDE, only partial results from opened files are displayed.
## View a list of changed files
To view a list of files you changed in the Web IDE:
- On the activity bar on the left, select **Source Control**,
or press Control+Shift+G.
Your `CHANGES`, `STAGED CHANGES`, and `MERGE CHANGES` are displayed.
For more information, see the [VS Code documentation](https://code.visualstudio.com/docs/sourcecontrol/overview#_commit).
## Upload a new file
To upload a new file and add it to the Git repository:
1. In the **Explorer** file tree, navigate to the directory where you want to upload the file.
1. Optional. If the directory does not exist yet, select the directory path where you want to have a new directory and either:
- Right-click on the directory path, and select **New Folder...**. You can create a nested directory path with the `/` separator, for example `parentdir/subdir1/subdir2`.
- In the **Explorer** panel, in the upper-right corner, select the new folder (**{folder-new}**) icon.
1. Enter the name of the new directory, and press Enter/Return to create it.
1. Right-click on the directory path and select `Upload...`.
1. Select the file you want to upload, then select `Open`. You can select and add multiple files at once.
The file is uploaded and automatically added as a new file to the Git repository.
## Switch branches
The Web IDE uses the currently selected branch by default.
To switch branches in the Web IDE:
1. On the status bar, in the lower-left corner, select the current branch name.
1. In the search box, start typing the branch name.
1. From the dropdown list, select the branch.
## Create a branch
To create a branch from the current branch in the Web IDE:
1. On the status bar, in the lower-left corner, select the current branch name.
1. From the dropdown list, select **Create new branch...**.
1. Enter the branch name.
1. Press Enter.
If you don't have write access to the repository, **Create new branch...** is not visible.
## Commit changes
To commit changes in the Web IDE:
1. On the activity bar on the left, select **Source Control**,
or press Control+Shift+G.
1. Enter your commit message.
1. Select **Commit & Push**.
1. Commit to the current branch, or create a new branch.
## Use the command palette
In the Web IDE, you can access many commands through the command palette.
To open the command palette and run a command in the Web IDE:
1. Press Shift+Command+P.
1. In the search box, start typing the command name.
1. From the dropdown list, select the command.
## Edit settings
You can use the settings editor to view and modify your user and workspace settings.
To open the settings editor in the Web IDE:
- On the top menu bar, select **File > Preferences > Settings**,
or press Command+,.
In the settings editor, you can search for the settings you want to modify.
## Edit keyboard shortcuts
You can use the keyboard shortcuts editor to view and modify the default keybindings for all available commands.
To open the keyboard shortcuts editor in the Web IDE:
- On the top menu bar, select **File > Preferences > Keyboard Shortcuts**,
or press Command+K then Command+S.
In the keyboard shortcuts editor, you can search for:
- The keybindings you want to change
- The commands you want to add or remove keybindings for
Keybindings are based on your keyboard layout. If you change your keyboard layout, existing keybindings are updated automatically.
## Change themes
You can choose between different themes for the Web IDE. The default theme for the Web IDE is **GitLab Dark**.
To change the Web IDE theme:
1. On the top menu bar, select **File > Preferences > Theme > Color Theme**,
or press Command+K then Command+T.
1. From the dropdown list, preview the themes with the arrow keys.
1. Select a theme.
The active color theme is stored in the [user settings](#edit-settings).
## Interactive web terminals for the Web IDE (Beta)
When you set up a remote development server in the Web IDE, you can use interactive web terminals to:
- Access a remote shell on the server.
- Interact with the server's file system and execute commands remotely.
You cannot use interactive web terminals to interact with a runner.
However, you can use a terminal to install dependencies and compile and debug code.
For more information about configuring a workspace that supports interactive web terminals, see [remote development](../remote_development/index.md).