factor/library/ui/checkboxes.factor

48 lines
1.5 KiB
Factor

! Copyright (C) 2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
IN: gadgets
USING: generic kernel lists math namespaces sdl ;
: check-size 8 ;
: <check> ( -- cross )
0 0 check-size dup <line> <gadget>
>r check-size 0 check-size neg check-size <line> <gadget> r>
2list <stack> ;
TUPLE: checkbox bevel selected? ;
: init-checkbox-bevel ( bevel checkbox -- )
2dup set-checkbox-bevel add-gadget ;
: update-checkbox ( checkbox -- )
#! Really, there should only be one child.
dup checkbox-bevel gadget-children [ unparent ] each
dup checkbox-selected? [
<check>
] [
0 0 check-size dup <rectangle> <gadget>
] ifte swap checkbox-bevel add-gadget ;
: toggle-checkbox ( checkbox -- )
dup checkbox-selected? not over set-checkbox-selected?
update-checkbox ;
: checkbox-update ( checkbox -- )
dup button-pressed? >r checkbox-bevel r>
reverse-video set-paint-prop ;
: checkbox-actions ( checkbox -- )
dup [ toggle-checkbox ] [ action ] set-action
dup [ dup checkbox-update button-clicked ] [ button-up 1 ] set-action
dup [ checkbox-update ] [ button-down 1 ] set-action
dup [ checkbox-update ] [ mouse-leave ] set-action
[ checkbox-bevel button-update ] [ mouse-enter ] set-action ;
C: checkbox ( label -- checkbox )
<default-shelf> over set-delegate
[ f line-border swap init-checkbox-bevel ] keep
[ >r <label> r> add-gadget ] keep
dup checkbox-actions
dup update-checkbox ;