aboutsummaryrefslogtreecommitdiff
path: root/module/output/html-search.scm
blob: 070a725efcd59075ca2fc29e9bc92bb7cdb7901f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
;; TODO rename this module
(define-module (output html-search)
  :use-module (util)
  :use-module (vcomponent)
  :use-module (vcomponent search)
  :use-module ((ice-9 pretty-print) :select (pretty-print))
  :use-module (html components)
  :use-module (html vcomponent)
  )

(define-public (search-result-page
                search-term search-result page paginator q=)
  (xhtml-doc
   (@ (lang sv))
   (head (title "Search results")
         ,(include-css "/static/style.css"))
   (body
    (h2 "Search term")
    (form
     (pre (textarea (@ (name "q") (rows 5) (spellcheck false)
                       (style "width:100%"))
                    ,(with-output-to-string
                       (lambda () (pretty-print search-term)))))
     (input (@ (type submit))))
    (h2 "Result (page " ,page ")")
    (ul
     ,@(compact-event-list search-result))
    (div (@ (class "paginator"))
         ,@(paginator->list
            paginator
            (lambda (p) (if (= p page)
                       `(span ,p)
                       `(a (@ (href "?" ,q= "&p=" ,p)) ,p)))
            (lambda (p) `(a (@ (href "?" ,q= "&p=" ,p)) "»"))))
    )))