71 lines
2.1 KiB
Racket
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)
|
|
)
|
|
|
|
)
|
|
) |