summaryrefslogtreecommitdiffstats
path: root/templates/repo/actions/dispatch.tmpl
diff options
context:
space:
mode:
authorDaniel Baumann <daniel@debian.org>2024-10-18 20:33:49 +0200
committerDaniel Baumann <daniel@debian.org>2024-12-12 23:57:56 +0100
commite68b9d00a6e05b3a941f63ffb696f91e554ac5ec (patch)
tree97775d6c13b0f416af55314eb6a89ef792474615 /templates/repo/actions/dispatch.tmpl
parentInitial commit. (diff)
downloadforgejo-e68b9d00a6e05b3a941f63ffb696f91e554ac5ec.tar.xz
forgejo-e68b9d00a6e05b3a941f63ffb696f91e554ac5ec.zip
Adding upstream version 9.0.3.
Signed-off-by: Daniel Baumann <daniel@debian.org>
Diffstat (limited to 'templates/repo/actions/dispatch.tmpl')
-rw-r--r--templates/repo/actions/dispatch.tmpl101
1 files changed, 101 insertions, 0 deletions
diff --git a/templates/repo/actions/dispatch.tmpl b/templates/repo/actions/dispatch.tmpl
new file mode 100644
index 0000000..48c2aa5
--- /dev/null
+++ b/templates/repo/actions/dispatch.tmpl
@@ -0,0 +1,101 @@
+<div class="ui info message tw-flex tw-items-center">
+ <span>
+ {{ctx.Locale.Tr "actions.workflow.dispatch.trigger_found"}}
+ </span>
+ <div class="ui dropdown custom tw-ml-4" id="workflow_dispatch_dropdown">
+ <button class="ui compact small basic button tw-flex">
+ <span class="text">{{ctx.Locale.Tr "actions.workflow.dispatch.run"}}</span>
+ {{svg "octicon-triangle-down" 14 "dropdown icon"}}
+ </button>
+ <div class="menu">
+ <div class="message ui form">
+ <div class="field">
+ <label>{{ctx.Locale.Tr "actions.workflow.dispatch.use_from"}}</label>
+ {{template "repo/branch_dropdown" dict
+ "root" (dict
+ "IsViewBranch" true
+ "BranchName" .Repo.BranchName
+ "CommitID" .Repo.CommitID
+ "RepoLink" .Repo.RepoLink
+ "Repository" .Repo.Repository
+ )
+ "disableCreateBranch" true
+ "branchForm" "branch-dropdown-form"
+ "setAction" false
+ "submitForm" false
+ }}
+ </div>
+
+ <form method="post" action="{{.Repo.RepoLink}}/actions/manual" id="branch-dropdown-form">
+ {{range $i, $key := .CurWorkflowDispatchInputKeys}}
+ {{$val := index $.CurWorkflowDispatch.Inputs $key}}
+ <div class="{{if $val.Required}}required {{end}}field">
+ {{if eq $val.Type "boolean"}}
+ <div class="ui checkbox">
+ <label><strong>{{if $val.Description}}{{$val.Description}}{{else}}{{$key}}{{end}}</strong></label>
+ {{/* These two inputs need to stay in exactly this order (checkbox first, hidden second) or boolean fields wont work correctly! */}}
+ <input type="checkbox" name="inputs[{{$key}}]" value="on" {{if eq $val.Default "true"}}checked{{end}}>
+ <input type="hidden" name="inputs[{{$key}}]" value="off" autocomplete="off">
+ </div>
+ {{else}}
+ <label>{{if $val.Description}}{{$val.Description}}{{else}}{{$key}}{{end}}</label>
+ {{if eq $val.Type "number"}}
+ <input {{if $val.Required}}required{{end}} type="number" name="inputs[{{$key}}]" {{if $val.Default}}value="{{$val.Default}}"{{end}}>
+ {{else if eq $val.Type "string"}}
+ <input {{if $val.Required}}required{{end}} type="text" name="inputs[{{$key}}]" {{if $val.Default}}value="{{$val.Default}}"{{end}}>
+ {{else if eq $val.Type "choice"}}
+ <div class="ui selection dropdown">
+ <input name="inputs[{{$key}}]" type="hidden" value="{{$val.Default}}">
+ {{svg "octicon-triangle-down" 14 "dropdown icon"}}
+ <div class="text"></div>
+ <div class="menu">
+ {{range $opt := $val.Options}}
+ <div data-value="{{$opt}}" class="{{if eq $val.Default $opt}}active selected {{end}}item">{{$opt}}</div>
+ {{end}}
+ </div>
+ </div>
+ {{else}}
+ <strong>{{ctx.Locale.Tr "actions.workflow.dispatch.invalid_input_type" $val.Type}}</strong>
+ {{end}}
+ {{end}}
+ </div>
+ {{end}}
+
+ {{if .WarnDispatchInputsLimit}}
+ <div class="text yellow tw-mb-4">
+ {{svg "octicon-alert"}} {{ctx.Locale.Tr "actions.workflow.dispatch.warn_input_limit" .DispatchInputsLimit}}
+ </div>
+ {{end}}
+
+ {{.CsrfTokenHtml}}
+ <input type="hidden" name="ref" value="{{if $.Repo.BranchName}}{{$.Repo.BranchName}}{{else}}{{$.Repo.Repository.DefaultBranch}}{{end}}">
+ <input type="hidden" name="workflow" value="{{$.CurWorkflow}}">
+ <input type="hidden" name="actor" value="{{$.CurActor}}">
+ <input type="hidden" name="status" value="{{$.CurStatus}}">
+ <button type="submit" id="workflow-dispatch-submit" class="ui primary small compact button">{{ctx.Locale.Tr "actions.workflow.dispatch.run"}}</button>
+ </form>
+ </div>
+ </div>
+ </div>
+ <script>
+ window.addEventListener('load', () => {
+ const dropdown = $('#workflow_dispatch_dropdown');
+ const menu = dropdown.find('> .menu');
+ $(document.body).on('click', (ev) => {
+ if (!dropdown[0].contains(ev.target) && menu.hasClass('visible')) {
+ menu.transition({ animation: 'slide down out', duration: 200, queue: false });
+ }
+ });
+ dropdown.on('click', (ev) => {
+ const inMenu = $(ev.target).closest(menu).length !== 0;
+ if (inMenu) return;
+ ev.stopPropagation();
+ if (menu.hasClass('visible')) {
+ menu.transition({ animation: 'slide down out', duration: 200, queue: false });
+ } else {
+ menu.transition({ animation: 'slide down in', duration: 200, queue: true });
+ }
+ });
+ });
+ </script>
+</div>