1
0
mirror of https://codeberg.org/cage/tinmop/ synced 2025-01-21 03:15:35 +01:00

- [GUI] restored auto-adjust width of TOC widget.

This commit is contained in:
cage 2023-05-20 16:50:31 +02:00
parent d3defee0ed
commit 0e7d9f9e0e

View File

@ -117,13 +117,13 @@
toc-max-width))) toc-max-width)))
(when toc (when toc
(let ((toc-widget-width (length (getf (first toc) :text)))) (let ((toc-widget-width (length (getf (first toc) :text))))
(setf (toc-char-width main-window) toc-widget-width)
(loop for ct from 0 (loop for ct from 0
for toc-item in toc do for toc-item in toc do
(gui:listbox-append (toc-listbox (toc-frame main-window)) (gui:listbox-append (toc-listbox (toc-frame main-window))
(getf toc-item :text))) (getf toc-item :text)))
(setf (toc-data (toc-frame main-window)) (setf (toc-data (toc-frame main-window))
(loop for toc-item in toc collect (getf toc-item :header-group-id))))) (loop for toc-item in toc collect (getf toc-item :header-group-id)))
(fit-toc-char-width main-window toc-widget-width)))
main-window))) main-window)))
(defun slurp-gemini-stream (main-window iri stream-wrapper &key (defun slurp-gemini-stream (main-window iri stream-wrapper &key
@ -1200,6 +1200,10 @@
:initform nil :initform nil
:initarg :search-frame :initarg :search-frame
:accessor search-frame) :accessor search-frame)
(gemini-paned-frame
:initform nil
:initarg :gemini-paned-frame
:accessor gemini-paned-frame)
(ir-rendered-lines (ir-rendered-lines
:initform (misc:make-fresh-array 0) :initform (misc:make-fresh-array 0)
:initarg :ir-rendered-lines :initarg :ir-rendered-lines
@ -1210,51 +1214,52 @@
:accessor ir-lines))) :accessor ir-lines)))
(defmethod initialize-instance :after ((object main-frame) &key &allow-other-keys) (defmethod initialize-instance :after ((object main-frame) &key &allow-other-keys)
(with-accessors ((main-window main-window) (with-accessors ((main-window main-window)
(tool-bar tool-bar) (tool-bar tool-bar)
(toc-frame toc-frame) (toc-frame toc-frame)
(info-frame info-frame) (info-frame info-frame)
(search-frame search-frame) (search-frame search-frame)
(info-text info-text) (info-text info-text)
(gemtext-widget gemtext-widget)) object (gemtext-widget gemtext-widget)
(let ((paned-frame (make-instance 'gui:paned-window (gemini-paned-frame gemini-paned-frame)) object
:orientation :horizontal (setf gemini-paned-frame (make-instance 'gui:paned-window
:master object))) :orientation :horizontal
(setf tool-bar (make-instance 'tool-bar :master object)) :master object))
(set-bookmark-button-false object) (setf tool-bar (make-instance 'tool-bar :master object))
(setf toc-frame (make-instance 'toc-frame :master paned-frame)) (set-bookmark-button-false object)
(let* ((gemtext-font (gui-conf:gemini-text-font-configuration)) (setf toc-frame (make-instance 'toc-frame :master gemini-paned-frame))
(padding (client-configuration:config-gemtext-padding)) (let* ((gemtext-font (gui-conf:gemini-text-font-configuration))
(padding-pixel (* padding (gui:font-measure gemtext-font "0")))) (padding (client-configuration:config-gemtext-padding))
(multiple-value-bind (select-bg select-fg) (padding-pixel (* padding (gui:font-measure gemtext-font "0"))))
(gui-conf:main-window-select-colors) (multiple-value-bind (select-bg select-fg)
(setf gemtext-widget (make-instance 'gui:scrolled-text (gui-conf:main-window-select-colors)
:background (gui-conf:gemini-window-colors) (setf gemtext-widget (make-instance 'gui:scrolled-text
:selectbackground select-bg :background (gui-conf:gemini-window-colors)
:selectforeground select-fg :selectbackground select-bg
:padx padding-pixel :selectforeground select-fg
:master paned-frame :padx padding-pixel
:read-only t :master gemini-paned-frame
:font gemtext-font))) :read-only t
(gui:configure gemtext-widget :wrap :word)) :font gemtext-font)))
(setf info-frame (make-instance 'gui:frame :master object :relief :sunken :borderwidth 1)) (gui:configure gemtext-widget :wrap :word))
(setf info-text (make-instance 'gui:text :height 2 :wrap :none :master info-frame)) (setf info-frame (make-instance 'gui:frame :master object :relief :sunken :borderwidth 1))
(gui:configure info-text :font gui:+tk-small-caption-font+) (setf info-text (make-instance 'gui:text :height 2 :wrap :none :master info-frame))
(setf search-frame (client-search-frame:init-window object)) (gui:configure info-text :font gui:+tk-small-caption-font+)
(gui:grid info-text 0 0 :sticky :news) (setf search-frame (client-search-frame:init-window object))
(gui-goodies:gui-resize-grid-all info-frame) (gui:grid info-text 0 0 :sticky :news)
(gui:grid tool-bar 0 0 :sticky :news) (gui-goodies:gui-resize-grid-all info-frame)
(gui:add-pane paned-frame toc-frame) (gui:grid tool-bar 0 0 :sticky :news)
(gui:add-pane paned-frame gemtext-widget) (gui:add-pane gemini-paned-frame toc-frame)
(gui:grid paned-frame 1 0 :sticky :news) (gui:add-pane gemini-paned-frame gemtext-widget)
(gui:grid search-frame 2 0 :sticky :news) (gui:grid gemini-paned-frame 1 0 :sticky :news)
(gui:grid-forget search-frame) (gui:grid search-frame 2 0 :sticky :news)
(gui:grid info-frame 3 0 :sticky :ews) (gui:grid-forget search-frame)
(gui:grid-columnconfigure object 0 :weight 1) (gui:grid info-frame 3 0 :sticky :ews)
(gui:grid-rowconfigure object 1 :weight 1) (gui:grid-columnconfigure object 0 :weight 1)
(setup-main-window-events object) (gui:grid-rowconfigure object 1 :weight 1)
(gui:focus (nodgui.mw:autocomplete-entry-widget (iri-entry (tool-bar object)))) (setup-main-window-events object)
object))) (gui:focus (nodgui.mw:autocomplete-entry-widget (iri-entry (tool-bar object))))
object))
(defgeneric toc-char-width (object)) (defgeneric toc-char-width (object))
@ -1267,8 +1272,22 @@
(defmethod toc-clear ((object main-frame)) (defmethod toc-clear ((object main-frame))
(gui:listbox-delete (toc-listbox (toc-frame object)))) (gui:listbox-delete (toc-listbox (toc-frame object))))
(defmethod (setf toc-char-width) (new-width (object main-frame)) (defgeneric fit-toc-char-width (object new-width))
(gui:configure (gui:listbox (toc-listbox (toc-frame object))) :width new-width))
(defmethod fit-toc-char-width ((object main-frame) new-width)
(with-accessors ((toc-frame toc-frame)
(gemini-paned-frame gemini-paned-frame)) object
(a:when-let* ((inner-listbox (gui:listbox (toc-listbox (toc-frame object))))
(listbox-items (gui:listbox-all-values inner-listbox))
(font (gui:cget inner-listbox :font))
(longest-value (reduce (lambda (a b)
(if (> (length a) (length b))
a
b))
listbox-items))
(width-pixel (gui:font-measure font (strcat longest-value "MM"))))
(gui:configure inner-listbox :width new-width)
(gui:sash-place gemini-paned-frame 0 width-pixel))))
(defun print-info-message (message &key (defun print-info-message (message &key
(color (gui-goodies:parse-color "black")) (color (gui-goodies:parse-color "black"))