-
Notifications
You must be signed in to change notification settings - Fork 0
/
inject-bsWidget.js
66 lines (62 loc) · 2.56 KB
/
inject-bsWidget.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
window.addEventListener('message', function (e) {
if (e.data == 'hidden.bs.modal') {
document.querySelector('.framediv').remove();
console.log('message', e.data); // debug
}
if (e.data == 'modalBs.show') {
document.querySelector('.lding').style.display = 'none';
console.log('message', e.data); // debug
}
});
cubeloader = document.createElement('link');
cubeloader.rel = 'stylesheet';
cubeloader.type = 'text/css';
cubeloader.href = 'cubeloader.css';
(document.head || document.documentElement).appendChild(cubeloader);
widgetButton = document.createElement('button');
widgetButton.type = 'button';
widgetButton.id = 'initButton';
widgetButton.className = 'btn btn-primary';
widgetButton.innerHTML = 'Pay with GOLOS';
document.querySelector('.bsMerch').appendChild(widgetButton); // button inject
lds = document.createElement('div');
lds.className = 'lding';
lds.innerHTML = `<div class="lds-css ng-scope">
<div class="lds-cube">
<div></div>
<div></div>
<div></div>
<div></div>
</div>
</div>`;
(document.body || document.documentElement).insertBefore(lds, (document.body || document.documentElement).firstChild); // lds inject
document.querySelector('#initButton').addEventListener('click', () => {
document.querySelector('.lding').style.display = 'block';
framediv = document.createElement('div');
framediv.className = 'framediv';
framediv.innerHTML = `<iframe id="bsIframe" frameborder="0" allowtransparency="true" src="bsWidget.html" style="display: none;"></iframe>`;
document.querySelector('.bsMerch').appendChild(framediv); // div inject
var iframe = document.getElementsByTagName('iframe')[0];
iframe.onload = function() {
iframe.style = `style="
z-index: 2147483647;
display: block;
overflow-y: auto;
visibility: visible;
margin: 0px;
padding: 0px;
position: fixed;
left: 0px;
top: 0px;
width: 100%;
height: 100%;"`;
iframe.contentWindow.postMessage(
`{ "data-account" : "` + document.querySelector('.golos-merchant-button').getAttribute('data-account') + `",
"data-amount" : "` + document.querySelector('.golos-merchant-button').getAttribute('data-amount') + `",
"data-fixprice" : "` + document.querySelector('.golos-merchant-button').getAttribute('data-fixprice') + `",
"data-description" : "` + document.querySelector('.golos-merchant-button').getAttribute('data-description') + `",
"data-image" : "` + document.querySelector('.golos-merchant-button').getAttribute('data-image') + `"
}`
, '*'); // get attr&send
};
}, false);