/** * 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']; var core = ['DGEmain','DGEoutcome','DGEreturn','DGElogic']; function createCategoryContainer(category){ var escapedCategory = category.replace(" ","_"); $("#palette-container").append('<div class="palette-category">'+ '<div id="header-'+category+'" class="palette-header"><i class="expanded fa fa-caret-down"></i><span>'+category.replace("_"," ")+'</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>'); $("#header-"+category).on('click', function(e) { $(this).next().slideToggle(); $(this).children("i").toggleClass("expanded"); }); } core.forEach(createCategoryContainer); function addNodeType(nt,def) { var nodeTypeId = nt.replace(" ","_"); 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; // calculate width of label text $.fn.textWidth = function(text, font) { if (!$.fn.textWidth.fakeEl) { $.fn.textWidth.fakeEl = $('<span>').hide().appendTo(document.body); } $.fn.textWidth.fakeEl.text(text || this.val() || this.text()).css('font', font || this.css('font')); return $.fn.textWidth.fakeEl.width(); }; 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)||""; } var pixels = $.fn.textWidth(label, '13px helvetica'); var nodeWidth = 90; var labelWidth = nodeWidth - 10; var numLines = Math.ceil(pixels / nodeWidth); var multiLine = numLines > 1; // styles matching with style.css var nodeHeight = 25; var lineHeight = 16; var portHeight = 10; var multiLineNodeHeight = lineHeight * numLines + (nodeHeight - lineHeight); d.innerHTML = '<div class="palette_label"'+ (multiLine ? 'style="line-height: '+ lineHeight + 'px; margin-top: 5px"' : '')+ '>'+label+"</div>"; d.className="palette_node"; if (def.icon) { d.style.backgroundImage = "url(icons/"+def.icon+")"; if (multiLine) { d.style.backgroundSize = "18px 27px"; } if (def.align == "right") { d.style.backgroundPosition = "95% 50%"; } else if (def.inputs > 0) { d.style.backgroundPosition = "10% 50%"; } } d.style.backgroundColor = def.color; d.style.height = multiLineNodeHeight + "px"; if (def.outputs > 0) { var portOut = document.createElement("div"); portOut.className = "palette_port palette_port_output"; if (multiLine) { portOut.style.top = ((multiLineNodeHeight - portHeight) / 2) + "px"; } d.appendChild(portOut); } if (def.inputs > 0) { var portIn = document.createElement("div"); portIn.className = "palette_port"; if (multiLine) { portIn.style.top = ((multiLineNodeHeight - portHeight) / 2) + "px"; } d.appendChild(portIn); } if ($("#palette-base-category-"+rootCategory).length === 0) { createCategoryContainer(rootCategory); } if ($("#palette-"+category).length === 0) { $("#palette-base-category-"+rootCategory).append('<div id="palette-'+category+'"></div>'); } $("#palette-"+category).append(d); d.onmousedown = function(e) { e.preventDefault(); }; var popOverContent; try { popOverContent = $("<p><b>"+label+"</b></p>"+($("script[data-help-name|='"+nt+"']").html().trim()||"<p>no information available</p>")).slice(0,2); } catch(err) { // Malformed HTML may cause errors. TODO: need to understand what can break console.log("Error generating pop-over label for '"+nt+"'."); console.log(err.toString()); popOverContent = "<p><b>"+label+"</b></p><p>no information available</p>"; } $(d).popover({ title:d.type, placement:"right", trigger: "hover", delay: { show: 750, hide: 50 }, html: true, container:'body', content: popOverContent }); $(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 }); } } function removeNodeType(nt) { var nodeTypeId = nt.replace(" ","_"); $("#palette_node_"+nodeTypeId).remove(); } function hideNodeType(nt) { var nodeTypeId = nt.replace(" ","_"); $("#palette_node_"+nodeTypeId).hide(); } function showNodeType(nt) { var nodeTypeId = nt.replace(" ","_"); $("#palette_node_"+nodeTypeId).show(); } 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, remove:removeNodeType, hide:hideNodeType, show:showNodeType }; })();