! Copyright (C) 2008 Slava Pestov ! See http://factorcode.org/license.txt for BSD license. USING: accessors kernel namespaces io math.parser assocs classes classes.tuple words arrays sequences splitting mirrors hashtables combinators continuations math strings inspector fry locals calendar calendar.format xml.entities validators urls present xmode.code2html lcs.diff2html farkup html.elements html.streams html.forms ; IN: html.components GENERIC: render* ( value name renderer -- ) : render ( name renderer -- ) prepare-value [ dup validation-error? [ [ message>> ] [ value>> ] bi ] [ f swap ] if ] 2dip render* [ render-error ] when* ; ; PRIVATE> SINGLETON: label M: label render* 2drop present escape-string write ; SINGLETON: hidden M: hidden render* drop "hidden" render-input ; : render-field ( value name size type -- ) ; TUPLE: field size ; : ( -- field ) field new ; M: field render* size>> "text" render-field ; TUPLE: password size ; : ( -- password ) password new ; M: password render* #! Don't send passwords back to the user [ drop "" ] 2dip size>> "password" render-field ; ! Text areas TUPLE: textarea rows cols ; : ; ! Choice TUPLE: choice size multiple choices ; : ( -- choice ) choice new ; : render-option ( text selected? -- ) ; : render-options ( options selected -- ) '[ dup _ member? render-option ] each ; M: choice render* ; ! Checkboxes TUPLE: checkbox label ; : ( -- checkbox ) checkbox new ; M: checkbox render* label>> escape-string write ; ! Link components GENERIC: link-title ( obj -- string ) GENERIC: link-href ( obj -- url ) M: string link-title ; M: string link-href ; M: url link-title ; M: url link-href ; TUPLE: link target ; M: link render* nip > [ =target ] when* dup link-href =href a> link-title present escape-string write ; ! XMode code component TUPLE: code mode ; : ( -- code ) code new ; M: code render* [ string-lines ] [ drop ] [ mode>> value ] tri* htmlize-lines ; ! Farkup component TUPLE: farkup no-follow disable-images parsed ; : ( -- farkup ) farkup new ; : string>boolean ( string -- boolean ) { { "true" [ t ] } { "false" [ f ] } { f [ f ] } } case ; M: farkup render* [ nip [ no-follow>> [ string>boolean link-no-follow? set ] when* ] [ disable-images>> [ string>boolean disable-images? set ] when* ] [ parsed>> string>boolean [ (write-farkup) ] [ write-farkup ] if ] tri ] with-scope ; ! Inspector component SINGLETON: inspector M: inspector render* 2drop [ describe ] with-html-writer ; ! Diff component SINGLETON: comparison M: comparison render* 2drop htmlize-diff ; ! HTML component SINGLETON: html M: html render* 2drop write ;