/** * */ /** * Operation Decsription */ var operation = { /** * Content might be empty, can contain text or an URL */ content: "Beispiel Text", /** * Connector: all PDF-AS Connector values */ connector: "local", /** * DIV id where to place to UI */ uiId: "" }; var pdfAsOrigin = "##REPLACE##DOMAIN##"; var pdfAsUrl = "##REPLACE##DOMAIN####REPLACE##CONTEXT##/Start"; var pdfAsVersionUrl = "##REPLACE##DOMAIN####REPLACE##CONTEXT##/version"; var pdfAs = {}; /** * create signed PDF Document containing * @param content The text content of the PDF Document * @returns */ pdfAs.signText = function(content, error, success) { this.createAsyncSignature(content.content, content.connector, content.uiId, pdfAsUrl, "TEXT", success, error); }; pdfAs.signPdf = function(content, error, success) { this.createAsyncSignature(content.content, content.connector, content.uiId, pdfAsUrl, "PDF", success, error); }; pdfAs.getVersion = function(cb, err) { var xmlhttp; if (window.XMLHttpRequest) { // code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp = new XMLHttpRequest(); } else { // code for IE6, IE5 xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange = function() { if (xmlhttp.readyState == 4 ) { if(xmlhttp.status == 200){ var obj = JSON.parse(xmlhttp.responseText); cb(obj); } else if(xmlhttp.status == 400) { err('There was an error 400') } else { err('something else other than 200 was returned') } } } xmlhttp.open("GET", pdfAsVersionUrl, true); xmlhttp.send(); } var postman = new NoJQueryPostMessageMixin('postMessage', 'receiveMessage'); var guid = (function() { function s4() { return Math.floor((1 + Math.random()) * 0x10000) .toString(16) .substring(1); } return function() { return s4() + s4() + '-' + s4() + '-' + s4() + '-' + s4() + '-' + s4() + s4() + s4(); }; })(); function encodeQueryData(data) { var ret = []; for (var d in data) { if (typeof data[d] != "undefined") { ret.push(encodeURIComponent(d) + "=" + encodeURIComponent(data[d])); } } return ret.join("&"); }; function addDataToForm(data, form) { var ret = []; for (var d in data) { if (typeof data[d] != "undefined") { var input = document.createElement('input'); input.type = 'hidden'; input.name = d; input.value = data[d]; form.appendChild(input); } } } pdfAs.cbMap = {}; pdfAs.autoResize = function(eventId, height, width){ var newheight = height; var newwidth = width; console.log("Resising iframe " + width + "x" + height); newheight = newheight + 20; document.getElementById(eventId).height= (newheight) + "px"; document.getElementById(eventId).width= (newwidth) + "px"; eventId = eventId.substring(0, eventId.length - 7); var custDiv = eventId + "_div"; var element = document.getElementById(custDiv); element.style.margin = '-' + element.scrollHeight / 2 + 'px 0 0 -' + element.scrollWidth / 2 + 'px'; }; pdfAs.createAsyncSignature = function(pdfUrl, connector, divID, pdfAsURL, type, success, error) { // generate EventID var eventId = guid(); var parameters = { PDFURL: pdfUrl, CONNECTOR: connector, EVENTID: eventId, TYPE: type, TARGETURL: document.URL, NEW: "1" }; /*var querystring = encodeQueryData(parameters); console.log("Querystring: " + querystring); var url = pdfAsURL; if(pdfAsURL.indexOf('?') === -1) { url = url + "?" + querystring; } else { url = url + "&" + querystring; } console.log("URL: " + url);*/ var iframeid = eventId + "_iframe"; var iframe = document.createElement('iframe'); iframe.width = '100%'; iframe.height = '100%'; iframe.frameBorder = '0'; //iframe.src = url; iframe.id = iframeid; iframe.name = iframeid; iframe.style.overflow="auto"; iframe.scrolling="no"; if (typeof divID === "undefined") { // Create a div var custDiv = eventId + "_div"; var docHeight = window.innerHeight; //grab the height of the page var scrollTop = window.screenTop; //grab the px value from the top of the page to where you're scrolling var div = document.createElement('div'); document.body.appendChild(div); div.id = custDiv; div.style.display = 'block'; div.style.zIndex = 32770; div.style.background = '#FFF'; div.style.position = 'absolute'; //div.style.width = '45em'; //div.style.height = '300px'; div.style.top = '50%'; div.style.left = '50%'; div.style.margin = '-150px 0 0 -22.5em'; div.style.textAlign = 'center'; div.style.boxShadow = '0 0 5px #E0E4CC'; div.style.borderStyle= 'groove'; div.style.borderRadius= '8px'; div.style.borderColor= '#E0E4CC'; var innerdiv = document.createElement('div'); innerdiv.style.display = 'block'; div.appendChild(innerdiv); var innerdivbottom = document.createElement('div'); innerdivbottom.style.display = 'block'; div.appendChild(innerdivbottom); innerdivbottom.innerHTML = "