factor/library/ui/gadgets/outliner.factor

64 lines
1.9 KiB
Factor
Raw Normal View History

2006-06-07 23:51:28 -04:00
! Copyright (C) 2005, 2006 Slava Pestov.
! See http://factorcode.org/license.txt for BSD license.
2005-09-25 01:16:35 -04:00
IN: gadgets-outliner
2005-09-27 14:12:17 -04:00
USING: arrays gadgets gadgets-borders gadgets-buttons
2006-06-07 23:51:28 -04:00
gadgets-frames gadgets-grids gadgets-labels gadgets-panes
2006-10-12 18:09:30 -04:00
gadgets-theme generic io kernel math opengl sequences styles
namespaces ;
! Vertical line.
TUPLE: guide color ;
M: guide draw-interior
guide-color gl-color
2006-10-12 18:09:30 -04:00
rect-dim dup { 0.5 0 0 } v* origin get v+
swap { 0.5 1 0 } v* origin get v+ gl-line ;
: guide-theme ( gadget -- )
T{ guide f { 0.5 0.5 0.5 1.0 } } swap set-gadget-interior ;
: <guide-gadget> ( -- gadget )
2006-10-12 18:09:30 -04:00
<gadget> dup guide-theme ;
2005-09-25 01:16:35 -04:00
2005-09-27 14:12:17 -04:00
! Outliner gadget.
TUPLE: outliner quot ;
2005-09-25 01:16:35 -04:00
2005-09-27 14:12:17 -04:00
: outliner-expanded? ( outliner -- ? )
#! If the outliner is expanded, it has a center gadget.
2006-06-07 23:04:37 -04:00
@center grid-child >boolean ;
2005-09-25 01:16:35 -04:00
2005-09-27 14:12:17 -04:00
: find-outliner ( gadget -- outliner )
[ outliner? ] find-parent ;
2005-09-25 01:16:35 -04:00
2005-09-27 14:12:17 -04:00
: <expand-arrow> ( ? -- gadget )
2006-01-18 18:50:52 -05:00
arrow-right arrow-down ? { 0.5 0.5 0.5 1.0 } swap
2005-12-17 20:03:41 -05:00
<polygon-gadget> <default-border> ;
2005-09-25 01:16:35 -04:00
DEFER: set-outliner-expanded?
2005-09-27 14:12:17 -04:00
: <expand-button> ( ? -- gadget )
#! If true, the button expands, otherwise it collapses.
dup [ swap find-outliner set-outliner-expanded? ] curry
>r <expand-arrow> r> <highlight-button> ;
: setup-expand ( expanded? outliner -- )
2006-06-07 23:04:37 -04:00
>r not <expand-button> r> @top-left grid-add ;
: setup-center ( expanded? outliner -- )
[ swap [ outliner-quot make-pane ] [ drop f ] if ] keep
2006-06-07 23:04:37 -04:00
@center grid-add ;
: setup-guide ( expanded? outliner -- )
2006-06-07 23:04:37 -04:00
>r [ <guide-gadget> ] [ f ] if r> @left grid-add ;
: set-outliner-expanded? ( expanded? outliner -- )
#! Call the expander quotation if expanding.
2dup setup-expand 2dup setup-center setup-guide ;
2005-09-25 01:16:35 -04:00
C: outliner ( gadget quot -- gadget )
#! The quotation generates child gadgets.
2005-10-09 21:27:14 -04:00
dup delegate>frame
2005-09-25 01:16:35 -04:00
[ set-outliner-quot ] keep
2006-06-07 23:04:37 -04:00
[ >r 1array make-shelf r> @top grid-add ] keep
2005-09-27 14:12:17 -04:00
f over set-outliner-expanded? ;