factor/library/ui/ui.factor

144 lines
3.6 KiB
Factor
Raw Normal View History

! Copyright (C) 2006 Slava Pestov.
! See http://factorcode.org/license.txt for BSD license.
IN: gadgets
USING: arrays gadgets gadgets-frames gadgets-labels
gadgets-theme gadgets-viewports hashtables kernel math
namespaces queues sequences threads ;
! Assoc mapping aliens to gadgets
SYMBOL: windows
: window ( handle -- world ) windows get-global assoc ;
: register-window ( world handle -- )
swap 2array windows get-global push ;
: unregister-window ( handle -- )
windows get-global
2006-05-29 01:33:29 -04:00
[ first = not ] subset-with
windows set-global ;
: raised-window ( world -- )
windows get-global [ second eq? ] find-with drop
windows get-global [ length 1- ] keep exchange ;
: frontmost-window ( -- world )
windows get dup empty? [ drop f ] [ peek second ] if ;
: update-hand ( gadget -- )
find-world [
dup hand-gadget get-global find-world eq?
[ hand-loc get-global swap move-hand ] [ drop ] if
] when* ;
2006-05-31 03:26:59 -04:00
: post-layout ( gadget -- )
find-world [ dup world-handle set ] when* ;
2006-05-31 03:26:59 -04:00
: layout-queued ( -- )
invalid dup queue-empty? [
drop
] [
2006-05-31 03:26:59 -04:00
deque dup layout post-layout layout-queued
] if ;
: init-ui ( -- )
2006-06-02 16:28:57 -04:00
<queue> \ invalid set-global
V{ } clone windows set-global ;
: ui-step ( -- )
do-timers
[ layout-queued ] make-hash hash-values [
dup update-hand
dup world-handle [ dup draw-world ] when
drop
] each
10 sleep ;
: <status-bar> ( -- gadget ) "" <label> dup highlight-theme ;
2006-05-26 02:29:44 -04:00
GENERIC: gadget-title ( gadget -- string )
M: gadget gadget-title drop "Factor" ;
M: world gadget-title world-gadget gadget-title ;
TUPLE: titled-gadget title ;
M: titled-gadget gadget-title titled-gadget-title ;
M: titled-gadget focusable-child* gadget-child ;
2006-05-26 02:44:31 -04:00
C: titled-gadget ( gadget title -- )
[ set-titled-gadget-title ] keep
{ { f f f @center } } make-frame* ;
2006-05-26 02:29:44 -04:00
: update-title ( gadget -- )
dup gadget-parent dup world?
[ >r gadget-title r> set-title ] [ 2drop ] if ;
: open-window ( gadget -- )
2006-06-29 00:00:21 -04:00
<world> dup pref-dim over set-gadget-dim open-window* ;
2006-05-26 02:29:44 -04:00
: open-titled-window ( gadget title -- )
<titled-gadget> open-window ;
: find-window ( quot -- world )
windows get [ second ] map
[ world-gadget swap call ] find-last-with nip ; inline
: open-tool ( arg cons setter -- )
2006-05-26 02:29:44 -04:00
>r call tuck r> call open-window ; inline
: call-tool ( arg pred cons setter -- )
rot find-window [
rot drop
dup raise-window
world-gadget swap call
] [
open-tool
] if* ; inline
: start-world ( world -- )
dup add-notify
dup gadget-title over set-title
dup relayout
world-gadget request-focus ;
: close-global ( world global -- )
dup get-global find-world rot eq?
[ f swap set-global ] [ drop ] if ;
: focus-world ( world -- )
#! Sent when native window receives focus
t over set-world-focused?
dup raised-window
focused-ancestors f focus-gestures ;
: unfocus-world ( world -- )
f over set-world-focused?
#! Sent when native window loses focus.
focused-ancestors f swap focus-gestures ;
: reset-world ( world -- )
dup unfocus-world
f over set-world-focus
f over set-world-handle
world-fonts clear-hash ;
: close-world ( world -- )
dup hand-clicked close-global
dup hand-gadget close-global
f over request-focus*
dup remove-notify
dup free-fonts
reset-world ;
: restore-windows ( -- )
windows get [ second ] map
0 windows get set-length
[ dup reset-world open-window* ] each
forget-rollover ;
: restore-windows? ( -- ? )
windows get [ empty? not ] [ f ] if* ;