2018-01-25 04:05:59 -06:00
|
|
|
(function() {
|
|
|
|
'use strict';
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
var page = require('webpage').create();
|
|
|
|
var args = require('system').args;
|
|
|
|
var params = {};
|
|
|
|
var regexp = /^([^=]+)=([^$]+)/;
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
args.forEach(function(arg) {
|
|
|
|
var parts = arg.match(regexp);
|
|
|
|
if (!parts) { return; }
|
|
|
|
params[parts[1]] = parts[2];
|
|
|
|
});
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
var usage = "url=<url> png=<filename> width=<width> height=<height> renderKey=<key>";
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
if (!params.url || !params.png || !params.renderKey || !params.domain) {
|
|
|
|
console.log(usage);
|
|
|
|
phantom.exit();
|
|
|
|
}
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
phantom.addCookie({
|
|
|
|
'name': 'renderKey',
|
|
|
|
'value': params.renderKey,
|
|
|
|
'domain': params.domain,
|
|
|
|
});
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
page.viewportSize = {
|
|
|
|
width: params.width || '800',
|
|
|
|
height: params.height || '400'
|
|
|
|
};
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
var timeoutMs = (parseInt(params.timeout) || 10) * 1000;
|
|
|
|
var waitBetweenReadyCheckMs = 50;
|
|
|
|
var totalWaitMs = 0;
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
page.open(params.url, function (status) {
|
|
|
|
console.log('Loading a web page: ' + params.url + ' status: ' + status, timeoutMs);
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
page.onError = function(msg, trace) {
|
|
|
|
var msgStack = ['ERROR: ' + msg];
|
|
|
|
if (trace && trace.length) {
|
|
|
|
msgStack.push('TRACE:');
|
|
|
|
trace.forEach(function(t) {
|
|
|
|
msgStack.push(' -> ' + t.file + ': ' + t.line + (t.function ? ' (in function "' + t.function +'")' : ''));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
console.error(msgStack.join('\n'));
|
|
|
|
};
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
function checkIsReady() {
|
|
|
|
var panelsRendered = page.evaluate(function() {
|
2018-05-24 08:26:27 -05:00
|
|
|
var panelCount = document.querySelectorAll('.panel').length;
|
|
|
|
return window.panelsRendered >= panelCount;
|
2018-01-25 04:05:59 -06:00
|
|
|
});
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
if (panelsRendered || totalWaitMs > timeoutMs) {
|
|
|
|
var bb = page.evaluate(function () {
|
2018-09-19 10:43:33 -05:00
|
|
|
return document.getElementsByClassName("dashboard-container")[0].getBoundingClientRect();
|
2018-01-25 04:05:59 -06:00
|
|
|
});
|
2018-09-19 10:43:33 -05:00
|
|
|
|
|
|
|
// reset viewport to render full page
|
|
|
|
page.viewportSize = {
|
|
|
|
width: bb.width,
|
|
|
|
height: bb.height
|
|
|
|
};
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
page.clipRect = {
|
|
|
|
top: bb.top,
|
|
|
|
left: bb.left,
|
|
|
|
width: bb.width,
|
|
|
|
height: bb.height
|
|
|
|
};
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
page.render(params.png);
|
|
|
|
phantom.exit();
|
|
|
|
} else {
|
|
|
|
totalWaitMs += waitBetweenReadyCheckMs;
|
|
|
|
setTimeout(checkIsReady, waitBetweenReadyCheckMs);
|
|
|
|
}
|
|
|
|
}
|
2018-02-15 05:42:17 -06:00
|
|
|
|
2018-01-25 04:05:59 -06:00
|
|
|
setTimeout(checkIsReady, waitBetweenReadyCheckMs);
|
|
|
|
});
|
2018-02-15 05:42:17 -06:00
|
|
|
})();
|