Skip to content
Toggle navigation
Toggle navigation
This project
Loading...
Sign in
brainfood
/
rivets
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Graphs
Network
Create a new issue
Commits
Issue Boards
Files
Commits
Network
Compare
Branches
Tags
615d3296
authored
2013-10-18 01:59:07 -0700
by
Michael Richards
Browse Files
Options
Browse Files
Tag
Download
Email Patches
Plain Diff
Build 0.6.1.
1 parent
ec20607f
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
22 additions
and
18 deletions
component.json
dist/rivets.js
dist/rivets.min.js
package.json
component.json
View file @
615d329
...
...
@@ -2,7 +2,7 @@
"name"
:
"rivets"
,
"repo"
:
"mikeric/rivets"
,
"description"
:
"Declarative data binding + templating solution."
,
"version"
:
"0.6.
0
"
,
"version"
:
"0.6.
1
"
,
"keywords"
:
[
"data binding"
,
"templating"
],
"scripts"
:
[
"dist/rivets.js"
],
"main"
:
"dist/rivets.js"
,
...
...
dist/rivets.js
View file @
615d329
// Rivets.js
// version: 0.6.
0
// version: 0.6.
1
// author: Michael Richards
// license: MIT
(
function
()
{
...
...
@@ -174,28 +174,22 @@
return
_this
.
bindings
.
push
(
new
Rivets
[
binding
](
_this
,
node
,
type
,
keypath
,
options
));
};
parse
=
function
(
node
)
{
var
attribute
,
attributes
,
binder
,
childNode
,
delimiters
,
identifier
,
n
,
parser
,
regexp
,
restTokens
,
startToken
,
text
,
token
,
tokens
,
type
,
value
,
_i
,
_j
,
_k
,
_l
,
_len
,
_len1
,
_len2
,
_len3
,
_len4
,
_m
,
_ref
,
_ref1
,
_ref2
,
_ref3
,
_ref4
,
_results
;
var
attribute
,
attributes
,
binder
,
childNode
,
delimiters
,
identifier
,
n
,
parser
,
regexp
,
text
,
token
,
tokens
,
type
,
value
,
_i
,
_j
,
_k
,
_l
,
_len
,
_len1
,
_len2
,
_len3
,
_len4
,
_m
,
_ref
,
_ref1
,
_ref2
,
_ref3
,
_ref4
,
_results
;
if
(
__indexOf
.
call
(
skipNodes
,
node
)
<
0
)
{
if
(
node
.
nodeType
===
Node
.
TEXT_NODE
)
{
parser
=
Rivets
.
TextTemplateParser
;
if
(
delimiters
=
_this
.
config
.
templateDelimiters
)
{
if
((
tokens
=
parser
.
parse
(
node
.
data
,
delimiters
)).
length
)
{
if
(
!
(
tokens
.
length
===
1
&&
tokens
[
0
].
type
===
parser
.
types
.
text
))
{
startToken
=
tokens
[
0
],
restTokens
=
2
<=
tokens
.
length
?
__slice
.
call
(
tokens
,
1
)
:
[];
node
.
data
=
startToken
.
value
;
if
(
startToken
.
type
===
0
)
{
node
.
data
=
startToken
.
value
;
}
else
{
buildBinding
(
'TextBinding'
,
node
,
null
,
startToken
.
value
);
}
for
(
_i
=
0
,
_len
=
restTokens
.
length
;
_i
<
_len
;
_i
++
)
{
token
=
restTokens
[
_i
];
for
(
_i
=
0
,
_len
=
tokens
.
length
;
_i
<
_len
;
_i
++
)
{
token
=
tokens
[
_i
];
text
=
document
.
createTextNode
(
token
.
value
);
node
.
parentNode
.
appendChild
(
text
);
node
.
parentNode
.
insertBefore
(
text
,
node
);
if
(
token
.
type
===
1
)
{
buildBinding
(
'TextBinding'
,
text
,
null
,
token
.
value
);
}
}
node
.
parentNode
.
removeChild
(
node
);
}
}
}
...
...
@@ -240,7 +234,16 @@
}
}
}
_ref4
=
(
function
()
{
var
_len4
,
_n
,
_ref4
,
_results1
;
_ref4
=
node
.
childNodes
;
_results1
=
[];
for
(
_n
=
0
,
_len4
=
_ref4
.
length
;
_n
<
_len4
;
_n
++
)
{
n
=
_ref4
[
_n
];
_results1
.
push
(
n
);
}
return
_results1
;
})();
_results
=
[];
for
(
_m
=
0
,
_len4
=
_ref4
.
length
;
_m
<
_len4
;
_m
++
)
{
childNode
=
_ref4
[
_m
];
...
...
@@ -668,9 +671,10 @@
};
TextTemplateParser
.
parse
=
function
(
template
,
delimiters
)
{
var
index
,
lastIndex
,
lastToken
,
length
,
substring
,
tokens
,
value
;
var
delimiterOffset
,
index
,
lastIndex
,
lastToken
,
length
,
substring
,
tokens
,
value
;
tokens
=
[];
length
=
template
.
length
;
delimiterOffset
=
delimiters
[
1
].
length
;
index
=
0
;
lastIndex
=
0
;
while
(
lastIndex
<
length
)
{
...
...
@@ -708,7 +712,7 @@
type
:
this
.
types
.
binding
,
value
:
value
});
lastIndex
=
index
+
2
;
lastIndex
=
index
+
delimiterOffset
;
}
}
return
tokens
;
...
...
dist/rivets.min.js
View file @
615d329
// Rivets.js
// version: 0.6.
0
// version: 0.6.
1
// author: Michael Richards
// license: MIT
(
function
(){
var
a
,
b
,
c
=
function
(
a
,
b
){
return
function
(){
return
a
.
apply
(
b
,
arguments
)}},
d
=
[].
indexOf
||
function
(
a
){
for
(
var
b
=
0
,
c
=
this
.
length
;
c
>
b
;
b
++
)
if
(
b
in
this
&&
this
[
b
]
===
a
)
return
b
;
return
-
1
},
e
=
[].
slice
,
f
=
{}.
hasOwnProperty
,
g
=
function
(
a
,
b
){
function
c
(){
this
.
constructor
=
a
}
for
(
var
d
in
b
)
f
.
call
(
b
,
d
)
&&
(
a
[
d
]
=
b
[
d
]);
return
c
.
prototype
=
b
.
prototype
,
a
.
prototype
=
new
c
,
a
.
__super__
=
b
.
prototype
,
a
};
b
=
{
binders
:{},
components
:{},
formatters
:{},
adapters
:{},
config
:{
prefix
:
"rv"
,
templateDelimiters
:[
"{"
,
"}"
],
rootInterface
:
"."
,
preloadData
:
!
0
,
handler
:
function
(
a
,
b
,
c
){
return
this
.
call
(
a
,
b
,
c
.
view
.
models
)}}},
b
.
Util
=
{
bindEvent
:
function
(
a
,
b
,
c
){
return
null
!=
window
.
jQuery
?(
a
=
jQuery
(
a
),
null
!=
a
.
on
?
a
.
on
(
b
,
c
):
a
.
bind
(
b
,
c
)):
null
!=
window
.
addEventListener
?
a
.
addEventListener
(
b
,
c
,
!
1
):(
b
=
"on"
+
b
,
a
.
attachEvent
(
b
,
c
))},
unbindEvent
:
function
(
a
,
b
,
c
){
return
null
!=
window
.
jQuery
?(
a
=
jQuery
(
a
),
null
!=
a
.
off
?
a
.
off
(
b
,
c
):
a
.
unbind
(
b
,
c
)):
null
!=
window
.
removeEventListener
?
a
.
removeEventListener
(
b
,
c
,
!
1
):(
b
=
"on"
+
b
,
a
.
detachEvent
(
b
,
c
))},
getInputValue
:
function
(
a
){
var
b
,
c
,
d
,
e
;
if
(
null
!=
window
.
jQuery
)
switch
(
a
=
jQuery
(
a
),
a
[
0
].
type
){
case
"checkbox"
:
return
a
.
is
(
":checked"
);
default
:
return
a
.
val
()}
else
switch
(
a
.
type
){
case
"checkbox"
:
return
a
.
checked
;
case
"select-multiple"
:
for
(
e
=
[],
c
=
0
,
d
=
a
.
length
;
d
>
c
;
c
++
)
b
=
a
[
c
],
b
.
selected
&&
e
.
push
(
b
.
value
);
return
e
;
default
:
return
a
.
value
}}},
b
.
View
=
function
(){
function
a
(
a
,
d
,
e
){
var
f
,
g
,
h
,
i
,
j
,
k
,
l
,
m
,
n
;
for
(
this
.
els
=
a
,
this
.
models
=
d
,
this
.
options
=
null
!=
e
?
e
:{},
this
.
update
=
c
(
this
.
update
,
this
),
this
.
publish
=
c
(
this
.
publish
,
this
),
this
.
sync
=
c
(
this
.
sync
,
this
),
this
.
unbind
=
c
(
this
.
unbind
,
this
),
this
.
bind
=
c
(
this
.
bind
,
this
),
this
.
select
=
c
(
this
.
select
,
this
),
this
.
build
=
c
(
this
.
build
,
this
),
this
.
componentRegExp
=
c
(
this
.
componentRegExp
,
this
),
this
.
bindingRegExp
=
c
(
this
.
bindingRegExp
,
this
),
this
.
els
.
jquery
||
this
.
els
instanceof
Array
||
(
this
.
els
=
[
this
.
els
]),
l
=
[
"config"
,
"binders"
,
"formatters"
,
"adapters"
],
j
=
0
,
k
=
l
.
length
;
k
>
j
;
j
++
){
if
(
g
=
l
[
j
],
this
[
g
]
=
{},
this
.
options
[
g
]){
m
=
this
.
options
[
g
];
for
(
f
in
m
)
h
=
m
[
f
],
this
[
g
][
f
]
=
h
}
n
=
b
[
g
];
for
(
f
in
n
)
h
=
n
[
f
],
null
==
(
i
=
this
[
g
])[
f
]
&&
(
i
[
f
]
=
h
)}
this
.
build
()}
return
a
.
prototype
.
bindingRegExp
=
function
(){
return
new
RegExp
(
"^"
+
this
.
config
.
prefix
+
"-"
)},
a
.
prototype
.
componentRegExp
=
function
(){
return
new
RegExp
(
"^"
+
this
.
config
.
prefix
.
toUpperCase
()
+
"-"
)},
a
.
prototype
.
build
=
function
(){
var
a
,
c
,
f
,
g
,
h
,
i
,
j
,
k
,
l
,
m
=
this
;
for
(
this
.
bindings
=
[],
i
=
[],
a
=
this
.
bindingRegExp
(),
f
=
this
.
componentRegExp
(),
c
=
function
(
a
,
c
,
d
,
e
){
var
f
,
g
,
h
,
i
,
j
,
k
,
l
;
return
j
=
{},
l
=
function
(){
var
a
,
b
,
c
,
d
;
for
(
c
=
e
.
split
(
"|"
),
d
=
[],
a
=
0
,
b
=
c
.
length
;
b
>
a
;
a
++
)
k
=
c
[
a
],
d
.
push
(
k
.
trim
());
return
d
}(),
f
=
function
(){
var
a
,
b
,
c
,
d
;
for
(
c
=
l
.
shift
().
split
(
"<"
),
d
=
[],
a
=
0
,
b
=
c
.
length
;
b
>
a
;
a
++
)
g
=
c
[
a
],
d
.
push
(
g
.
trim
());
return
d
}(),
i
=
f
.
shift
(),
j
.
formatters
=
l
,(
h
=
f
.
shift
())
&&
(
j
.
dependencies
=
h
.
split
(
/
\s
+/
)),
m
.
bindings
.
push
(
new
b
[
a
](
m
,
c
,
d
,
i
,
j
))},
h
=
function
(
g
){
var
j
,
k
,
l
,
n
,
o
,
p
,
q
,
r
,
s
,
t
,
u
,
v
,
w
,
x
,
y
,
z
,
A
,
B
,
C
,
D
,
E
,
F
,
G
,
H
,
I
,
J
,
K
,
L
,
M
,
N
,
O
,
P
;
if
(
d
.
call
(
i
,
g
)
<
0
){
if
(
g
.
nodeType
===
Node
.
TEXT_NODE
){
if
(
r
=
b
.
TextTemplateParser
,(
o
=
m
.
config
.
templateDelimiters
)
&&
(
x
=
r
.
parse
(
g
.
data
,
o
)).
length
&&
(
1
!==
x
.
length
||
x
[
0
].
type
!==
r
.
types
.
text
))
for
(
u
=
x
[
0
],
t
=
2
<=
x
.
length
?
e
.
call
(
x
,
1
):[],
g
.
data
=
u
.
value
,
0
===
u
.
type
?
g
.
data
=
u
.
value
:
c
(
"TextBinding"
,
g
,
null
,
u
.
value
),
A
=
0
,
E
=
t
.
length
;
E
>
A
;
A
++
)
w
=
t
[
A
],
v
=
document
.
createTextNode
(
w
.
value
),
g
.
parentNode
.
appendChild
(
v
),
1
===
w
.
type
&&
c
(
"TextBinding"
,
v
,
null
,
w
.
value
)}
else
if
(
f
.
test
(
g
.
tagName
))
y
=
g
.
tagName
.
replace
(
f
,
""
).
toLowerCase
(),
m
.
bindings
.
push
(
new
b
.
ComponentBinding
(
m
,
g
,
y
));
else
if
(
null
!=
g
.
attributes
){
for
(
K
=
g
.
attributes
,
B
=
0
,
F
=
K
.
length
;
F
>
B
;
B
++
)
if
(
j
=
K
[
B
],
a
.
test
(
j
.
name
)){
if
(
y
=
j
.
name
.
replace
(
a
,
""
),
!
(
l
=
m
.
binders
[
y
])){
L
=
m
.
binders
;
for
(
p
in
L
)
z
=
L
[
p
],
"*"
!==
p
&&-
1
!==
p
.
indexOf
(
"*"
)
&&
(
s
=
new
RegExp
(
"^"
+
p
.
replace
(
"*"
,
".+"
)
+
"$"
),
s
.
test
(
y
)
&&
(
l
=
z
))}
if
(
l
||
(
l
=
m
.
binders
[
"*"
]),
l
.
block
){
for
(
M
=
g
.
childNodes
,
C
=
0
,
G
=
M
.
length
;
G
>
C
;
C
++
)
q
=
M
[
C
],
i
.
push
(
q
);
k
=
[
j
]}}
for
(
N
=
k
||
g
.
attributes
,
D
=
0
,
H
=
N
.
length
;
H
>
D
;
D
++
)
j
=
N
[
D
],
a
.
test
(
j
.
name
)
&&
(
y
=
j
.
name
.
replace
(
a
,
""
),
c
(
"Binding"
,
g
,
y
,
j
.
value
))}
for
(
O
=
g
.
childNodes
,
P
=
[],
J
=
0
,
I
=
O
.
length
;
I
>
J
;
J
++
)
n
=
O
[
J
],
P
.
push
(
h
(
n
));
return
P
}},
l
=
this
.
els
,
j
=
0
,
k
=
l
.
length
;
k
>
j
;
j
++
)
g
=
l
[
j
],
h
(
g
)},
a
.
prototype
.
select
=
function
(
a
){
var
b
,
c
,
d
,
e
,
f
;
for
(
e
=
this
.
bindings
,
f
=
[],
c
=
0
,
d
=
e
.
length
;
d
>
c
;
c
++
)
b
=
e
[
c
],
a
(
b
)
&&
f
.
push
(
b
);
return
f
},
a
.
prototype
.
bind
=
function
(){
var
a
,
b
,
c
,
d
,
e
;
for
(
d
=
this
.
bindings
,
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
bind
());
return
e
},
a
.
prototype
.
unbind
=
function
(){
var
a
,
b
,
c
,
d
,
e
;
for
(
d
=
this
.
bindings
,
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
unbind
());
return
e
},
a
.
prototype
.
sync
=
function
(){
var
a
,
b
,
c
,
d
,
e
;
for
(
d
=
this
.
bindings
,
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
sync
());
return
e
},
a
.
prototype
.
publish
=
function
(){
var
a
,
b
,
c
,
d
,
e
;
for
(
d
=
this
.
select
(
function
(
a
){
return
a
.
binder
.
publishes
}),
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
publish
());
return
e
},
a
.
prototype
.
update
=
function
(
a
){
var
b
,
c
,
d
,
e
,
f
,
g
,
h
;
null
==
a
&&
(
a
=
{});
for
(
c
in
a
)
d
=
a
[
c
],
this
.
models
[
c
]
=
d
;
for
(
g
=
this
.
bindings
,
h
=
[],
e
=
0
,
f
=
g
.
length
;
f
>
e
;
e
++
)
b
=
g
[
e
],
h
.
push
(
b
.
update
(
a
));
return
h
},
a
}(),
b
.
Binding
=
function
(){
function
d
(
a
,
b
,
d
,
e
,
f
){
this
.
view
=
a
,
this
.
el
=
b
,
this
.
type
=
d
,
this
.
keypath
=
e
,
this
.
options
=
null
!=
f
?
f
:{},
this
.
update
=
c
(
this
.
update
,
this
),
this
.
unbind
=
c
(
this
.
unbind
,
this
),
this
.
bind
=
c
(
this
.
bind
,
this
),
this
.
publish
=
c
(
this
.
publish
,
this
),
this
.
sync
=
c
(
this
.
sync
,
this
),
this
.
set
=
c
(
this
.
set
,
this
),
this
.
eventHandler
=
c
(
this
.
eventHandler
,
this
),
this
.
formattedValue
=
c
(
this
.
formattedValue
,
this
),
this
.
setObserver
=
c
(
this
.
setObserver
,
this
),
this
.
setBinder
=
c
(
this
.
setBinder
,
this
),
this
.
formatters
=
this
.
options
.
formatters
||
[],
this
.
dependencies
=
[],
this
.
setBinder
(),
this
.
setObserver
()}
return
d
.
prototype
.
setBinder
=
function
(){
var
a
,
b
,
c
,
d
;
if
(
!
(
this
.
binder
=
this
.
view
.
binders
[
this
.
type
])){
d
=
this
.
view
.
binders
;
for
(
a
in
d
)
c
=
d
[
a
],
"*"
!==
a
&&-
1
!==
a
.
indexOf
(
"*"
)
&&
(
b
=
new
RegExp
(
"^"
+
a
.
replace
(
"*"
,
".+"
)
+
"$"
),
b
.
test
(
this
.
type
)
&&
(
this
.
binder
=
c
,
this
.
args
=
new
RegExp
(
"^"
+
a
.
replace
(
"*"
,
"(.+)"
)
+
"$"
).
exec
(
this
.
type
),
this
.
args
.
shift
()))}
return
this
.
binder
||
(
this
.
binder
=
this
.
view
.
binders
[
"*"
]),
this
.
binder
instanceof
Function
?
this
.
binder
=
{
routine
:
this
.
binder
}:
void
0
},
d
.
prototype
.
setObserver
=
function
(){
var
b
=
this
;
return
this
.
observer
=
new
a
(
this
.
view
,
this
.
view
.
models
,
this
.
keypath
,
function
(
a
){
return
b
.
key
&&
b
.
unbind
(
!
0
),
b
.
model
=
a
.
target
,
b
.
key
&&
b
.
bind
(
!
0
),
b
.
sync
()}),
this
.
key
=
this
.
observer
.
key
,
this
.
model
=
this
.
observer
.
target
},
d
.
prototype
.
formattedValue
=
function
(
a
){
var
b
,
c
,
d
,
f
,
g
,
h
;
for
(
h
=
this
.
formatters
,
f
=
0
,
g
=
h
.
length
;
g
>
f
;
f
++
)
c
=
h
[
f
],
b
=
c
.
split
(
/
\s
+/
),
d
=
b
.
shift
(),
c
=
this
.
view
.
formatters
[
d
],(
null
!=
c
?
c
.
read
:
void
0
)
instanceof
Function
?
a
=
c
.
read
.
apply
(
c
,[
a
].
concat
(
e
.
call
(
b
))):
c
instanceof
Function
&&
(
a
=
c
.
apply
(
null
,[
a
].
concat
(
e
.
call
(
b
))));
return
a
},
d
.
prototype
.
eventHandler
=
function
(
a
){
var
b
,
c
;
return
c
=
(
b
=
this
).
view
.
config
.
handler
,
function
(
d
){
return
c
.
call
(
a
,
this
,
d
,
b
)}},
d
.
prototype
.
set
=
function
(
a
){
var
b
;
return
a
=
a
instanceof
Function
&&!
this
.
binder
[
"function"
]?
this
.
formattedValue
(
a
.
call
(
this
.
model
)):
this
.
formattedValue
(
a
),
null
!=
(
b
=
this
.
binder
.
routine
)?
b
.
call
(
this
,
this
.
el
,
a
):
void
0
},
d
.
prototype
.
sync
=
function
(){
return
this
.
set
(
this
.
key
?
this
.
view
.
adapters
[
this
.
key
[
"interface"
]].
read
(
this
.
model
,
this
.
key
.
path
):
this
.
model
)},
d
.
prototype
.
publish
=
function
(){
var
a
,
c
,
d
,
f
,
g
,
h
,
i
,
j
,
k
;
for
(
f
=
b
.
Util
.
getInputValue
(
this
.
el
),
i
=
this
.
formatters
.
slice
(
0
).
reverse
(),
g
=
0
,
h
=
i
.
length
;
h
>
g
;
g
++
)
c
=
i
[
g
],
a
=
c
.
split
(
/
\s
+/
),
d
=
a
.
shift
(),(
null
!=
(
j
=
this
.
view
.
formatters
[
d
])?
j
.
publish
:
void
0
)
&&
(
f
=
(
k
=
this
.
view
.
formatters
[
d
]).
publish
.
apply
(
k
,[
f
].
concat
(
e
.
call
(
a
))));
return
this
.
view
.
adapters
[
this
.
key
[
"interface"
]].
publish
(
this
.
model
,
this
.
key
.
path
,
f
)},
d
.
prototype
.
bind
=
function
(
b
){
var
c
,
d
,
e
,
f
,
g
,
h
,
i
,
j
,
k
,
l
=
this
;
if
(
null
==
b
&&
(
b
=!
1
),
b
||
null
!=
(
h
=
this
.
binder
.
bind
)
&&
h
.
call
(
this
,
this
.
el
),
this
.
key
&&
this
.
view
.
adapters
[
this
.
key
[
"interface"
]].
subscribe
(
this
.
model
,
this
.
key
.
path
,
this
.
sync
),(
b
?
void
0
:
this
.
view
.
config
.
preloadData
)
&&
this
.
sync
(),
null
!=
(
i
=
this
.
options
.
dependencies
)?
i
.
length
:
void
0
){
for
(
j
=
this
.
options
.
dependencies
,
k
=
[],
f
=
0
,
g
=
j
.
length
;
g
>
f
;
f
++
)
c
=
j
[
f
],
e
=
new
a
(
this
.
view
,
this
.
model
,
c
,
function
(
a
,
b
){
var
c
;
return
c
=
a
.
key
,
l
.
view
.
adapters
[
c
[
"interface"
]].
unsubscribe
(
b
,
c
.
path
,
l
.
sync
),
l
.
view
.
adapters
[
c
[
"interface"
]].
subscribe
(
a
.
target
,
c
.
path
,
l
.
sync
),
l
.
sync
()}),
d
=
e
.
key
,
this
.
view
.
adapters
[
d
[
"interface"
]].
subscribe
(
e
.
target
,
d
.
path
,
this
.
sync
),
k
.
push
(
this
.
dependencies
.
push
(
e
));
return
k
}},
d
.
prototype
.
unbind
=
function
(
a
){
var
b
,
c
,
d
,
e
,
f
,
g
;
if
(
null
==
a
&&
(
a
=!
1
),
a
||
null
!=
(
f
=
this
.
binder
.
unbind
)
&&
f
.
call
(
this
,
this
.
el
),
this
.
key
&&
this
.
view
.
adapters
[
this
.
key
[
"interface"
]].
unsubscribe
(
this
.
model
,
this
.
key
.
path
,
this
.
sync
),
this
.
dependencies
.
length
){
for
(
g
=
this
.
dependencies
,
d
=
0
,
e
=
g
.
length
;
e
>
d
;
d
++
)
c
=
g
[
d
],
b
=
c
.
key
,
this
.
view
.
adapters
[
b
[
"interface"
]].
unsubscribe
(
c
.
target
,
b
.
path
,
this
.
sync
);
return
this
.
dependencies
=
[]}},
d
.
prototype
.
update
=
function
(
a
){
var
b
;
return
null
==
a
&&
(
a
=
{}),
null
!=
(
b
=
this
.
binder
.
update
)?
b
.
call
(
this
,
a
):
void
0
},
d
}(),
b
.
ComponentBinding
=
function
(
a
){
function
e
(
a
,
e
,
f
){
var
g
,
h
,
i
,
j
,
k
;
for
(
this
.
view
=
a
,
this
.
el
=
e
,
this
.
type
=
f
,
this
.
unbind
=
c
(
this
.
unbind
,
this
),
this
.
bind
=
c
(
this
.
bind
,
this
),
this
.
update
=
c
(
this
.
update
,
this
),
this
.
locals
=
c
(
this
.
locals
,
this
),
this
.
component
=
b
.
components
[
this
.
type
],
this
.
attributes
=
{},
this
.
inflections
=
{},
j
=
this
.
el
.
attributes
||
[],
h
=
0
,
i
=
j
.
length
;
i
>
h
;
h
++
)
g
=
j
[
h
],
k
=
g
.
name
,
d
.
call
(
this
.
component
.
attributes
,
k
)
>=
0
?
this
.
attributes
[
g
.
name
]
=
g
.
value
:
this
.
inflections
[
g
.
name
]
=
g
.
value
}
return
g
(
e
,
a
),
e
.
prototype
.
sync
=
function
(){},
e
.
prototype
.
locals
=
function
(
a
){
var
b
,
c
,
d
,
e
,
f
,
g
,
h
,
i
,
j
;
null
==
a
&&
(
a
=
this
.
view
.
models
),
f
=
{},
i
=
this
.
inflections
;
for
(
c
in
i
)
for
(
b
=
i
[
c
],
j
=
b
.
split
(
"."
),
g
=
0
,
h
=
j
.
length
;
h
>
g
;
g
++
)
e
=
j
[
g
],
f
[
c
]
=
(
f
[
c
]
||
a
)[
e
];
for
(
c
in
a
)
d
=
a
[
c
],
null
==
f
[
c
]
&&
(
f
[
c
]
=
d
);
return
f
},
e
.
prototype
.
update
=
function
(
a
){
var
b
;
return
null
!=
(
b
=
this
.
componentView
)?
b
.
update
(
this
.
locals
(
a
)):
void
0
},
e
.
prototype
.
bind
=
function
(){
var
a
,
c
;
return
null
!=
this
.
componentView
?
null
!=
(
c
=
this
.
componentView
)?
c
.
bind
():
void
0
:(
a
=
this
.
component
.
build
.
call
(
this
.
attributes
),(
this
.
componentView
=
new
b
.
View
(
a
,
this
.
locals
(),
this
.
view
.
options
)).
bind
(),
this
.
el
.
parentNode
.
replaceChild
(
a
,
this
.
el
))},
e
.
prototype
.
unbind
=
function
(){
var
a
;
return
null
!=
(
a
=
this
.
componentView
)?
a
.
unbind
():
void
0
},
e
}(
b
.
Binding
),
b
.
TextBinding
=
function
(
a
){
function
b
(
a
,
b
,
d
,
e
,
f
){
this
.
view
=
a
,
this
.
el
=
b
,
this
.
type
=
d
,
this
.
keypath
=
e
,
this
.
options
=
null
!=
f
?
f
:{},
this
.
sync
=
c
(
this
.
sync
,
this
),
this
.
formatters
=
this
.
options
.
formatters
||
[],
this
.
dependencies
=
[],
this
.
setObserver
()}
return
g
(
b
,
a
),
b
.
prototype
.
binder
=
{
routine
:
function
(
a
,
b
){
return
a
.
data
=
null
!=
b
?
b
:
""
}},
b
.
prototype
.
sync
=
function
(){
return
b
.
__super__
.
sync
.
apply
(
this
,
arguments
)},
b
}(
b
.
Binding
),
b
.
KeypathParser
=
function
(){
function
a
(){}
return
a
.
parse
=
function
(
a
,
b
,
c
){
var
e
,
f
,
g
,
h
;
h
=
[],
f
=
{
"interface"
:
c
,
path
:
""
};
for
(
g
in
a
)
e
=
a
[
g
],
d
.
call
(
b
,
e
)
>=
0
?(
h
.
push
(
f
),
f
=
{
"interface"
:
e
,
path
:
""
}):
f
.
path
+=
e
;
return
h
.
push
(
f
),
h
},
a
}(),
b
.
TextTemplateParser
=
function
(){
function
a
(){}
return
a
.
types
=
{
text
:
0
,
binding
:
1
},
a
.
parse
=
function
(
a
,
b
){
var
c
,
d
,
e
,
f
,
g
,
h
,
i
;
for
(
h
=
[],
f
=
a
.
length
,
c
=
0
,
d
=
0
;
f
>
d
;){
if
(
c
=
a
.
indexOf
(
b
[
0
],
d
),
0
>
c
){
h
.
push
({
type
:
this
.
types
.
text
,
value
:
a
.
slice
(
d
)});
break
}
if
(
c
>
0
&&
c
>
d
&&
h
.
push
({
type
:
this
.
types
.
text
,
value
:
a
.
slice
(
d
,
c
)}),
d
=
c
+
2
,
c
=
a
.
indexOf
(
b
[
1
],
d
),
0
>
c
){
g
=
a
.
slice
(
d
-
2
),
e
=
h
[
h
.
length
-
1
],(
null
!=
e
?
e
.
type
:
void
0
)
===
this
.
types
.
text
?
e
.
value
+=
g
:
h
.
push
({
type
:
this
.
types
.
text
,
value
:
g
});
break
}
i
=
a
.
slice
(
d
,
c
).
trim
(),
h
.
push
({
type
:
this
.
types
.
binding
,
value
:
i
}),
d
=
c
+
2
}
return
h
},
a
}(),
a
=
function
(){
function
a
(
a
,
b
,
d
,
e
){
this
.
view
=
a
,
this
.
model
=
b
,
this
.
keypath
=
d
,
this
.
callback
=
e
,
this
.
realize
=
c
(
this
.
realize
,
this
),
this
.
update
=
c
(
this
.
update
,
this
),
this
.
parse
=
c
(
this
.
parse
,
this
),
this
.
parse
(),
this
.
objectPath
=
[],
this
.
target
=
this
.
realize
()}
return
a
.
prototype
.
parse
=
function
(){
var
a
,
c
,
e
,
f
,
g
,
h
;
return
a
=
function
(){
var
a
,
b
;
a
=
this
.
view
.
adapters
,
b
=
[];
for
(
c
in
a
)
g
=
a
[
c
],
b
.
push
(
c
);
return
b
}.
call
(
this
),
h
=
this
.
keypath
[
0
],
d
.
call
(
a
,
h
)
>=
0
?(
f
=
this
.
keypath
[
0
],
e
=
this
.
keypath
.
substr
(
1
)):(
f
=
this
.
view
.
config
.
rootInterface
,
e
=
this
.
keypath
),
this
.
tokens
=
b
.
KeypathParser
.
parse
(
e
,
a
,
f
),
this
.
key
=
this
.
tokens
.
pop
()},
a
.
prototype
.
update
=
function
(){
var
a
,
b
;
return
(
a
=
this
.
realize
())
!==
this
.
target
?(
b
=
this
.
target
,
this
.
target
=
a
,
this
.
callback
(
this
,
b
)):
void
0
},
a
.
prototype
.
realize
=
function
(){
var
a
,
b
,
c
,
d
,
e
,
f
,
g
;
for
(
a
=
this
.
model
,
g
=
this
.
tokens
,
b
=
e
=
0
,
f
=
g
.
length
;
f
>
e
;
b
=++
e
)
d
=
g
[
b
],
null
!=
this
.
objectPath
[
b
]?
a
!==
(
c
=
this
.
objectPath
[
b
])
&&
(
this
.
view
.
adapters
[
d
[
"interface"
]].
unsubscribe
(
c
,
d
.
path
,
this
.
update
),
this
.
view
.
adapters
[
d
[
"interface"
]].
subscribe
(
a
,
d
.
path
,
this
.
update
),
this
.
objectPath
[
b
]
=
a
):(
this
.
view
.
adapters
[
d
[
"interface"
]].
subscribe
(
a
,
d
.
path
,
this
.
update
),
this
.
objectPath
[
b
]
=
a
),
a
=
this
.
view
.
adapters
[
d
[
"interface"
]].
read
(
a
,
d
.
path
);
return
a
},
a
}(),
b
.
binders
.
enabled
=
function
(
a
,
b
){
return
a
.
disabled
=!
b
},
b
.
binders
.
disabled
=
function
(
a
,
b
){
return
a
.
disabled
=!!
b
},
b
.
binders
.
checked
=
{
publishes
:
!
0
,
bind
:
function
(
a
){
return
b
.
Util
.
bindEvent
(
a
,
"change"
,
this
.
publish
)},
unbind
:
function
(
a
){
return
b
.
Util
.
unbindEvent
(
a
,
"change"
,
this
.
publish
)},
routine
:
function
(
a
,
b
){
var
c
;
return
a
.
checked
=
"radio"
===
a
.
type
?(
null
!=
(
c
=
a
.
value
)?
c
.
toString
():
void
0
)
===
(
null
!=
b
?
b
.
toString
():
void
0
):
!!
b
}},
b
.
binders
.
unchecked
=
{
publishes
:
!
0
,
bind
:
function
(
a
){
return
b
.
Util
.
bindEvent
(
a
,
"change"
,
this
.
publish
)},
unbind
:
function
(
a
){
return
b
.
Util
.
unbindEvent
(
a
,
"change"
,
this
.
publish
)},
routine
:
function
(
a
,
b
){
var
c
;
return
a
.
checked
=
"radio"
===
a
.
type
?(
null
!=
(
c
=
a
.
value
)?
c
.
toString
():
void
0
)
!==
(
null
!=
b
?
b
.
toString
():
void
0
):
!
b
}},
b
.
binders
.
show
=
function
(
a
,
b
){
return
a
.
style
.
display
=
b
?
""
:
"none"
},
b
.
binders
.
hide
=
function
(
a
,
b
){
return
a
.
style
.
display
=
b
?
"none"
:
""
},
b
.
binders
.
html
=
function
(
a
,
b
){
return
a
.
innerHTML
=
null
!=
b
?
b
:
""
},
b
.
binders
.
value
=
{
publishes
:
!
0
,
bind
:
function
(
a
){
return
b
.
Util
.
bindEvent
(
a
,
"change"
,
this
.
publish
)},
unbind
:
function
(
a
){
return
b
.
Util
.
unbindEvent
(
a
,
"change"
,
this
.
publish
)},
routine
:
function
(
a
,
b
){
var
c
,
e
,
f
,
g
,
h
,
i
,
j
;
if
(
null
!=
window
.
jQuery
){
if
(
a
=
jQuery
(
a
),(
null
!=
b
?
b
.
toString
():
void
0
)
!==
(
null
!=
(
g
=
a
.
val
())?
g
.
toString
():
void
0
))
return
a
.
val
(
null
!=
b
?
b
:
""
)}
else
if
(
"select-multiple"
===
a
.
type
){
if
(
null
!=
b
){
for
(
j
=
[],
e
=
0
,
f
=
a
.
length
;
f
>
e
;
e
++
)
c
=
a
[
e
],
j
.
push
(
c
.
selected
=
(
h
=
c
.
value
,
d
.
call
(
b
,
h
)
>=
0
));
return
j
}}
else
if
((
null
!=
b
?
b
.
toString
():
void
0
)
!==
(
null
!=
(
i
=
a
.
value
)?
i
.
toString
():
void
0
))
return
a
.
value
=
null
!=
b
?
b
:
""
}},
b
.
binders
.
text
=
function
(
a
,
b
){
return
null
!=
a
.
innerText
?
a
.
innerText
=
null
!=
b
?
b
:
""
:
a
.
textContent
=
null
!=
b
?
b
:
""
},
b
.
binders
[
"if"
]
=
{
block
:
!
0
,
bind
:
function
(
a
){
var
b
,
c
;
return
null
==
this
.
marker
?(
b
=
[
this
.
view
.
config
.
prefix
,
this
.
type
].
join
(
"-"
).
replace
(
"--"
,
"-"
),
c
=
a
.
getAttribute
(
b
),
this
.
marker
=
document
.
createComment
(
" rivets: "
+
this
.
type
+
" "
+
c
+
" "
),
a
.
removeAttribute
(
b
),
a
.
parentNode
.
insertBefore
(
this
.
marker
,
a
),
a
.
parentNode
.
removeChild
(
a
)):
void
0
},
unbind
:
function
(){
var
a
;
return
null
!=
(
a
=
this
.
nested
)?
a
.
unbind
():
void
0
},
routine
:
function
(
a
,
c
){
var
d
,
e
,
f
,
g
,
h
;
if
(
!!
c
==
(
null
==
this
.
nested
)){
if
(
c
){
f
=
{},
h
=
this
.
view
.
models
;
for
(
d
in
h
)
e
=
h
[
d
],
f
[
d
]
=
e
;
return
g
=
{
binders
:
this
.
view
.
options
.
binders
,
formatters
:
this
.
view
.
options
.
formatters
,
adapters
:
this
.
view
.
options
.
adapters
,
config
:
this
.
view
.
options
.
config
},(
this
.
nested
=
new
b
.
View
(
a
,
f
,
g
)).
bind
(),
this
.
marker
.
parentNode
.
insertBefore
(
a
,
this
.
marker
.
nextSibling
)}
return
a
.
parentNode
.
removeChild
(
a
),
this
.
nested
.
unbind
(),
delete
this
.
nested
}},
update
:
function
(
a
){
var
b
;
return
null
!=
(
b
=
this
.
nested
)?
b
.
update
(
a
):
void
0
}},
b
.
binders
.
unless
=
{
block
:
!
0
,
bind
:
function
(
a
){
return
b
.
binders
[
"if"
].
bind
.
call
(
this
,
a
)},
unbind
:
function
(){
return
b
.
binders
[
"if"
].
unbind
.
call
(
this
)},
routine
:
function
(
a
,
c
){
return
b
.
binders
[
"if"
].
routine
.
call
(
this
,
a
,
!
c
)},
update
:
function
(
a
){
return
b
.
binders
[
"if"
].
update
.
call
(
this
,
a
)}},
b
.
binders
[
"on-*"
]
=
{
"function"
:
!
0
,
unbind
:
function
(
a
){
return
this
.
handler
?
b
.
Util
.
unbindEvent
(
a
,
this
.
args
[
0
],
this
.
handler
):
void
0
},
routine
:
function
(
a
,
c
){
return
this
.
handler
&&
b
.
Util
.
unbindEvent
(
a
,
this
.
args
[
0
],
this
.
handler
),
b
.
Util
.
bindEvent
(
a
,
this
.
args
[
0
],
this
.
handler
=
this
.
eventHandler
(
c
))}},
b
.
binders
[
"each-*"
]
=
{
block
:
!
0
,
bind
:
function
(
a
){
var
b
;
return
null
==
this
.
marker
?(
b
=
[
this
.
view
.
config
.
prefix
,
this
.
type
].
join
(
"-"
).
replace
(
"--"
,
"-"
),
this
.
marker
=
document
.
createComment
(
" rivets: "
+
this
.
type
+
" "
),
this
.
iterated
=
[],
a
.
removeAttribute
(
b
),
a
.
parentNode
.
insertBefore
(
this
.
marker
,
a
),
a
.
parentNode
.
removeChild
(
a
)):
void
0
},
unbind
:
function
(){
var
a
,
b
,
c
,
d
,
e
;
if
(
null
!=
this
.
iterated
){
for
(
d
=
this
.
iterated
,
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
unbind
());
return
e
}},
routine
:
function
(
a
,
c
){
var
d
,
e
,
f
,
g
,
h
,
i
,
j
,
k
,
l
,
m
,
n
,
o
,
p
,
q
,
r
,
s
,
t
,
u
,
v
,
w
,
x
,
y
,
z
,
A
;
if
(
k
=
this
.
args
[
0
],
c
=
c
||
[],
this
.
iterated
.
length
>
c
.
length
)
for
(
w
=
Array
(
this
.
iterated
.
length
-
c
.
length
),
q
=
0
,
t
=
w
.
length
;
t
>
q
;
q
++
)
f
=
w
[
q
],
p
=
this
.
iterated
.
pop
(),
p
.
unbind
(),
this
.
marker
.
parentNode
.
removeChild
(
p
.
els
[
0
]);
for
(
g
=
r
=
0
,
u
=
c
.
length
;
u
>
r
;
g
=++
r
)
if
(
j
=
c
[
g
],
e
=
{},
e
[
k
]
=
j
,
null
==
this
.
iterated
[
g
]){
x
=
this
.
view
.
models
;
for
(
i
in
x
)
j
=
x
[
i
],
null
==
e
[
i
]
&&
(
e
[
i
]
=
j
);
m
=
this
.
iterated
.
length
?
this
.
iterated
[
this
.
iterated
.
length
-
1
].
els
[
0
]:
this
.
marker
,
l
=
{
binders
:
this
.
view
.
options
.
binders
,
formatters
:
this
.
view
.
options
.
formatters
,
adapters
:
this
.
view
.
options
.
adapters
,
config
:{}},
y
=
this
.
view
.
options
.
config
;
for
(
h
in
y
)
o
=
y
[
h
],
l
.
config
[
h
]
=
o
;
l
.
config
.
preloadData
=!
0
,
n
=
a
.
cloneNode
(
!
0
),
p
=
new
b
.
View
(
n
,
e
,
l
),
p
.
bind
(),
this
.
iterated
.
push
(
p
),
this
.
marker
.
parentNode
.
insertBefore
(
n
,
m
.
nextSibling
)}
else
this
.
iterated
[
g
].
models
[
k
]
!==
j
&&
this
.
iterated
[
g
].
update
(
e
);
if
(
"OPTION"
===
a
.
nodeName
){
for
(
z
=
this
.
view
.
bindings
,
A
=
[],
s
=
0
,
v
=
z
.
length
;
v
>
s
;
s
++
)
d
=
z
[
s
],
d
.
el
===
this
.
marker
.
parentNode
&&
"value"
===
d
.
type
?
A
.
push
(
d
.
sync
()):
A
.
push
(
void
0
);
return
A
}},
update
:
function
(
a
){
var
b
,
c
,
d
,
e
,
f
,
g
,
h
,
i
;
b
=
{};
for
(
c
in
a
)
d
=
a
[
c
],
c
!==
this
.
args
[
0
]
&&
(
b
[
c
]
=
d
);
for
(
h
=
this
.
iterated
,
i
=
[],
f
=
0
,
g
=
h
.
length
;
g
>
f
;
f
++
)
e
=
h
[
f
],
i
.
push
(
e
.
update
(
b
));
return
i
}},
b
.
binders
[
"class-*"
]
=
function
(
a
,
b
){
var
c
;
return
c
=
" "
+
a
.
className
+
" "
,
!
b
==
(
-
1
!==
c
.
indexOf
(
" "
+
this
.
args
[
0
]
+
" "
))?
a
.
className
=
b
?
""
+
a
.
className
+
" "
+
this
.
args
[
0
]:
c
.
replace
(
" "
+
this
.
args
[
0
]
+
" "
,
" "
).
trim
():
void
0
},
b
.
binders
[
"*"
]
=
function
(
a
,
b
){
return
b
?
a
.
setAttribute
(
this
.
type
,
b
):
a
.
removeAttribute
(
this
.
type
)},
b
.
adapters
[
"."
]
=
{
id
:
"_rv"
,
counter
:
0
,
weakmap
:{},
weakReference
:
function
(
a
){
var
b
;
return
null
==
a
[
this
.
id
]
&&
(
b
=
this
.
counter
++
,
this
.
weakmap
[
b
]
=
{
callbacks
:{}},
Object
.
defineProperty
(
a
,
this
.
id
,{
value
:
b
})),
this
.
weakmap
[
a
[
this
.
id
]]},
stubFunction
:
function
(
a
,
b
){
var
c
,
d
,
e
;
return
d
=
a
[
b
],
c
=
this
.
weakReference
(
a
),
e
=
this
.
weakmap
,
a
[
b
]
=
function
(){
var
b
,
f
,
g
,
h
,
i
,
j
,
k
,
l
,
m
,
n
;
h
=
d
.
apply
(
a
,
arguments
),
k
=
c
.
pointers
;
for
(
g
in
k
)
for
(
f
=
k
[
g
],
n
=
null
!=
(
l
=
null
!=
(
m
=
e
[
g
])?
m
.
callbacks
[
f
]:
void
0
)?
l
:[],
i
=
0
,
j
=
n
.
length
;
j
>
i
;
i
++
)
b
=
n
[
i
],
b
();
return
h
}},
observeMutations
:
function
(
a
,
b
,
c
){
var
e
,
f
,
g
,
h
,
i
,
j
;
if
(
Array
.
isArray
(
a
)){
if
(
g
=
this
.
weakReference
(
a
),
null
==
g
.
pointers
)
for
(
g
.
pointers
=
{},
f
=
[
"push"
,
"pop"
,
"shift"
,
"unshift"
,
"sort"
,
"reverse"
,
"splice"
],
i
=
0
,
j
=
f
.
length
;
j
>
i
;
i
++
)
e
=
f
[
i
],
this
.
stubFunction
(
a
,
e
);
if
(
null
==
(
h
=
g
.
pointers
)[
b
]
&&
(
h
[
b
]
=
[]),
d
.
call
(
g
.
pointers
[
b
],
c
)
<
0
)
return
g
.
pointers
[
b
].
push
(
c
)}},
unobserveMutations
:
function
(
a
,
b
,
c
){
var
d
,
e
;
return
Array
.
isArray
(
a
&&
null
!=
a
[
this
.
id
])
&&
(
d
=
null
!=
(
e
=
this
.
weakReference
(
a
).
pointers
)?
e
[
b
]:
void
0
)?
d
.
splice
(
d
.
indexOf
(
c
),
1
):
void
0
},
subscribe
:
function
(
a
,
b
,
c
){
var
e
,
f
,
g
=
this
;
return
e
=
this
.
weakReference
(
a
).
callbacks
,
null
==
e
[
b
]
&&
(
e
[
b
]
=
[],
f
=
a
[
b
],
Object
.
defineProperty
(
a
,
b
,{
get
:
function
(){
return
f
},
set
:
function
(
d
){
var
h
,
i
,
j
;
if
(
d
!==
f
){
for
(
f
=
d
,
j
=
e
[
b
],
h
=
0
,
i
=
j
.
length
;
i
>
h
;
h
++
)
c
=
j
[
h
],
c
();
return
g
.
observeMutations
(
d
,
a
[
g
.
id
],
b
)}}})),
d
.
call
(
e
[
b
],
c
)
<
0
&&
e
[
b
].
push
(
c
),
this
.
observeMutations
(
a
[
b
],
a
[
this
.
id
],
b
)},
unsubscribe
:
function
(
a
,
b
,
c
){
var
d
;
return
d
=
this
.
weakmap
[
a
[
this
.
id
]].
callbacks
[
b
],
d
.
splice
(
d
.
indexOf
(
c
),
1
),
this
.
unobserveMutations
(
a
[
b
],
a
[
this
.
id
],
b
)},
read
:
function
(
a
,
b
){
return
a
[
b
]},
publish
:
function
(
a
,
b
,
c
){
return
a
[
b
]
=
c
}},
b
.
factory
=
function
(
a
){
return
a
.
_
=
b
,
a
.
binders
=
b
.
binders
,
a
.
components
=
b
.
components
,
a
.
formatters
=
b
.
formatters
,
a
.
adapters
=
b
.
adapters
,
a
.
config
=
b
.
config
,
a
.
configure
=
function
(
a
){
var
c
,
d
;
null
==
a
&&
(
a
=
{});
for
(
c
in
a
)
d
=
a
[
c
],
b
.
config
[
c
]
=
d
},
a
.
bind
=
function
(
a
,
c
,
d
){
var
e
;
return
null
==
c
&&
(
c
=
{}),
null
==
d
&&
(
d
=
{}),
e
=
new
b
.
View
(
a
,
c
,
d
),
e
.
bind
(),
e
}},
"object"
==
typeof
exports
?
b
.
factory
(
exports
):
"function"
==
typeof
define
&&
define
.
amd
?
define
([
"exports"
],
function
(
a
){
return
b
.
factory
(
this
.
rivets
=
a
),
a
}):
b
.
factory
(
this
.
rivets
=
{})}).
call
(
this
);
\ No newline at end of file
(
function
(){
var
a
,
b
,
c
=
function
(
a
,
b
){
return
function
(){
return
a
.
apply
(
b
,
arguments
)}},
d
=
[].
indexOf
||
function
(
a
){
for
(
var
b
=
0
,
c
=
this
.
length
;
c
>
b
;
b
++
)
if
(
b
in
this
&&
this
[
b
]
===
a
)
return
b
;
return
-
1
},
e
=
[].
slice
,
f
=
{}.
hasOwnProperty
,
g
=
function
(
a
,
b
){
function
c
(){
this
.
constructor
=
a
}
for
(
var
d
in
b
)
f
.
call
(
b
,
d
)
&&
(
a
[
d
]
=
b
[
d
]);
return
c
.
prototype
=
b
.
prototype
,
a
.
prototype
=
new
c
,
a
.
__super__
=
b
.
prototype
,
a
};
b
=
{
binders
:{},
components
:{},
formatters
:{},
adapters
:{},
config
:{
prefix
:
"rv"
,
templateDelimiters
:[
"{"
,
"}"
],
rootInterface
:
"."
,
preloadData
:
!
0
,
handler
:
function
(
a
,
b
,
c
){
return
this
.
call
(
a
,
b
,
c
.
view
.
models
)}}},
b
.
Util
=
{
bindEvent
:
function
(
a
,
b
,
c
){
return
null
!=
window
.
jQuery
?(
a
=
jQuery
(
a
),
null
!=
a
.
on
?
a
.
on
(
b
,
c
):
a
.
bind
(
b
,
c
)):
null
!=
window
.
addEventListener
?
a
.
addEventListener
(
b
,
c
,
!
1
):(
b
=
"on"
+
b
,
a
.
attachEvent
(
b
,
c
))},
unbindEvent
:
function
(
a
,
b
,
c
){
return
null
!=
window
.
jQuery
?(
a
=
jQuery
(
a
),
null
!=
a
.
off
?
a
.
off
(
b
,
c
):
a
.
unbind
(
b
,
c
)):
null
!=
window
.
removeEventListener
?
a
.
removeEventListener
(
b
,
c
,
!
1
):(
b
=
"on"
+
b
,
a
.
detachEvent
(
b
,
c
))},
getInputValue
:
function
(
a
){
var
b
,
c
,
d
,
e
;
if
(
null
!=
window
.
jQuery
)
switch
(
a
=
jQuery
(
a
),
a
[
0
].
type
){
case
"checkbox"
:
return
a
.
is
(
":checked"
);
default
:
return
a
.
val
()}
else
switch
(
a
.
type
){
case
"checkbox"
:
return
a
.
checked
;
case
"select-multiple"
:
for
(
e
=
[],
c
=
0
,
d
=
a
.
length
;
d
>
c
;
c
++
)
b
=
a
[
c
],
b
.
selected
&&
e
.
push
(
b
.
value
);
return
e
;
default
:
return
a
.
value
}}},
b
.
View
=
function
(){
function
a
(
a
,
d
,
e
){
var
f
,
g
,
h
,
i
,
j
,
k
,
l
,
m
,
n
;
for
(
this
.
els
=
a
,
this
.
models
=
d
,
this
.
options
=
null
!=
e
?
e
:{},
this
.
update
=
c
(
this
.
update
,
this
),
this
.
publish
=
c
(
this
.
publish
,
this
),
this
.
sync
=
c
(
this
.
sync
,
this
),
this
.
unbind
=
c
(
this
.
unbind
,
this
),
this
.
bind
=
c
(
this
.
bind
,
this
),
this
.
select
=
c
(
this
.
select
,
this
),
this
.
build
=
c
(
this
.
build
,
this
),
this
.
componentRegExp
=
c
(
this
.
componentRegExp
,
this
),
this
.
bindingRegExp
=
c
(
this
.
bindingRegExp
,
this
),
this
.
els
.
jquery
||
this
.
els
instanceof
Array
||
(
this
.
els
=
[
this
.
els
]),
l
=
[
"config"
,
"binders"
,
"formatters"
,
"adapters"
],
j
=
0
,
k
=
l
.
length
;
k
>
j
;
j
++
){
if
(
g
=
l
[
j
],
this
[
g
]
=
{},
this
.
options
[
g
]){
m
=
this
.
options
[
g
];
for
(
f
in
m
)
h
=
m
[
f
],
this
[
g
][
f
]
=
h
}
n
=
b
[
g
];
for
(
f
in
n
)
h
=
n
[
f
],
null
==
(
i
=
this
[
g
])[
f
]
&&
(
i
[
f
]
=
h
)}
this
.
build
()}
return
a
.
prototype
.
bindingRegExp
=
function
(){
return
new
RegExp
(
"^"
+
this
.
config
.
prefix
+
"-"
)},
a
.
prototype
.
componentRegExp
=
function
(){
return
new
RegExp
(
"^"
+
this
.
config
.
prefix
.
toUpperCase
()
+
"-"
)},
a
.
prototype
.
build
=
function
(){
var
a
,
c
,
e
,
f
,
g
,
h
,
i
,
j
,
k
,
l
=
this
;
for
(
this
.
bindings
=
[],
h
=
[],
a
=
this
.
bindingRegExp
(),
e
=
this
.
componentRegExp
(),
c
=
function
(
a
,
c
,
d
,
e
){
var
f
,
g
,
h
,
i
,
j
,
k
,
m
;
return
j
=
{},
m
=
function
(){
var
a
,
b
,
c
,
d
;
for
(
c
=
e
.
split
(
"|"
),
d
=
[],
a
=
0
,
b
=
c
.
length
;
b
>
a
;
a
++
)
k
=
c
[
a
],
d
.
push
(
k
.
trim
());
return
d
}(),
f
=
function
(){
var
a
,
b
,
c
,
d
;
for
(
c
=
m
.
shift
().
split
(
"<"
),
d
=
[],
a
=
0
,
b
=
c
.
length
;
b
>
a
;
a
++
)
g
=
c
[
a
],
d
.
push
(
g
.
trim
());
return
d
}(),
i
=
f
.
shift
(),
j
.
formatters
=
m
,(
h
=
f
.
shift
())
&&
(
j
.
dependencies
=
h
.
split
(
/
\s
+/
)),
l
.
bindings
.
push
(
new
b
[
a
](
l
,
c
,
d
,
i
,
j
))},
g
=
function
(
f
){
var
i
,
j
,
k
,
m
,
n
,
o
,
p
,
q
,
r
,
s
,
t
,
u
,
v
,
w
,
x
,
y
,
z
,
A
,
B
,
C
,
D
,
E
,
F
,
G
,
H
,
I
,
J
,
K
,
L
,
M
;
if
(
d
.
call
(
h
,
f
)
<
0
){
if
(
f
.
nodeType
===
Node
.
TEXT_NODE
){
if
(
q
=
b
.
TextTemplateParser
,(
n
=
l
.
config
.
templateDelimiters
)
&&
(
u
=
q
.
parse
(
f
.
data
,
n
)).
length
&&
(
1
!==
u
.
length
||
u
[
0
].
type
!==
q
.
types
.
text
)){
for
(
x
=
0
,
B
=
u
.
length
;
B
>
x
;
x
++
)
t
=
u
[
x
],
s
=
document
.
createTextNode
(
t
.
value
),
f
.
parentNode
.
insertBefore
(
s
,
f
),
1
===
t
.
type
&&
c
(
"TextBinding"
,
s
,
null
,
t
.
value
);
f
.
parentNode
.
removeChild
(
f
)}}
else
if
(
e
.
test
(
f
.
tagName
))
v
=
f
.
tagName
.
replace
(
e
,
""
).
toLowerCase
(),
l
.
bindings
.
push
(
new
b
.
ComponentBinding
(
l
,
f
,
v
));
else
if
(
null
!=
f
.
attributes
){
for
(
H
=
f
.
attributes
,
y
=
0
,
C
=
H
.
length
;
C
>
y
;
y
++
)
if
(
i
=
H
[
y
],
a
.
test
(
i
.
name
)){
if
(
v
=
i
.
name
.
replace
(
a
,
""
),
!
(
k
=
l
.
binders
[
v
])){
I
=
l
.
binders
;
for
(
o
in
I
)
w
=
I
[
o
],
"*"
!==
o
&&-
1
!==
o
.
indexOf
(
"*"
)
&&
(
r
=
new
RegExp
(
"^"
+
o
.
replace
(
"*"
,
".+"
)
+
"$"
),
r
.
test
(
v
)
&&
(
k
=
w
))}
if
(
k
||
(
k
=
l
.
binders
[
"*"
]),
k
.
block
){
for
(
J
=
f
.
childNodes
,
z
=
0
,
D
=
J
.
length
;
D
>
z
;
z
++
)
p
=
J
[
z
],
h
.
push
(
p
);
j
=
[
i
]}}
for
(
K
=
j
||
f
.
attributes
,
A
=
0
,
E
=
K
.
length
;
E
>
A
;
A
++
)
i
=
K
[
A
],
a
.
test
(
i
.
name
)
&&
(
v
=
i
.
name
.
replace
(
a
,
""
),
c
(
"Binding"
,
f
,
v
,
i
.
value
))}
for
(
L
=
function
(){
var
a
,
b
,
c
,
d
;
for
(
c
=
f
.
childNodes
,
d
=
[],
b
=
0
,
a
=
c
.
length
;
a
>
b
;
b
++
)
p
=
c
[
b
],
d
.
push
(
p
);
return
d
}(),
M
=
[],
G
=
0
,
F
=
L
.
length
;
F
>
G
;
G
++
)
m
=
L
[
G
],
M
.
push
(
g
(
m
));
return
M
}},
k
=
this
.
els
,
i
=
0
,
j
=
k
.
length
;
j
>
i
;
i
++
)
f
=
k
[
i
],
g
(
f
)},
a
.
prototype
.
select
=
function
(
a
){
var
b
,
c
,
d
,
e
,
f
;
for
(
e
=
this
.
bindings
,
f
=
[],
c
=
0
,
d
=
e
.
length
;
d
>
c
;
c
++
)
b
=
e
[
c
],
a
(
b
)
&&
f
.
push
(
b
);
return
f
},
a
.
prototype
.
bind
=
function
(){
var
a
,
b
,
c
,
d
,
e
;
for
(
d
=
this
.
bindings
,
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
bind
());
return
e
},
a
.
prototype
.
unbind
=
function
(){
var
a
,
b
,
c
,
d
,
e
;
for
(
d
=
this
.
bindings
,
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
unbind
());
return
e
},
a
.
prototype
.
sync
=
function
(){
var
a
,
b
,
c
,
d
,
e
;
for
(
d
=
this
.
bindings
,
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
sync
());
return
e
},
a
.
prototype
.
publish
=
function
(){
var
a
,
b
,
c
,
d
,
e
;
for
(
d
=
this
.
select
(
function
(
a
){
return
a
.
binder
.
publishes
}),
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
publish
());
return
e
},
a
.
prototype
.
update
=
function
(
a
){
var
b
,
c
,
d
,
e
,
f
,
g
,
h
;
null
==
a
&&
(
a
=
{});
for
(
c
in
a
)
d
=
a
[
c
],
this
.
models
[
c
]
=
d
;
for
(
g
=
this
.
bindings
,
h
=
[],
e
=
0
,
f
=
g
.
length
;
f
>
e
;
e
++
)
b
=
g
[
e
],
h
.
push
(
b
.
update
(
a
));
return
h
},
a
}(),
b
.
Binding
=
function
(){
function
d
(
a
,
b
,
d
,
e
,
f
){
this
.
view
=
a
,
this
.
el
=
b
,
this
.
type
=
d
,
this
.
keypath
=
e
,
this
.
options
=
null
!=
f
?
f
:{},
this
.
update
=
c
(
this
.
update
,
this
),
this
.
unbind
=
c
(
this
.
unbind
,
this
),
this
.
bind
=
c
(
this
.
bind
,
this
),
this
.
publish
=
c
(
this
.
publish
,
this
),
this
.
sync
=
c
(
this
.
sync
,
this
),
this
.
set
=
c
(
this
.
set
,
this
),
this
.
eventHandler
=
c
(
this
.
eventHandler
,
this
),
this
.
formattedValue
=
c
(
this
.
formattedValue
,
this
),
this
.
setObserver
=
c
(
this
.
setObserver
,
this
),
this
.
setBinder
=
c
(
this
.
setBinder
,
this
),
this
.
formatters
=
this
.
options
.
formatters
||
[],
this
.
dependencies
=
[],
this
.
setBinder
(),
this
.
setObserver
()}
return
d
.
prototype
.
setBinder
=
function
(){
var
a
,
b
,
c
,
d
;
if
(
!
(
this
.
binder
=
this
.
view
.
binders
[
this
.
type
])){
d
=
this
.
view
.
binders
;
for
(
a
in
d
)
c
=
d
[
a
],
"*"
!==
a
&&-
1
!==
a
.
indexOf
(
"*"
)
&&
(
b
=
new
RegExp
(
"^"
+
a
.
replace
(
"*"
,
".+"
)
+
"$"
),
b
.
test
(
this
.
type
)
&&
(
this
.
binder
=
c
,
this
.
args
=
new
RegExp
(
"^"
+
a
.
replace
(
"*"
,
"(.+)"
)
+
"$"
).
exec
(
this
.
type
),
this
.
args
.
shift
()))}
return
this
.
binder
||
(
this
.
binder
=
this
.
view
.
binders
[
"*"
]),
this
.
binder
instanceof
Function
?
this
.
binder
=
{
routine
:
this
.
binder
}:
void
0
},
d
.
prototype
.
setObserver
=
function
(){
var
b
=
this
;
return
this
.
observer
=
new
a
(
this
.
view
,
this
.
view
.
models
,
this
.
keypath
,
function
(
a
){
return
b
.
key
&&
b
.
unbind
(
!
0
),
b
.
model
=
a
.
target
,
b
.
key
&&
b
.
bind
(
!
0
),
b
.
sync
()}),
this
.
key
=
this
.
observer
.
key
,
this
.
model
=
this
.
observer
.
target
},
d
.
prototype
.
formattedValue
=
function
(
a
){
var
b
,
c
,
d
,
f
,
g
,
h
;
for
(
h
=
this
.
formatters
,
f
=
0
,
g
=
h
.
length
;
g
>
f
;
f
++
)
c
=
h
[
f
],
b
=
c
.
split
(
/
\s
+/
),
d
=
b
.
shift
(),
c
=
this
.
view
.
formatters
[
d
],(
null
!=
c
?
c
.
read
:
void
0
)
instanceof
Function
?
a
=
c
.
read
.
apply
(
c
,[
a
].
concat
(
e
.
call
(
b
))):
c
instanceof
Function
&&
(
a
=
c
.
apply
(
null
,[
a
].
concat
(
e
.
call
(
b
))));
return
a
},
d
.
prototype
.
eventHandler
=
function
(
a
){
var
b
,
c
;
return
c
=
(
b
=
this
).
view
.
config
.
handler
,
function
(
d
){
return
c
.
call
(
a
,
this
,
d
,
b
)}},
d
.
prototype
.
set
=
function
(
a
){
var
b
;
return
a
=
a
instanceof
Function
&&!
this
.
binder
[
"function"
]?
this
.
formattedValue
(
a
.
call
(
this
.
model
)):
this
.
formattedValue
(
a
),
null
!=
(
b
=
this
.
binder
.
routine
)?
b
.
call
(
this
,
this
.
el
,
a
):
void
0
},
d
.
prototype
.
sync
=
function
(){
return
this
.
set
(
this
.
key
?
this
.
view
.
adapters
[
this
.
key
[
"interface"
]].
read
(
this
.
model
,
this
.
key
.
path
):
this
.
model
)},
d
.
prototype
.
publish
=
function
(){
var
a
,
c
,
d
,
f
,
g
,
h
,
i
,
j
,
k
;
for
(
f
=
b
.
Util
.
getInputValue
(
this
.
el
),
i
=
this
.
formatters
.
slice
(
0
).
reverse
(),
g
=
0
,
h
=
i
.
length
;
h
>
g
;
g
++
)
c
=
i
[
g
],
a
=
c
.
split
(
/
\s
+/
),
d
=
a
.
shift
(),(
null
!=
(
j
=
this
.
view
.
formatters
[
d
])?
j
.
publish
:
void
0
)
&&
(
f
=
(
k
=
this
.
view
.
formatters
[
d
]).
publish
.
apply
(
k
,[
f
].
concat
(
e
.
call
(
a
))));
return
this
.
view
.
adapters
[
this
.
key
[
"interface"
]].
publish
(
this
.
model
,
this
.
key
.
path
,
f
)},
d
.
prototype
.
bind
=
function
(
b
){
var
c
,
d
,
e
,
f
,
g
,
h
,
i
,
j
,
k
,
l
=
this
;
if
(
null
==
b
&&
(
b
=!
1
),
b
||
null
!=
(
h
=
this
.
binder
.
bind
)
&&
h
.
call
(
this
,
this
.
el
),
this
.
key
&&
this
.
view
.
adapters
[
this
.
key
[
"interface"
]].
subscribe
(
this
.
model
,
this
.
key
.
path
,
this
.
sync
),(
b
?
void
0
:
this
.
view
.
config
.
preloadData
)
&&
this
.
sync
(),
null
!=
(
i
=
this
.
options
.
dependencies
)?
i
.
length
:
void
0
){
for
(
j
=
this
.
options
.
dependencies
,
k
=
[],
f
=
0
,
g
=
j
.
length
;
g
>
f
;
f
++
)
c
=
j
[
f
],
e
=
new
a
(
this
.
view
,
this
.
model
,
c
,
function
(
a
,
b
){
var
c
;
return
c
=
a
.
key
,
l
.
view
.
adapters
[
c
[
"interface"
]].
unsubscribe
(
b
,
c
.
path
,
l
.
sync
),
l
.
view
.
adapters
[
c
[
"interface"
]].
subscribe
(
a
.
target
,
c
.
path
,
l
.
sync
),
l
.
sync
()}),
d
=
e
.
key
,
this
.
view
.
adapters
[
d
[
"interface"
]].
subscribe
(
e
.
target
,
d
.
path
,
this
.
sync
),
k
.
push
(
this
.
dependencies
.
push
(
e
));
return
k
}},
d
.
prototype
.
unbind
=
function
(
a
){
var
b
,
c
,
d
,
e
,
f
,
g
;
if
(
null
==
a
&&
(
a
=!
1
),
a
||
null
!=
(
f
=
this
.
binder
.
unbind
)
&&
f
.
call
(
this
,
this
.
el
),
this
.
key
&&
this
.
view
.
adapters
[
this
.
key
[
"interface"
]].
unsubscribe
(
this
.
model
,
this
.
key
.
path
,
this
.
sync
),
this
.
dependencies
.
length
){
for
(
g
=
this
.
dependencies
,
d
=
0
,
e
=
g
.
length
;
e
>
d
;
d
++
)
c
=
g
[
d
],
b
=
c
.
key
,
this
.
view
.
adapters
[
b
[
"interface"
]].
unsubscribe
(
c
.
target
,
b
.
path
,
this
.
sync
);
return
this
.
dependencies
=
[]}},
d
.
prototype
.
update
=
function
(
a
){
var
b
;
return
null
==
a
&&
(
a
=
{}),
null
!=
(
b
=
this
.
binder
.
update
)?
b
.
call
(
this
,
a
):
void
0
},
d
}(),
b
.
ComponentBinding
=
function
(
a
){
function
e
(
a
,
e
,
f
){
var
g
,
h
,
i
,
j
,
k
;
for
(
this
.
view
=
a
,
this
.
el
=
e
,
this
.
type
=
f
,
this
.
unbind
=
c
(
this
.
unbind
,
this
),
this
.
bind
=
c
(
this
.
bind
,
this
),
this
.
update
=
c
(
this
.
update
,
this
),
this
.
locals
=
c
(
this
.
locals
,
this
),
this
.
component
=
b
.
components
[
this
.
type
],
this
.
attributes
=
{},
this
.
inflections
=
{},
j
=
this
.
el
.
attributes
||
[],
h
=
0
,
i
=
j
.
length
;
i
>
h
;
h
++
)
g
=
j
[
h
],
k
=
g
.
name
,
d
.
call
(
this
.
component
.
attributes
,
k
)
>=
0
?
this
.
attributes
[
g
.
name
]
=
g
.
value
:
this
.
inflections
[
g
.
name
]
=
g
.
value
}
return
g
(
e
,
a
),
e
.
prototype
.
sync
=
function
(){},
e
.
prototype
.
locals
=
function
(
a
){
var
b
,
c
,
d
,
e
,
f
,
g
,
h
,
i
,
j
;
null
==
a
&&
(
a
=
this
.
view
.
models
),
f
=
{},
i
=
this
.
inflections
;
for
(
c
in
i
)
for
(
b
=
i
[
c
],
j
=
b
.
split
(
"."
),
g
=
0
,
h
=
j
.
length
;
h
>
g
;
g
++
)
e
=
j
[
g
],
f
[
c
]
=
(
f
[
c
]
||
a
)[
e
];
for
(
c
in
a
)
d
=
a
[
c
],
null
==
f
[
c
]
&&
(
f
[
c
]
=
d
);
return
f
},
e
.
prototype
.
update
=
function
(
a
){
var
b
;
return
null
!=
(
b
=
this
.
componentView
)?
b
.
update
(
this
.
locals
(
a
)):
void
0
},
e
.
prototype
.
bind
=
function
(){
var
a
,
c
;
return
null
!=
this
.
componentView
?
null
!=
(
c
=
this
.
componentView
)?
c
.
bind
():
void
0
:(
a
=
this
.
component
.
build
.
call
(
this
.
attributes
),(
this
.
componentView
=
new
b
.
View
(
a
,
this
.
locals
(),
this
.
view
.
options
)).
bind
(),
this
.
el
.
parentNode
.
replaceChild
(
a
,
this
.
el
))},
e
.
prototype
.
unbind
=
function
(){
var
a
;
return
null
!=
(
a
=
this
.
componentView
)?
a
.
unbind
():
void
0
},
e
}(
b
.
Binding
),
b
.
TextBinding
=
function
(
a
){
function
b
(
a
,
b
,
d
,
e
,
f
){
this
.
view
=
a
,
this
.
el
=
b
,
this
.
type
=
d
,
this
.
keypath
=
e
,
this
.
options
=
null
!=
f
?
f
:{},
this
.
sync
=
c
(
this
.
sync
,
this
),
this
.
formatters
=
this
.
options
.
formatters
||
[],
this
.
dependencies
=
[],
this
.
setObserver
()}
return
g
(
b
,
a
),
b
.
prototype
.
binder
=
{
routine
:
function
(
a
,
b
){
return
a
.
data
=
null
!=
b
?
b
:
""
}},
b
.
prototype
.
sync
=
function
(){
return
b
.
__super__
.
sync
.
apply
(
this
,
arguments
)},
b
}(
b
.
Binding
),
b
.
KeypathParser
=
function
(){
function
a
(){}
return
a
.
parse
=
function
(
a
,
b
,
c
){
var
e
,
f
,
g
,
h
;
h
=
[],
f
=
{
"interface"
:
c
,
path
:
""
};
for
(
g
in
a
)
e
=
a
[
g
],
d
.
call
(
b
,
e
)
>=
0
?(
h
.
push
(
f
),
f
=
{
"interface"
:
e
,
path
:
""
}):
f
.
path
+=
e
;
return
h
.
push
(
f
),
h
},
a
}(),
b
.
TextTemplateParser
=
function
(){
function
a
(){}
return
a
.
types
=
{
text
:
0
,
binding
:
1
},
a
.
parse
=
function
(
a
,
b
){
var
c
,
d
,
e
,
f
,
g
,
h
,
i
,
j
;
for
(
i
=
[],
g
=
a
.
length
,
c
=
b
[
1
].
length
,
d
=
0
,
e
=
0
;
g
>
e
;){
if
(
d
=
a
.
indexOf
(
b
[
0
],
e
),
0
>
d
){
i
.
push
({
type
:
this
.
types
.
text
,
value
:
a
.
slice
(
e
)});
break
}
if
(
d
>
0
&&
d
>
e
&&
i
.
push
({
type
:
this
.
types
.
text
,
value
:
a
.
slice
(
e
,
d
)}),
e
=
d
+
2
,
d
=
a
.
indexOf
(
b
[
1
],
e
),
0
>
d
){
h
=
a
.
slice
(
e
-
2
),
f
=
i
[
i
.
length
-
1
],(
null
!=
f
?
f
.
type
:
void
0
)
===
this
.
types
.
text
?
f
.
value
+=
h
:
i
.
push
({
type
:
this
.
types
.
text
,
value
:
h
});
break
}
j
=
a
.
slice
(
e
,
d
).
trim
(),
i
.
push
({
type
:
this
.
types
.
binding
,
value
:
j
}),
e
=
d
+
c
}
return
i
},
a
}(),
a
=
function
(){
function
a
(
a
,
b
,
d
,
e
){
this
.
view
=
a
,
this
.
model
=
b
,
this
.
keypath
=
d
,
this
.
callback
=
e
,
this
.
realize
=
c
(
this
.
realize
,
this
),
this
.
update
=
c
(
this
.
update
,
this
),
this
.
parse
=
c
(
this
.
parse
,
this
),
this
.
parse
(),
this
.
objectPath
=
[],
this
.
target
=
this
.
realize
()}
return
a
.
prototype
.
parse
=
function
(){
var
a
,
c
,
e
,
f
,
g
,
h
;
return
a
=
function
(){
var
a
,
b
;
a
=
this
.
view
.
adapters
,
b
=
[];
for
(
c
in
a
)
g
=
a
[
c
],
b
.
push
(
c
);
return
b
}.
call
(
this
),
h
=
this
.
keypath
[
0
],
d
.
call
(
a
,
h
)
>=
0
?(
f
=
this
.
keypath
[
0
],
e
=
this
.
keypath
.
substr
(
1
)):(
f
=
this
.
view
.
config
.
rootInterface
,
e
=
this
.
keypath
),
this
.
tokens
=
b
.
KeypathParser
.
parse
(
e
,
a
,
f
),
this
.
key
=
this
.
tokens
.
pop
()},
a
.
prototype
.
update
=
function
(){
var
a
,
b
;
return
(
a
=
this
.
realize
())
!==
this
.
target
?(
b
=
this
.
target
,
this
.
target
=
a
,
this
.
callback
(
this
,
b
)):
void
0
},
a
.
prototype
.
realize
=
function
(){
var
a
,
b
,
c
,
d
,
e
,
f
,
g
;
for
(
a
=
this
.
model
,
g
=
this
.
tokens
,
b
=
e
=
0
,
f
=
g
.
length
;
f
>
e
;
b
=++
e
)
d
=
g
[
b
],
null
!=
this
.
objectPath
[
b
]?
a
!==
(
c
=
this
.
objectPath
[
b
])
&&
(
this
.
view
.
adapters
[
d
[
"interface"
]].
unsubscribe
(
c
,
d
.
path
,
this
.
update
),
this
.
view
.
adapters
[
d
[
"interface"
]].
subscribe
(
a
,
d
.
path
,
this
.
update
),
this
.
objectPath
[
b
]
=
a
):(
this
.
view
.
adapters
[
d
[
"interface"
]].
subscribe
(
a
,
d
.
path
,
this
.
update
),
this
.
objectPath
[
b
]
=
a
),
a
=
this
.
view
.
adapters
[
d
[
"interface"
]].
read
(
a
,
d
.
path
);
return
a
},
a
}(),
b
.
binders
.
enabled
=
function
(
a
,
b
){
return
a
.
disabled
=!
b
},
b
.
binders
.
disabled
=
function
(
a
,
b
){
return
a
.
disabled
=!!
b
},
b
.
binders
.
checked
=
{
publishes
:
!
0
,
bind
:
function
(
a
){
return
b
.
Util
.
bindEvent
(
a
,
"change"
,
this
.
publish
)},
unbind
:
function
(
a
){
return
b
.
Util
.
unbindEvent
(
a
,
"change"
,
this
.
publish
)},
routine
:
function
(
a
,
b
){
var
c
;
return
a
.
checked
=
"radio"
===
a
.
type
?(
null
!=
(
c
=
a
.
value
)?
c
.
toString
():
void
0
)
===
(
null
!=
b
?
b
.
toString
():
void
0
):
!!
b
}},
b
.
binders
.
unchecked
=
{
publishes
:
!
0
,
bind
:
function
(
a
){
return
b
.
Util
.
bindEvent
(
a
,
"change"
,
this
.
publish
)},
unbind
:
function
(
a
){
return
b
.
Util
.
unbindEvent
(
a
,
"change"
,
this
.
publish
)},
routine
:
function
(
a
,
b
){
var
c
;
return
a
.
checked
=
"radio"
===
a
.
type
?(
null
!=
(
c
=
a
.
value
)?
c
.
toString
():
void
0
)
!==
(
null
!=
b
?
b
.
toString
():
void
0
):
!
b
}},
b
.
binders
.
show
=
function
(
a
,
b
){
return
a
.
style
.
display
=
b
?
""
:
"none"
},
b
.
binders
.
hide
=
function
(
a
,
b
){
return
a
.
style
.
display
=
b
?
"none"
:
""
},
b
.
binders
.
html
=
function
(
a
,
b
){
return
a
.
innerHTML
=
null
!=
b
?
b
:
""
},
b
.
binders
.
value
=
{
publishes
:
!
0
,
bind
:
function
(
a
){
return
b
.
Util
.
bindEvent
(
a
,
"change"
,
this
.
publish
)},
unbind
:
function
(
a
){
return
b
.
Util
.
unbindEvent
(
a
,
"change"
,
this
.
publish
)},
routine
:
function
(
a
,
b
){
var
c
,
e
,
f
,
g
,
h
,
i
,
j
;
if
(
null
!=
window
.
jQuery
){
if
(
a
=
jQuery
(
a
),(
null
!=
b
?
b
.
toString
():
void
0
)
!==
(
null
!=
(
g
=
a
.
val
())?
g
.
toString
():
void
0
))
return
a
.
val
(
null
!=
b
?
b
:
""
)}
else
if
(
"select-multiple"
===
a
.
type
){
if
(
null
!=
b
){
for
(
j
=
[],
e
=
0
,
f
=
a
.
length
;
f
>
e
;
e
++
)
c
=
a
[
e
],
j
.
push
(
c
.
selected
=
(
h
=
c
.
value
,
d
.
call
(
b
,
h
)
>=
0
));
return
j
}}
else
if
((
null
!=
b
?
b
.
toString
():
void
0
)
!==
(
null
!=
(
i
=
a
.
value
)?
i
.
toString
():
void
0
))
return
a
.
value
=
null
!=
b
?
b
:
""
}},
b
.
binders
.
text
=
function
(
a
,
b
){
return
null
!=
a
.
innerText
?
a
.
innerText
=
null
!=
b
?
b
:
""
:
a
.
textContent
=
null
!=
b
?
b
:
""
},
b
.
binders
[
"if"
]
=
{
block
:
!
0
,
bind
:
function
(
a
){
var
b
,
c
;
return
null
==
this
.
marker
?(
b
=
[
this
.
view
.
config
.
prefix
,
this
.
type
].
join
(
"-"
).
replace
(
"--"
,
"-"
),
c
=
a
.
getAttribute
(
b
),
this
.
marker
=
document
.
createComment
(
" rivets: "
+
this
.
type
+
" "
+
c
+
" "
),
a
.
removeAttribute
(
b
),
a
.
parentNode
.
insertBefore
(
this
.
marker
,
a
),
a
.
parentNode
.
removeChild
(
a
)):
void
0
},
unbind
:
function
(){
var
a
;
return
null
!=
(
a
=
this
.
nested
)?
a
.
unbind
():
void
0
},
routine
:
function
(
a
,
c
){
var
d
,
e
,
f
,
g
,
h
;
if
(
!!
c
==
(
null
==
this
.
nested
)){
if
(
c
){
f
=
{},
h
=
this
.
view
.
models
;
for
(
d
in
h
)
e
=
h
[
d
],
f
[
d
]
=
e
;
return
g
=
{
binders
:
this
.
view
.
options
.
binders
,
formatters
:
this
.
view
.
options
.
formatters
,
adapters
:
this
.
view
.
options
.
adapters
,
config
:
this
.
view
.
options
.
config
},(
this
.
nested
=
new
b
.
View
(
a
,
f
,
g
)).
bind
(),
this
.
marker
.
parentNode
.
insertBefore
(
a
,
this
.
marker
.
nextSibling
)}
return
a
.
parentNode
.
removeChild
(
a
),
this
.
nested
.
unbind
(),
delete
this
.
nested
}},
update
:
function
(
a
){
var
b
;
return
null
!=
(
b
=
this
.
nested
)?
b
.
update
(
a
):
void
0
}},
b
.
binders
.
unless
=
{
block
:
!
0
,
bind
:
function
(
a
){
return
b
.
binders
[
"if"
].
bind
.
call
(
this
,
a
)},
unbind
:
function
(){
return
b
.
binders
[
"if"
].
unbind
.
call
(
this
)},
routine
:
function
(
a
,
c
){
return
b
.
binders
[
"if"
].
routine
.
call
(
this
,
a
,
!
c
)},
update
:
function
(
a
){
return
b
.
binders
[
"if"
].
update
.
call
(
this
,
a
)}},
b
.
binders
[
"on-*"
]
=
{
"function"
:
!
0
,
unbind
:
function
(
a
){
return
this
.
handler
?
b
.
Util
.
unbindEvent
(
a
,
this
.
args
[
0
],
this
.
handler
):
void
0
},
routine
:
function
(
a
,
c
){
return
this
.
handler
&&
b
.
Util
.
unbindEvent
(
a
,
this
.
args
[
0
],
this
.
handler
),
b
.
Util
.
bindEvent
(
a
,
this
.
args
[
0
],
this
.
handler
=
this
.
eventHandler
(
c
))}},
b
.
binders
[
"each-*"
]
=
{
block
:
!
0
,
bind
:
function
(
a
){
var
b
;
return
null
==
this
.
marker
?(
b
=
[
this
.
view
.
config
.
prefix
,
this
.
type
].
join
(
"-"
).
replace
(
"--"
,
"-"
),
this
.
marker
=
document
.
createComment
(
" rivets: "
+
this
.
type
+
" "
),
this
.
iterated
=
[],
a
.
removeAttribute
(
b
),
a
.
parentNode
.
insertBefore
(
this
.
marker
,
a
),
a
.
parentNode
.
removeChild
(
a
)):
void
0
},
unbind
:
function
(){
var
a
,
b
,
c
,
d
,
e
;
if
(
null
!=
this
.
iterated
){
for
(
d
=
this
.
iterated
,
e
=
[],
b
=
0
,
c
=
d
.
length
;
c
>
b
;
b
++
)
a
=
d
[
b
],
e
.
push
(
a
.
unbind
());
return
e
}},
routine
:
function
(
a
,
c
){
var
d
,
e
,
f
,
g
,
h
,
i
,
j
,
k
,
l
,
m
,
n
,
o
,
p
,
q
,
r
,
s
,
t
,
u
,
v
,
w
,
x
,
y
,
z
,
A
;
if
(
k
=
this
.
args
[
0
],
c
=
c
||
[],
this
.
iterated
.
length
>
c
.
length
)
for
(
w
=
Array
(
this
.
iterated
.
length
-
c
.
length
),
q
=
0
,
t
=
w
.
length
;
t
>
q
;
q
++
)
f
=
w
[
q
],
p
=
this
.
iterated
.
pop
(),
p
.
unbind
(),
this
.
marker
.
parentNode
.
removeChild
(
p
.
els
[
0
]);
for
(
g
=
r
=
0
,
u
=
c
.
length
;
u
>
r
;
g
=++
r
)
if
(
j
=
c
[
g
],
e
=
{},
e
[
k
]
=
j
,
null
==
this
.
iterated
[
g
]){
x
=
this
.
view
.
models
;
for
(
i
in
x
)
j
=
x
[
i
],
null
==
e
[
i
]
&&
(
e
[
i
]
=
j
);
m
=
this
.
iterated
.
length
?
this
.
iterated
[
this
.
iterated
.
length
-
1
].
els
[
0
]:
this
.
marker
,
l
=
{
binders
:
this
.
view
.
options
.
binders
,
formatters
:
this
.
view
.
options
.
formatters
,
adapters
:
this
.
view
.
options
.
adapters
,
config
:{}},
y
=
this
.
view
.
options
.
config
;
for
(
h
in
y
)
o
=
y
[
h
],
l
.
config
[
h
]
=
o
;
l
.
config
.
preloadData
=!
0
,
n
=
a
.
cloneNode
(
!
0
),
p
=
new
b
.
View
(
n
,
e
,
l
),
p
.
bind
(),
this
.
iterated
.
push
(
p
),
this
.
marker
.
parentNode
.
insertBefore
(
n
,
m
.
nextSibling
)}
else
this
.
iterated
[
g
].
models
[
k
]
!==
j
&&
this
.
iterated
[
g
].
update
(
e
);
if
(
"OPTION"
===
a
.
nodeName
){
for
(
z
=
this
.
view
.
bindings
,
A
=
[],
s
=
0
,
v
=
z
.
length
;
v
>
s
;
s
++
)
d
=
z
[
s
],
d
.
el
===
this
.
marker
.
parentNode
&&
"value"
===
d
.
type
?
A
.
push
(
d
.
sync
()):
A
.
push
(
void
0
);
return
A
}},
update
:
function
(
a
){
var
b
,
c
,
d
,
e
,
f
,
g
,
h
,
i
;
b
=
{};
for
(
c
in
a
)
d
=
a
[
c
],
c
!==
this
.
args
[
0
]
&&
(
b
[
c
]
=
d
);
for
(
h
=
this
.
iterated
,
i
=
[],
f
=
0
,
g
=
h
.
length
;
g
>
f
;
f
++
)
e
=
h
[
f
],
i
.
push
(
e
.
update
(
b
));
return
i
}},
b
.
binders
[
"class-*"
]
=
function
(
a
,
b
){
var
c
;
return
c
=
" "
+
a
.
className
+
" "
,
!
b
==
(
-
1
!==
c
.
indexOf
(
" "
+
this
.
args
[
0
]
+
" "
))?
a
.
className
=
b
?
""
+
a
.
className
+
" "
+
this
.
args
[
0
]:
c
.
replace
(
" "
+
this
.
args
[
0
]
+
" "
,
" "
).
trim
():
void
0
},
b
.
binders
[
"*"
]
=
function
(
a
,
b
){
return
b
?
a
.
setAttribute
(
this
.
type
,
b
):
a
.
removeAttribute
(
this
.
type
)},
b
.
adapters
[
"."
]
=
{
id
:
"_rv"
,
counter
:
0
,
weakmap
:{},
weakReference
:
function
(
a
){
var
b
;
return
null
==
a
[
this
.
id
]
&&
(
b
=
this
.
counter
++
,
this
.
weakmap
[
b
]
=
{
callbacks
:{}},
Object
.
defineProperty
(
a
,
this
.
id
,{
value
:
b
})),
this
.
weakmap
[
a
[
this
.
id
]]},
stubFunction
:
function
(
a
,
b
){
var
c
,
d
,
e
;
return
d
=
a
[
b
],
c
=
this
.
weakReference
(
a
),
e
=
this
.
weakmap
,
a
[
b
]
=
function
(){
var
b
,
f
,
g
,
h
,
i
,
j
,
k
,
l
,
m
,
n
;
h
=
d
.
apply
(
a
,
arguments
),
k
=
c
.
pointers
;
for
(
g
in
k
)
for
(
f
=
k
[
g
],
n
=
null
!=
(
l
=
null
!=
(
m
=
e
[
g
])?
m
.
callbacks
[
f
]:
void
0
)?
l
:[],
i
=
0
,
j
=
n
.
length
;
j
>
i
;
i
++
)
b
=
n
[
i
],
b
();
return
h
}},
observeMutations
:
function
(
a
,
b
,
c
){
var
e
,
f
,
g
,
h
,
i
,
j
;
if
(
Array
.
isArray
(
a
)){
if
(
g
=
this
.
weakReference
(
a
),
null
==
g
.
pointers
)
for
(
g
.
pointers
=
{},
f
=
[
"push"
,
"pop"
,
"shift"
,
"unshift"
,
"sort"
,
"reverse"
,
"splice"
],
i
=
0
,
j
=
f
.
length
;
j
>
i
;
i
++
)
e
=
f
[
i
],
this
.
stubFunction
(
a
,
e
);
if
(
null
==
(
h
=
g
.
pointers
)[
b
]
&&
(
h
[
b
]
=
[]),
d
.
call
(
g
.
pointers
[
b
],
c
)
<
0
)
return
g
.
pointers
[
b
].
push
(
c
)}},
unobserveMutations
:
function
(
a
,
b
,
c
){
var
d
,
e
;
return
Array
.
isArray
(
a
&&
null
!=
a
[
this
.
id
])
&&
(
d
=
null
!=
(
e
=
this
.
weakReference
(
a
).
pointers
)?
e
[
b
]:
void
0
)?
d
.
splice
(
d
.
indexOf
(
c
),
1
):
void
0
},
subscribe
:
function
(
a
,
b
,
c
){
var
e
,
f
,
g
=
this
;
return
e
=
this
.
weakReference
(
a
).
callbacks
,
null
==
e
[
b
]
&&
(
e
[
b
]
=
[],
f
=
a
[
b
],
Object
.
defineProperty
(
a
,
b
,{
get
:
function
(){
return
f
},
set
:
function
(
d
){
var
h
,
i
,
j
;
if
(
d
!==
f
){
for
(
f
=
d
,
j
=
e
[
b
],
h
=
0
,
i
=
j
.
length
;
i
>
h
;
h
++
)
c
=
j
[
h
],
c
();
return
g
.
observeMutations
(
d
,
a
[
g
.
id
],
b
)}}})),
d
.
call
(
e
[
b
],
c
)
<
0
&&
e
[
b
].
push
(
c
),
this
.
observeMutations
(
a
[
b
],
a
[
this
.
id
],
b
)},
unsubscribe
:
function
(
a
,
b
,
c
){
var
d
;
return
d
=
this
.
weakmap
[
a
[
this
.
id
]].
callbacks
[
b
],
d
.
splice
(
d
.
indexOf
(
c
),
1
),
this
.
unobserveMutations
(
a
[
b
],
a
[
this
.
id
],
b
)},
read
:
function
(
a
,
b
){
return
a
[
b
]},
publish
:
function
(
a
,
b
,
c
){
return
a
[
b
]
=
c
}},
b
.
factory
=
function
(
a
){
return
a
.
_
=
b
,
a
.
binders
=
b
.
binders
,
a
.
components
=
b
.
components
,
a
.
formatters
=
b
.
formatters
,
a
.
adapters
=
b
.
adapters
,
a
.
config
=
b
.
config
,
a
.
configure
=
function
(
a
){
var
c
,
d
;
null
==
a
&&
(
a
=
{});
for
(
c
in
a
)
d
=
a
[
c
],
b
.
config
[
c
]
=
d
},
a
.
bind
=
function
(
a
,
c
,
d
){
var
e
;
return
null
==
c
&&
(
c
=
{}),
null
==
d
&&
(
d
=
{}),
e
=
new
b
.
View
(
a
,
c
,
d
),
e
.
bind
(),
e
}},
"object"
==
typeof
exports
?
b
.
factory
(
exports
):
"function"
==
typeof
define
&&
define
.
amd
?
define
([
"exports"
],
function
(
a
){
return
b
.
factory
(
this
.
rivets
=
a
),
a
}):
b
.
factory
(
this
.
rivets
=
{})}).
call
(
this
);
\ No newline at end of file
...
...
package.json
View file @
615d329
{
"name"
:
"rivets"
,
"description"
:
"Declarative data binding + templating solution."
,
"version"
:
"0.6.
0
"
,
"version"
:
"0.6.
1
"
,
"author"
:
"Michael Richards"
,
"url"
:
"http://rivetsjs.com"
,
"main"
:
"./dist/rivets.js"
,
...
...
Please
register
or
sign in
to post a comment