115 lines
No EOL
4.3 KiB
JavaScript
115 lines
No EOL
4.3 KiB
JavaScript
'use strict';
|
|
|
|
oml.ui.list = function() {
|
|
|
|
var ui = oml.user.ui,
|
|
|
|
that = oml.ui[ui.listView + 'View']()
|
|
.bindEvent({
|
|
closepreview: function() {
|
|
oml.$ui.previewButton.options({value: false});
|
|
oml.$ui.previewDialog.close();
|
|
delete oml.$ui.previewDialog;
|
|
},
|
|
copy: function(data) {
|
|
oml.clipboard.copy(data.ids, 'item');
|
|
},
|
|
copyadd: function(data) {
|
|
oml.clipboard.copy(data.ids, 'item');
|
|
},
|
|
cut: function(data) {
|
|
var listData = oml.getListData();
|
|
if (listData.editable && listData.type == 'static') {
|
|
oml.clipboard.copy(data.ids, 'item');
|
|
oml.doHistory('cut', data.ids, ui._list, function() {
|
|
oml.UI.set({listSelection: []});
|
|
oml.reloadList();
|
|
});
|
|
}
|
|
},
|
|
cutadd: function(data) {
|
|
var listData = oml.getListData();
|
|
if (listData.editable && listData.type == 'static') {
|
|
oml.clipboard.add(data.ids, 'item');
|
|
oml.doHistory('cut', data.ids, ui._list, function() {
|
|
oml.UI.set({listSelection: []});
|
|
oml.reloadList();
|
|
});
|
|
}
|
|
},
|
|
'delete': function() {
|
|
var listData = oml.getListData();
|
|
if (listData.editable && listData.type == 'static') {
|
|
oml.doHistory('delete', data.ids, ui._list, function() {
|
|
oml.UI.set({listSelection: []});
|
|
oml.reloadList();
|
|
});
|
|
}
|
|
},
|
|
init: function(data) {
|
|
oml.$ui.statusbar.set('total', data);
|
|
},
|
|
key_control_delete: function() {
|
|
var listData = oml.getListData();
|
|
if (listData.own) {
|
|
oml.ui.deleteItemsDialog().open();
|
|
}
|
|
},
|
|
open: function(data) {
|
|
oml.UI.set({
|
|
item: data.ids[0],
|
|
itemView: 'info'
|
|
});
|
|
},
|
|
openpreview: function() {
|
|
if (!oml.$ui.previewDialog) {
|
|
oml.$ui.previewButton.options({value: true});
|
|
oml.$ui.previewDialog = oml.ui.previewDialog()
|
|
.open()
|
|
.bindEvent({
|
|
close: function() {
|
|
that.closePreview();
|
|
delete oml.$ui.previewDialog;
|
|
}
|
|
});
|
|
} else {
|
|
oml.$ui.previewDialog.updateElement();
|
|
}
|
|
},
|
|
resize: function(data) {
|
|
// this is the resize event of the split panel
|
|
that.size();
|
|
},
|
|
select: function(data) {
|
|
oml.UI.set({listSelection: data.ids});
|
|
},
|
|
oml_find: function() {
|
|
that.reloadList();
|
|
},
|
|
oml_item: function() {
|
|
if (!ui.item) {
|
|
that.gainFocus();
|
|
} else {
|
|
that.options({selected: [ui.item]});
|
|
}
|
|
},
|
|
oml_listselection: function(data) {
|
|
that.options({selected: data.value});
|
|
},
|
|
oml_listsort: function(data) {
|
|
that.options({sort: data.value});
|
|
},
|
|
oml_sidebarsize: function(data) {
|
|
that.size();
|
|
}
|
|
});
|
|
|
|
oml.enableDragAndDrop(that);
|
|
|
|
that.updateElement = function() {
|
|
that.reloadList(true);
|
|
};
|
|
|
|
return that;
|
|
|
|
}; |