forked from 0x2620/pandora
205 lines
9.6 KiB
JavaScript
205 lines
9.6 KiB
JavaScript
// vim: et:ts=4:sw=4:sts=4:ft=javascript
|
|
|
|
'use strict';
|
|
|
|
pandora.ui.clipList = function(videoRatio) {
|
|
|
|
var ui = pandora.user.ui,
|
|
fixedRatio = !ui.item ? 16/9 : videoRatio,
|
|
isClipView = !ui.item ? ui.listView == 'clip' : ui.itemView == 'clips',
|
|
that = Ox.IconList({
|
|
fixedRatio: fixedRatio,
|
|
item: function(data, sort, size) {
|
|
size = size || 128; // fixme: is this needed?
|
|
var ratio, width, height,
|
|
format, info, sortKey, title, url;
|
|
if (!ui.item) {
|
|
ratio = data.videoRatio;
|
|
width = ratio > fixedRatio ? size : Math.round(size * ratio / fixedRatio);
|
|
height = Math.round(width / ratio);
|
|
} else {
|
|
width = fixedRatio > 1 ? size : Math.round(size * fixedRatio);
|
|
height = fixedRatio > 1 ? Math.round(size / fixedRatio) : size;
|
|
}
|
|
title = data.annotations ? data.annotations.map(function(annotation) {
|
|
return Ox.stripTags(annotation.value);
|
|
}).join('; ') : '',
|
|
url = '/' + data.id.split('/')[0] + '/' + height + 'p' + data['in'] + '.jpg';
|
|
sortKey = sort[0].key;
|
|
if (['text', 'position', 'duration'].indexOf(sortKey) > -1) {
|
|
info = Ox.formatDuration(data['in']) + ' - '
|
|
+ Ox.formatDuration(data.out);
|
|
} else {
|
|
format = pandora.getSortKeyData(sortKey).format;
|
|
if (format) {
|
|
info = (
|
|
/^color/.test(format.type.toLowerCase()) ? Ox.Theme : Ox
|
|
)['format' + Ox.toTitleCase(format.type)].apply(
|
|
this, Ox.merge([data[sortKey]], format.args || [])
|
|
);
|
|
} else {
|
|
info = data[sortKey];
|
|
}
|
|
}
|
|
return {
|
|
height: height,
|
|
id: data.id,
|
|
info: info,
|
|
title: title,
|
|
url: url,
|
|
width: width
|
|
};
|
|
},
|
|
items: function(data, callback) {
|
|
if (!isClipView) {
|
|
// fixme: this will have to be updated
|
|
callback({data: {items: []}});
|
|
return;
|
|
}
|
|
var itemsQuery, query;
|
|
if (!ui.item) {
|
|
itemsQuery = ui.find;
|
|
query = {conditions: [], operator: '&'};
|
|
// if the item query contains a layer condition,
|
|
// then this condition is added to the clip query
|
|
itemsQuery.conditions.forEach(function(condition) {
|
|
if (condition.key == 'annotations'
|
|
|| Ox.getIndexById(pandora.site.layers, condition.key) > -1) {
|
|
query.conditions.push(condition);
|
|
}
|
|
});
|
|
} else {
|
|
itemsQuery = {
|
|
conditions:[{key: 'id', value: ui.item, operator: '=='}],
|
|
operator: '&'
|
|
};
|
|
query = pandora.user.ui.itemFind;
|
|
}
|
|
pandora.api.findClips(Ox.extend({
|
|
itemsQuery: itemsQuery,
|
|
query: query
|
|
}, data), callback);
|
|
},
|
|
keys: Ox.merge(
|
|
['annotations', 'id', 'in', 'out'],
|
|
!ui.item ? ['videoRatio'] : []
|
|
),
|
|
max: 1,
|
|
orientation: 'both',
|
|
size: 128,
|
|
sort: !ui.item ? ui.listSort : ui.itemSort,
|
|
unique: 'id'
|
|
})
|
|
.bindEvent({
|
|
init: function(data) {
|
|
// fixme: status needs an overhaul
|
|
if (!ui.item && pandora.$ui.total) {
|
|
pandora.$ui.total.html(pandora.ui.status('total', data));
|
|
}
|
|
},
|
|
open: function(data) {
|
|
var id = data.ids[0],
|
|
item = !ui.item ? id.split('/')[0] : ui.item,
|
|
points = {
|
|
annotation: that.value(id, 'annotations')[0].id.split('/')[1],
|
|
'in': that.value(id, 'in'),
|
|
out: that.value(id, 'out'),
|
|
position: that.value(id, 'in')
|
|
},
|
|
set = {
|
|
item: item,
|
|
itemView: pandora.user.ui.videoView
|
|
};
|
|
set['videoPoints.' + item] = Ox.extend(points, {
|
|
position: points['in']
|
|
});
|
|
pandora.UI.set(set);
|
|
},
|
|
openpreview: function(data) {
|
|
// on press space key
|
|
var $video = that.find('.OxItem.OxSelected > .OxIcon > .OxVideoPlayer');
|
|
if ($video) {
|
|
// trigger singleclick
|
|
$video.trigger('mousedown');
|
|
Ox.UI.$window.trigger('mouseup');
|
|
}
|
|
that.closePreview();
|
|
},
|
|
select: function(data) {
|
|
if (data.ids.length) {
|
|
var id = data.ids[0],
|
|
item = id.split('/')[0], width, height,
|
|
$img = that.find('.OxItem.OxSelected > .OxIcon > img'),
|
|
$video = that.find('.OxItem.OxSelected > .OxIcon > .OxVideoPlayer'),
|
|
size = 128, ratio, width, height;
|
|
if ($img.length) {
|
|
if (!ui.item) {
|
|
ratio = that.value(id, 'videoRatio');
|
|
width = ratio > fixedRatio ? size : Math.round(size * ratio / fixedRatio);
|
|
height = Math.round(width / ratio);
|
|
} else {
|
|
width = fixedRatio > 1 ? size : Math.round(size * fixedRatio);
|
|
height = fixedRatio > 1 ? Math.round(size / fixedRatio) : size;
|
|
}
|
|
pandora.api.get({id: item, keys: ['durations', 'rightslevel']}, function(result) {
|
|
var points = [that.value(id, 'in'), that.value(id, 'out')],
|
|
partsAndPoints = pandora.getVideoPartsAndPoints(
|
|
result.data.durations, points
|
|
),
|
|
$player = Ox.VideoPlayer({
|
|
censored: pandora.site.capabilities.canPlayClips[pandora.user.level] < result.data.rightslevel
|
|
? [{'in': partsAndPoints.points[0], out: partsAndPoints.points[1]}]
|
|
: [],
|
|
height: height,
|
|
'in': partsAndPoints.points[0],
|
|
out: partsAndPoints.points[1],
|
|
paused: true,
|
|
playInToOut: true,
|
|
poster: '/' + item + '/' + height + 'p' + points[0] + '.jpg',
|
|
rewind: true,
|
|
video: partsAndPoints.parts.map(function(i) {
|
|
var part = (i + 1),
|
|
prefix = pandora.site.site.videoprefix.replace('PART', part);
|
|
return prefix + '/' + item + '/96p' + part + '.' + pandora.user.videoFormat;
|
|
}),
|
|
width: width
|
|
})
|
|
.addClass('OxTarget')
|
|
.bindEvent({
|
|
// doubleclick opens item
|
|
singleclick: function() {
|
|
$player.$element.is('.OxSelectedVideo') && $player.togglePaused();
|
|
}
|
|
});
|
|
$img.replaceWith($player.$element);
|
|
$('.OxSelectedVideo').removeClass('OxSelectedVideo');
|
|
$player.$element.addClass('OxSelectedVideo');
|
|
});
|
|
} else if ($video.length) {
|
|
// item select fires before video click
|
|
// so we have to make sure that selecting
|
|
// an item that already has a video
|
|
// doesn't click through to play
|
|
///*
|
|
setTimeout(function() {
|
|
$('.OxSelectedVideo').removeClass('OxSelectedVideo');
|
|
$video.addClass('OxSelectedVideo');
|
|
}, 300);
|
|
//*/
|
|
}
|
|
!ui.item && pandora.UI.set('listSelection', [item]);
|
|
} else {
|
|
$('.OxSelectedVideo').removeClass('OxSelectedVideo');
|
|
!ui.item && pandora.UI.set('listSelection', []);
|
|
}
|
|
},
|
|
pandora_itemsort: function(data) {
|
|
that.options({sort: data.value});
|
|
},
|
|
pandora_listsort: function(data) {
|
|
that.options({sort: data.value});
|
|
}
|
|
});
|
|
return that;
|
|
|
|
}
|