[update] use :local-nicknames to import package

This commit is contained in:
Akira Tempaku 2024-01-30 10:28:28 +09:00
commit d62ff175dd
5 changed files with 36 additions and 46 deletions

View file

@ -3,8 +3,7 @@
(:use #:cl)
(:import-from #:clack)
(:import-from #:lack)
(:import-from #:hp/pages/**/*
#:*index-app*)
(:local-nicknames (#:pages #:hp/pages/**/*))
(:export #:start-app
#:stop-app))
(in-package :hp)
@ -13,7 +12,7 @@
(defun start-app ()
(unless *handler*
(setf *handler* (clack:clackup (lack:builder *index-app*)
(setf *handler* (clack:clackup (lack:builder pages:*index-app*)
:address "localhost"
:port 3000))))

View file

@ -1,44 +1,42 @@
(defpackage #:hp/pages/index
(:use #:cl)
(:import-from #:jingle)
(:import-from #:markup)
(:import-from #:hp/ui/layout
#:layout)
(:import-from #:hp/utils
#:render-html
#:register-routes)
(:local-nicknames (#:jg #:jingle))
(:local-nicknames (#:mk #:markup))
(:local-nicknames (#:ui #:hp/ui/*))
(:local-nicknames (#:utils #:hp/utils/*))
(:export #:*index-app*))
(in-package #:hp/pages/index)
(markup:enable-reader)
(mk:enable-reader)
(defparameter *counter* 0)
(markup:deftag counter (&key value)
<div id="counter">,(progn value)</div>)
(mk:deftag counter (&key id value)
<div id=id >,(progn value)</div>)
(defun index-page (params)
(declare (ignore params))
(render-html
<layout>
<counter value=*counter* />
(jg:with-html-response
(mk:write-html
<ui:layout>
<counter id="counter" value=*counter* />
<button hx-target="#counter" hx-post="/decrease"> - </button>
<button hx-target="#counter" hx-post="/increase"> + </button>
</layout>))
</ui:layout>)))
(defun increase (params)
(declare (ignore params))
(render-html
<counter value=(incf *counter*) />))
(jg:with-html-response
(mk:write-html <counter id="counter" value=(incf *counter*) />)))
(defun decrease (params)
(declare (ignore params))
(render-html
<counter value=(decf *counter*) />))
(jg:with-html-response
(mk:write-html <counter id= "counter" value=(decf *counter*) />)))
(defparameter *index-app* (jingle:make-app))
(defparameter *index-app* (jg:make-app))
(register-routes
(utils:register-routes
*index-app*
`((:method :GET :path "/" :handler ,#'index-page)
(:method :POST :path "/increase" :handler ,#'increase)

View file

@ -1,12 +1,12 @@
(defpackage #:hp/ui/layout
(:use #:cl)
(:import-from #:markup)
(:local-nicknames (#:mk #:markup))
(:export #:layout))
(in-package #:hp/ui/layout)
(markup:enable-reader)
(markup:deftag layout (children)
(mk:deftag layout (children)
<html>
<head>
<title>skyizwhite.dev</title>

View file

@ -1,19 +0,0 @@
(defpackage #:hp/utils
(:use #:cl)
(:import-from #:markup)
(:import-from #:jingle)
(:export #:register-routes
#:render-html))
(in-package #:hp/utils)
(defun register-routes (app routes)
(loop :for item :in routes
:for path = (getf item :path)
:for handler = (getf item :handler)
:for method = (getf item :method)
:do (setf (jingle:route app path :method method) handler)))
(defmacro render-html (&body body)
`(jingle:with-html-response
(markup:write-html
,@body)))

12
src/utils/routes.lisp Normal file
View file

@ -0,0 +1,12 @@
(defpackage #:hp/utils/routes
(:use #:cl)
(:local-nicknames (#:jg #:jingle))
(:export #:register-routes))
(in-package #:hp/utils/routes)
(defun register-routes (app routes)
(loop :for item :in routes
:for path = (getf item :path)
:for handler = (getf item :handler)
:for method = (getf item :method)
:do (setf (jg:route app path :method method) handler)))