diff options
author | fvogel <fvogelnew1@free.fr> | 2023-07-24 20:30:30 (GMT) |
---|---|---|
committer | fvogel <fvogelnew1@free.fr> | 2023-07-24 20:30:30 (GMT) |
commit | 0eb6496a31cdc5e9b0e89a0a986c83cf856ef5c4 (patch) | |
tree | 251021da16a2026a14d5148e52440e243e908ce6 /library | |
parent | e044dc2b6c6a2ba749f903a112660a03b8cf1c99 (diff) | |
parent | 669b3ffcb6f73ff6ea763a093d836c92424efb37 (diff) | |
download | tk-0eb6496a31cdc5e9b0e89a0a986c83cf856ef5c4.zip tk-0eb6496a31cdc5e9b0e89a0a986c83cf856ef5c4.tar.gz tk-0eb6496a31cdc5e9b0e89a0a986c83cf856ef5c4.tar.bz2 |
merge trunk
Diffstat (limited to 'library')
-rw-r--r-- | library/systray.tcl | 156 |
1 files changed, 45 insertions, 111 deletions
diff --git a/library/systray.tcl b/library/systray.tcl index 3aa6da0..48ab89d 100644 --- a/library/systray.tcl +++ b/library/systray.tcl @@ -116,128 +116,62 @@ namespace eval ::tk::systray { # Pure-Tcl system notification window for use if native implementation not available. -# This is supposed to happen only on X11 when libnotify is not present. namespace eval ::tk::sysnotify:: { - # These defaults mimics the default behaviour of gnome and xfce - # notifications. - # These options are meant to be "public" - option add *Sysnotify.padX 3 - option add *Sysnotify.padY 3 - option add *Sysnotify.background gray15 - option add *Sysnotify.foreground white - option add *Sysnotify.delay 10000 - option add *Sysnotify.alpha 0.85 proc _notifywindow {title msg} { - - # cleanup any previous notify window and create a new one - set w ._notify - _notifyDestroy $w - toplevel $w -class Sysnotify - - set xpos [tk::ScaleNum 16] - set ypos [tk::ScaleNum 48] - # position from the "ne" corner - wm geometry $w -$xpos+$ypos - wm overrideredirect $w true - - # internal options - option add *Sysnotify.Label.anchor w - option add *Sysnotify.Label.justify left - option add *Sysnotify.Label.wrapLength [expr {[winfo screenwidth .] / 4}] - foreach option {padX padY foreground background} { - option add *Sysnotify.Label.$option [option get $w $option ""] + catch {destroy ._notify} + set w [toplevel ._notify] + if {[tk windowingsystem] eq "aqua"} { + ::tk::unsupported::MacWindowStyle style $w utility {hud closeBox resizable} + wm title $w "Alert" } - set icon ::tk::icons::information - set width [expr {[image width $icon] + 2*[option get $w padX ""]}] - set height [expr {[image height $icon] + 2*[option get $w padY ""]}] - label $w.icon -image $icon -width $width -height $height -anchor c - label $w.title -text $title -font TkHeadingFont - label $w.message -text [_filterMarkup $msg] -font TkTooltipFont - - grid $w.icon $w.title -sticky news - grid ^ $w.message -sticky news - - bind Sysnotify <Map> [namespace code { - # set the wm attribute here; it is ignored if set - # before the window is mapped - wm attributes %W -alpha 0.0 - if {[wm attributes %W -alpha] == 0.0} { - _fadeIn %W - } - }] - bind Sysnotify <Enter> [namespace code {_onEnter %W}] - bind Sysnotify <Leave> [namespace code {_onLeave %W}] - bind $w <Button-1> [namespace code [list _notifyDestroy $w]] - after [option get $w delay ""] [namespace code [list _fadeOut $w]] - return - } - - # Fade the window into view. - proc _fadeIn {w} { - raise $w - set alpha [option get $w alpha ""] - set before [wm attributes $w -alpha] - set new [expr { min($alpha, $before + 0.10) }] - wm attributes $w -alpha $new - set after [wm attributes $w -alpha] - if {($before == 1.0) || ($before == $after)} { - # not supported or we're done - return + if {[tk windowingsystem] eq "win32"} { + wm attributes $w -toolwindow true + wm title $w "Alert" } - after 40 [namespace code [list _fadeIn $w]] - } - - # Fade out and destroy window. - proc _fadeOut {w} { - set before [wm attributes $w -alpha] - set new [expr { $before - 0.02 }] - wm attributes $w -alpha $new - set after [wm attributes $w -alpha] - if {($after == 1.0) || ($before == $after)} { - _notifyDestroy $w - return + label $w.l -bg gray30 -fg white -image ::tk::icons::information + pack $w.l -fill both -expand yes -side left + message $w.message -aspect 150 -bg gray30 -fg white -text $title\n\n$msg -width 210p + pack $w.message -side right -fill both -expand yes + if {[tk windowingsystem] eq "x11"} { + wm overrideredirect $w true } - after 40 [namespace code [list _fadeOut $w]] + wm attributes $w -alpha 0.0 + set xpos [expr {[winfo screenwidth $w] - [::tk::ScaleNum 325]}] + wm geometry $w +$xpos+[::tk::ScaleNum 30] + ::tk::sysnotify::_fade_in $w + after 3000 ::tk::sysnotify::_fade_out $w } - proc _notifyDestroy {w} { - # cancel any pending fade in or fade out - _cancelFading $w - destroy $w - } - - proc _onEnter {w} { - wm attributes $w -alpha 1.0 - _cancelFading $w - } - - proc _onLeave {w} { - wm attributes $w -alpha [option get $w alpha ""] - after [option get $w delay ""] [namespace code [list _fadeOut $w]] - } - - proc _cancelFading {w} { - after cancel [namespace code [list _fadeOut $w]] - after cancel [namespace code [list _fadeIn $w]] + #Fade and destroy window. + proc _fade_out {w} { + catch { + set prev_degree [wm attributes $w -alpha] + set new_degree [expr {$prev_degree - 0.05}] + set current_degree [wm attributes $w -alpha $new_degree] + if {$new_degree > 0.0 && $new_degree != $prev_degree} { + after 10 [list ::tk::sysnotify::_fade_out $w] + } else { + destroy $w + } + } } - # The Desktop Notifications Specification allow for some markup - # in the message to display. It also specifies - # "Notification servers that do not support these tags should - # filter them out" - # See https://specifications.freedesktop.org/notification-spec/latest/ar01s04.html - # We don't event try to render those properly - proc _filterMarkup {txt} { - # remove fixed tags - set maplist {<b> "" </b> "" <i> "" </i> "" <u> "" </u> "" </a> ""} - set txt [string map $maplist $txt] - # remove <img> tags leaving (possible) alt text - set txt [regsub -- {<img *src="[^"]*" *(alt="([^"]*)")? */?>} $txt {\2}] - # remove <a href=""> variable tag - set txt [regsub -- {<a[^>]*>} $txt {}] - return $txt + #Fade the window into view. + proc _fade_in {w} { + catch { + raise $w + wm attributes $w -topmost 1 + set prev_degree [wm attributes $w -alpha] + set new_degree [expr {$prev_degree + 0.05}] + set current_degree [wm attributes $w -alpha $new_degree] + focus -force $w + if {$new_degree < 0.9 && $new_degree != $prev_degree} { + after 10 [list ::tk::sysnotify::_fade_in $w] + } + } } + namespace export * } |