| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- (function() {
- 'use strict';
- var page = require('webpage').create();
- var args = require('system').args;
- var params = {};
- var regexp = /^([^=]+)=([^$]+)/;
- args.forEach(function(arg) {
- var parts = arg.match(regexp);
- if (!parts) { return; }
- params[parts[1]] = parts[2];
- });
- var usage = "url=<url> png=<filename> width=<width> height=<height> cookiename=<cookiename> sessionid=<sessionid> domain=<domain>";
- if (!params.url || !params.png || !params.cookiename || ! params.sessionid || !params.domain) {
- console.log(usage);
- phantom.exit();
- }
- phantom.addCookie({
- 'name': params.cookiename,
- 'value': params.sessionid,
- 'domain': params.domain
- });
- page.viewportSize = {
- width: params.width || '800',
- height: params.height || '400'
- };
- var tries = 0;
- page.open(params.url, function (status) {
- console.log('Loading a web page: ' + params.url + ' status: ' + status);
- function checkIsReady() {
- var canvas = page.evaluate(function() {
- if (!window.angular) { return false; }
- var body = window.angular.element(document.body); // 1
- if (!body.scope) { return false; }
- var rootScope = body.scope();
- if (!rootScope) {return false;}
- if (!rootScope.performance) { return false; }
- var panelsToLoad = window.angular.element('div.panel').length;
- return rootScope.performance.panelsRendered >= panelsToLoad;
- });
- if (canvas || tries === 1000) {
- var bb = page.evaluate(function () {
- return document.getElementsByClassName("main-view")[0].getBoundingClientRect();
- });
- page.clipRect = {
- top: bb.top,
- left: bb.left,
- width: bb.width,
- height: bb.height
- };
- page.render(params.png);
- phantom.exit();
- }
- else {
- tries++;
- setTimeout(checkIsReady, 10);
- }
- }
- setTimeout(checkIsReady, 200);
- });
- })();
|