node-red/public/red/ui/palette.js

161 lines
5.2 KiB
JavaScript
Raw Normal View History

2013-09-05 16:02:48 +02:00
/**
* Copyright 2013 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.
**/
2014-06-30 17:31:02 +02:00
RED.palette = function() {
2014-06-30 17:31:02 +02:00
var exclusion = ['config','unknown','deprecated'];
var core = ['input', 'output', 'function', 'social', 'storage', 'analysis', 'advanced'];
function createCategoryContainer(category){
$("#palette-container").append('\
<div class="palette-category">\
<div id="header-'+category+'" class="palette-header"><i class="expanded icon-chevron-down"></i><span>'+category+'</span></div>\
<div class="palette-content" id="palette-base-category-'+category+'">\
<div id="palette-'+category+'-input"></div>\
<div id="palette-'+category+'-output"></div>\
<div id="palette-'+category+'-function"></div>\
</div>\
</div>');
}
core.forEach(createCategoryContainer);
2013-09-05 16:02:48 +02:00
function addNodeType(nt,def) {
if (exclusion.indexOf(def.category)===-1) {
var category = def.category.split("-");
2014-06-30 17:31:02 +02:00
var d = document.createElement("div");
d.id = "pn_"+nt;
d.type = nt;
var label = /^(.*?)([ -]in|[ -]out)?$/.exec(nt)[1];
2014-06-30 17:31:02 +02:00
d.innerHTML = '<div class="palette_label">'+label+"</div>";
d.className="palette_node";
if (def.icon) {
d.style.backgroundImage = "url(icons/"+def.icon+")";
if (def.align == "right") {
d.style.backgroundPosition = "95% 50%";
} else if (def.inputs > 0) {
d.style.backgroundPosition = "10% 50%";
}
}
d.style.backgroundColor = def.color;
if (def.outputs > 0) {
var port = document.createElement("div");
port.className = "palette_port palette_port_output";
d.appendChild(port);
}
if (def.inputs > 0) {
var port = document.createElement("div");
port.className = "palette_port";
d.appendChild(port);
}
if($("#palette-base-category-"+category[0]).length == 0){
createCategoryContainer(category[0]);
}
if($("#palette-"+def.category).length == 0){
$("#palette-base-category-"+category[0]).append('\
<div id="palette-'+def.category+'"></div>');
}
2014-06-30 17:31:02 +02:00
$("#palette-"+def.category).append(d);
d.onmousedown = function(e) { e.preventDefault(); }
$(d).popover({
title:d.type,
placement:"right",
trigger: "hover",
delay: { show: 750, hide: 50 },
html: true,
container:'body',
content: $(($("script[data-help-name|='"+nt+"']").html()||"<p>no information available</p>").trim())[0]
});
$(d).click(function() {
var help = '<div class="node-help">'+($("script[data-help-name|='"+d.type+"']").html()||"")+"</div>";
$("#tab-info").html(help);
});
$(d).draggable({
helper: 'clone',
appendTo: 'body',
revert: true,
revertDuration: 50
});
$("#header-"+category[0]).off('click').on('click', function(e) {
$(this).next().slideToggle();
$(this).children("i").toggleClass("expanded");
});
}
2013-09-05 16:02:48 +02:00
}
2014-01-19 01:01:27 +01:00
function filterChange() {
var val = $("#palette-search-input").val();
if (val == "") {
$("#palette-search-clear").hide();
} else {
$("#palette-search-clear").show();
}
var re = new RegExp(val);
$(".palette_node").each(function(i,el) {
if (val == "" || re.test(el.id)) {
$(this).show();
} else {
$(this).hide();
}
2013-09-05 16:02:48 +02:00
});
2014-01-19 01:01:27 +01:00
}
$("#palette-search-input").focus(function(e) {
RED.keyboard.disable();
});
$("#palette-search-input").blur(function(e) {
RED.keyboard.enable();
});
$("#palette-search-clear").on("click",function(e) {
e.preventDefault();
$("#palette-search-input").val("");
filterChange();
$("#palette-search-input").focus();
});
$("#palette-search-input").val("");
2014-01-19 01:01:27 +01:00
$("#palette-search-input").on("keyup",function() {
filterChange();
});
2013-09-05 16:02:48 +02:00
2014-01-19 01:01:27 +01:00
$("#palette-search-input").on("focus",function() {
$("body").one("mousedown",function() {
$("#palette-search-input").blur();
});
});
2013-09-05 16:02:48 +02:00
return {
add:addNodeType
};
}();