Skip to content

Commit 18b111f

Browse files
committed
workflow: setup issue template
1 parent e83ab3f commit 18b111f

File tree

4 files changed

+164
-0
lines changed

4 files changed

+164
-0
lines changed

.github/ISSUE_TEMPLATE/bug_report.yml

+98
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,98 @@
1+
name: "\U0001F41E Bug report"
2+
description: Create a report to help us improve
3+
body:
4+
- type: checkboxes
5+
attributes:
6+
label: "More than half issues of json-editor-vue turned out to be irrelevant. So before you start, make sure to:"
7+
options:
8+
- label: Read the [doc](https://github.com/cloydlau/json-editor-vue/blob/main/README.md)
9+
required: true
10+
- label: Be aware that json-editor-vue is only a Vue wrapper for [svelte-jsoneditor](https://github.com/josdejong/svelte-jsoneditor)
11+
required: true
12+
- label: Have a try at the latest version
13+
required: true
14+
- label: Search to see if your issue already exists
15+
required: true
16+
- label: Look for / ask questions on [Stack Overflow](https://stackoverflow.com/questions/ask)
17+
required: false
18+
- type: input
19+
id: json-editor-vue_version
20+
attributes:
21+
label: json-editor-vue version
22+
validations:
23+
required: true
24+
- type: input
25+
id: vanilla-jsoneditor_version
26+
attributes:
27+
label: vanilla-jsoneditor version
28+
validations:
29+
required: true
30+
- type: input
31+
id: vue_version
32+
attributes:
33+
label: vue version
34+
validations:
35+
required: true
36+
- type: input
37+
id: vue-composition-api_version
38+
attributes:
39+
label: "@vue/composition-api version"
40+
placeholder: Only for Vue 2.6 or earlier
41+
validations:
42+
required: false
43+
- type: input
44+
id: nuxt_version
45+
attributes:
46+
label: nuxt version
47+
validations:
48+
required: false
49+
- type: input
50+
id: reproduction-link
51+
attributes:
52+
label: Link to minimal reproduction
53+
description: |
54+
The easiest way to provide a reproduction is by showing the bug in [The SFC Playground](https://sfc.vuejs.org/).
55+
If it cannot be reproduced in the playground and requires a proper build setup, try [StackBlitz](https://vite.new/vue).
56+
If neither of these are suitable, you can always provide a GitHub repository.
57+
58+
The reproduction should be **minimal** - i.e. it should contain only the bare minimum amount of code needed
59+
to show the bug. See [Bug Reproduction Guidelines](https://github.com/cloydlau/json-editor-vue/blob/main/.github/bug-repro-guidelines.md) for more details.
60+
61+
Please do not just fill in a random link. The issue will be closed if no valid reproduction is provided.
62+
[Why reproduction is required?](https://antfu.me/posts/why-reproductions-are-required)
63+
placeholder: Reproduction Link
64+
validations:
65+
required: true
66+
- type: textarea
67+
id: steps-to-reproduce
68+
attributes:
69+
label: Steps to reproduce
70+
description: |
71+
What do we need to do after opening your repro in order to make the bug happen? Clear and concise reproduction instructions are important for us to be able to triage your issue in a timely manner. Note that you can use [Markdown](https://guides.github.com/features/mastering-markdown/) to format lists and code.
72+
placeholder: Steps to reproduce
73+
validations:
74+
required: true
75+
- type: textarea
76+
id: expected
77+
attributes:
78+
label: What is expected?
79+
validations:
80+
required: true
81+
- type: textarea
82+
id: actually-happening
83+
attributes:
84+
label: What is actually happening?
85+
validations:
86+
required: true
87+
- type: textarea
88+
id: system-info
89+
attributes:
90+
label: System Info
91+
description: Output of `npx envinfo --system --npmPackages json-editor-vue,vanilla-jsoneditor,vue,@vue/composition-api,nuxt --binaries --browsers`
92+
render: shell
93+
placeholder: System, Binaries, Browsers
94+
- type: textarea
95+
id: additional-comments
96+
attributes:
97+
label: Any additional comments?
98+
description: e.g. some background/context of how you ran into this bug.

.github/ISSUE_TEMPLATE/config.yml

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
blank_issues_enabled: false
+36
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
name: "\U0001F680 New feature proposal"
2+
description: Suggest an idea for this project
3+
labels: [":sparkles: feature request"]
4+
body:
5+
- type: checkboxes
6+
attributes:
7+
label: "More than half issues of json-editor-vue turned out to be irrelevant. So before you start, make sure to:"
8+
options:
9+
- label: Read the [doc](https://github.com/cloydlau/json-editor-vue/blob/main/README.md)
10+
required: true
11+
- label: Be aware that json-editor-vue is only a Vue wrapper for [svelte-jsoneditor](https://github.com/josdejong/svelte-jsoneditor)
12+
required: true
13+
- label: Have a try at the latest version
14+
required: true
15+
- label: Search to see if your issue already exists
16+
required: true
17+
- label: Look for / ask questions on [Stack Overflow](https://stackoverflow.com/questions/ask)
18+
required: false
19+
- type: textarea
20+
id: problem-description
21+
attributes:
22+
label: What problem does this feature solve?
23+
description: |
24+
Explain your use case, context, and rationale behind this feature request. More importantly, what is the **end user experience** you are trying to build that led to the need for this feature?
25+
placeholder: Problem description
26+
validations:
27+
required: true
28+
- type: textarea
29+
id: proposed-API
30+
attributes:
31+
label: What does the proposed API look like?
32+
description: |
33+
Describe how you propose to solve the problem and provide code samples of how the API would work once implemented. Note that you can use [Markdown](https://guides.github.com/features/mastering-markdown/) to format your code blocks.
34+
placeholder: Steps to reproduce
35+
validations:
36+
required: true

.github/bug-repro-guidelines.md

+29
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
## About Bug Reproductions
2+
3+
A bug reproduction is a piece of code that can run and demonstrate how a bug can happen。
4+
5+
### Text is not enough
6+
7+
It's impossible to fix a bug from mere text descriptions。First,it's very difficult to precisely describe a technical problem while keeping it easy to follow;Second,the real cause may very well be something that you forgot to even mention。A reproduction is the only way that can reliably help us understand what is going on,so please provide one。
8+
9+
### A repro must be runnable
10+
11+
Screenshots or videos are NOT reproductions!They only show that the bug exists,but do not provide enough information on why it happens。Only runnable code provides the most complete context and allows us to properly debug the scenario。That said,in some cases videos/gifs can help explain interaction issues that are hard to describe in text。
12+
13+
### A repro should be minimal
14+
15+
Some users would give us a link to a real project and hope we can help them figure out what is wrong。We generally do not accept such requests because:
16+
17+
You are already familiar with your codebase,but we are not。It is extremely time-consuming to hunt a bug in a big and unfamiliar codebase。
18+
19+
The problematic behavior may very well be caused by your code rather than by a bug in json-editor-vue。
20+
21+
A minimal reproduction means it demonstrates the bug,and the bug only。It should only contain the bare minimum amount of code that can reliably cause the bug。Try your best to get rid of anything that aren't directly related to the problem。
22+
23+
### How to create a repro
24+
25+
For Vue 3 core reproductions,try reproducing it in [The SFC Playground](https://sfc.vuejs.org/)
26+
27+
If it cannot be reproduced in the playground and requires a proper build setup,try [StackBlitz](https://vite.new/vue)
28+
29+
If neither of these are suitable,you can always provide a GitHub repository。

0 commit comments

Comments
 (0)