1 ! Copyright (C) 2005, 2009 Slava Pestov.
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: accessors arrays colors.constants combinators fonts
4 kernel make math.functions models namespaces sequences splitting
5 strings ui.baseline-alignment ui.gadgets ui.gadgets.tracks
6 ui.pens.solid ui.render ui.text ;
9 ! A label gadget draws a string.
10 TUPLE: label < aligned-gadget text font ;
14 M: label string>> ( label -- string )
15 text>> dup string? [ "\n" join ] unless ; inline
19 PREDICATE: string-array < array [ string? ] all? ;
23 : ?string-lines ( string -- string/array )
24 CHAR: \n over member-eq? [ string-lines ] when ;
26 ERROR: not-a-string object ;
28 M: label string<< ( string label -- )
31 { [ dup string-array? ] [ ] }
32 { [ dup string? ] [ ?string-lines ] }
35 ] dip [ text<< ] [ relayout ] bi ; inline
37 : label-theme ( gadget -- gadget )
38 sans-serif-font >>font ; inline
40 : new-label ( string class -- label )
45 : <label> ( string -- label )
48 : >label< ( label -- font text )
49 [ font>> ] [ text>> ] bi ; inline
56 : label-metrics ( label -- metrics )
57 >label< dup string? [ first ] unless line-metrics ;
62 label-metrics ascent>> round ;
65 label-metrics cap-height>> round ;
70 background get [ font-with-background ] when*
71 foreground get [ font-with-foreground ] when*
75 M: label gadget-text* string>> % ;
77 TUPLE: label-control < label ;
79 M: label-control model-changed
80 [ value>> ] [ string<< ] bi* ;
82 : <label-control> ( model -- gadget )
83 "" label-control new-label
86 : text-theme ( gadget -- gadget )
87 monospace-font >>font ;
89 : reverse-video-theme ( label -- label )
90 sans-serif-font reverse-video-font >>font
91 COLOR: black <solid> >>interior ;
93 GENERIC: >label ( obj -- gadget )
94 M: string >label <label> ;
95 M: array >label <label> ;
97 M: f >label drop <gadget> ;
101 : label-on-left/right ( -- track )
105 { 5 5 } >>gap ; inline
108 : label-on-left ( gadget label -- track )
110 swap >label f track-add
113 : label-on-right ( label gadget -- track )
116 swap >label 1 track-add ;