/** * 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. **/ RED.palette = function() { var exclusion = ['config','unknown','deprecated']; var core = ['input', 'output', 'function', 'social', 'storage', 'analysis', 'advanced']; function createCategoryContainer(category){ $("#palette-container").append('\
\
'+category+'
\
\
\
\
\
\
'); } core.forEach(createCategoryContainer); function addNodeType(nt,def) { if (exclusion.indexOf(def.category)===-1) { var category = def.category.split("-"); var d = document.createElement("div"); d.id = "pn_"+nt; d.type = nt; var label = /^(.*?)([ -]in|[ -]out)?$/.exec(nt)[1]; d.innerHTML = '
'+label+"
"; 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('\
'); } $("#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()||"

no information available

").trim())[0] }); $(d).click(function() { var help = '
'+($("script[data-help-name|='"+d.type+"']").html()||"")+"
"; $("#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"); }); } } 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(); } }); } $("#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(""); $("#palette-search-input").on("keyup",function() { filterChange(); }); $("#palette-search-input").on("focus",function() { $("body").one("mousedown",function() { $("#palette-search-input").blur(); }); }); return { add:addNodeType }; }();