diff options
| -rw-r--r-- | crocoite/behavior.py | 3 | ||||
| -rw-r--r-- | crocoite/data/scroll.js | 57 | 
2 files changed, 33 insertions, 27 deletions
| diff --git a/crocoite/behavior.py b/crocoite/behavior.py index d5c82a0..5f66538 100644 --- a/crocoite/behavior.py +++ b/crocoite/behavior.py @@ -120,9 +120,10 @@ class JsOnload (Behavior):          tab = self.loader.tab          yield self.script          result = await tab.Runtime.evaluate (expression=str (self.script)) +        exception = result.get ('exceptionDetails', None)          result = result['result']          assert result['type'] == 'object' -        assert result.get ('subtype') != 'error' +        assert result.get ('subtype') != 'error', exception          self.context = result['objectId']      async def onstop (self): diff --git a/crocoite/data/scroll.js b/crocoite/data/scroll.js index 8a4b35d..aacfe83 100644 --- a/crocoite/data/scroll.js +++ b/crocoite/data/scroll.js @@ -1,33 +1,38 @@  /*	Continuously scrolls the page   */  (function(){ -let scrolled = new Map (); -let interval = null; -function stop() { -	window.clearInterval (interval); -	window.scrollTo (0, 0); -	scrolled.forEach (function (value, key, map) { -		key.scrollTop = value; -	}); -} -/* save initial scroll state */ -function save(obj) { -	if (!scrolled.has (obj)) { -		scrolled.set (obj, obj.scrollTop); +class Scroll { +	constructor () { +		this.scrolled = new Map (); +		this.interval = window.setInterval (this.scroll.bind (this), 200);  	} -} -/* perform a single scroll step */ -function scroll (event) { -	window.scrollBy (0, window.innerHeight/2); -	document.querySelectorAll ('html body *').forEach ( -		function (d) { -			if (d.scrollHeight-d.scrollTop > d.clientHeight) { -				save (d); -				d.scrollBy (0, d.clientHeight/2); -			} + +	stop() { +		window.clearInterval (this.interval); +		window.scrollTo (0, 0); +		this.scrolled.forEach (function (value, key, map) { +			key.scrollTop = value;  		}); -	return true; +	} +	/* save initial scroll state */ +	save(obj) { +		if (!this.scrolled.has (obj)) { +			this.scrolled.set (obj, obj.scrollTop); +		} +	} +	/* perform a single scroll step */ +	scroll (event) { +		window.scrollBy (0, window.innerHeight/2); +		document.querySelectorAll ('html body *').forEach ( +			function (d) { +				if (d.scrollHeight-d.scrollTop > d.clientHeight) { +					this.save (d); +					d.scrollBy (0, d.clientHeight/2); +				} +			}.bind (this)); +		return true; +	}  } -interval = window.setInterval (scroll, 200); -return {'stop': stop}; + +return new Scroll();  }()) | 
