2023-04-13 15:03:57 +02:00
|
|
|
(in-package :client-tour-window)
|
|
|
|
|
|
|
|
(named-readtables:in-readtable nodgui.syntax:nodgui-syntax)
|
|
|
|
|
|
|
|
(defclass tour-frame (gui-goodies:table-frame) ())
|
|
|
|
|
|
|
|
(defun resync-rows (tour-frame new-rows)
|
|
|
|
(with-accessors ((tree gui-goodies:tree)
|
|
|
|
(rows gui-goodies:rows)) tour-frame
|
|
|
|
(gui:treeview-delete-all tree)
|
|
|
|
(setf rows new-rows)
|
|
|
|
(loop for row in rows do
|
|
|
|
(let* ((tree-row (make-instance 'gui:tree-item
|
|
|
|
:id (getf row :target)
|
|
|
|
:text (getf row :target)
|
|
|
|
:column-values (list (getf row :name))
|
|
|
|
:index gui:+treeview-last-index+)))
|
|
|
|
(gui:treeview-insert-item tree :item tree-row))))
|
|
|
|
(gui:treeview-refit-columns-width (gui-goodies:tree tour-frame))
|
|
|
|
tour-frame)
|
|
|
|
|
|
|
|
(defun all-rows ()
|
|
|
|
(cev:enqueue-request-and-wait-results :tour-all-links
|
|
|
|
1
|
|
|
|
ev:+standard-event-priority+))
|
|
|
|
|
|
|
|
(defmethod initialize-instance :after ((object tour-frame) &key &allow-other-keys)
|
|
|
|
(with-accessors ((tree gui-goodies:tree)
|
|
|
|
(rows gui-goodies:rows)) object
|
|
|
|
(let ((new-rows (all-rows))
|
|
|
|
(treeview (make-instance 'gui:scrolled-treeview
|
|
|
|
:master object
|
|
|
|
:pack '(:side :top :expand t :fill :both)
|
|
|
|
:columns (list (_ "Description")))))
|
|
|
|
(setf tree treeview)
|
|
|
|
(gui:treeview-heading tree gui:+treeview-first-column-id+
|
|
|
|
:text (_ "Address"))
|
|
|
|
(resync-rows object new-rows)
|
|
|
|
object)))
|
|
|
|
|
|
|
|
(defun delete-tour-clsr (tour-frame)
|
|
|
|
(lambda ()
|
|
|
|
(a:when-let* ((selections (gui:treeview-get-selection (gui-goodies:tree tour-frame))))
|
|
|
|
(loop for selection in selections do
|
|
|
|
(let ((url (gui:id selection)))
|
|
|
|
(ev:with-enqueued-process-and-unblock ()
|
|
|
|
(comm:make-request :tour-delete-link
|
|
|
|
1
|
|
|
|
url))
|
|
|
|
(let ((new-rows (all-rows)))
|
|
|
|
(resync-rows tour-frame new-rows)))))))
|
|
|
|
|
2023-04-14 15:09:38 +02:00
|
|
|
(defun enqueue-shuffle-tour ()
|
|
|
|
(ev:with-enqueued-process-and-unblock ()
|
|
|
|
(comm:make-request :tour-shuffle 1)))
|
|
|
|
|
|
|
|
(defun shuffle-tour-clsr (tour-frame)
|
|
|
|
(lambda ()
|
|
|
|
(enqueue-shuffle-tour)
|
|
|
|
(let ((new-rows (all-rows)))
|
|
|
|
(resync-rows tour-frame new-rows))))
|
|
|
|
|
2023-04-13 15:03:57 +02:00
|
|
|
(defun init-window (master)
|
|
|
|
(gui:with-toplevel (toplevel :master master :title (_ "Tour"))
|
|
|
|
(gui:transient toplevel master)
|
|
|
|
(let* ((table (make-instance 'tour-frame :master toplevel))
|
|
|
|
(buttons-frame (make-instance 'gui:frame :master toplevel))
|
|
|
|
(delete-button (make-instance 'gui:button
|
|
|
|
:master buttons-frame
|
|
|
|
:image icons:*document-delete*
|
2023-04-14 15:09:38 +02:00
|
|
|
:command (delete-tour-clsr table)))
|
|
|
|
(shuffle-button (make-instance 'gui:button
|
|
|
|
:master buttons-frame
|
|
|
|
:image icons:*dice*
|
|
|
|
:command (shuffle-tour-clsr table))))
|
|
|
|
(gui-goodies:attach-tooltips (delete-button (_ "delete selected links"))
|
2023-04-14 15:21:08 +02:00
|
|
|
(shuffle-button (_ "shuffle links")))
|
2023-04-14 15:09:38 +02:00
|
|
|
(gui:grid table 0 0 :sticky :nwe)
|
|
|
|
(gui:grid buttons-frame 1 0 :sticky :s)
|
|
|
|
(gui:grid delete-button 0 0 :sticky :s)
|
|
|
|
(gui:grid shuffle-button 0 1 :sticky :s))))
|