main branch of the repository so that they can autopopulate the form when users are
creating issues and pull requests. This will cut down on the initial back and forth
of getting some clarifying details.
Additionally, the New Issue page URL can be suffixed with `?title=Issue+Title&body=Issue+Text` and the form will be populated with those strings. Those strings will be used instead of the template if there is one.
## File names
Possible file names for issue templates:
-`ISSUE_TEMPLATE.md`
-`ISSUE_TEMPLATE.yaml`
-`ISSUE_TEMPLATE.yml`
-`issue_template.md`
-`issue_template.yaml`
-`issue_template.yml`
-`.gitea/ISSUE_TEMPLATE.md`
-`.gitea/ISSUE_TEMPLATE.yaml`
-`.gitea/ISSUE_TEMPLATE.yml`
-`.gitea/issue_template.md`
-`.gitea/issue_template.yaml`
-`.gitea/issue_template.yml`
-`.github/ISSUE_TEMPLATE.md`
-`.github/ISSUE_TEMPLATE.yaml`
-`.github/ISSUE_TEMPLATE.yml`
-`.github/issue_template.md`
-`.github/issue_template.yaml`
-`.github/issue_template.yml`
Possible file names for PR templates:
-`PULL_REQUEST_TEMPLATE.md`
-`PULL_REQUEST_TEMPLATE.yaml`
-`PULL_REQUEST_TEMPLATE.yml`
-`pull_request_template.md`
-`pull_request_template.yaml`
-`pull_request_template.yml`
-`.gitea/PULL_REQUEST_TEMPLATE.md`
-`.gitea/PULL_REQUEST_TEMPLATE.yaml`
-`.gitea/PULL_REQUEST_TEMPLATE.yml`
-`.gitea/pull_request_template.md`
-`.gitea/pull_request_template.yaml`
-`.gitea/pull_request_template.yml`
-`.github/PULL_REQUEST_TEMPLATE.md`
-`.github/PULL_REQUEST_TEMPLATE.yaml`
-`.github/PULL_REQUEST_TEMPLATE.yml`
-`.github/pull_request_template.md`
-`.github/pull_request_template.yaml`
-`.github/pull_request_template.yml`
## Directory names
Alternatively, users can create multiple issue templates inside a special directory and allow users to choose one that more specifically
addresses their problem.
Possible directory names for issue templates:
-`ISSUE_TEMPLATE`
-`issue_template`
-`.gitea/ISSUE_TEMPLATE`
-`.gitea/issue_template`
-`.github/ISSUE_TEMPLATE`
-`.github/issue_template`
-`.gitlab/ISSUE_TEMPLATE`
-`.gitlab/issue_template`
Inside the directory can be multiple markdown (`.md`) or yaml (`.yaml`/`.yml`) issue templates of the form.
| label | A brief description of the expected user input, which is also displayed in the form. | Required | String | - | - |
| description | A description of the text area to provide context or guidance, which is displayed in the form. | Optional | String | Empty String | - |
| placeholder | A semi-opaque placeholder that renders in the text area when empty. | Optional | String | Empty String | - |
| value | Text that is pre-filled in the text area. | Optional | String | - | - |
| render | If a value is provided, submitted text will be formatted into a codeblock. When this key is provided, the text area will not expand for file attachments or Markdown editing. | Optional | String | - | Languages known to Forgejo. |
| required | Prevents form submission until element is completed. | Optional | Boolean | false | - |
| is_number | Prevents form submission until element is filled with a number. | Optional | Boolean | false | - |
| regex | Prevents form submission until element is filled with a value that match the regular expression. | Optional | String | - | a [regular expression](https://en.wikipedia.org/wiki/Regular_expression) |
### Dropdown
You can use a `dropdown` element to add a dropdown menu in your form.
| label | A brief description of the expected user input, which is displayed in the form. | Required | String | - | - |
| description | A description of the dropdown to provide extra context or guidance, which is displayed in the form. | Optional | String | Empty String | - |
| multiple | Determines if the user can select more than one option. | Optional | Boolean | false | - |
| options | An array of options the user can choose from. Cannot be empty and all choices must be distinct. | Required | String array | - | - |
| label | A brief description of the expected user input, which is displayed in the form. | Required | String | - | - |
| description | A description of the set of checkboxes, which is displayed in the form. Supports Markdown formatting. | Optional | String | Empty String | - |
| options | An array of checkboxes that the user can select. For syntax, see below. | Required | Array | - | - |
For each value in the options array, you can set the following keys.
| label | The identifier for the option, which is displayed in the form. Markdown is supported for bold or italic text formatting, and hyperlinks. | Required | String | - | - |
| required | Prevents form submission until element is completed. | Optional | Boolean | false | - |