pandora/static/pdf.js/embeds.js

152 lines
6.4 KiB
JavaScript
Raw Permalink Normal View History

Ox.load({
'UI': {
loadCSS: false
}
}, function() {
2023-10-27 11:19:54 +00:00
var currentPage = PDFViewerApplication.page;
2023-10-27 11:47:56 +00:00
PDFViewerApplication.initializedPromise.then(function() {
PDFViewerApplication.pdfViewer.eventBus.on("pagechanging", function(event) {
var page = event.pageNumber;
if (page && page != currentPage) {
currentPage = page;
Ox.$parent.postMessage('page', {
page: page
});
}
})
})
2014-09-25 19:55:44 +00:00
Ox.$parent.bindMessage({
page: function(data) {
2023-10-27 11:19:54 +00:00
if (data.page != PDFViewerApplication.page) {
PDFViewerApplication.page = data.page;
2013-12-31 11:04:23 +00:00
}
},
pdf: function(data) {
2023-10-27 11:19:54 +00:00
if (PDFViewerApplication.url != data.pdf) {
PDFViewerApplication.open(data.pdf);
2014-01-07 15:34:55 +00:00
}
}
});
});
2013-02-21 14:09:23 +00:00
function getVideoOverlay(page) {
var links = (window.embeds || []).filter(function(embed) {
2013-02-21 14:52:41 +00:00
return embed.page == page && embed.type =='inline';
});
return (window.editable || links.length) ? {
2013-02-21 14:09:23 +00:00
beginLayout: function() {
this.counter = 0;
},
endLayout: function() {
},
appendImage: function(image) {
var id = ++this.counter,
2013-02-21 14:52:41 +00:00
video = links.filter(function(embed) {
return embed.id == id;
})[0],
2016-04-04 13:48:46 +00:00
$interface, $playButton, $editButton,
pixelRatio = window.devicePixelRatio || 1;
2013-02-21 14:52:41 +00:00
if (editable || video) {
2013-02-21 14:09:23 +00:00
$interface = Ox.$('<div>')
.addClass('interface')
.css({
2016-04-04 13:48:46 +00:00
left: (image.left / pixelRatio) + 'px',
top: (image.top / pixelRatio) + 'px',
width: (image.width / pixelRatio) + 'px',
height: (image.height / pixelRatio) + 'px'
2013-02-21 14:09:23 +00:00
});
$playButton = Ox.$('<img>')
.addClass('button playButton')
.attr({
src: ''
})
.hide()
.appendTo($interface);
$editButton = Ox.$('<img>')
.addClass('button editButton')
.attr({
src: '',
title: 'Click to add video'
})
.on({click: edit})
.hide()
.appendTo($interface);
if (editable) {
$editButton.show();
}
2013-02-21 14:52:41 +00:00
if (video) {
2013-02-21 14:09:23 +00:00
enableVideoUI();
}
this.div.appendChild($interface[0]);
2014-09-25 19:55:44 +00:00
Ox.$parent.bindMessage('update', function(data) {
if (video && data.id == video.id && data.page == video.page) {
video.src = data.src;
video.src !== '' ? enableVideoUI() : disableVideoUI();
}
});
2013-02-21 14:09:23 +00:00
}
function play(e) {
e.preventDefault();
e.stopPropagation();
var videoId = 'video' + page + id + Ox.uid(),
$iframe = Ox.Element('<iframe>')
2013-02-21 14:09:23 +00:00
.attr({
id: videoId,
2013-09-08 18:12:44 +00:00
src: video.src
+ (video.src.indexOf('?') == -1 ? '?' : '&')
+ '&showCloseButton=true&fullscreen=false&paused=false',
2013-02-21 14:09:23 +00:00
width: '100%',
height: '100%',
scrolling: 'no',
2013-02-21 14:09:23 +00:00
frameborder: 0
})
.bindMessage({
close: function(data) {
if(!closed) {
closed = true;
$iframe.remove();
delete $iframe;
$playButton.show();
$editButton.show();
}
}
})
.appendTo($interface),
closed = false;
2013-02-21 14:09:23 +00:00
$playButton.hide();
$editButton.hide();
return false;
}
function edit(e) {
var url;
e.preventDefault();
e.stopPropagation();
video = video || {
id: id,
page: page,
src: '',
type: 'inline'
};
2014-09-25 19:55:44 +00:00
Ox.$parent.postMessage('edit', video);
2013-02-21 14:09:23 +00:00
return false;
}
function enableVideoUI() {
$interface
.addClass('video')
.attr({title: 'Click to play video'})
.on({click: play});
$playButton.show();
$editButton.attr({title: 'Click to edit or remove video'});
}
function disableVideoUI() {
$interface
.removeClass('video')
.attr({title: ''})
.off({click: play});
$playButton.hide();
$editButton.attr({title: 'Click to add video'});
}
}
} : null;
}