Ox.load('UI', {
    debug: true,
    theme: 'modern'
}, function() {

    //var id = '0393109';
    var id = '0097514';

    Ox.get('srt/' + id + '.srt', function(srt) {

        var subtitles = Ox.parseSRT(srt/*, 25*/),
            layers = [
                {
                    editable: true,
                    id: 'privatenotes',
                    items: [],
                    title: 'Private Notes'
                },
                {
                    editable: true,
                    id: 'publicnotes',
                    items: [],
                    title: 'Public Notes'
                },
                {
                    id: 'subtitles',
                    items: subtitles.map(function(subtitle, i) {
                        return {id: i, 'in': subtitle.in, out: subtitle.out, value: subtitle.text};
                    }),
                    title: 'Subtitles'
                }
            ];

        var $appPanel, $mainPanel;

        var $videoEditor = Ox.VideoEditor({
            annotationsSize: 256,
            duration: 3029.96,
            find: 'dode',
            getFrameURL: function(position, width) {
                return 'http://next.0xdb.org/' + id + '/frame/' + width + '/' + position + '.jpg'
            },
            getLargeTimelineImageURL: function(i) {
                return 'http://next.0xdb.org/' + id + '/timelines/timeline.64.' + i + '.png';
            },
            getSmallTimelineImageURL: function(i) {
                return 'http://next.0xdb.org/' + id + '/timelines/timeline.16.' + i + '.png';
            },
            height: window.innerHeight - 129,
            'in': 0,
            layers: layers,
            out: 0,
            position: 0,
            posterFrame: 1515,
            showAnnotations: true,
            subtitles: subtitles,
            video: {
                96: 'http://next.0xdb.org/' + id + '/96p.webm',
                240: 'http://next.0xdb.org/' + id + '/96p.webm?240p',
                480: 'http://next.0xdb.org/' + id + '/96p.webm?480p'
            },
            videoHeight: 96,
            videoSize: 'small',
            videoWidth: 124,
            width: window.innerWidth - 257
        });

        $appPanel = Ox.SplitPanel({
            elements: [
                {
                    collapsible: true,
                    element: Ox.Element(),
                    resizable: true,
                    resize: [128, 256, 384],
                    size: 256
                },
                {
                    element: $mainPanel = Ox.SplitPanel({
                        elements: [
                            {
                                collapsible: true,
                                element: Ox.Element(),
                                resizable: true,
                                resize: [64, 128, 192],
                                size: 128
                            },
                            {
                                element: $videoEditor
                            }
                        ],
                        orientation: 'vertical'
                    })
                }
            ],
            orientation: 'horizontal'
        })
        .appendTo(Ox.UI.$body);

        Ox.UI.$window.bind({
            resize: function() {
                $videoEditor.options({
                    width: $appPanel.getSize(1),
                    height: $mainPanel.getSize(1)
                });
            }
        });

        $mainPanel.bindEvent({
            resize: function(foo, size) {
                $videoEditor.options({
                    width: size
                });
            }
        });

        $videoEditor.bindEvent({
            resize: function(foo, size) {
                Ox.print('RESIZING', size)
                $videoEditor.options({
                    height: size
                });
            }
        });

        $videoEditor.$element.bindEvent({
            resize: function(foo, size) {
                Ox.print('RESIZING', size)
                $videoEditor.options({
                    height: size
                });
            }
        });


    });

});