77f661fa2c
Add client-side validation to ensure a repository is selected before form submission. Split owner/repo on both change and submit events. Show inline error messages via form-error div. Update CreateIssue handler to return HTMX-friendly HTML error fragments on 400/500. Closes leeworks-agents/gitea-mobile#30 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
77 lines
2.5 KiB
HTML
77 lines
2.5 KiB
HTML
{{define "content"}}
|
|
<h1>Create Issue</h1>
|
|
|
|
<div id="form-error" class="empty" style="display:none;"></div>
|
|
|
|
<form id="create-issue-form" hx-post="/issues" hx-swap="innerHTML" hx-target="#main-content">
|
|
<div class="form-group">
|
|
<label for="repo-select">Repository</label>
|
|
<select id="repo-select" name="owner_repo" required>
|
|
<option value="">Select a repository...</option>
|
|
{{range $org, $repos := .Repos}}
|
|
<optgroup label="{{$org}}">
|
|
{{range $repos}}
|
|
<option value="{{.Owner.Login}}/{{.Name}}">{{.FullName}}</option>
|
|
{{end}}
|
|
</optgroup>
|
|
{{end}}
|
|
</select>
|
|
<input type="hidden" name="owner" id="owner-input">
|
|
<input type="hidden" name="repo" id="repo-input">
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="title">Title</label>
|
|
<input type="text" id="title" name="title" placeholder="Issue title" required>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="body">Description</label>
|
|
<textarea id="body" name="body" placeholder="Describe the issue..."></textarea>
|
|
</div>
|
|
|
|
<button type="submit" class="btn btn-primary">Create Issue</button>
|
|
</form>
|
|
|
|
<script>
|
|
(function() {
|
|
var repoSelect = document.getElementById('repo-select');
|
|
var ownerInput = document.getElementById('owner-input');
|
|
var repoInput = document.getElementById('repo-input');
|
|
var formError = document.getElementById('form-error');
|
|
|
|
function splitOwnerRepo() {
|
|
var val = repoSelect.value;
|
|
if (val) {
|
|
var parts = val.split('/');
|
|
ownerInput.value = parts[0] || '';
|
|
repoInput.value = parts[1] || '';
|
|
} else {
|
|
ownerInput.value = '';
|
|
repoInput.value = '';
|
|
}
|
|
}
|
|
|
|
repoSelect.addEventListener('change', splitOwnerRepo);
|
|
|
|
// Validate before HTMX submit.
|
|
document.getElementById('create-issue-form').addEventListener('htmx:configRequest', function(evt) {
|
|
splitOwnerRepo();
|
|
if (!ownerInput.value || !repoInput.value) {
|
|
evt.preventDefault();
|
|
formError.textContent = 'Please select a repository before submitting.';
|
|
formError.style.display = 'block';
|
|
return false;
|
|
}
|
|
formError.style.display = 'none';
|
|
});
|
|
|
|
// Show server-side errors inline on HTMX error responses.
|
|
document.getElementById('create-issue-form').addEventListener('htmx:responseError', function(evt) {
|
|
formError.textContent = evt.detail.xhr.responseText || 'An error occurred. Please try again.';
|
|
formError.style.display = 'block';
|
|
});
|
|
})();
|
|
</script>
|
|
{{end}}
|