feat(web/panettone): Disallow issues with an empty subject
Disallow creating issues with an empty subject, and render a nice(ish) alert box indicating the error. Change-Id: I2857923dc0eb7702c85cd1974a73270ca27720fc Reviewed-on: https://cl.tvl.fyi/c/depot/+/1404 Reviewed-by: kanepyork <rikingcoding@gmail.com> Tested-by: BuildkiteCI
This commit is contained in:
parent
280ec4a46c
commit
943a4c9214
2 changed files with 25 additions and 10 deletions
|
@ -146,6 +146,11 @@
|
||||||
|
|
||||||
,@(button '.new-issue)
|
,@(button '.new-issue)
|
||||||
|
|
||||||
|
(.alert
|
||||||
|
:padding "0.5rem"
|
||||||
|
:margin-bottom "1rem"
|
||||||
|
:background-color ,color/failure)
|
||||||
|
|
||||||
(.login-form
|
(.login-form
|
||||||
:width "300px"
|
:width "300px"
|
||||||
:margin "0 auto")
|
:margin "0 auto")
|
||||||
|
|
|
@ -185,6 +185,13 @@ updated issue"
|
||||||
(:div :class "content"
|
(:div :class "content"
|
||||||
,@body))))
|
,@body))))
|
||||||
|
|
||||||
|
(defun render/alert (message)
|
||||||
|
"Render an alert box for MESSAGE, if non-null"
|
||||||
|
(check-type message (or null string))
|
||||||
|
(who:with-html-output (*standard-output*)
|
||||||
|
(when message
|
||||||
|
(who:htm (:div :class "alert" (who:esc message))))))
|
||||||
|
|
||||||
(defun render/login (&optional message)
|
(defun render/login (&optional message)
|
||||||
(render
|
(render
|
||||||
(:div
|
(:div
|
||||||
|
@ -193,8 +200,7 @@ updated issue"
|
||||||
(:h1 "Login"))
|
(:h1 "Login"))
|
||||||
(:main
|
(:main
|
||||||
:class "login-form"
|
:class "login-form"
|
||||||
(when message
|
(render/alert message)
|
||||||
(who:htm (:div :class "alert" (who:esc message))))
|
|
||||||
(:form
|
(:form
|
||||||
:method :post :action "/login"
|
:method :post :action "/login"
|
||||||
(:div
|
(:div
|
||||||
|
@ -276,11 +282,12 @@ updated issue"
|
||||||
(:a :href "/" "View open isues"))
|
(:a :href "/" "View open isues"))
|
||||||
(render/issue-list :issues issues))))
|
(render/issue-list :issues issues))))
|
||||||
|
|
||||||
(defun render/new-issue ()
|
(defun render/new-issue (&optional message)
|
||||||
(render
|
(render
|
||||||
(:header
|
(:header
|
||||||
(:h1 "New Issue"))
|
(:h1 "New Issue"))
|
||||||
(:main
|
(:main
|
||||||
|
(render/alert message)
|
||||||
(:form :method "post"
|
(:form :method "post"
|
||||||
:action "/issues"
|
:action "/issues"
|
||||||
:class "issue-form"
|
:class "issue-form"
|
||||||
|
@ -400,13 +407,16 @@ updated issue"
|
||||||
(defroute handle-create-issue
|
(defroute handle-create-issue
|
||||||
("/issues" :method :post :decorators (@auth))
|
("/issues" :method :post :decorators (@auth))
|
||||||
(&post subject body)
|
(&post subject body)
|
||||||
|
(if (string= subject "")
|
||||||
|
(render/new-issue "Subject is required")
|
||||||
|
(progn
|
||||||
(cl-prevalence:execute-transaction
|
(cl-prevalence:execute-transaction
|
||||||
(create-issue *p-system*
|
(create-issue *p-system*
|
||||||
'subject subject
|
'subject subject
|
||||||
'body body
|
'body body
|
||||||
'author-dn (dn *user*)))
|
'author-dn (dn *user*)))
|
||||||
(cl-prevalence:snapshot *p-system*)
|
(cl-prevalence:snapshot *p-system*)
|
||||||
(hunchentoot:redirect "/"))
|
(hunchentoot:redirect "/"))))
|
||||||
|
|
||||||
(defroute show-issue ("/issues/:id" :decorators (@auth))
|
(defroute show-issue ("/issues/:id" :decorators (@auth))
|
||||||
(&path (id 'integer))
|
(&path (id 'integer))
|
||||||
|
|
Loading…
Reference in a new issue