2019-10-12 21:52:04 +05:30
|
|
|
---
|
|
|
|
type: howto
|
|
|
|
---
|
|
|
|
|
2016-09-29 09:46:39 +05:30
|
|
|
# GitLab Web Editor
|
|
|
|
|
|
|
|
Sometimes it's easier to make quick changes directly from the GitLab interface
|
|
|
|
than to clone the project and use the Git command line tool. In this feature
|
|
|
|
highlight we look at how you can create a new file, directory, branch or
|
|
|
|
tag from the file browser. All of these actions are available from a single
|
|
|
|
dropdown menu.
|
|
|
|
|
|
|
|
## Create a file
|
|
|
|
|
|
|
|
From a project's files page, click the '+' button to the right of the branch selector.
|
|
|
|
Choose **New file** from the dropdown.
|
|
|
|
|
|
|
|
![New file dropdown menu](img/web_editor_new_file_dropdown.png)
|
|
|
|
|
|
|
|
Enter a file name in the **File name** box. Then, add file content in the editor
|
|
|
|
area. Add a descriptive commit message and choose a branch. The branch field
|
|
|
|
will default to the branch you were viewing in the file browser. If you enter
|
|
|
|
a new branch name, a checkbox will appear allowing you to start a new merge
|
|
|
|
request after you commit the changes.
|
|
|
|
|
|
|
|
When you are satisfied with your new file, click **Commit Changes** at the bottom.
|
|
|
|
|
|
|
|
![Create file editor](img/web_editor_new_file_editor.png)
|
|
|
|
|
|
|
|
### Template dropdowns
|
|
|
|
|
|
|
|
When starting a new project, there are some common files which the new project
|
|
|
|
might need too. Therefore a message will be displayed by GitLab to make this
|
|
|
|
easy for you.
|
|
|
|
|
|
|
|
![First file for your project](img/web_editor_template_dropdown_first_file.png)
|
|
|
|
|
2019-07-07 11:18:12 +05:30
|
|
|
When clicking on either `LICENSE` or `.gitignore`, etc., a dropdown will be displayed
|
2016-09-29 09:46:39 +05:30
|
|
|
to provide you with a template which might be suitable for your project.
|
|
|
|
|
|
|
|
![MIT license selected](img/web_editor_template_dropdown_mit_license.png)
|
|
|
|
|
|
|
|
The license, changelog, contribution guide, or `.gitlab-ci.yml` file could also
|
2019-07-07 11:18:12 +05:30
|
|
|
be added through a button on the project page. In the example below, the license
|
2016-09-29 09:46:39 +05:30
|
|
|
has already been created, which creates a link to the license itself.
|
|
|
|
|
|
|
|
![New file button](img/web_editor_template_dropdown_buttons.png)
|
|
|
|
|
|
|
|
>**Note:**
|
2018-03-17 18:26:18 +05:30
|
|
|
The **Set up CI/CD** button will not appear on an empty repository. You have to at
|
2016-09-29 09:46:39 +05:30
|
|
|
least add a file in order for the button to show up.
|
|
|
|
|
|
|
|
## Upload a file
|
|
|
|
|
|
|
|
The ability to create a file is great when the content is text. However, this
|
|
|
|
doesn't work well for binary data such as images, PDFs or other file types. In
|
|
|
|
this case you need to upload a file.
|
|
|
|
|
|
|
|
From a project's files page, click the '+' button to the right of the branch
|
|
|
|
selector. Choose **Upload file** from the dropdown.
|
|
|
|
|
|
|
|
![Upload file dropdown menu](img/web_editor_upload_file_dropdown.png)
|
|
|
|
|
|
|
|
Once the upload dialog pops up there are two ways to upload your file. Either
|
|
|
|
drag and drop a file on the pop up or use the **click to upload** link. A file
|
|
|
|
preview will appear once you have selected a file to upload.
|
|
|
|
|
|
|
|
Enter a commit message, choose a branch, and click **Upload file** when you are
|
|
|
|
ready.
|
|
|
|
|
|
|
|
![Upload file dialog](img/web_editor_upload_file_dialog.png)
|
|
|
|
|
|
|
|
## Create a directory
|
|
|
|
|
|
|
|
To keep files in the repository organized it is often helpful to create a new
|
|
|
|
directory.
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
From a project's files page, click the plus button (`+`) to the right of the branch selector.
|
2016-09-29 09:46:39 +05:30
|
|
|
Choose **New directory** from the dropdown.
|
|
|
|
|
|
|
|
![New directory dropdown](img/web_editor_new_directory_dropdown.png)
|
|
|
|
|
|
|
|
In the new directory dialog enter a directory name, a commit message and choose
|
|
|
|
the target branch. Click **Create directory** to finish.
|
|
|
|
|
|
|
|
![New directory dialog](img/web_editor_new_directory_dialog.png)
|
|
|
|
|
|
|
|
## Create a new branch
|
|
|
|
|
|
|
|
There are multiple ways to create a branch from GitLab's web interface.
|
|
|
|
|
|
|
|
### Create a new branch from an issue
|
|
|
|
|
2020-04-22 19:07:51 +05:30
|
|
|
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/merge_requests/2808) in GitLab 8.6.
|
2020-04-08 14:13:33 +05:30
|
|
|
|
|
|
|
If your development workflow dictates to have an issue for every merge
|
|
|
|
request, you can quickly create a branch directly from the issue to speed the process up.
|
|
|
|
The new branch, and later its merge request, will be marked as related to this issue.
|
|
|
|
Once merged, the MR will automatically close the issue.
|
|
|
|
You can see a **Create merge request** dropdown below the issue description.
|
2016-09-29 09:46:39 +05:30
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
NOTE: **Note:**
|
|
|
|
You won't see the **Create merge request** button if there is already a branch with the same
|
|
|
|
name or a referenced merge request or your project has an active
|
|
|
|
fork relationship.
|
|
|
|
If you would like to make this button appear, a possible workaround is to [remove your project's
|
|
|
|
fork relationship](../settings/index.md#removing-a-fork-relationship). Once removed, the fork
|
|
|
|
relationship cannot be restored and you will no longer be able to send merge requests to the source.
|
2016-09-29 09:46:39 +05:30
|
|
|
|
2020-01-01 13:55:28 +05:30
|
|
|
![Create Button](img/web_editor_new_branch_from_issue_create_button_v12_6.png)
|
2016-09-29 09:46:39 +05:30
|
|
|
|
2020-01-01 13:55:28 +05:30
|
|
|
This dropdown contains the options **Create merge request and branch** and **Create branch**.
|
|
|
|
|
|
|
|
![New Branch Button](img/web_editor_new_branch_from_issue_v_12_6.png)
|
|
|
|
|
|
|
|
Once you choose one of these options, a new branch or branch and merge request
|
|
|
|
will be created, based on the default
|
2016-09-29 09:46:39 +05:30
|
|
|
branch of your project, by default `master`. The branch name will be based on
|
2018-03-17 18:26:18 +05:30
|
|
|
the title of the issue and as a prefix, it will have its internal ID. Thus, the example
|
2020-01-01 13:55:28 +05:30
|
|
|
screenshot above will create a branch named
|
|
|
|
`2-make-static-site-auto-deploy-and-serve`.
|
|
|
|
|
|
|
|
When you click the **Create branch** button in an empty
|
|
|
|
repository project, GitLab automatically creates a `master` branch, commits
|
|
|
|
a blank `README.md` file to it, and creates and redirects you to a new branch
|
|
|
|
based on the issue title.
|
2020-04-22 19:07:51 +05:30
|
|
|
If your [project is already configured with a deployment service](../integrations/overview.md),
|
2020-01-01 13:55:28 +05:30
|
|
|
such as Kubernetes, GitLab takes one step further and prompts you to set up
|
2020-04-22 19:07:51 +05:30
|
|
|
[auto deploy](../../../topics/autodevops/stages.md#auto-deploy)
|
2020-01-01 13:55:28 +05:30
|
|
|
by helping you create a `.gitlab-ci.yml` file.
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2016-09-29 09:46:39 +05:30
|
|
|
After the branch is created, you can edit files in the repository to fix
|
|
|
|
the issue. When a merge request is created based on the newly created branch,
|
2019-09-30 21:07:59 +05:30
|
|
|
the description field will automatically display the [issue closing pattern](../issues/managing_issues.md#closing-issues-automatically)
|
2016-09-29 09:46:39 +05:30
|
|
|
`Closes #ID`, where `ID` the ID of the issue. This will close the issue once the
|
|
|
|
merge request is merged.
|
|
|
|
|
|
|
|
### Create a new branch from a project's dashboard
|
|
|
|
|
|
|
|
If you want to make changes to several files before creating a new merge
|
|
|
|
request, you can create a new branch up front. From a project's files page,
|
|
|
|
choose **New branch** from the dropdown.
|
|
|
|
|
|
|
|
![New branch dropdown](img/web_editor_new_branch_dropdown.png)
|
|
|
|
|
|
|
|
Enter a new **Branch name**. Optionally, change the **Create from** field
|
|
|
|
to choose which branch, tag or commit SHA this new branch will originate from.
|
|
|
|
This field will autocomplete if you start typing an existing branch or tag.
|
|
|
|
Click **Create branch** and you will be returned to the file browser on this new
|
|
|
|
branch.
|
|
|
|
|
|
|
|
![New branch page](img/web_editor_new_branch_page.png)
|
|
|
|
|
|
|
|
You can now make changes to any files, as needed. When you're ready to merge
|
|
|
|
the changes back to master you can use the widget at the top of the screen.
|
|
|
|
This widget only appears for a period of time after you create the branch or
|
|
|
|
modify files.
|
|
|
|
|
|
|
|
![New push widget](img/web_editor_new_push_widget.png)
|
|
|
|
|
|
|
|
## Create a new tag
|
|
|
|
|
|
|
|
Tags are useful for marking major milestones such as production releases,
|
|
|
|
release candidates, and more. You can create a tag from a branch or a commit
|
|
|
|
SHA. From a project's files page, choose **New tag** from the dropdown.
|
|
|
|
|
|
|
|
![New tag dropdown](img/web_editor_new_tag_dropdown.png)
|
|
|
|
|
|
|
|
Give the tag a name such as `v1.0.0`. Choose the branch or SHA from which you
|
|
|
|
would like to create this new tag. You can optionally add a message and
|
2020-01-01 13:55:28 +05:30
|
|
|
release notes. The release notes section supports Markdown format and you can
|
2016-09-29 09:46:39 +05:30
|
|
|
also upload an attachment. Click **Create tag** and you will be taken to the tag
|
|
|
|
list page.
|
|
|
|
|
|
|
|
![New tag page](img/web_editor_new_tag_page.png)
|
|
|
|
|
|
|
|
## Tips
|
|
|
|
|
|
|
|
When creating or uploading a new file, or creating a new directory, you can
|
|
|
|
trigger a new merge request rather than committing directly to master. Enter
|
|
|
|
a new branch name in the **Target branch** field. You will notice a checkbox
|
|
|
|
appear that is labeled **Start a new merge request with these changes**. After
|
|
|
|
you commit the changes you will be taken to a new merge request form.
|
|
|
|
|
|
|
|
![Start a new merge request with these changes](img/web_editor_start_new_merge_request.png)
|
|
|
|
|
2018-12-05 23:21:45 +05:30
|
|
|
If you'd prefer _not_ to use your primary email address for commits created
|
|
|
|
through the web editor, you can choose to use another of your linked email
|
|
|
|
addresses from the **User Settings > Edit Profile** page.
|
|
|
|
|
2019-10-12 21:52:04 +05:30
|
|
|
<!-- ## Troubleshooting
|
|
|
|
|
|
|
|
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
|
|
|
|
one might have when setting this up, or when something is changed, or on upgrading, it's
|
|
|
|
important to describe those, too. Think of things that may go wrong and include them here.
|
|
|
|
This is important to minimize requests for support, and to avoid doc comments with
|
|
|
|
questions that you know someone might ask.
|
|
|
|
|
|
|
|
Each scenario can be a third-level heading, e.g. `### Getting error message X`.
|
|
|
|
If you have none to add when creating a doc, leave this section in place
|
|
|
|
but commented out to help encourage others to add to it in the future. -->
|