Add m.redraw() support for multiple mount points

To better match `0.2.x` behavior: https://jsfiddle.net/xbpyqL9k/
This commit is contained in:
Pat Cavit 2016-05-20 15:27:17 -07:00
parent 058b25002d
commit 71c77ba603
8 changed files with 97 additions and 30 deletions

View file

@ -3,7 +3,7 @@
var createRenderer = require("../render/render") var createRenderer = require("../render/render")
var throttle = require("../api/throttle") var throttle = require("../api/throttle")
module.exports = function($window, redraw) { module.exports = function($window, renderers) {
var renderer = createRenderer($window) var renderer = createRenderer($window)
return function(root, component) { return function(root, component) {
var run = throttle(function() { var run = throttle(function() {
@ -12,7 +12,7 @@ module.exports = function($window, redraw) {
renderer.setEventCallback(run) renderer.setEventCallback(run)
redraw.run = run renderers.push(run)
run() run()
} }
} }

12
api/redraw.js Normal file
View file

@ -0,0 +1,12 @@
"use strict"
module.exports = function(renderers) {
return function() {
if (renderers.length === 0) return
if (renderers.length === 1) return renderers[0]()
for (var i = 0; i < renderers.length; i++) {
renderers[i]()
}
}
}

View file

@ -4,7 +4,7 @@ var createRenderer = require("../render/render")
var createRouter = require("../router/router") var createRouter = require("../router/router")
var throttle = require("../api/throttle") var throttle = require("../api/throttle")
module.exports = function($window, redraw) { module.exports = function($window, renderers) {
var renderer = createRenderer($window) var renderer = createRenderer($window)
var router = createRouter($window) var router = createRouter($window)
var route = function(root, defaultRoute, routes) { var route = function(root, defaultRoute, routes) {
@ -16,7 +16,7 @@ module.exports = function($window, redraw) {
var run = throttle(replay) var run = throttle(replay)
renderer.setEventCallback(run) renderer.setEventCallback(run)
redraw.run = run renderers.push(run)
} }
route.link = router.link route.link = router.link
route.prefix = router.setPrefix route.prefix = router.setPrefix

View file

@ -19,10 +19,12 @@
<script src="../../querystring/parse.js"></script> <script src="../../querystring/parse.js"></script>
<script src="../../request/request.js"></script> <script src="../../request/request.js"></script>
<script src="../../router/router.js"></script> <script src="../../router/router.js"></script>
<script src="../redraw.js"></script>
<script src="../throttle.js"></script> <script src="../throttle.js"></script>
<script src="../mount.js"></script> <script src="../mount.js"></script>
<script src="../router.js"></script> <script src="../router.js"></script>
<script src="./test-redraw.js"></script>
<script src="./test-throttle.js"></script> <script src="./test-throttle.js"></script>
<script src="./test-mount.js"></script> <script src="./test-mount.js"></script>
<script src="./test-router.js"></script> <script src="./test-router.js"></script>

View file

@ -8,28 +8,30 @@ var createMounter = require("../mount")
o.spec("m.mount", function() { o.spec("m.mount", function() {
var FRAME_BUDGET = 1000 / 60 var FRAME_BUDGET = 1000 / 60
var $window, root var $window, root, mount, renderers
o.beforeEach(function() { o.beforeEach(function() {
$window = domMock() $window = domMock()
root = $window.document.body root = $window.document.body
renderers = []
mount = createMounter($window, renderers)
}) })
o("updates redraw object", function() { o("pushes a render function", function() {
var redraw = {}
var mount = createMounter($window, redraw)
mount(root, { mount(root, {
view : function() { view : function() {
return m("div") return m("div")
} }
}) })
o(typeof redraw.run).equals("function") o(renderers.length).equals(1)
o(typeof renderers[0]).equals("function")
}) })
o("renders into `root`", function() { o("renders into `root`", function() {
var mount = createMounter($window, {}) var mount = createMounter($window, [])
mount(root, { mount(root, {
view : function() { view : function() {
@ -44,7 +46,6 @@ o.spec("m.mount", function() {
var onupdate = o.spy() var onupdate = o.spy()
var oninit = o.spy() var oninit = o.spy()
var onclick = o.spy() var onclick = o.spy()
var mount = createMounter($window, {})
var e = $window.document.createEvent("MouseEvents") var e = $window.document.createEvent("MouseEvents")
e.initEvent("click", true, true) e.initEvent("click", true, true)
@ -80,7 +81,6 @@ o.spec("m.mount", function() {
o("event handlers can skip redraw", function(done) { o("event handlers can skip redraw", function(done) {
var onupdate = o.spy() var onupdate = o.spy()
var oninit = o.spy() var oninit = o.spy()
var mount = createMounter($window, {})
var e = $window.document.createEvent("MouseEvents") var e = $window.document.createEvent("MouseEvents")
e.initEvent("click", true, true) e.initEvent("click", true, true)
@ -109,11 +109,9 @@ o.spec("m.mount", function() {
}, 20) }, 20)
}) })
o("redraws on redraw.run()", function(done) { o("redraws when the render function is run", function(done) {
var onupdate = o.spy() var onupdate = o.spy()
var oninit = o.spy() var oninit = o.spy()
var redraw = {}
var mount = createMounter($window, redraw)
mount(root, { mount(root, {
view : function() { view : function() {
@ -127,7 +125,7 @@ o.spec("m.mount", function() {
o(oninit.callCount).equals(1) o(oninit.callCount).equals(1)
o(onupdate.callCount).equals(0) o(onupdate.callCount).equals(0)
redraw.run() renderers[0]()
// Wrapped to give time for the rate-limited redraw to fire // Wrapped to give time for the rate-limited redraw to fire
setTimeout(function() { setTimeout(function() {

55
api/tests/test-redraw.js Normal file
View file

@ -0,0 +1,55 @@
"use strict"
var o = require("../../ospec/ospec")
var createRedraw = require("../../api/redraw")
o.spec("m.redraw", function() {
var redraw, renderers
o.beforeEach(function() {
renderers = []
redraw = createRedraw(renderers)
})
o("it shouldn't error if there are no renderers", function() {
redraw()
})
o("it should run a single renderer entry", function() {
var spy = o.spy()
renderers.push(spy)
redraw()
o(spy.callCount).equals(1)
redraw()
redraw()
redraw()
o(spy.callCount).equals(4)
})
o("it should run all renderer entries", function() {
var spy1 = o.spy()
var spy2 = o.spy()
var spy3 = o.spy()
renderers.push(spy1, spy2, spy3)
redraw()
o(spy1.callCount).equals(1)
o(spy2.callCount).equals(1)
o(spy3.callCount).equals(1)
redraw()
redraw()
redraw()
o(spy1.callCount).equals(4)
o(spy2.callCount).equals(4)
o(spy3.callCount).equals(4)
})
})

View file

@ -9,7 +9,7 @@ var router = require("../../api/router")
o.spec("m.route", function() { o.spec("m.route", function() {
var FRAME_BUDGET = 1000 / 60 var FRAME_BUDGET = 1000 / 60
var $window, root, route, redraw var $window, root, route, renderers
o.beforeEach(function() { o.beforeEach(function() {
$window = {} $window = {}
@ -22,11 +22,11 @@ o.spec("m.route", function() {
root = $window.document.body root = $window.document.body
redraw = {} renderers = []
route = router($window, redraw) route = router($window, renderers)
}) })
o("updates redraw object", function() { o("pushes a render function", function() {
route(root, "/", { route(root, "/", {
"/" : { "/" : {
view: function() { view: function() {
@ -35,7 +35,8 @@ o.spec("m.route", function() {
} }
}) })
o(typeof redraw.run).equals("function") o(renderers.length).equals(1)
o(typeof renderers[0]).equals("function")
}) })
o("renders into `root`", function() { o("renders into `root`", function() {
@ -50,7 +51,7 @@ o.spec("m.route", function() {
o(root.firstChild.nodeName).equals("DIV") o(root.firstChild.nodeName).equals("DIV")
}) })
o("redraws on redraw.run()", function(done) { o("redraws when render function is executed", function(done) {
var onupdate = o.spy() var onupdate = o.spy()
var oninit = o.spy() var oninit = o.spy()
@ -67,7 +68,7 @@ o.spec("m.route", function() {
o(oninit.callCount).equals(1) o(oninit.callCount).equals(1)
redraw.run() renderers[0]()
// Wrapped to give time for the rate-limited redraw to fire // Wrapped to give time for the rate-limited redraw to fire
setTimeout(function() { setTimeout(function() {

View file

@ -3,18 +3,17 @@
var m = require("./render/hyperscript") var m = require("./render/hyperscript")
var trust = require("./render/trust") var trust = require("./render/trust")
var createRenderer = require("./render/render") var createRenderer = require("./render/render")
var createRedraw = require("./api/redraw")
var createMounter = require("./api/mount") var createMounter = require("./api/mount")
var createRouterInstance = require("./api/router") var createRouterInstance = require("./api/router")
var createRequester = require("./request/request") var createRequester = require("./request/request")
var redraw = {run: function() {}} var renderers = []
m.redraw = function() { m.redraw = createRedraw(renderers)
redraw.run()
}
m.trust = trust m.trust = trust
m.render = createRenderer(window).render m.render = createRenderer(window).render
m.mount = createMounter(window, redraw) m.mount = createMounter(window, renderers)
m.route = createRouterInstance(window, redraw) m.route = createRouterInstance(window, renderers)
m.request = createRequester(window, Promise).ajax m.request = createRequester(window, Promise).ajax
module.exports = m module.exports = m