Ox.load({
    'UI': {
        loadCSS: false
    }
}, function() {
    var currentPage = PDFViewerApplication.page;
    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
                });
            }
        })
    })
    Ox.$parent.bindMessage({
        page: function(data) {
            if (data.page != PDFViewerApplication.page) {
                PDFViewerApplication.page = data.page;
            }
        },
        pdf: function(data) {
            if (PDFViewerApplication.url != data.pdf) {
                PDFViewerApplication.open(data.pdf);
            }
        }
    });
});

function getVideoOverlay(page) {
    var links = (window.embeds || []).filter(function(embed) {
        return embed.page == page && embed.type =='inline';
    });
    return (window.editable || links.length) ? {
        beginLayout: function() {
            this.counter = 0;
        },
        endLayout: function() {
        },
        appendImage: function(image) {
            var id = ++this.counter,
                video = links.filter(function(embed) {
                    return embed.id == id;
                })[0],
                $interface, $playButton, $editButton,
                pixelRatio = window.devicePixelRatio || 1;
            if (editable || video) {
                $interface = Ox.$('<div>')
                    .addClass('interface')
                    .css({
                        left: (image.left / pixelRatio) + 'px',
                        top: (image.top / pixelRatio) + 'px',
                        width: (image.width / pixelRatio) + 'px',
                        height: (image.height / pixelRatio) + 'px'
                    });
                $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();
                }
                if (video) {
                    enableVideoUI();
                }
                this.div.appendChild($interface[0]);
                Ox.$parent.bindMessage('update', function(data) {
                    if (video && data.id == video.id && data.page == video.page) {
                        video.src = data.src;
                        video.src !== '' ? enableVideoUI() : disableVideoUI();
                    }
                });
            }
            function play(e) {
                e.preventDefault();
                e.stopPropagation();
                var videoId = 'video' + page + id + Ox.uid(),
                    $iframe = Ox.Element('<iframe>')
                        .attr({
                            id: videoId,
                            src: video.src
                                + (video.src.indexOf('?') == -1 ? '?' : '&')
                                + '&showCloseButton=true&fullscreen=false&paused=false',
                            width: '100%',
                            height: '100%',
                            scrolling: 'no',
                            frameborder: 0
                        })
                        .bindMessage({
                            close: function(data) {
                                if(!closed) {
                                    closed = true;
                                    $iframe.remove();
                                    delete $iframe;
                                    $playButton.show();
                                    $editButton.show();
                                }
                            }
                        })
                        .appendTo($interface),
                    closed = false;
                $playButton.hide();
                $editButton.hide();
                return false;
            }
            function edit(e) {
                var url;
                e.preventDefault();
                e.stopPropagation();
                video = video || {
                    id: id,
                    page: page,
                    src: '',
                    type: 'inline'
                };
                Ox.$parent.postMessage('edit', video);
                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;
}