! 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 xml.writer xml.interpolate xml xmode.code2html lcs.diff2html farkup io.streams.string html.elements html.streams html.forms ; IN: html.components GENERIC: render* ( value name renderer -- xml ) : render ( name renderer -- ) prepare-value [ dup validation-error? [ [ message>> ] [ value>> ] bi ] [ f swap ] if ] 2dip render* write-xml-chunk [ render-error ] when* ; name=<-> type=<->/> XML] ; PRIVATE> SINGLETON: label M: label render* 2drop present ; SINGLETON: hidden M: hidden render* drop "hidden" render-input ; : render-field ( value name size type -- xml ) [XML name=<-> size=<-> type=<->/> XML] ; 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 ; : XML] ; ! Choice TUPLE: choice size multiple choices ; : ( -- choice ) choice new ; : render-option ( text selected? -- xml ) "selected" and swap [XML XML] ; : render-options ( value choice -- xml ) [ choices>> value ] [ multiple>> ] bi [ swap ] [ swap 1array ] if '[ dup _ member? render-option ] map ; M:: choice render* ( value name choice -- xml ) choice size>> :> size choice multiple>> "true" and :> multiple value choice render-options :> contents [XML XML] ; ! Checkboxes TUPLE: checkbox label ; : ( -- checkbox ) checkbox new ; M: checkbox render* [ "true" and ] [ ] [ label>> ] tri* [XML name=<->><-> XML] ; ! 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 swap [ target>> ] [ [ link-href ] [ link-title ] bi ] bi* [XML href=<->><-> XML] ; ! 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) ] [ farkup>xml ] if ] tri ] with-scope ; ! Inspector component SINGLETON: inspector M: inspector render* 2drop [ [ describe ] with-html-writer ] with-string-writer string>xml-chunk ; ! Diff component SINGLETON: comparison M: comparison render* 2drop htmlize-diff ; ! HTML component SINGLETON: html M: html render* 2drop string>xml-chunk ;