mirror of
https://github.com/node-red/node-red.git
synced 2025-03-01 10:36:34 +00:00
Compare commits
5 Commits
4401-fix-d
...
phase-out-
Author | SHA1 | Date | |
---|---|---|---|
|
2350540a98 | ||
|
c021c4020e | ||
|
11a6925ae4 | ||
|
24ff5262d9 | ||
|
c24d7fafa9 |
@@ -152,6 +152,7 @@ module.exports = function(grunt) {
|
|||||||
"packages/node_modules/@node-red/editor-client/src/js/history.js",
|
"packages/node_modules/@node-red/editor-client/src/js/history.js",
|
||||||
"packages/node_modules/@node-red/editor-client/src/js/validators.js",
|
"packages/node_modules/@node-red/editor-client/src/js/validators.js",
|
||||||
"packages/node_modules/@node-red/editor-client/src/js/ui/utils.js",
|
"packages/node_modules/@node-red/editor-client/src/js/ui/utils.js",
|
||||||
|
"packages/node_modules/@node-red/editor-client/src/js/ui/utils-domselection.js",
|
||||||
"packages/node_modules/@node-red/editor-client/src/js/ui/common/editableList.js",
|
"packages/node_modules/@node-red/editor-client/src/js/ui/common/editableList.js",
|
||||||
"packages/node_modules/@node-red/editor-client/src/js/ui/common/treeList.js",
|
"packages/node_modules/@node-red/editor-client/src/js/ui/common/treeList.js",
|
||||||
"packages/node_modules/@node-red/editor-client/src/js/ui/common/checkboxSet.js",
|
"packages/node_modules/@node-red/editor-client/src/js/ui/common/checkboxSet.js",
|
||||||
|
@@ -267,7 +267,7 @@ RED.keyboard = (function() {
|
|||||||
return resolveKeyEvent(evt);
|
return resolveKeyEvent(evt);
|
||||||
}
|
}
|
||||||
if (Object.keys(handler).length > 0) {
|
if (Object.keys(handler).length > 0) {
|
||||||
// check if there's a potential combined handler initiated by this keyCode
|
// check if there's a potential combined handler initiated by this keyCode
|
||||||
for (let h in handler) {
|
for (let h in handler) {
|
||||||
if (matchHandlerToEvent(evt,handler[h]) > -1) {
|
if (matchHandlerToEvent(evt,handler[h]) > -1) {
|
||||||
partialState = handler;
|
partialState = handler;
|
||||||
@@ -298,21 +298,21 @@ RED.keyboard = (function() {
|
|||||||
return resolveKeyEvent(evt);
|
return resolveKeyEvent(evt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
d3.select(window).on("keydown",function() {
|
document.addEventListener("keydown", function(event) {
|
||||||
if (!handlersActive) {
|
if (!handlersActive) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (metaKeyCodes[d3.event.keyCode]) {
|
if (metaKeyCodes[event.keyCode]) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var handler = resolveKeyEvent(d3.event);
|
var handler = resolveKeyEvent(event);
|
||||||
if (handler && handler.ondown) {
|
if (handler && handler.ondown) {
|
||||||
if (typeof handler.ondown === "string") {
|
if (typeof handler.ondown === "string") {
|
||||||
RED.actions.invoke(handler.ondown);
|
RED.actions.invoke(handler.ondown);
|
||||||
} else {
|
} else {
|
||||||
handler.ondown();
|
handler.ondown();
|
||||||
}
|
}
|
||||||
d3.event.preventDefault();
|
event.preventDefault();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@@ -299,7 +299,7 @@ RED.palette = (function() {
|
|||||||
RED.view.focus();
|
RED.view.focus();
|
||||||
},
|
},
|
||||||
stop: function() {
|
stop: function() {
|
||||||
d3.select('.red-ui-flow-link-splice').classed('red-ui-flow-link-splice',false);
|
document.querySelectorAll(".red-ui-flow-link-splice").forEach(n => { n.classList.remove("red-ui-flow-link-splice") })
|
||||||
if (hoverGroup) {
|
if (hoverGroup) {
|
||||||
document.getElementById("group_select_"+hoverGroup.id).classList.remove("red-ui-flow-group-hovered");
|
document.getElementById("group_select_"+hoverGroup.id).classList.remove("red-ui-flow-group-hovered");
|
||||||
}
|
}
|
||||||
@@ -358,26 +358,26 @@ RED.palette = (function() {
|
|||||||
var mx = mouseX / RED.view.scale();
|
var mx = mouseX / RED.view.scale();
|
||||||
var my = mouseY / RED.view.scale();
|
var my = mouseY / RED.view.scale();
|
||||||
for (var i=0;i<nodes.length;i++) {
|
for (var i=0;i<nodes.length;i++) {
|
||||||
var node = d3.select(nodes[i]);
|
var node = nodes[i];
|
||||||
if (node.classed('red-ui-flow-link-background') && !node.classed('red-ui-flow-link-link')) {
|
if (node.classList.contains('red-ui-flow-link-background') && !node.classList.contains('red-ui-flow-link-link')) {
|
||||||
var length = nodes[i].getTotalLength();
|
var length = node.getTotalLength();
|
||||||
for (var j=0;j<length;j+=10) {
|
for (var j=0;j<length;j+=10) {
|
||||||
var p = nodes[i].getPointAtLength(j);
|
var p = node.getPointAtLength(j);
|
||||||
var d2 = ((p.x-mx)*(p.x-mx))+((p.y-my)*(p.y-my));
|
var d2 = ((p.x-mx)*(p.x-mx))+((p.y-my)*(p.y-my));
|
||||||
if (d2 < 200 && d2 < bestDistance) {
|
if (d2 < 200 && d2 < bestDistance) {
|
||||||
bestDistance = d2;
|
bestDistance = d2;
|
||||||
bestLink = nodes[i];
|
bestLink = node;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (activeSpliceLink && activeSpliceLink !== bestLink) {
|
if (activeSpliceLink && activeSpliceLink !== bestLink) {
|
||||||
d3.select(activeSpliceLink.parentNode).classed('red-ui-flow-link-splice',false);
|
activeSpliceLink.parentNode.classList.remove('red-ui-flow-link-splice');
|
||||||
}
|
}
|
||||||
if (bestLink) {
|
if (bestLink) {
|
||||||
d3.select(bestLink.parentNode).classed('red-ui-flow-link-splice',true)
|
bestLink.parentNode.classList.add('red-ui-flow-link-splice');
|
||||||
} else {
|
} else {
|
||||||
d3.select('.red-ui-flow-link-splice').classed('red-ui-flow-link-splice',false);
|
document.querySelectorAll(".red-ui-flow-link-splice").forEach(n => { n.classList.remove("red-ui-flow-link-splice") })
|
||||||
}
|
}
|
||||||
if (activeSpliceLink !== bestLink) {
|
if (activeSpliceLink !== bestLink) {
|
||||||
if (bestLink) {
|
if (bestLink) {
|
||||||
|
@@ -27,26 +27,24 @@ RED.touch.radialMenu = (function() {
|
|||||||
function createRadial(obj,pos,options) {
|
function createRadial(obj,pos,options) {
|
||||||
isActive = true;
|
isActive = true;
|
||||||
try {
|
try {
|
||||||
touchMenu = d3.select("body").append("div").classed("red-ui-editor-radial-menu",true)
|
touchMenu = $('<div>', {class: 'red-ui-editor-radial-menu'}).appendTo('body')
|
||||||
.on('touchstart',function() {
|
.on('touchstart',function(evt) {
|
||||||
hide();
|
hide();
|
||||||
d3.event.preventDefault();
|
evt.preventDefault();
|
||||||
});
|
});
|
||||||
|
|
||||||
var menu = touchMenu.append("div")
|
var menu = $('<div>').appendTo(touchMenu).css({
|
||||||
.style({
|
|
||||||
top: (pos[1]-80)+"px",
|
top: (pos[1]-80)+"px",
|
||||||
left:(pos[0]-80)+"px",
|
left:(pos[0]-80)+"px",
|
||||||
});
|
});
|
||||||
|
|
||||||
var menuOpts = [];
|
var menuOpts = [];
|
||||||
var createMenuOpt = function(x,y,opt) {
|
var createMenuOpt = function(x,y,opt) {
|
||||||
opt.el = menu.append("div").classed("red-ui-editor-radial-menu-opt",true)
|
opt.el = $('<div>', {class: 'red-ui-editor-radial-menu-opt'}).appendTo(menu)
|
||||||
.style({
|
.css({
|
||||||
top: (y+80-25)+"px",
|
top: (y+80-25)+"px",
|
||||||
left:(x+80-25)+"px"
|
left:(x+80-25)+"px"
|
||||||
})
|
})
|
||||||
.classed("red-ui-editor-radial-menu-opt-disabled",!!opt.disabled)
|
.toggleClass("red-ui-editor-radial-menu-opt-disabled",!!opt.disabled)
|
||||||
|
|
||||||
opt.el.html(opt.name);
|
opt.el.html(opt.name);
|
||||||
|
|
||||||
@@ -54,16 +52,16 @@ RED.touch.radialMenu = (function() {
|
|||||||
opt.y = y;
|
opt.y = y;
|
||||||
menuOpts.push(opt);
|
menuOpts.push(opt);
|
||||||
|
|
||||||
opt.el.on('touchstart',function() {
|
opt.el.on('touchstart',function(evt) {
|
||||||
opt.el.classed("red-ui-editor-radial-menu-opt-active",true)
|
opt.el.toggleClass("red-ui-editor-radial-menu-opt-active",true)
|
||||||
d3.event.preventDefault();
|
evt.preventDefault();
|
||||||
d3.event.stopPropagation();
|
evt.stopPropagation();
|
||||||
});
|
});
|
||||||
opt.el.on('touchend',function() {
|
opt.el.on('touchend',function(evt) {
|
||||||
hide();
|
hide();
|
||||||
opt.onselect();
|
opt.onselect();
|
||||||
d3.event.preventDefault();
|
evt.preventDefault();
|
||||||
d3.event.stopPropagation();
|
evt.stopPropagation();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -88,8 +86,8 @@ RED.touch.radialMenu = (function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
obj.on('touchend.radial',function() {
|
obj.on('touchend.radial',function() {
|
||||||
obj.on('touchend.radial',null);
|
obj.off('touchend.radial');
|
||||||
obj.on('touchmenu.radial',null);
|
obj.off('touchmenu.radial');
|
||||||
|
|
||||||
if (activeOption) {
|
if (activeOption) {
|
||||||
try {
|
try {
|
||||||
@@ -103,9 +101,9 @@ RED.touch.radialMenu = (function() {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
obj.on('touchmove.radial',function() {
|
obj.on('touchmove.radial',function(evt) {
|
||||||
try {
|
try {
|
||||||
var touch0 = d3.event.touches.item(0);
|
var touch0 = evt.touches.item(0);
|
||||||
var p = [touch0.pageX - pos[0],touch0.pageY-pos[1]];
|
var p = [touch0.pageX - pos[0],touch0.pageY-pos[1]];
|
||||||
for (var i=0;i<menuOpts.length;i++) {
|
for (var i=0;i<menuOpts.length;i++) {
|
||||||
var opt = menuOpts[i];
|
var opt = menuOpts[i];
|
||||||
@@ -119,7 +117,7 @@ RED.touch.radialMenu = (function() {
|
|||||||
if (opt === activeOption) {
|
if (opt === activeOption) {
|
||||||
activeOption = null;
|
activeOption = null;
|
||||||
}
|
}
|
||||||
opt.el.classed("selected",false);
|
opt.el.toggleClass("selected",false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
61
packages/node_modules/@node-red/editor-client/src/js/ui/utils-domselection.js
vendored
Normal file
61
packages/node_modules/@node-red/editor-client/src/js/ui/utils-domselection.js
vendored
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
/**
|
||||||
|
* Modelled after `d3.selection` this provides a way to keep a mapping of
|
||||||
|
* DOM Nodes with a data collection.
|
||||||
|
*
|
||||||
|
* The goal here is not to reproduce d3 functionality as-is, but to provide an
|
||||||
|
* api that is specific to what we need to do
|
||||||
|
*
|
||||||
|
* const domSelection = RED.utils.domSelection(container, selector, createNode, eachNode)
|
||||||
|
*
|
||||||
|
* - container - a DOM Node that is the container of the DOM Nodes to track
|
||||||
|
* - selector - CSS selector to get the DOM nodes to track
|
||||||
|
* - createNode - function called when a DOM node must be created for a piece of data.
|
||||||
|
* `this` is the data item. Should return the DOM Node. It will
|
||||||
|
* get added to the container.
|
||||||
|
* - eachNode - function called for each DOM node/data item in the selection
|
||||||
|
*
|
||||||
|
* DomSelection.refresh(data) - called whenever the selection should be refreshed.
|
||||||
|
* Data is expected to be an array of objects that contain an 'id' property
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
RED.utils.domSelection = (function() {
|
||||||
|
|
||||||
|
class DomSelection {
|
||||||
|
constructor(container, selector, createNode, eachNode) {
|
||||||
|
this.container = container
|
||||||
|
this.selector = selector
|
||||||
|
this.createNode = createNode
|
||||||
|
this.eachNode = eachNode
|
||||||
|
this.data = []
|
||||||
|
}
|
||||||
|
|
||||||
|
refresh(data) {
|
||||||
|
const domNodes = this.container.querySelectorAll(this.selector)
|
||||||
|
const domItems = new Map()
|
||||||
|
const dataLength = data.length
|
||||||
|
const domLength = domNodes.length
|
||||||
|
for (let i = 0; i < domLength; i++) {
|
||||||
|
const domNode = domNodes[i]
|
||||||
|
if (domNode.__data__) {
|
||||||
|
domItems.set(domNode.__data__.id, domNode)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (let i = 0; i < dataLength; i++) {
|
||||||
|
const datum = data[i]
|
||||||
|
let domNode = domItems.get(datum.id)
|
||||||
|
if (!domNode) {
|
||||||
|
domNode = this.createNode.call(datum)
|
||||||
|
this.container.appendChild(domNode)
|
||||||
|
domNode.__data__ = datum
|
||||||
|
} else {
|
||||||
|
domItems.delete(datum.id)
|
||||||
|
}
|
||||||
|
this.eachNode.call(datum, domNode)
|
||||||
|
}
|
||||||
|
for (const remainingDomNodes of domItems) {
|
||||||
|
remainingDomNodes[1].remove()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return (container, selector, createNode, eachNode) => new DomSelection(container, selector, createNode, eachNode)
|
||||||
|
})()
|
@@ -1397,6 +1397,17 @@ RED.utils = (function() {
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function createSVGElement(tag, attrs = {}, parent) {
|
||||||
|
const element = document.createElementNS('http://www.w3.org/2000/svg', tag)
|
||||||
|
for (const k in attrs) {
|
||||||
|
element.setAttribute(k, attrs[k])
|
||||||
|
}
|
||||||
|
if (parent) {
|
||||||
|
parent.appendChild(element)
|
||||||
|
}
|
||||||
|
return element
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
createObjectElement: createObjectElement,
|
createObjectElement: createObjectElement,
|
||||||
getMessageProperty: getMessageProperty,
|
getMessageProperty: getMessageProperty,
|
||||||
@@ -1420,6 +1431,7 @@ RED.utils = (function() {
|
|||||||
getDarkerColor: getDarkerColor,
|
getDarkerColor: getDarkerColor,
|
||||||
parseModuleList: parseModuleList,
|
parseModuleList: parseModuleList,
|
||||||
checkModuleAllowed: checkModuleAllowed,
|
checkModuleAllowed: checkModuleAllowed,
|
||||||
getBrowserInfo: getBrowserInfo
|
getBrowserInfo: getBrowserInfo,
|
||||||
|
createSVGElement: createSVGElement
|
||||||
}
|
}
|
||||||
})();
|
})();
|
||||||
|
@@ -91,8 +91,7 @@ RED.view.annotations = (function() {
|
|||||||
function addAnnotation(id,evt) {
|
function addAnnotation(id,evt) {
|
||||||
var opts = annotations[id];
|
var opts = annotations[id];
|
||||||
evt.el.__annotations__ = evt.el.__annotations__ || [];
|
evt.el.__annotations__ = evt.el.__annotations__ || [];
|
||||||
var annotationGroup = document.createElementNS("http://www.w3.org/2000/svg","g");
|
var annotationGroup = RED.utils.createSVGElement("g", { class: opts.class || '' })
|
||||||
annotationGroup.setAttribute("class",opts.class || "");
|
|
||||||
evt.el.__annotations__.push({
|
evt.el.__annotations__.push({
|
||||||
id:id,
|
id:id,
|
||||||
element: annotationGroup
|
element: annotationGroup
|
||||||
|
@@ -15,133 +15,128 @@
|
|||||||
**/
|
**/
|
||||||
|
|
||||||
|
|
||||||
RED.view.navigator = (function() {
|
RED.view.navigator = (function() {
|
||||||
|
var nav_scale = 25;
|
||||||
|
var nav_width = 5000/nav_scale;
|
||||||
|
var nav_height = 5000/nav_scale;
|
||||||
|
|
||||||
var nav_scale = 25;
|
var navContainer;
|
||||||
var nav_width = 5000/nav_scale;
|
var navBox;
|
||||||
var nav_height = 5000/nav_scale;
|
var navBorder;
|
||||||
|
var scrollPos;
|
||||||
|
var scaleFactor;
|
||||||
|
var chartSize;
|
||||||
|
var dimensions;
|
||||||
|
var isDragging;
|
||||||
|
var isShowing = false;
|
||||||
|
|
||||||
var navContainer;
|
var domSelection
|
||||||
var navBox;
|
|
||||||
var navBorder;
|
|
||||||
var navVis;
|
|
||||||
var scrollPos;
|
|
||||||
var scaleFactor;
|
|
||||||
var chartSize;
|
|
||||||
var dimensions;
|
|
||||||
var isDragging;
|
|
||||||
var isShowing = false;
|
|
||||||
|
|
||||||
function refreshNodes() {
|
function refreshNodes() {
|
||||||
if (!isShowing) {
|
if (!isShowing) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var navNode = navVis.selectAll(".red-ui-navigator-node").data(RED.view.getActiveNodes(),function(d){return d.id});
|
domSelection.refresh(RED.view.getActiveNodes())
|
||||||
navNode.exit().remove();
|
}
|
||||||
navNode.enter().insert("rect")
|
|
||||||
.attr('class','red-ui-navigator-node')
|
|
||||||
.attr("pointer-events", "none");
|
|
||||||
navNode.each(function(d) {
|
|
||||||
d3.select(this).attr("x",function(d) { return (d.x-d.w/2)/nav_scale })
|
|
||||||
.attr("y",function(d) { return (d.y-d.h/2)/nav_scale })
|
|
||||||
.attr("width",function(d) { return Math.max(9,d.w/nav_scale) })
|
|
||||||
.attr("height",function(d) { return Math.max(3,d.h/nav_scale) })
|
|
||||||
.attr("fill",function(d) { return RED.utils.getNodeColor(d.type,d._def);})
|
|
||||||
});
|
|
||||||
}
|
|
||||||
function onScroll() {
|
|
||||||
if (!isDragging) {
|
|
||||||
resizeNavBorder();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
function resizeNavBorder() {
|
|
||||||
if (navBorder) {
|
|
||||||
scaleFactor = RED.view.scale();
|
|
||||||
chartSize = [ $("#red-ui-workspace-chart").width(), $("#red-ui-workspace-chart").height()];
|
|
||||||
scrollPos = [$("#red-ui-workspace-chart").scrollLeft(),$("#red-ui-workspace-chart").scrollTop()];
|
|
||||||
navBorder.attr('x',scrollPos[0]/nav_scale)
|
|
||||||
.attr('y',scrollPos[1]/nav_scale)
|
|
||||||
.attr('width',chartSize[0]/nav_scale/scaleFactor)
|
|
||||||
.attr('height',chartSize[1]/nav_scale/scaleFactor)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
function toggle() {
|
|
||||||
if (!isShowing) {
|
|
||||||
isShowing = true;
|
|
||||||
$("#red-ui-view-navigate").addClass("selected");
|
|
||||||
resizeNavBorder();
|
|
||||||
refreshNodes();
|
|
||||||
$("#red-ui-workspace-chart").on("scroll",onScroll);
|
|
||||||
navContainer.fadeIn(200);
|
|
||||||
} else {
|
|
||||||
isShowing = false;
|
|
||||||
navContainer.fadeOut(100);
|
|
||||||
$("#red-ui-workspace-chart").off("scroll",onScroll);
|
|
||||||
$("#red-ui-view-navigate").removeClass("selected");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
function onScroll() {
|
||||||
init: function() {
|
if (!isDragging) {
|
||||||
|
resizeNavBorder();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function resizeNavBorder() {
|
||||||
|
if (navBorder) {
|
||||||
|
scaleFactor = RED.view.scale();
|
||||||
|
chartSize = [ $("#red-ui-workspace-chart").width(), $("#red-ui-workspace-chart").height()];
|
||||||
|
scrollPos = [$("#red-ui-workspace-chart").scrollLeft(),$("#red-ui-workspace-chart").scrollTop()];
|
||||||
|
|
||||||
$(window).on("resize", resizeNavBorder);
|
navBorder.attr('x', scrollPos[0]/nav_scale)
|
||||||
RED.events.on("sidebar:resize",resizeNavBorder);
|
navBorder.attr('y', scrollPos[1]/nav_scale)
|
||||||
RED.actions.add("core:toggle-navigator",toggle);
|
navBorder.attr('width',chartSize[0]/nav_scale/scaleFactor)
|
||||||
var hideTimeout;
|
navBorder.attr('height',chartSize[1]/nav_scale/scaleFactor)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function toggle() {
|
||||||
|
if (!isShowing) {
|
||||||
|
isShowing = true;
|
||||||
|
$("#red-ui-view-navigate").addClass("selected");
|
||||||
|
resizeNavBorder();
|
||||||
|
refreshNodes();
|
||||||
|
$("#red-ui-workspace-chart").on("scroll",onScroll);
|
||||||
|
navContainer.fadeIn(200);
|
||||||
|
} else {
|
||||||
|
isShowing = false;
|
||||||
|
navContainer.fadeOut(100);
|
||||||
|
$("#red-ui-workspace-chart").off("scroll",onScroll);
|
||||||
|
$("#red-ui-view-navigate").removeClass("selected");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
navContainer = $('<div>').css({
|
return {
|
||||||
"position":"absolute",
|
init: function() {
|
||||||
"bottom":$("#red-ui-workspace-footer").height(),
|
|
||||||
"right":0,
|
|
||||||
zIndex: 1
|
|
||||||
}).appendTo("#red-ui-workspace").hide();
|
|
||||||
|
|
||||||
navBox = d3.select(navContainer[0])
|
$(window).on("resize", resizeNavBorder);
|
||||||
.append("svg:svg")
|
RED.events.on("sidebar:resize",resizeNavBorder);
|
||||||
.attr("width", nav_width)
|
RED.actions.add("core:toggle-navigator",toggle);
|
||||||
.attr("height", nav_height)
|
|
||||||
.attr("pointer-events", "all")
|
|
||||||
.attr("id","red-ui-navigator-canvas")
|
|
||||||
|
|
||||||
navBox.append("rect").attr("x",0).attr("y",0).attr("width",nav_width).attr("height",nav_height).style({
|
navContainer = $('<div>').css({
|
||||||
fill:"none",
|
"position":"absolute",
|
||||||
stroke:"none",
|
"bottom":$("#red-ui-workspace-footer").height(),
|
||||||
pointerEvents:"all"
|
"right":0,
|
||||||
}).on("mousedown", function() {
|
zIndex: 1
|
||||||
// Update these in case they have changed
|
}).appendTo("#red-ui-workspace").hide();
|
||||||
scaleFactor = RED.view.scale();
|
|
||||||
chartSize = [ $("#red-ui-workspace-chart").width(), $("#red-ui-workspace-chart").height()];
|
|
||||||
dimensions = [chartSize[0]/nav_scale/scaleFactor, chartSize[1]/nav_scale/scaleFactor];
|
|
||||||
var newX = Math.max(0,Math.min(d3.event.offsetX+dimensions[0]/2,nav_width)-dimensions[0]);
|
|
||||||
var newY = Math.max(0,Math.min(d3.event.offsetY+dimensions[1]/2,nav_height)-dimensions[1]);
|
|
||||||
navBorder.attr('x',newX).attr('y',newY);
|
|
||||||
isDragging = true;
|
|
||||||
$("#red-ui-workspace-chart").scrollLeft(newX*nav_scale*scaleFactor);
|
|
||||||
$("#red-ui-workspace-chart").scrollTop(newY*nav_scale*scaleFactor);
|
|
||||||
}).on("mousemove", function() {
|
|
||||||
if (!isDragging) { return }
|
|
||||||
if (d3.event.buttons === 0) {
|
|
||||||
isDragging = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var newX = Math.max(0,Math.min(d3.event.offsetX+dimensions[0]/2,nav_width)-dimensions[0]);
|
|
||||||
var newY = Math.max(0,Math.min(d3.event.offsetY+dimensions[1]/2,nav_height)-dimensions[1]);
|
|
||||||
navBorder.attr('x',newX).attr('y',newY);
|
|
||||||
$("#red-ui-workspace-chart").scrollLeft(newX*nav_scale*scaleFactor);
|
|
||||||
$("#red-ui-workspace-chart").scrollTop(newY*nav_scale*scaleFactor);
|
|
||||||
}).on("mouseup", function() {
|
|
||||||
isDragging = false;
|
|
||||||
})
|
|
||||||
|
|
||||||
navBorder = navBox.append("rect").attr("class","red-ui-navigator-border")
|
navBox = $(RED.utils.createSVGElement('svg', {id: "red-ui-navigator-canvas", width: nav_width, height: nav_height, 'pointer-events': 'all'})).appendTo(navContainer)
|
||||||
|
|
||||||
navVis = navBox.append("svg:g")
|
const navBoxBody = $(RED.utils.createSVGElement("rect", { x: 0, y: 0, width: nav_width, height: nav_height, fill: 'none', stroke: 'none', 'pointer-events': 'all'}))
|
||||||
|
.css({'cursor': 'pointer'})
|
||||||
|
navBoxBody.on('mousedown',function(event) {
|
||||||
|
// Update these in case they have changed
|
||||||
|
scaleFactor = RED.view.scale();
|
||||||
|
chartSize = [ $("#red-ui-workspace-chart").width(), $("#red-ui-workspace-chart").height()];
|
||||||
|
dimensions = [chartSize[0]/nav_scale/scaleFactor, chartSize[1]/nav_scale/scaleFactor];
|
||||||
|
var newX = Math.max(0,Math.min(event.offsetX+dimensions[0]/2,nav_width)-dimensions[0]);
|
||||||
|
var newY = Math.max(0,Math.min(event.offsetY+dimensions[1]/2,nav_height)-dimensions[1]);
|
||||||
|
navBorder.attr('x',newX)
|
||||||
|
navBorder.attr('y',newY);
|
||||||
|
isDragging = true;
|
||||||
|
$("#red-ui-workspace-chart").scrollLeft(newX*nav_scale*scaleFactor);
|
||||||
|
$("#red-ui-workspace-chart").scrollTop(newY*nav_scale*scaleFactor);
|
||||||
|
}).on('mousemove', function(event) {
|
||||||
|
if (!isDragging) { return }
|
||||||
|
if (event.buttons === 0) {
|
||||||
|
isDragging = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var newX = Math.max(0,Math.min(event.offsetX+dimensions[0]/2,nav_width)-dimensions[0]);
|
||||||
|
var newY = Math.max(0,Math.min(event.offsetY+dimensions[1]/2,nav_height)-dimensions[1]);
|
||||||
|
navBorder.attr('x',newX)
|
||||||
|
navBorder.attr('y',newY);
|
||||||
|
$("#red-ui-workspace-chart").scrollLeft(newX*nav_scale*scaleFactor);
|
||||||
|
$("#red-ui-workspace-chart").scrollTop(newY*nav_scale*scaleFactor);
|
||||||
|
}).on('mouseup', function() {
|
||||||
|
isDragging = false;
|
||||||
|
}).appendTo(navBox)
|
||||||
|
|
||||||
RED.statusBar.add({
|
navBorder = $(RED.utils.createSVGElement("rect", { "class": "red-ui-navigator-border" })).appendTo(navBox)
|
||||||
id: "view-navigator",
|
|
||||||
align: "right",
|
const navVis = $(RED.utils.createSVGElement('g')).appendTo(navBox)
|
||||||
element: $('<button class="red-ui-footer-button-toggle single" id="red-ui-view-navigate"><i class="fa fa-map-o"></i></button>')
|
|
||||||
})
|
domSelection = RED.utils.domSelection(navVis[0], '.red-ui-navigator-node', function() {
|
||||||
|
return RED.utils.createSVGElement('rect', { class: 'red-ui-navigator-node', 'pointer-events': 'none' })
|
||||||
|
}, function(node) {
|
||||||
|
node.setAttribute('x', (this.x-this.w/2)/nav_scale)
|
||||||
|
node.setAttribute('y', (this.y-this.h/2)/nav_scale)
|
||||||
|
node.setAttribute('width', Math.max(9,this.w/nav_scale))
|
||||||
|
node.setAttribute('height', Math.max(3,this.h/nav_scale))
|
||||||
|
node.setAttribute('fill', RED.utils.getNodeColor(this.type,this._def))
|
||||||
|
})
|
||||||
|
|
||||||
|
RED.statusBar.add({
|
||||||
|
id: "view-navigator",
|
||||||
|
align: "right",
|
||||||
|
element: $('<button class="red-ui-footer-button-toggle single" id="red-ui-view-navigate"><i class="fa fa-map-o"></i></button>')
|
||||||
|
})
|
||||||
|
|
||||||
$("#red-ui-view-navigate").on("click", function(evt) {
|
$("#red-ui-view-navigate").on("click", function(evt) {
|
||||||
evt.preventDefault();
|
evt.preventDefault();
|
||||||
|
@@ -294,25 +294,13 @@ RED.view = (function() {
|
|||||||
]
|
]
|
||||||
startTouchDistance = Math.sqrt((a*a)+(b*b));
|
startTouchDistance = Math.sqrt((a*a)+(b*b));
|
||||||
} else {
|
} else {
|
||||||
var obj = d3.select(document.body);
|
|
||||||
touch0 = d3.event.touches.item(0);
|
touch0 = d3.event.touches.item(0);
|
||||||
var pos = [touch0.pageX,touch0.pageY];
|
var pos = [touch0.pageX,touch0.pageY];
|
||||||
startTouchCenter = [touch0.pageX,touch0.pageY];
|
startTouchCenter = [touch0.pageX,touch0.pageY];
|
||||||
startTouchDistance = 0;
|
startTouchDistance = 0;
|
||||||
var point = d3.touches(this)[0];
|
|
||||||
touchStartTime = setTimeout(function() {
|
touchStartTime = setTimeout(function() {
|
||||||
touchStartTime = null;
|
touchStartTime = null;
|
||||||
showTouchMenu(obj,pos);
|
showTouchMenu(document.body,pos);
|
||||||
//lasso = eventLayer.append("rect")
|
|
||||||
// .attr("ox",point[0])
|
|
||||||
// .attr("oy",point[1])
|
|
||||||
// .attr("rx",2)
|
|
||||||
// .attr("ry",2)
|
|
||||||
// .attr("x",point[0])
|
|
||||||
// .attr("y",point[1])
|
|
||||||
// .attr("width",0)
|
|
||||||
// .attr("height",0)
|
|
||||||
// .attr("class","nr-ui-view-lasso");
|
|
||||||
},touchLongPressTimeout);
|
},touchLongPressTimeout);
|
||||||
}
|
}
|
||||||
d3.event.preventDefault();
|
d3.event.preventDefault();
|
||||||
@@ -712,11 +700,11 @@ RED.view = (function() {
|
|||||||
type: "badge",
|
type: "badge",
|
||||||
class: "red-ui-flow-node-changed",
|
class: "red-ui-flow-node-changed",
|
||||||
element: function() {
|
element: function() {
|
||||||
var changeBadge = document.createElementNS("http://www.w3.org/2000/svg","circle");
|
return RED.utils.createSVGElement("circle", {
|
||||||
changeBadge.setAttribute("cx",5);
|
cx: 5,
|
||||||
changeBadge.setAttribute("cy",5);
|
cy: 5,
|
||||||
changeBadge.setAttribute("r",5);
|
r: 5
|
||||||
return changeBadge;
|
})
|
||||||
},
|
},
|
||||||
show: function(n) { return n.changed||n.moved }
|
show: function(n) { return n.changed||n.moved }
|
||||||
})
|
})
|
||||||
@@ -725,9 +713,9 @@ RED.view = (function() {
|
|||||||
type: "badge",
|
type: "badge",
|
||||||
class: "red-ui-flow-node-error",
|
class: "red-ui-flow-node-error",
|
||||||
element: function(d) {
|
element: function(d) {
|
||||||
var errorBadge = document.createElementNS("http://www.w3.org/2000/svg","path");
|
return RED.utils.createSVGElement("path", {
|
||||||
errorBadge.setAttribute("d","M 0,9 l 10,0 -5,-8 z");
|
d: "M 0,9 l 10,0 -5,-8 z"
|
||||||
return errorBadge
|
})
|
||||||
},
|
},
|
||||||
tooltip: function(d) {
|
tooltip: function(d) {
|
||||||
if (d.validationErrors && d.validationErrors.length > 0) {
|
if (d.validationErrors && d.validationErrors.length > 0) {
|
||||||
@@ -3703,13 +3691,12 @@ RED.view = (function() {
|
|||||||
}
|
}
|
||||||
function nodeTouchStart(d) {
|
function nodeTouchStart(d) {
|
||||||
if (RED.view.DEBUG) { console.warn("nodeTouchStart", mouse_mode,d); }
|
if (RED.view.DEBUG) { console.warn("nodeTouchStart", mouse_mode,d); }
|
||||||
var obj = d3.select(this);
|
|
||||||
var touch0 = d3.event.touches.item(0);
|
var touch0 = d3.event.touches.item(0);
|
||||||
var pos = [touch0.pageX,touch0.pageY];
|
var pos = [touch0.pageX,touch0.pageY];
|
||||||
startTouchCenter = [touch0.pageX,touch0.pageY];
|
startTouchCenter = [touch0.pageX,touch0.pageY];
|
||||||
startTouchDistance = 0;
|
startTouchDistance = 0;
|
||||||
touchStartTime = setTimeout(function() {
|
touchStartTime = setTimeout(function() {
|
||||||
showTouchMenu(obj,pos);
|
showTouchMenu(this,pos);
|
||||||
},touchLongPressTimeout);
|
},touchLongPressTimeout);
|
||||||
nodeMouseDown.call(this,d)
|
nodeMouseDown.call(this,d)
|
||||||
d3.event.preventDefault();
|
d3.event.preventDefault();
|
||||||
@@ -3868,12 +3855,11 @@ RED.view = (function() {
|
|||||||
focusView();
|
focusView();
|
||||||
d3.event.stopPropagation();
|
d3.event.stopPropagation();
|
||||||
|
|
||||||
var obj = d3.select(document.body);
|
|
||||||
var touch0 = d3.event.touches.item(0);
|
var touch0 = d3.event.touches.item(0);
|
||||||
var pos = [touch0.pageX,touch0.pageY];
|
var pos = [touch0.pageX,touch0.pageY];
|
||||||
touchStartTime = setTimeout(function() {
|
touchStartTime = setTimeout(function() {
|
||||||
touchStartTime = null;
|
touchStartTime = null;
|
||||||
showTouchMenu(obj,pos);
|
showTouchMenu(document.body,pos);
|
||||||
},touchLongPressTimeout);
|
},touchLongPressTimeout);
|
||||||
d3.event.preventDefault();
|
d3.event.preventDefault();
|
||||||
}
|
}
|
||||||
@@ -4247,13 +4233,14 @@ RED.view = (function() {
|
|||||||
d.resize = true;
|
d.resize = true;
|
||||||
d.dirty = true;
|
d.dirty = true;
|
||||||
|
|
||||||
var mainRect = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
var mainRect = RED.utils.createSVGElement("rect", {
|
||||||
|
class: "red-ui-flow-subflow-port",
|
||||||
|
rx: 8,
|
||||||
|
ry: 8,
|
||||||
|
width: 40,
|
||||||
|
height: 40,
|
||||||
|
})
|
||||||
mainRect.__data__ = d;
|
mainRect.__data__ = d;
|
||||||
mainRect.setAttribute("class", "red-ui-flow-subflow-port");
|
|
||||||
mainRect.setAttribute("rx", 8);
|
|
||||||
mainRect.setAttribute("ry", 8);
|
|
||||||
mainRect.setAttribute("width", 40);
|
|
||||||
mainRect.setAttribute("height", 40);
|
|
||||||
node[0][0].__mainRect__ = mainRect;
|
node[0][0].__mainRect__ = mainRect;
|
||||||
d3.select(mainRect)
|
d3.select(mainRect)
|
||||||
.on("mouseup",nodeMouseUp)
|
.on("mouseup",nodeMouseUp)
|
||||||
@@ -4262,50 +4249,50 @@ RED.view = (function() {
|
|||||||
.on("touchend",nodeTouchEnd)
|
.on("touchend",nodeTouchEnd)
|
||||||
nodeContents.appendChild(mainRect);
|
nodeContents.appendChild(mainRect);
|
||||||
|
|
||||||
var output_groupEl = document.createElementNS("http://www.w3.org/2000/svg","g");
|
var output_groupEl = RED.utils.createSVGElement("g", { x: 0, y: 0 })
|
||||||
output_groupEl.setAttribute("x",0);
|
|
||||||
output_groupEl.setAttribute("y",0);
|
|
||||||
node[0][0].__outputLabelGroup__ = output_groupEl;
|
node[0][0].__outputLabelGroup__ = output_groupEl;
|
||||||
|
|
||||||
var output_output = document.createElementNS("http://www.w3.org/2000/svg","text");
|
var output_output = RED.utils.createSVGElement("text", { class: "red-ui-flow-port-label" })
|
||||||
output_output.setAttribute("class","red-ui-flow-port-label");
|
|
||||||
output_output.style["font-size"] = "10px";
|
output_output.style["font-size"] = "10px";
|
||||||
output_output.textContent = "output";
|
output_output.textContent = "output";
|
||||||
output_groupEl.appendChild(output_output);
|
output_groupEl.appendChild(output_output);
|
||||||
node[0][0].__outputOutput__ = output_output;
|
node[0][0].__outputOutput__ = output_output;
|
||||||
|
|
||||||
var output_number = document.createElementNS("http://www.w3.org/2000/svg","text");
|
var output_number = RED.utils.createSVGElement("text", {
|
||||||
output_number.setAttribute("class","red-ui-flow-port-label red-ui-flow-port-index");
|
class: "red-ui-flow-port-label red-ui-flow-port-index",
|
||||||
output_number.setAttribute("x",0);
|
x: 0,
|
||||||
output_number.setAttribute("y",0);
|
y: 0
|
||||||
|
})
|
||||||
output_number.textContent = d.i+1;
|
output_number.textContent = d.i+1;
|
||||||
output_groupEl.appendChild(output_number);
|
output_groupEl.appendChild(output_number);
|
||||||
node[0][0].__outputNumber__ = output_number;
|
node[0][0].__outputNumber__ = output_number;
|
||||||
|
|
||||||
var output_border = document.createElementNS("http://www.w3.org/2000/svg","path");
|
var output_border = RED.utils.createSVGElement("path", {
|
||||||
output_border.setAttribute("d","M 40 1 l 0 38")
|
d: "M 40 1 l 0 38",
|
||||||
output_border.setAttribute("class", "red-ui-flow-node-icon-shade-border")
|
class: "red-ui-flow-node-icon-shade-border"
|
||||||
|
})
|
||||||
output_groupEl.appendChild(output_border);
|
output_groupEl.appendChild(output_border);
|
||||||
node[0][0].__outputBorder__ = output_border;
|
node[0][0].__outputBorder__ = output_border;
|
||||||
|
|
||||||
nodeContents.appendChild(output_groupEl);
|
nodeContents.appendChild(output_groupEl);
|
||||||
|
|
||||||
var text = document.createElementNS("http://www.w3.org/2000/svg","g");
|
var text = RED.utils.createSVGElement("g", {
|
||||||
text.setAttribute("class","red-ui-flow-port-label");
|
class: "red-ui-flow-port-label",
|
||||||
text.setAttribute("transform","translate(38,0)");
|
transform: "translate(38,0)",
|
||||||
text.setAttribute('style', 'fill : #888'); // hard coded here!
|
style: 'fill : #888' // hard coded here!
|
||||||
|
})
|
||||||
node[0][0].__textGroup__ = text;
|
node[0][0].__textGroup__ = text;
|
||||||
nodeContents.append(text);
|
nodeContents.append(text);
|
||||||
|
|
||||||
var portEl = document.createElementNS("http://www.w3.org/2000/svg","g");
|
var portEl = RED.utils.createSVGElement("g", { transform: 'translate(-5,15)'})
|
||||||
portEl.setAttribute('transform','translate(-5,15)')
|
|
||||||
|
|
||||||
var port = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
var port = RED.utils.createSVGElement("rect", {
|
||||||
port.setAttribute("class","red-ui-flow-port");
|
class: "red-ui-flow-port",
|
||||||
port.setAttribute("rx",3);
|
rx: 3,
|
||||||
port.setAttribute("ry",3);
|
ry: 3,
|
||||||
port.setAttribute("width",10);
|
width: 10,
|
||||||
port.setAttribute("height",10);
|
height: 10
|
||||||
|
})
|
||||||
portEl.appendChild(port);
|
portEl.appendChild(port);
|
||||||
port.__data__ = d;
|
port.__data__ = d;
|
||||||
|
|
||||||
@@ -4434,10 +4421,11 @@ RED.view = (function() {
|
|||||||
}
|
}
|
||||||
for (var i=0; i<sn; i++) {
|
for (var i=0; i<sn; i++) {
|
||||||
if (i===textLines.length) {
|
if (i===textLines.length) {
|
||||||
var line = document.createElementNS("http://www.w3.org/2000/svg","text");
|
var line = RED.utils.createSVGElement("text", {
|
||||||
line.setAttribute("class","red-ui-flow-node-label-text");
|
class: "red-ui-flow-node-label-text",
|
||||||
line.setAttribute("x",0);
|
x: 0,
|
||||||
line.setAttribute("y",i*24);
|
y: i*24
|
||||||
|
});
|
||||||
this.__textGroup__.appendChild(line);
|
this.__textGroup__.appendChild(line);
|
||||||
}
|
}
|
||||||
textLines[i].textContent = sa[i];
|
textLines[i].textContent = sa[i];
|
||||||
@@ -4507,32 +4495,35 @@ RED.view = (function() {
|
|||||||
d.resize = true;
|
d.resize = true;
|
||||||
|
|
||||||
if (d._def.button) {
|
if (d._def.button) {
|
||||||
var buttonGroup = document.createElementNS("http://www.w3.org/2000/svg","g");
|
var buttonGroup = RED.utils.createSVGElement("g", {
|
||||||
|
class: "red-ui-flow-node-button",
|
||||||
|
transform: "translate("+((d._def.align == "right") ? 94 : -25)+",2)"
|
||||||
|
})
|
||||||
buttonGroup.__data__ = d;
|
buttonGroup.__data__ = d;
|
||||||
buttonGroup.setAttribute("transform", "translate("+((d._def.align == "right") ? 94 : -25)+",2)");
|
|
||||||
buttonGroup.setAttribute("class","red-ui-flow-node-button");
|
|
||||||
node[0][0].__buttonGroup__ = buttonGroup;
|
node[0][0].__buttonGroup__ = buttonGroup;
|
||||||
|
|
||||||
var bgBackground = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
var bgBackground = RED.utils.createSVGElement("rect", {
|
||||||
|
class: "red-ui-flow-node-button-background",
|
||||||
|
rx: 5,
|
||||||
|
ry: 5,
|
||||||
|
width: 32,
|
||||||
|
height: node_height-4
|
||||||
|
})
|
||||||
bgBackground.__data__ = d;
|
bgBackground.__data__ = d;
|
||||||
bgBackground.setAttribute("class","red-ui-flow-node-button-background");
|
|
||||||
bgBackground.setAttribute("rx",5);
|
|
||||||
bgBackground.setAttribute("ry",5);
|
|
||||||
bgBackground.setAttribute("width",32);
|
|
||||||
bgBackground.setAttribute("height",node_height-4);
|
|
||||||
buttonGroup.appendChild(bgBackground);
|
buttonGroup.appendChild(bgBackground);
|
||||||
node[0][0].__buttonGroupBackground__ = bgBackground;
|
node[0][0].__buttonGroupBackground__ = bgBackground;
|
||||||
|
|
||||||
var bgButton = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
var bgButton = RED.utils.createSVGElement("rect", {
|
||||||
|
class: "red-ui-flow-node-button-button",
|
||||||
|
x: d._def.align == "right"? 11:5,
|
||||||
|
y: 4,
|
||||||
|
rx: 4,
|
||||||
|
ry: 4,
|
||||||
|
width: 16,
|
||||||
|
height: node_height-12,
|
||||||
|
fill: RED.utils.getNodeColor(d.type,d._def)
|
||||||
|
})
|
||||||
bgButton.__data__ = d;
|
bgButton.__data__ = d;
|
||||||
bgButton.setAttribute("class","red-ui-flow-node-button-button");
|
|
||||||
bgButton.setAttribute("x", d._def.align == "right"? 11:5);
|
|
||||||
bgButton.setAttribute("y",4);
|
|
||||||
bgButton.setAttribute("rx",4);
|
|
||||||
bgButton.setAttribute("ry",4);
|
|
||||||
bgButton.setAttribute("width",16);
|
|
||||||
bgButton.setAttribute("height",node_height-12);
|
|
||||||
bgButton.setAttribute("fill", RED.utils.getNodeColor(d.type,d._def));
|
|
||||||
d3.select(bgButton)
|
d3.select(bgButton)
|
||||||
.on("mousedown",function(d) {if (!lasso && isButtonEnabled(d)) {focusView();d3.select(this).attr("fill-opacity",0.2);d3.event.preventDefault(); d3.event.stopPropagation();}})
|
.on("mousedown",function(d) {if (!lasso && isButtonEnabled(d)) {focusView();d3.select(this).attr("fill-opacity",0.2);d3.event.preventDefault(); d3.event.stopPropagation();}})
|
||||||
.on("mouseup",function(d) {if (!lasso && isButtonEnabled(d)) { d3.select(this).attr("fill-opacity",0.4);d3.event.preventDefault();d3.event.stopPropagation();}})
|
.on("mouseup",function(d) {if (!lasso && isButtonEnabled(d)) { d3.select(this).attr("fill-opacity",0.4);d3.event.preventDefault();d3.event.stopPropagation();}})
|
||||||
@@ -4553,12 +4544,13 @@ RED.view = (function() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var mainRect = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
var mainRect = RED.utils.createSVGElement("rect", {
|
||||||
|
class: "red-ui-flow-node "+(d.type == "unknown"?"red-ui-flow-node-unknown":""),
|
||||||
|
rx: 5,
|
||||||
|
ry: 5,
|
||||||
|
fill: RED.utils.getNodeColor(d.type,d._def)
|
||||||
|
})
|
||||||
mainRect.__data__ = d;
|
mainRect.__data__ = d;
|
||||||
mainRect.setAttribute("class", "red-ui-flow-node "+(d.type == "unknown"?"red-ui-flow-node-unknown":""));
|
|
||||||
mainRect.setAttribute("rx", 5);
|
|
||||||
mainRect.setAttribute("ry", 5);
|
|
||||||
mainRect.setAttribute("fill", RED.utils.getNodeColor(d.type,d._def));
|
|
||||||
node[0][0].__mainRect__ = mainRect;
|
node[0][0].__mainRect__ = mainRect;
|
||||||
d3.select(mainRect)
|
d3.select(mainRect)
|
||||||
.on("mouseup",nodeMouseUp)
|
.on("mouseup",nodeMouseUp)
|
||||||
@@ -4573,61 +4565,65 @@ RED.view = (function() {
|
|||||||
|
|
||||||
if (d._def.icon) {
|
if (d._def.icon) {
|
||||||
var icon_url = RED.utils.getNodeIcon(d._def,d);
|
var icon_url = RED.utils.getNodeIcon(d._def,d);
|
||||||
var icon_groupEl = document.createElementNS("http://www.w3.org/2000/svg","g");
|
var icon_groupEl = RED.utils.createSVGElement("g", {
|
||||||
icon_groupEl.__data__ = d;
|
class: "red-ui-flow-node-icon-group"+("right" == d._def.align?" red-ui-flow-node-icon-group-right":""),
|
||||||
icon_groupEl.setAttribute("class","red-ui-flow-node-icon-group"+("right" == d._def.align?" red-ui-flow-node-icon-group-right":""));
|
x: 0,
|
||||||
icon_groupEl.setAttribute("x",0);
|
y: 0
|
||||||
icon_groupEl.setAttribute("y",0);
|
})
|
||||||
icon_groupEl.style["pointer-events"] = "none";
|
icon_groupEl.style["pointer-events"] = "none";
|
||||||
|
icon_groupEl.__data__ = d;
|
||||||
node[0][0].__iconGroup__ = icon_groupEl;
|
node[0][0].__iconGroup__ = icon_groupEl;
|
||||||
var icon_shade = document.createElementNS("http://www.w3.org/2000/svg","path");
|
var icon_shade = RED.utils.createSVGElement("path", {
|
||||||
icon_shade.setAttribute("x",0);
|
x: 0,
|
||||||
icon_shade.setAttribute("y",0);
|
y: 0,
|
||||||
icon_shade.setAttribute("class","red-ui-flow-node-icon-shade")
|
class: "red-ui-flow-node-icon-shade"
|
||||||
|
})
|
||||||
icon_groupEl.appendChild(icon_shade);
|
icon_groupEl.appendChild(icon_shade);
|
||||||
node[0][0].__iconShade__ = icon_shade;
|
node[0][0].__iconShade__ = icon_shade;
|
||||||
|
|
||||||
var icon_group = d3.select(icon_groupEl)
|
var icon_group = d3.select(icon_groupEl)
|
||||||
createIconAttributes(icon_url, icon_group, d);
|
createIconAttributes(icon_url, icon_group, d);
|
||||||
|
|
||||||
var icon_shade_border = document.createElementNS("http://www.w3.org/2000/svg","path");
|
var icon_shade_border = RED.utils.createSVGElement("path", {
|
||||||
icon_shade_border.setAttribute("d","right" != d._def.align ? "M 30 1 l 0 "+(d.h-2) : "M 0 1 l 0 "+(d.h-2) )
|
d: "right" != d._def.align ? "M 30 1 l 0 "+(d.h-2) : "M 0 1 l 0 "+(d.h-2),
|
||||||
icon_shade_border.setAttribute("class", "red-ui-flow-node-icon-shade-border")
|
class: "red-ui-flow-node-icon-shade-border"
|
||||||
|
})
|
||||||
icon_groupEl.appendChild(icon_shade_border);
|
icon_groupEl.appendChild(icon_shade_border);
|
||||||
node[0][0].__iconShadeBorder__ = icon_shade_border;
|
node[0][0].__iconShadeBorder__ = icon_shade_border;
|
||||||
|
|
||||||
nodeContents.appendChild(icon_groupEl);
|
nodeContents.appendChild(icon_groupEl);
|
||||||
}
|
}
|
||||||
var text = document.createElementNS("http://www.w3.org/2000/svg","g");
|
var text = RED.utils.createSVGElement("g", {
|
||||||
text.setAttribute("class","red-ui-flow-node-label"+(hideLabel?" hide":"")+(d._def.align?" red-ui-flow-node-label-"+d._def.align:""));
|
class: "red-ui-flow-node-label"+(hideLabel?" hide":"")+(d._def.align?" red-ui-flow-node-label-"+d._def.align:""),
|
||||||
text.setAttribute("transform","translate(38,0)");
|
transform: "translate(38,0)"
|
||||||
// text.setAttribute("dy", ".3px");
|
// dy: ".3px",
|
||||||
// text.setAttribute("text-anchor",d._def.align !== "right" ? "start":"end");
|
// "text-anchor": d._def.align !== "right" ? "start":"end"
|
||||||
|
})
|
||||||
nodeContents.appendChild(text);
|
nodeContents.appendChild(text);
|
||||||
node[0][0].__textGroup__ = text;
|
node[0][0].__textGroup__ = text;
|
||||||
|
|
||||||
var statusEl = document.createElementNS("http://www.w3.org/2000/svg","g");
|
var statusEl = RED.utils.createSVGElement("g", { class: "red-ui-flow-node-status-group" })
|
||||||
// statusEl.__data__ = d;
|
|
||||||
statusEl.setAttribute("class","red-ui-flow-node-status-group");
|
|
||||||
statusEl.style.display = "none";
|
statusEl.style.display = "none";
|
||||||
node[0][0].__statusGroup__ = statusEl;
|
node[0][0].__statusGroup__ = statusEl;
|
||||||
|
|
||||||
var statusRect = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
var statusRect = RED.utils.createSVGElement("rect", {
|
||||||
statusRect.setAttribute("class","red-ui-flow-node-status");
|
class: "red-ui-flow-node-status",
|
||||||
statusRect.setAttribute("x",6);
|
x: 6,
|
||||||
statusRect.setAttribute("y",1);
|
y: 1,
|
||||||
statusRect.setAttribute("width",9);
|
width: 9,
|
||||||
statusRect.setAttribute("height",9);
|
height: 9,
|
||||||
statusRect.setAttribute("rx",2);
|
rx: 2,
|
||||||
statusRect.setAttribute("ry",2);
|
ry: 2,
|
||||||
statusRect.setAttribute("stroke-width","3");
|
"stroke-width": 3
|
||||||
|
})
|
||||||
statusEl.appendChild(statusRect);
|
statusEl.appendChild(statusRect);
|
||||||
node[0][0].__statusShape__ = statusRect;
|
node[0][0].__statusShape__ = statusRect;
|
||||||
|
|
||||||
var statusLabel = document.createElementNS("http://www.w3.org/2000/svg","text");
|
var statusLabel = RED.utils.createSVGElement("text", {
|
||||||
statusLabel.setAttribute("class","red-ui-flow-node-status-label");
|
class: "red-ui-flow-node-status-label",
|
||||||
statusLabel.setAttribute("x",20);
|
x: 20,
|
||||||
statusLabel.setAttribute("y",10);
|
y: 10
|
||||||
|
})
|
||||||
statusEl.appendChild(statusLabel);
|
statusEl.appendChild(statusLabel);
|
||||||
node[0][0].__statusLabel__ = statusLabel;
|
node[0][0].__statusLabel__ = statusLabel;
|
||||||
|
|
||||||
@@ -4712,10 +4708,11 @@ RED.view = (function() {
|
|||||||
}
|
}
|
||||||
for (var i=0; i<sn; i++) {
|
for (var i=0; i<sn; i++) {
|
||||||
if (i===textLines.length) {
|
if (i===textLines.length) {
|
||||||
var line = document.createElementNS("http://www.w3.org/2000/svg","text");
|
var line = RED.utils.createSVGElement("text", {
|
||||||
line.setAttribute("class","red-ui-flow-node-label-text");
|
class: "red-ui-flow-node-label-text",
|
||||||
line.setAttribute("x",0);
|
x: 0,
|
||||||
line.setAttribute("y",i*24);
|
y: i*24
|
||||||
|
})
|
||||||
this.__textGroup__.appendChild(line);
|
this.__textGroup__.appendChild(line);
|
||||||
}
|
}
|
||||||
textLines[i].textContent = sa[i];
|
textLines[i].textContent = sa[i];
|
||||||
@@ -4814,22 +4811,23 @@ RED.view = (function() {
|
|||||||
for(var portIndex = 0; portIndex < numOutputs; portIndex++ ) {
|
for(var portIndex = 0; portIndex < numOutputs; portIndex++ ) {
|
||||||
var portGroup;
|
var portGroup;
|
||||||
if (portIndex === this.__outputs__.length) {
|
if (portIndex === this.__outputs__.length) {
|
||||||
portGroup = document.createElementNS("http://www.w3.org/2000/svg","g");
|
portGroup = RED.utils.createSVGElement("g", { class: "red-ui-flow-port-output" })
|
||||||
portGroup.setAttribute("class","red-ui-flow-port-output");
|
|
||||||
var portPort;
|
var portPort;
|
||||||
if (d.type === "link out") {
|
if (d.type === "link out") {
|
||||||
portPort = document.createElementNS("http://www.w3.org/2000/svg","circle");
|
portPort = RED.utils.createSVGElement("circle", {
|
||||||
portPort.setAttribute("cx",11);
|
cx: 11,
|
||||||
portPort.setAttribute("cy",5);
|
cy: 5,
|
||||||
portPort.setAttribute("r",5);
|
r: 5,
|
||||||
portPort.setAttribute("class","red-ui-flow-port red-ui-flow-link-port");
|
class: "red-ui-flow-port red-ui-flow-link-port"
|
||||||
|
})
|
||||||
} else {
|
} else {
|
||||||
portPort = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
portPort = RED.utils.createSVGElement("rect", {
|
||||||
portPort.setAttribute("rx",3);
|
rx: 3,
|
||||||
portPort.setAttribute("ry",3);
|
ry: 3,
|
||||||
portPort.setAttribute("width",10);
|
width: 10,
|
||||||
portPort.setAttribute("height",10);
|
height: 10,
|
||||||
portPort.setAttribute("class","red-ui-flow-port");
|
class: "red-ui-flow-port"
|
||||||
|
})
|
||||||
}
|
}
|
||||||
portGroup.appendChild(portPort);
|
portGroup.appendChild(portPort);
|
||||||
portGroup.__port__ = portPort;
|
portGroup.__port__ = portPort;
|
||||||
@@ -4981,26 +4979,28 @@ RED.view = (function() {
|
|||||||
var junction = d3.select(this);
|
var junction = d3.select(this);
|
||||||
var contents = document.createDocumentFragment();
|
var contents = document.createDocumentFragment();
|
||||||
// d.added = true;
|
// d.added = true;
|
||||||
var junctionBack = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
var junctionBack = RED.utils.createSVGElement("rect", {
|
||||||
junctionBack.setAttribute("class","red-ui-flow-junction-background");
|
class: "red-ui-flow-junction-background",
|
||||||
junctionBack.setAttribute("x",-5);
|
x: -5,
|
||||||
junctionBack.setAttribute("y",-5);
|
y: -5,
|
||||||
junctionBack.setAttribute("width",10);
|
width: 10,
|
||||||
junctionBack.setAttribute("height",10);
|
height: 10,
|
||||||
junctionBack.setAttribute("rx",3);
|
rx: 3,
|
||||||
junctionBack.setAttribute("ry",3);
|
ry: 3
|
||||||
|
})
|
||||||
junctionBack.__data__ = d;
|
junctionBack.__data__ = d;
|
||||||
this.__junctionBack__ = junctionBack;
|
this.__junctionBack__ = junctionBack;
|
||||||
contents.appendChild(junctionBack);
|
contents.appendChild(junctionBack);
|
||||||
|
|
||||||
var junctionInput = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
var junctionInput = RED.utils.createSVGElement("rect", {
|
||||||
junctionInput.setAttribute("class","red-ui-flow-junction-port red-ui-flow-junction-port-input");
|
class: "red-ui-flow-junction-port red-ui-flow-junction-port-input",
|
||||||
junctionInput.setAttribute("x",-5);
|
x: -5,
|
||||||
junctionInput.setAttribute("y",-5);
|
y: -5,
|
||||||
junctionInput.setAttribute("width",10);
|
width: 10,
|
||||||
junctionInput.setAttribute("height",10);
|
height: 10,
|
||||||
junctionInput.setAttribute("rx",3);
|
rx: 3,
|
||||||
junctionInput.setAttribute("ry",3);
|
ry: 3
|
||||||
|
})
|
||||||
junctionInput.__data__ = d;
|
junctionInput.__data__ = d;
|
||||||
junctionInput.__portType__ = PORT_TYPE_INPUT;
|
junctionInput.__portType__ = PORT_TYPE_INPUT;
|
||||||
junctionInput.__portIndex__ = 0;
|
junctionInput.__portIndex__ = 0;
|
||||||
@@ -5012,14 +5012,15 @@ RED.view = (function() {
|
|||||||
|
|
||||||
this.__junctionInput__ = junctionInput;
|
this.__junctionInput__ = junctionInput;
|
||||||
contents.appendChild(junctionInput);
|
contents.appendChild(junctionInput);
|
||||||
var junctionOutput = document.createElementNS("http://www.w3.org/2000/svg","rect");
|
var junctionOutput = RED.utils.createSVGElement("rect", {
|
||||||
junctionOutput.setAttribute("class","red-ui-flow-junction-port red-ui-flow-junction-port-output");
|
class: "red-ui-flow-junction-port red-ui-flow-junction-port-output",
|
||||||
junctionOutput.setAttribute("x",-5);
|
x: -5,
|
||||||
junctionOutput.setAttribute("y",-5);
|
y: -5,
|
||||||
junctionOutput.setAttribute("width",10);
|
width: 10,
|
||||||
junctionOutput.setAttribute("height",10);
|
height: 10,
|
||||||
junctionOutput.setAttribute("rx",3);
|
rx: 3,
|
||||||
junctionOutput.setAttribute("ry",3);
|
ry: 3,
|
||||||
|
})
|
||||||
junctionOutput.__data__ = d;
|
junctionOutput.__data__ = d;
|
||||||
junctionOutput.__portType__ = PORT_TYPE_OUTPUT;
|
junctionOutput.__portType__ = PORT_TYPE_OUTPUT;
|
||||||
junctionOutput.__portIndex__ = 0;
|
junctionOutput.__portIndex__ = 0;
|
||||||
@@ -5076,9 +5077,8 @@ RED.view = (function() {
|
|||||||
var pathContents = document.createDocumentFragment();
|
var pathContents = document.createDocumentFragment();
|
||||||
|
|
||||||
d.added = true;
|
d.added = true;
|
||||||
var pathBack = document.createElementNS("http://www.w3.org/2000/svg","path");
|
var pathBack = RED.utils.createSVGElement("path", { class: "red-ui-flow-link-background red-ui-flow-link-path"+(d.link?" red-ui-flow-link-link":"")})
|
||||||
pathBack.__data__ = d;
|
pathBack.__data__ = d;
|
||||||
pathBack.setAttribute("class","red-ui-flow-link-background red-ui-flow-link-path"+(d.link?" red-ui-flow-link-link":""));
|
|
||||||
this.__pathBack__ = pathBack;
|
this.__pathBack__ = pathBack;
|
||||||
pathContents.appendChild(pathBack);
|
pathContents.appendChild(pathBack);
|
||||||
d3.select(pathBack)
|
d3.select(pathBack)
|
||||||
@@ -5114,16 +5114,17 @@ RED.view = (function() {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
var pathOutline = document.createElementNS("http://www.w3.org/2000/svg","path");
|
var pathOutline = RED.utils.createSVGElement("path", {
|
||||||
|
class: "red-ui-flow-link-outline red-ui-flow-link-path"
|
||||||
|
})
|
||||||
pathOutline.__data__ = d;
|
pathOutline.__data__ = d;
|
||||||
pathOutline.setAttribute("class","red-ui-flow-link-outline red-ui-flow-link-path");
|
|
||||||
this.__pathOutline__ = pathOutline;
|
this.__pathOutline__ = pathOutline;
|
||||||
pathContents.appendChild(pathOutline);
|
pathContents.appendChild(pathOutline);
|
||||||
|
|
||||||
var pathLine = document.createElementNS("http://www.w3.org/2000/svg","path");
|
var pathLine = RED.utils.createSVGElement("path", {
|
||||||
|
class: "red-ui-flow-link-line red-ui-flow-link-path"+(d.link?" red-ui-flow-link-link":(activeSubflow?" red-ui-flow-subflow-link":""))
|
||||||
|
})
|
||||||
pathLine.__data__ = d;
|
pathLine.__data__ = d;
|
||||||
pathLine.setAttribute("class","red-ui-flow-link-line red-ui-flow-link-path"+
|
|
||||||
(d.link?" red-ui-flow-link-link":(activeSubflow?" red-ui-flow-subflow-link":"")));
|
|
||||||
this.__pathLine__ = pathLine;
|
this.__pathLine__ = pathLine;
|
||||||
pathContents.appendChild(pathLine);
|
pathContents.appendChild(pathLine);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user