Skip to content

Commit

Permalink
Fixes JuliaGizmos#109. Always calls evalscripts in fill.
Browse files Browse the repository at this point in the history
Moves the fade/no-fade decision from julia down into javascript, so that
more code can be reused between the two.

This also simplifies the `content!` function body, which will make
fixing JuliaGizmos#108 a bit easier.

Updates "Fade False" test to not @test_throws. Tests still pass.
  • Loading branch information
NHDaly committed Jan 17, 2018
1 parent 1a0a8f4 commit 7104f25
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 8 deletions.
15 changes: 12 additions & 3 deletions res/blink.js
Original file line number Diff line number Diff line change
Expand Up @@ -97,18 +97,27 @@
}
}

function fill(node, html) {
function fill(node, html, fade) {
node = select(node);
fade ?
fillfade(node, html) :
fillnofade(node, html)
}
function fillfade(node, html) {
node = select(node);
node.classList.add('blink-show');
callback(function () {
node.classList.add('blink-fade');
callback(0.2, function() {
node.innerHTML = html;
evalscripts(node);
fillnofade(node, html);
node.classList.remove('blink-fade');
});
});
}
function fillnofade(node, html) {
node.innerHTML = html;
evalscripts(node);
}

Blink.fill = fill;

Expand Down
8 changes: 3 additions & 5 deletions src/content/api.jl
Original file line number Diff line number Diff line change
@@ -1,11 +1,9 @@
export body!, content!, loadcss!, loadjs!, load!, importhtml!

content!(o, sel, html::AbstractString; fade = true) =
fade ?
@js_(o, Blink.fill($sel, $html)) :
@js_ o document.querySelector($sel).innerHTML = $html
content!(o, sel, html::AbstractString; fade=true) =
@js_(o, Blink.fill($sel, $html, $fade))

content!(o, sel, html; fade = true) =
content!(o, sel, html; fade=true) =
content!(o, sel, stringmime(MIME"text/html"(), html), fade = fade)

body!(w, html; fade = true) = content!(w, "body", html, fade = fade)
Expand Down

0 comments on commit 7104f25

Please sign in to comment.