summaryrefslogtreecommitdiffstats
path: root/templates/repo/issue/fields
diff options
context:
space:
mode:
Diffstat (limited to 'templates/repo/issue/fields')
-rw-r--r--templates/repo/issue/fields/checkboxes.tmpl14
-rw-r--r--templates/repo/issue/fields/dropdown.tmpl17
-rw-r--r--templates/repo/issue/fields/header.tmpl6
-rw-r--r--templates/repo/issue/fields/input.tmpl4
-rw-r--r--templates/repo/issue/fields/markdown.tmpl3
-rw-r--r--templates/repo/issue/fields/textarea.tmpl24
6 files changed, 68 insertions, 0 deletions
diff --git a/templates/repo/issue/fields/checkboxes.tmpl b/templates/repo/issue/fields/checkboxes.tmpl
new file mode 100644
index 0000000..531f401
--- /dev/null
+++ b/templates/repo/issue/fields/checkboxes.tmpl
@@ -0,0 +1,14 @@
+<div class="field {{if not .item.VisibleOnForm}}tw-hidden{{end}}">
+ {{template "repo/issue/fields/header" .}}
+ {{range $i, $opt := .item.Attributes.options}}
+ <div class="field inline">
+ <div class="ui checkbox tw-mr-0 {{if and ($opt.visible) (not (SliceUtils.Contains $opt.visible "form"))}}tw-hidden{{end}}">
+ <input type="checkbox" name="form-field-{{$.item.ID}}-{{$i}}" {{if $opt.required}}required{{end}}>
+ <label>{{RenderMarkdownToHtml $.context $opt.label}}</label>
+ </div>
+ {{if $opt.required}}
+ <label class="required"></label>
+ {{end}}
+ </div>
+ {{end}}
+</div>
diff --git a/templates/repo/issue/fields/dropdown.tmpl b/templates/repo/issue/fields/dropdown.tmpl
new file mode 100644
index 0000000..26505f5
--- /dev/null
+++ b/templates/repo/issue/fields/dropdown.tmpl
@@ -0,0 +1,17 @@
+<div class="field {{if not .item.VisibleOnForm}}tw-hidden{{end}}">
+ {{template "repo/issue/fields/header" .}}
+ {{/* FIXME: required validation */}}
+ <div class="ui fluid selection dropdown {{if .item.Attributes.multiple}}multiple clearable{{end}}">
+ <input type="hidden" name="form-field-{{.item.ID}}" value="{{.item.Attributes.default}}">
+ {{svg "octicon-triangle-down" 14 "dropdown icon"}}
+ {{if not .item.Validations.required}}
+ {{svg "octicon-x" 14 "remove icon"}}
+ {{end}}
+ <div class="default text"></div>
+ <div class="menu">
+ {{range $i, $opt := .item.Attributes.options}}
+ <div class="item" data-value="{{$i}}">{{$opt}}</div>
+ {{end}}
+ </div>
+ </div>
+</div>
diff --git a/templates/repo/issue/fields/header.tmpl b/templates/repo/issue/fields/header.tmpl
new file mode 100644
index 0000000..06c41af
--- /dev/null
+++ b/templates/repo/issue/fields/header.tmpl
@@ -0,0 +1,6 @@
+{{if and (.item.Attributes.label) (not .item.Attributes.hide_label)}}
+ <h3>{{.item.Attributes.label}}{{if .item.Validations.required}}<label class="required"></label>{{end}}</h3>
+{{end}}
+{{if .item.Attributes.description}}
+ <span class="help">{{RenderMarkdownToHtml .Context .item.Attributes.description}}</span>
+{{end}}
diff --git a/templates/repo/issue/fields/input.tmpl b/templates/repo/issue/fields/input.tmpl
new file mode 100644
index 0000000..039f9a9
--- /dev/null
+++ b/templates/repo/issue/fields/input.tmpl
@@ -0,0 +1,4 @@
+<div class="field {{if not .item.VisibleOnForm}}tw-hidden{{end}}">
+ {{template "repo/issue/fields/header" .}}
+ <input type="{{if .item.Validations.is_number}}number{{else}}text{{end}}" name="form-field-{{.item.ID}}" placeholder="{{.item.Attributes.placeholder}}" value="{{.item.Attributes.value}}" {{if .item.Validations.required}}required{{end}} {{if .item.Validations.regex}}pattern="{{.item.Validations.regex}}" title="{{.item.Validations.regex}}"{{end}}>
+</div>
diff --git a/templates/repo/issue/fields/markdown.tmpl b/templates/repo/issue/fields/markdown.tmpl
new file mode 100644
index 0000000..934699e
--- /dev/null
+++ b/templates/repo/issue/fields/markdown.tmpl
@@ -0,0 +1,3 @@
+<div class="field {{if not .item.VisibleOnForm}}tw-hidden{{end}}">
+ <div>{{RenderMarkdownToHtml .Context .item.Attributes.value}}</div>
+</div>
diff --git a/templates/repo/issue/fields/textarea.tmpl b/templates/repo/issue/fields/textarea.tmpl
new file mode 100644
index 0000000..3ad69e1
--- /dev/null
+++ b/templates/repo/issue/fields/textarea.tmpl
@@ -0,0 +1,24 @@
+{{$useMarkdownEditor := not .item.Attributes.render}}
+<div class="field {{if not .item.VisibleOnForm}}tw-hidden{{end}} {{if $useMarkdownEditor}}combo-editor-dropzone{{end}}">
+ {{template "repo/issue/fields/header" .}}
+
+ {{/* the real form element to provide the value */}}
+ <textarea class="form-field-real" name="form-field-{{.item.ID}}" placeholder="{{.item.Attributes.placeholder}}" {{if and .item.Validations.required}}required{{end}}>{{.item.Attributes.value}}</textarea>
+
+ {{if $useMarkdownEditor}}
+ {{template "shared/combomarkdowneditor" (dict
+ "ContainerClasses" "tw-hidden"
+ "MarkdownPreviewUrl" (print .root.RepoLink "/markup")
+ "MarkdownPreviewContext" .root.RepoLink
+ "TextareaContent" .item.Attributes.value
+ "TextareaPlaceholder" .item.Attributes.placeholder
+ "DropzoneParentContainer" ".combo-editor-dropzone"
+ )}}
+
+ {{if .root.IsAttachmentEnabled}}
+ <div class="tw-mt-4 form-field-dropzone tw-hidden">
+ {{template "repo/upload" .root}}
+ </div>
+ {{end}}
+ {{end}}
+</div>