forked from 0x2620/pandora
77 lines
2.1 KiB
JavaScript
77 lines
2.1 KiB
JavaScript
// vim: et:ts=4:sw=4:sts=4:ft=javascript
|
|
'use strict';
|
|
|
|
pandora.ui.embedDialog = function(data) {
|
|
|
|
var content = Ox.Element().css({margin: '16px'}),
|
|
height = 360,
|
|
width = 640,
|
|
that = Ox.Dialog({
|
|
buttons: [
|
|
Ox.Button({
|
|
id: 'close',
|
|
title: 'Close'
|
|
}).bindEvent({
|
|
click: function() {
|
|
that.close();
|
|
}
|
|
})
|
|
],
|
|
closeButton: true,
|
|
content: content,
|
|
height: 120,
|
|
keys: {
|
|
'escape': 'close'
|
|
},
|
|
removeOnClose: true,
|
|
title: 'Embed Video',
|
|
width: 600
|
|
})
|
|
.bindEvent({
|
|
close: function(data) {
|
|
}
|
|
});
|
|
|
|
data.view = 'player';
|
|
|
|
content.html('To embed this video use this code on your page:<br>');
|
|
content.append(
|
|
$('<textarea>')
|
|
.css({
|
|
width: '520px',
|
|
margin: '16px',
|
|
height: '100%'
|
|
}).val(
|
|
'<iframe width="' + width
|
|
+ '" height="' + height
|
|
+ '" src="' + constructURL(data)
|
|
+ '" frameborder="0" allowfullscreen></iframe>'
|
|
).on({
|
|
click: function() {
|
|
this.focus();
|
|
this.select();
|
|
}
|
|
})
|
|
);
|
|
|
|
function constructURL(data) {
|
|
var url = document.location.protocol
|
|
+ '//' + document.location.host
|
|
+ '/' + pandora.user.ui.item + '/embed?',
|
|
query = [];
|
|
Ox.forEach(data, function(value, key) {
|
|
if (['in', 'out'].indexOf(key) > -1) {
|
|
value = value.toFixed(3);
|
|
}
|
|
if (key[0] != '_') {
|
|
query.push(
|
|
encodeURIComponent(key) + '=' + encodeURIComponent(value)
|
|
);
|
|
}
|
|
});
|
|
return url + query.join('&');
|
|
}
|
|
|
|
return that;
|
|
|
|
};
|