allow selecting multiple annotations to get in/out range
This commit is contained in:
parent
168cdd691c
commit
96d4dfe71d
3 changed files with 65 additions and 4 deletions
|
@ -1398,6 +1398,9 @@ Video
|
||||||
.$themeClass .OxAnnotationFolder .OxArrayEditable .OxEditableElement.OxEditable.OxSelected {
|
.$themeClass .OxAnnotationFolder .OxArrayEditable .OxEditableElement.OxEditable.OxSelected {
|
||||||
background-color: $videoAnnotationEditableSelectedBackground;
|
background-color: $videoAnnotationEditableSelectedBackground;
|
||||||
}
|
}
|
||||||
|
.$themeClass .OxAnnotationFolder .OxArrayEditable .OxEditableElement.OxEditable.OxSelected.OxMultiple {
|
||||||
|
background-color: $videoAnnotationSelectedBackground;
|
||||||
|
}
|
||||||
.$themeClass .OxAnnotationFolder .OxArrayEditable .OxEditableElement.OxSelected .OxHighlight {
|
.$themeClass .OxAnnotationFolder .OxArrayEditable .OxEditableElement.OxSelected .OxHighlight {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
background-image: -moz-repeating-linear-gradient(
|
background-image: -moz-repeating-linear-gradient(
|
||||||
|
|
|
@ -146,12 +146,20 @@ Ox.ArrayEditable = function(options, self) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getId(position) {
|
||||||
|
return position > -1 ? self.options.items[position].id : '';
|
||||||
|
}
|
||||||
|
|
||||||
function getSelectedId() {
|
function getSelectedId() {
|
||||||
return self.selected > -1 ? self.options.items[self.selected].id : '';
|
return getId(self.selected);
|
||||||
|
}
|
||||||
|
|
||||||
|
function getPosition(id) {
|
||||||
|
return Ox.getIndexById(self.options.items, id);
|
||||||
}
|
}
|
||||||
|
|
||||||
function getSelectedPosition() {
|
function getSelectedPosition() {
|
||||||
return Ox.getIndexById(self.options.items, self.options.selected);
|
return getPosition(self.options.selected);
|
||||||
}
|
}
|
||||||
|
|
||||||
function renderItems(blur) {
|
function renderItems(blur) {
|
||||||
|
@ -267,6 +275,42 @@ Ox.ArrayEditable = function(options, self) {
|
||||||
: that.triggerEvent('selectprevious');
|
: that.triggerEvent('selectprevious');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
function toggleItem(idOrPosition) {
|
||||||
|
var id, position;
|
||||||
|
if (Ox.isString(idOrPosition)) {
|
||||||
|
id = idOrPosition
|
||||||
|
position = getPosition(id);
|
||||||
|
} else {
|
||||||
|
position = idOrPosition
|
||||||
|
id = getId(position);
|
||||||
|
}
|
||||||
|
if (!Ox.isArray(self.options.selected)) {
|
||||||
|
self.options.selected = [self.options.selected]
|
||||||
|
}
|
||||||
|
if (!Ox.isArray(self.selected)) {
|
||||||
|
self.selected = [self.selected]
|
||||||
|
}
|
||||||
|
if (self.options.selected.includes(id)) {
|
||||||
|
self.options.selected.pop(id)
|
||||||
|
self.selected.pop(position)
|
||||||
|
} else {
|
||||||
|
self.options.selected.push(id)
|
||||||
|
self.selected.push(position)
|
||||||
|
}
|
||||||
|
that.find('.OxSelected').removeClass('OxSelected').removeClass('OxMultiple');
|
||||||
|
that.find('.OxGroup').removeClass('OxGroup')
|
||||||
|
if (self.options.selected.length == 1) {
|
||||||
|
self.options.selected = self.options.selected[0]
|
||||||
|
self.selected = self.selected[0]
|
||||||
|
self.$items[self.selected].addClass('OxSelected');
|
||||||
|
self.options.highlightGroup && that.updateItemGroup()
|
||||||
|
} else {
|
||||||
|
Ox.forEach(self.selected, function(selected) {
|
||||||
|
self.$items[selected].addClass('OxSelected').addClass('OxMultiple');
|
||||||
|
})
|
||||||
|
}
|
||||||
|
triggerSelectEvent();
|
||||||
|
}
|
||||||
|
|
||||||
function selectItem(idOrPosition) {
|
function selectItem(idOrPosition) {
|
||||||
if (Ox.isString(idOrPosition)) {
|
if (Ox.isString(idOrPosition)) {
|
||||||
|
@ -327,8 +371,14 @@ Ox.ArrayEditable = function(options, self) {
|
||||||
position = $element.data('position');
|
position = $element.data('position');
|
||||||
// if clicked on an element
|
// if clicked on an element
|
||||||
if (position != self.selected) {
|
if (position != self.selected) {
|
||||||
// select another item
|
if (e.shiftKey) {
|
||||||
selectItem(position);
|
// add/remove item from multiple selection
|
||||||
|
document.getSelection().removeAllRanges();
|
||||||
|
toggleItem(position);
|
||||||
|
} else {
|
||||||
|
// select another item
|
||||||
|
selectItem(position);
|
||||||
|
}
|
||||||
} else if (e.metaKey) {
|
} else if (e.metaKey) {
|
||||||
// or deselect current item
|
// or deselect current item
|
||||||
selectNone();
|
selectNone();
|
||||||
|
|
|
@ -1350,6 +1350,14 @@ Ox.VideoAnnotationPanel = function(options, self) {
|
||||||
if (Ox.isUndefined(data)) {
|
if (Ox.isUndefined(data)) {
|
||||||
// doubleclick on small timeline
|
// doubleclick on small timeline
|
||||||
data = getAnnotation();
|
data = getAnnotation();
|
||||||
|
} else if (Ox.isArray(data.id)) {
|
||||||
|
var range = data.id.map(id => {
|
||||||
|
return Ox.getObjectById(self.annotations, id)
|
||||||
|
})
|
||||||
|
data['in'] = Ox.min(range.map(annotation => { return annotation["in"]; }))
|
||||||
|
data['out'] = Ox.max(range.map(annotation => { return annotation["out"]; }))
|
||||||
|
setPoint('in', data['in'], true);
|
||||||
|
setPoint('out', data.out, true);
|
||||||
} else if (!data.id && Ox.$elements[that.oxid]) {
|
} else if (!data.id && Ox.$elements[that.oxid]) {
|
||||||
// focus only if in the dom
|
// focus only if in the dom
|
||||||
that.gainFocus();
|
that.gainFocus();
|
||||||
|
|
Loading…
Reference in a new issue