Files
rktplayer/tray.rkt
T
2026-05-04 16:05:34 +02:00

71 lines
2.1 KiB
Racket

#lang racket
(require racket-webview
racket/runtime-path
"translate.rkt"
"utils.rkt"
)
(provide rktplayer-tray%)
(define-runtime-path rkt-gui-dir "gui")
(define rktplayer-tray%
(class wv-tray%
(init-field [rktplayer-gui (error "Must be called with the GUI Window of RktPlayer")]
)
(define (adjust-menu)
(dbg-rktplayer "adjust menu called, window state = ~a" (send rktplayer-gui window-state))
(let ((mnu (wv-menu 'tray-menu
(wv-menu-item 'm-hide-show
(if (eq? (send rktplayer-gui window-state) 'hidden)
(tr "Show window")
(tr "Hide window")))
(wv-menu-item 'm-pause-play (tr "Pause / Play"))
(wv-menu-item 'm-quit (tr "Quit"))
)
)
)
(send this set-menu! mnu)
(send this connect-menu! 'm-hide-show (λ () (show-hide)))
(send this connect-menu! 'm-quit (λ () (quit)))
(send this connect-menu! 'm-pause-play (λ () (pause-play)))
))
(define (quit)
(send rktplayer-gui quit))
(define (pause-play)
(send rktplayer-gui play-or-pause))
(define (show-hide)
(send rktplayer-gui show-hide)
(adjust-menu)
)
(define/override (activated reason)
(show-hide)
#t)
(super-new [icon (build-path rkt-gui-dir "rktplayer.png")]
[tooltip (tr "Racket Music Player")])
(begin
(send rktplayer-gui set-window-state-change-callback!
(λ ()
(let ((st (send rktplayer-gui window-state)))
(if (eq? st 'minimized)
(begin
(dbg-rktplayer "state = ~a, hiding window" st)
(send rktplayer-gui present)
(send rktplayer-gui hide))
(adjust-menu))
)
)
)
(adjust-menu)
)
)
)