]> gitweb.factorcode.org Git - factor.git/blob - basis/ui/gadgets/tracks/tracks.factor
Merge branch 'master' into experimental (untested!)
[factor.git] / basis / ui / gadgets / tracks / tracks.factor
1 ! Copyright (C) 2006, 2008 Slava Pestov.
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: accessors io kernel namespaces fry
4 math math.vectors math.geometry.rect math.order
5 sequences words ui.gadgets ui.gadgets.packs ;
6
7 IN: ui.gadgets.tracks
8
9 TUPLE: track < pack sizes ;
10
11 : normalized-sizes ( track -- seq )
12     sizes>> dup sift sum '[ dup [ _ / ] when ] map ;
13
14 : init-track ( track -- track )
15     init-gadget
16     V{ } clone >>sizes
17     1 >>fill ;
18
19 : new-track ( orientation class -- track )
20     new
21         init-track
22         swap >>orientation ;
23
24 : <track> ( orientation -- track ) track new-track ;
25
26 : alloted-dim ( track -- dim )
27     [ children>> ] [ sizes>> ] bi { 0 0 }
28     [ [ drop { 0 0 } ] [ pref-dim ] if v+ ] 2reduce ;
29
30 : available-dim ( track -- dim ) [ dim>> ] [ alloted-dim ] bi v- ;
31
32 : track-layout ( track -- sizes )
33     [ available-dim ] [ children>> ] [ normalized-sizes ] tri
34     [ [ over n*v ] [ pref-dim ] ?if ] 2map nip ;
35
36 M: track layout* ( track -- ) dup track-layout pack-layout ;
37
38 : track-pref-dims-1 ( track -- dim )
39     children>> pref-dims max-dim ;
40
41 : track-pref-dims-2 ( track -- dim )
42     [
43         [ children>> pref-dims ] [ normalized-sizes ] bi
44         [ dup { 0 f } memq? [ drop ] [ v/n ] if ] 2map
45         max-dim [ >fixnum ] map
46     ]
47     [ [ gap>> ] [ children>> length 1 [-] ] bi v*n ] bi
48     v+ ;
49
50 M: track pref-dim* ( gadget -- dim )
51     [ track-pref-dims-1 ]
52     [ [ alloted-dim ] [ track-pref-dims-2 ] bi v+ ]
53     [ orientation>> ]
54     tri
55     set-axis ;
56
57 : track-add ( track gadget constraint -- track )
58     pick sizes>> push add-gadget ;
59
60 : track-remove ( track gadget -- track )
61     dupd dup [
62         [ swap children>> index ]
63         [ unparent sizes>> ] 2bi
64         delete-nth 
65     ] [ 2drop ] if ;
66
67 : clear-track ( track -- ) V{ } clone >>sizes clear-gadget ;