2016-05-20 23:13:28 +02:00
|
|
|
/**
|
|
|
|
* Copyright 2016 IBM Corp.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
**/
|
|
|
|
(function($) {
|
|
|
|
|
2016-05-29 23:25:30 +02:00
|
|
|
/**
|
|
|
|
* options:
|
|
|
|
* - addButton : boolean|string - text for add label, default 'tab'
|
|
|
|
* - addable : boolean (true) - whether to show the add button
|
|
|
|
* - height : number|'auto'
|
|
|
|
* - resize : function - called when list as a whole is resized
|
|
|
|
* - resizeItem : function(item) - called to resize individual item
|
|
|
|
* - sortable : boolean|string - string is the css selector for handle
|
|
|
|
* - sortItems : function(items) - when order of items changes
|
|
|
|
* - connectWith : css selector of other sortables
|
|
|
|
* - removable : boolean - whether to display delete button on items
|
|
|
|
* - addItem : function(row,index,itemData) - when an item is added
|
|
|
|
* - removeItem : function(itemData) - called when an item is removed
|
|
|
|
* methods:
|
|
|
|
* - addItem(itemData)
|
|
|
|
* - removeItem(itemData)
|
|
|
|
* - width(width)
|
|
|
|
* - height(height)
|
|
|
|
* - items()
|
|
|
|
* - empty()
|
|
|
|
*/
|
2016-05-20 23:13:28 +02:00
|
|
|
$.widget( "nodered.editableList", {
|
|
|
|
_create: function() {
|
|
|
|
var that = this;
|
|
|
|
|
|
|
|
this.element.addClass('red-ui-editableList-list');
|
|
|
|
this.uiWidth = this.element.width();
|
|
|
|
this.uiContainer = this.element
|
|
|
|
.wrap( "<div>" )
|
|
|
|
.parent();
|
|
|
|
this.topContainer = this.uiContainer.wrap("<div>").parent();
|
|
|
|
|
|
|
|
this.topContainer.addClass('red-ui-editableList');
|
|
|
|
|
2016-05-29 23:25:30 +02:00
|
|
|
if (this.options.addButton !== false) {
|
|
|
|
var addLabel;
|
|
|
|
if (typeof this.options.addButton === 'string') {
|
|
|
|
addLabel = this.options.addButton
|
|
|
|
} else {
|
|
|
|
if (RED && RED._) {
|
|
|
|
addLabel = RED._("editableList.add");
|
|
|
|
} else {
|
|
|
|
addLabel = 'add';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$('<a href="#" class="editor-button editor-button-small" style="margin-top: 4px;"><i class="fa fa-plus"></i> '+addLabel+'</a>')
|
|
|
|
.appendTo(this.topContainer)
|
|
|
|
.click(function(evt) {
|
|
|
|
evt.preventDefault();
|
|
|
|
that.addItem({});
|
|
|
|
});
|
2016-05-20 23:13:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
this.uiContainer.addClass("red-ui-editableList-container");
|
|
|
|
|
|
|
|
this.uiHeight = this.element.height();
|
|
|
|
|
|
|
|
var minHeight = this.element.css("minHeight");
|
|
|
|
if (minHeight !== '0px') {
|
|
|
|
this.uiContainer.css("minHeight",minHeight);
|
|
|
|
this.element.css("minHeight",0);
|
|
|
|
}
|
2016-05-29 23:25:30 +02:00
|
|
|
if (this.options.height !== 'auto') {
|
|
|
|
this.uiContainer.css("overflow-y","scroll");
|
|
|
|
if (!isNaN(this.options.height)) {
|
|
|
|
this.uiHeight = this.options.height;
|
|
|
|
}
|
|
|
|
}
|
2016-05-20 23:13:28 +02:00
|
|
|
if (this.options.sortable) {
|
2016-05-29 23:25:30 +02:00
|
|
|
var handle = (typeof this.options.sortable === 'string')?
|
|
|
|
this.options.sortable :
|
|
|
|
".red-ui-editableList-item-handle";
|
|
|
|
var sortOptions = {
|
2016-05-20 23:13:28 +02:00
|
|
|
axis: "y",
|
|
|
|
update: function( event, ui ) {
|
2016-05-29 23:25:30 +02:00
|
|
|
if (that.options.sortItems) {
|
|
|
|
that.options.sortItems(that.items());
|
2016-05-20 23:13:28 +02:00
|
|
|
}
|
|
|
|
},
|
2016-05-29 23:25:30 +02:00
|
|
|
handle:handle,
|
|
|
|
cursor: "move",
|
|
|
|
tolerance: "pointer",
|
|
|
|
forcePlaceholderSize:true,
|
|
|
|
placeholder: "red-ui-editabelList-item-placeholder",
|
|
|
|
start: function(e, ui){
|
|
|
|
ui.placeholder.height(ui.item.height()-4);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
if (this.options.connectWith) {
|
|
|
|
sortOptions.connectWith = this.options.connectWith;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.element.sortable(sortOptions);
|
2016-05-20 23:13:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
this._resize();
|
|
|
|
|
|
|
|
// this.menu = this._createMenu(this.types, function(v) { that.type(v) });
|
|
|
|
// this.type(this.options.default||this.types[0].value);
|
|
|
|
},
|
|
|
|
_resize: function() {
|
|
|
|
var currentFullHeight = this.topContainer.height();
|
|
|
|
var innerHeight = this.uiContainer.height();
|
|
|
|
var delta = currentFullHeight - innerHeight;
|
2016-05-29 23:41:25 +02:00
|
|
|
if (this.uiHeight !== 0) {
|
2016-05-29 23:25:30 +02:00
|
|
|
this.uiContainer.height(this.uiHeight-delta);
|
|
|
|
}
|
2016-05-20 23:13:28 +02:00
|
|
|
if (this.options.resize) {
|
|
|
|
this.options.resize();
|
|
|
|
}
|
|
|
|
if (this.options.resizeItem) {
|
|
|
|
var that = this;
|
|
|
|
this.element.children().each(function(i) {
|
|
|
|
that.options.resizeItem($(this).find(".red-ui-editableList-item-content"));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
_destroy: function() {
|
|
|
|
},
|
|
|
|
width: function(desiredWidth) {
|
|
|
|
this.uiWidth = desiredWidth;
|
|
|
|
this._resize();
|
|
|
|
},
|
|
|
|
height: function(desiredHeight) {
|
|
|
|
this.uiHeight = desiredHeight;
|
|
|
|
this._resize();
|
|
|
|
},
|
|
|
|
addItem: function(data) {
|
|
|
|
var that = this;
|
|
|
|
data = data || {};
|
|
|
|
var li = $('<li>').appendTo(this.element);
|
|
|
|
var row = $('<div/>').addClass("red-ui-editableList-item-content").appendTo(li);
|
2016-05-29 23:25:30 +02:00
|
|
|
row.data('data',data);
|
|
|
|
if (this.options.sortable === true) {
|
2016-05-20 23:13:28 +02:00
|
|
|
$('<i class="red-ui-editableList-item-handle fa fa-bars"></i>').appendTo(li);
|
|
|
|
li.addClass("red-ui-editableList-item-sortable");
|
|
|
|
}
|
2016-05-29 23:25:30 +02:00
|
|
|
if (this.options.removable) {
|
|
|
|
var deleteButton = $('<a/>',{href:"#",class:"red-ui-editableList-item-remove editor-button editor-button-small"}).appendTo(li);
|
2016-05-20 23:13:28 +02:00
|
|
|
$('<i/>',{class:"fa fa-remove"}).appendTo(deleteButton);
|
2016-05-29 23:25:30 +02:00
|
|
|
li.addClass("red-ui-editableList-item-removable");
|
2016-05-20 23:13:28 +02:00
|
|
|
deleteButton.click(function() {
|
|
|
|
li.addClass("red-ui-editableList-item-deleting")
|
|
|
|
li.fadeOut(300, function() {
|
|
|
|
$(this).remove();
|
2016-05-29 23:25:30 +02:00
|
|
|
if (that.options.removeItem) {
|
|
|
|
that.options.removeItem(row.data('data'));
|
2016-05-20 23:13:28 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
if (this.options.addItem) {
|
|
|
|
var index = that.element.children().length-1;
|
|
|
|
setTimeout(function() {
|
|
|
|
that.options.addItem(row,index,data);
|
|
|
|
},0);
|
|
|
|
}
|
|
|
|
},
|
2016-05-29 23:25:30 +02:00
|
|
|
removeItem: function(data) {
|
|
|
|
var items = this.element.children().filter(function(f) {
|
|
|
|
return data === $(this).find(".red-ui-editableList-item-content").data('data');
|
|
|
|
});
|
|
|
|
items.remove();
|
|
|
|
if (this.options.removeItem) {
|
|
|
|
this.options.removeItem(data);
|
|
|
|
}
|
|
|
|
},
|
2016-05-20 23:13:28 +02:00
|
|
|
items: function() {
|
|
|
|
return this.element.children().map(function(i) { return $(this).find(".red-ui-editableList-item-content"); });
|
2016-05-29 23:25:30 +02:00
|
|
|
},
|
|
|
|
empty: function() {
|
|
|
|
this.element.empty();
|
2016-05-20 23:13:28 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
})(jQuery);
|