urbit/lib/react.hoon

139 lines
5.1 KiB
Plaintext
Raw Normal View History

2016-02-05 05:57:44 +03:00
::
2016-02-05 06:05:37 +03:00
:::: /hoon/react/lib
2016-02-05 05:57:44 +03:00
::
2016-02-18 02:36:43 +03:00
/? 310
2016-10-24 23:41:42 +03:00
=, markup
2015-05-20 06:29:04 +03:00
|%
++ react-elems :: XX /~
2016-01-30 05:25:52 +03:00
~+ %- silt ^- (list term)
2015-05-20 06:29:04 +03:00
:~ %a %abbr %address %area %article %aside %audio %b %base
%bdi %bdo %big %blockquote %body %br %button %canvas %caption
%cite %code %col %colgroup %data %datalist %dd %del %details
%dfn %dialog %div %dl %dt %em %embed %fieldset %figcaption
%figure %footer %form %h1 %h2 %h3 %h4 %h5 %h6 %head %header
%hr %html %i %iframe %img %input %ins %kbd %keygen %label
%legend %li %link %main %map %mark %menu %menuitem %meta
%meter %nav %noscript %object %ol %optgroup %option %output %p
%param %picture %pre %progress %q %rp %rt %ruby %s %samp
%script %section %select %small %source %span %strong %style
%sub %summary %sup %table %tbody %td %textarea %tfoot %th
%thead %time %title %tr %track %u %ul %var %video %wbr
%circle %defs %ellipse %g %line %linear-gradient %mask %path
%pattern %polygon %polyline %radial-gradient %rect %stop %svg
%text %tspan
==
++ react-attrs
~+ ^- (map term cord)
2016-01-30 05:25:52 +03:00
%- molt ^- (list (pair term cord))
:- [%class 'className']
2016-01-30 05:25:52 +03:00
=- (rash - (more next (cook |=(a/tape [(cass a) (crip a)]) (star alf))))
'''
accept acceptCharset accessKey action allowFullScreen allowTransparency alt
async autoComplete autoFocus autoPlay cellPadding cellSpacing charSet checked
classID className colSpan cols content contentEditable contextMenu controls
coords crossOrigin data dateTime defer dir disabled download draggable encType
form formAction formEncType formMethod formNoValidate formTarget frameBorder
headers height hidden high href hrefLang htmlFor httpEquiv icon id label lang
list loop low manifest marginHeight marginWidth max maxLength media mediaGroup
method min multiple muted name noValidate open optimum pattern placeholder
poster preload radioGroup readOnly rel required role rowSpan rows sandbox
scope scoped scrolling seamless selected shape size sizes span spellCheck
src srcDoc srcSet start step style tabIndex target title type useMap value
width wmode
'''
2015-06-11 21:55:02 +03:00
++ react-vale
2015-05-20 06:29:04 +03:00
~(has in react-elems)
::
++ react-to-json
|= src/manx ^- json
2016-01-30 05:25:52 +03:00
?: ?=(_;/(**) src)
(jape v.i.a.g.src)
2016-01-30 05:25:52 +03:00
=+ atr=(molt `(list (pair mane tape))`a.g.src)
2015-07-18 02:30:34 +03:00
?: (~(has by atr) [%urb %codemirror])
2016-01-30 05:25:52 +03:00
?> ?=({{$pre *} _;/(**) $~} src)
=. a.g.src
[value+v.i.a.g.i.c.src (skip a.g.src |=({a/mane *} ?=(^ a)))]
$(src [[%codemirror a.g.src] ~])
2015-07-18 02:30:34 +03:00
?: (~(has by atr) [%urb %exec]) :: runnable code attribute tag
2016-01-30 05:25:52 +03:00
?> ?=({{$pre *} _;/(**) $~} src) :: verify its only a text node
=* code v.i.a.g.i.c.src
%_ $
src
=+ =< result=(mule .)
!.(|.((slap !>(.) (ream (crip code))))) :: compile and run safely
=+ claz=?:(-.result "rancode" "failedcode")
;div(class "{claz}")
;pre:"{code}"
;+ ?: ?=($& -.result)
;code:"{~(ram re (sell p.result))}"
;pre
;div:"error"
;* %+ turn p.result
|= a/tank
^- manx
;div:"{~(ram re a)}"
== ==
==
%- jobe :~
c+a+(turn c.src ..$)
gn+s+(mane-to-cord n.g.src)
=< ga+(jobe (turn a.g.src .))
|= {a/mane b/tape} ^- {cord json}
:_ (jape b)
?^ a (mane-to-cord a)
(fall (~(get by react-attrs) a) a)
==
::
++ mane-to-cord |=(a/mane `cord`?@(a a (rap 3 -.a ':' +.a ~)))
:: generates React javascript XX deprecated
++ react-to-tape
|= src/manx ^- tape
2016-01-30 05:25:52 +03:00
?: (~(has by (molt `(list (pair mane tape))`a.g.src)) [%urb %codemirror])
?> ?=({{$pre *} _;/(**) $~} src)
2015-05-21 01:13:27 +03:00
$(src ;codemirror(value "{v.i.a.g.i.c.src}");)
2016-01-30 05:25:52 +03:00
?: (~(has by (molt `(list (pair mane tape))`a.g.src)) [%urb %exec])
?> ?=({{$pre *} _;/(**) $~} src) :: verify its only a text node
2015-06-11 21:55:02 +03:00
=* code v.i.a.g.i.c.src
=+ ^= result
(mule |.((slap !>(.) (ream (crip code))))) :: compile and run safely
?: ?=($.y -.result) :: it was ok
2015-06-11 21:55:02 +03:00
=+ ^= new
;div(class "rancode")
;pre:"{code}"
;code:"{~(ram re (sell p.result))}"
==
$(src new)
=+ ^= error
;div(class "failedcode")
;pre:"{code}"
;pre
;div:"error"
;* %+ turn
(scag (dec (lent p.result)) p.result) :: hide react trace
|= a/tank
2015-06-11 21:55:02 +03:00
^- manx
;div:"{~(ram re a)}"
==
==
$(src error)
2015-05-20 06:29:04 +03:00
;: weld
2016-01-30 05:25:52 +03:00
"React.createElement("
?^ n.g.src !! :: namespaces unsupported
2016-02-18 02:36:43 +03:00
?: (react-vale n.g.src)
2016-01-30 05:25:52 +03:00
"'{(trip n.g.src)}'"
(trip n.g.src)
2015-05-20 06:29:04 +03:00
", "
=- (pojo (jobe (turn a.g.src -)))
|= {a/mane b/tape}
=. a ?+(a a $class 'className')
?^(a !! [a (jape b)])
2015-05-20 06:29:04 +03:00
", "
2016-01-30 05:25:52 +03:00
=< ~(ram re %rose [", " "[" "]"] (turn c.src .))
|= a/manx
2016-01-30 05:25:52 +03:00
?: ?=(_;/(**) a)
leaf+(pojo (jape v.i.a.g.a))
leaf+^$(src a)
2015-05-20 06:29:04 +03:00
")"
==
--