/** * Copyright 2013, 2015 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 = ['subflows', 'input', 'output', 'function', 'social', 'storage', 'analysis', 'advanced']; function createCategoryContainer(category){ var escapedCategory = category.replace(" ","_"); var catDiv = $("#palette-container").append('
'+ '
'+category.replace("_"," ")+'
'+ '
'+ '
'+ '
'+ '
'+ '
'+ '
'); $("#palette-header-"+category).on('click', function(e) { $(this).next().slideToggle(); $(this).children("i").toggleClass("expanded"); }); } function setLabel(type, el,label) { var nodeWidth = 80; var nodeHeight = 25; var lineHeight = 20; var portHeight = 10; var words = label.split(" "); var displayLines = []; var currentLine = words[0]; var currentLineWidth = RED.view.calculateTextWidth(currentLine, "palette_label", 0); for (var i=1;i"); var multiLineNodeHeight = 8+(lineHeight*displayLines.length); el.css({height:multiLineNodeHeight+"px"}); var labelElement = el.find(".palette_label"); labelElement.html(lines); el.find(".palette_port").css({top:(multiLineNodeHeight/2-5)+"px"}); var popOverContent; try { var l = "

"+label+"

"; if (label != type) { l = "

"+label+"
"+type+"

"; } popOverContent = $(l+($("script[data-help-name|='"+type+"']").html()||"

"+RED._("palette.noInfo")+"

").trim()) .filter(function(n) { return this.nodeType == 1 || (this.nodeType == 3 && this.textContent.trim().length > 0) }).slice(0,2); } catch(err) { // Malformed HTML may cause errors. TODO: need to understand what can break console.log(RED._("palette.popOverError",{type:type})); console.log(err.toString()); popOverContent = "

"+label+"

"+RED._("palette.noInfo")+"

"; } el.data('popover').options.content = popOverContent; } function escapeNodeType(nt) { return nt.replace(" ","_").replace(".","_").replace(":","_"); } function addNodeType(nt,def) { var nodeTypeId = escapeNodeType(nt); if ($("#palette_node_"+nodeTypeId).length) { return; } if (exclusion.indexOf(def.category)===-1) { var category = def.category.replace(" ","_"); var rootCategory = category.split("-")[0]; var d = document.createElement("div"); d.id = "palette_node_"+nodeTypeId; d.type = nt; var label; if (typeof def.paletteLabel === "undefined") { label = /^(.*?)([ -]in|[ -]out)?$/.exec(nt)[1]; } else { label = (typeof def.paletteLabel === "function" ? def.paletteLabel.call(def) : def.paletteLabel)||""; } $('
',{class:"palette_label"+(def.align=="right"?" palette_label_right":"")}).appendTo(d); d.className="palette_node"; if (def.icon) { var icon_url = (typeof def.icon === "function" ? def.icon.call({}) : def.icon); var iconContainer = $('
',{class:"palette_icon_container"+(def.align=="right"?" palette_icon_container_right":"")}).appendTo(d); $('
',{class:"palette_icon",style:"background-image: url(icons/"+icon_url+")"}).appendTo(iconContainer); } d.style.backgroundColor = def.color; if (def.outputs > 0) { var portOut = document.createElement("div"); portOut.className = "palette_port palette_port_output"; d.appendChild(portOut); } if (def.inputs > 0) { var portIn = document.createElement("div"); portIn.className = "palette_port palette_port_input"; d.appendChild(portIn); } if ($("#palette-base-category-"+rootCategory).length === 0) { createCategoryContainer(rootCategory); } $("#palette-container-"+rootCategory).show(); if ($("#palette-"+category).length === 0) { $("#palette-base-category-"+rootCategory).append('
'); } $("#palette-"+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' }); $(d).click(function() { RED.view.focus(); var help = '
'+($("script[data-help-name|='"+d.type+"']").html()||"")+"
"; $("#tab-info").html(help); }); $(d).draggable({ helper: 'clone', appendTo: 'body', revert: true, revertDuration: 50, start: function() {RED.view.focus();} }); if (def.category == "subflows") { $(d).dblclick(function(e) { RED.workspaces.show(nt.substring(8)); e.preventDefault(); }); } setLabel(nt,$(d),label); var categoryNode = $("#palette-container-"+category); if (categoryNode.find(".palette_node").length === 1) { if (!categoryNode.find("i").hasClass("expanded")) { categoryNode.find(".palette-content").slideToggle(); categoryNode.find("i").toggleClass("expanded"); } } } } function removeNodeType(nt) { var nodeTypeId = escapeNodeType(nt); var paletteNode = $("#palette_node_"+nodeTypeId); var categoryNode = paletteNode.closest(".palette-category"); paletteNode.remove(); if (categoryNode.find(".palette_node").length === 0) { if (categoryNode.find("i").hasClass("expanded")) { categoryNode.find(".palette-content").slideToggle(); categoryNode.find("i").toggleClass("expanded"); } } } function hideNodeType(nt) { var nodeTypeId = escapeNodeType(nt); $("#palette_node_"+nodeTypeId).hide(); } function showNodeType(nt) { var nodeTypeId = escapeNodeType(nt); $("#palette_node_"+nodeTypeId).show(); } function refreshNodeTypes() { RED.nodes.eachSubflow(function(sf) { var paletteNode = $("#palette_node_subflow_"+sf.id.replace(".","_")); var portInput = paletteNode.find(".palette_port_input"); var portOutput = paletteNode.find(".palette_port_output"); if (portInput.length === 0 && sf.in.length > 0) { var portIn = document.createElement("div"); portIn.className = "palette_port palette_port_input"; paletteNode.append(portIn); } else if (portInput.length !== 0 && sf.in.length === 0) { portInput.remove(); } if (portOutput.length === 0 && sf.out.length > 0) { var portOut = document.createElement("div"); portOut.className = "palette_port palette_port_output"; paletteNode.append(portOut); } else if (portOutput.length !== 0 && sf.out.length === 0) { portOutput.remove(); } setLabel(sf.type+":"+sf.id,paletteNode,sf.name); }); } function filterChange() { var val = $("#palette-search-input").val(); if (val === "") { $("#palette-search-clear").hide(); } else { $("#palette-search-clear").show(); } var re = new RegExp(val,'i'); $(".palette_node").each(function(i,el) { var currentLabel = $(el).find(".palette_label").text(); if (val === "" || re.test(el.id) || re.test(currentLabel)) { $(this).show(); } else { $(this).hide(); } }); } function init() { $(".palette-spinner").show(); if (RED.settings.paletteCategories) { RED.settings.paletteCategories.forEach(createCategoryContainer); } else { core.forEach(createCategoryContainer); } $("#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 { init: init, add:addNodeType, remove:removeNodeType, hide:hideNodeType, show:showNodeType, refresh:refreshNodeTypes }; })();