mirror of
				https://github.com/node-red/node-red.git
				synced 2025-03-01 10:36:34 +00:00 
			
		
		
		
	Compare commits
	
		
			22 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 81387396c0 | ||
|  | e2b7377ab7 | ||
|  | fb1918d839 | ||
|  | 5d5a112c2b | ||
|  | 4a6941a0d2 | ||
|  | 8e8cac60b0 | ||
|  | 61f42f9efa | ||
|  | fc590c66c0 | ||
|  | 45a6348669 | ||
|  | 981a9c4f8f | ||
|  | 22dd2cd084 | ||
|  | 69d5ffe1ed | ||
|  | d3afa8fd47 | ||
|  | 8b8bd83ec2 | ||
|  | 9f1ad64f5d | ||
|  | c3bc3f3780 | ||
|  | 43a07301fd | ||
|  | 6de8b33769 | ||
|  | 0950041d26 | ||
|  | cc584331ed | ||
|  | 8c64b2a898 | ||
|  | 842e9d761e | 
| @@ -45,7 +45,8 @@ | |||||||
|                 "rtl": "Right-to-left", |                 "rtl": "Right-to-left", | ||||||
|                 "auto": "Contextual", |                 "auto": "Contextual", | ||||||
|                 "language": "Language", |                 "language": "Language", | ||||||
|                 "browserDefault": "Browser default" |                 "browserDefault": "Browser default", | ||||||
|  |                 "flowVertical": "Vertical flow" | ||||||
|             }, |             }, | ||||||
|             "sidebar": { |             "sidebar": { | ||||||
|                 "show": "Show sidebar" |                 "show": "Show sidebar" | ||||||
|   | |||||||
| @@ -45,7 +45,8 @@ | |||||||
|                 "rtl": "右から左", |                 "rtl": "右から左", | ||||||
|                 "auto": "文脈", |                 "auto": "文脈", | ||||||
|                 "language": "表示言語", |                 "language": "表示言語", | ||||||
|                 "browserDefault": "ブラウザのデフォルト" |                 "browserDefault": "ブラウザのデフォルト", | ||||||
|  |                 "flowVertical": "縦フロー" | ||||||
|             }, |             }, | ||||||
|             "sidebar": { |             "sidebar": { | ||||||
|                 "show": "サイドバーを表示" |                 "show": "サイドバーを表示" | ||||||
|   | |||||||
| @@ -36,7 +36,8 @@ | |||||||
|                 "defaultDir": "默认方向", |                 "defaultDir": "默认方向", | ||||||
|                 "ltr": "从左到右", |                 "ltr": "从左到右", | ||||||
|                 "rtl": "从右到左", |                 "rtl": "从右到左", | ||||||
|                 "auto": "上下文" |                 "auto": "上下文", | ||||||
|  |                 "flowVertical": "Vertical flow" | ||||||
|             }, |             }, | ||||||
|             "sidebar": { |             "sidebar": { | ||||||
|                 "show": "显示侧边栏" |                 "show": "显示侧边栏" | ||||||
|   | |||||||
| @@ -139,7 +139,14 @@ RED.palette = (function() { | |||||||
|         var labelElement = el.find(".red-ui-palette-label"); |         var labelElement = el.find(".red-ui-palette-label"); | ||||||
|         labelElement.html(lines).attr('dir', RED.text.bidi.resolveBaseTextDir(lines)); |         labelElement.html(lines).attr('dir', RED.text.bidi.resolveBaseTextDir(lines)); | ||||||
|  |  | ||||||
|         el.find(".red-ui-palette-port").css({top:(multiLineNodeHeight/2-5)+"px"}); |         if (RED.view.vertical()) { | ||||||
|  |             // el.find(".red-ui-palette-port").css({top:(multiLineNodeHeight/2-5)+"px", left: "55px"}); | ||||||
|  |             // el.find(".red-ui-palette-port-output").css({top:(multiLineNodeHeight-5)+"px", right: "55px"}); | ||||||
|  |             // el.find(".red-ui-palette-port-input").css({top: "-5px"}); | ||||||
|  |         }else{ | ||||||
|  |             el.find(".red-ui-palette-port").css({top:(multiLineNodeHeight/2-5)+"px"}); | ||||||
|  |             // el.find(".palette_port_output").css({top:(multiLineNodeHeight/2-5)+"px", right: "-6px", left: "auto"}); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         var popOverContent; |         var popOverContent; | ||||||
|         try { |         try { | ||||||
| @@ -228,16 +235,19 @@ RED.palette = (function() { | |||||||
|  |  | ||||||
|             d.css("backgroundColor", RED.utils.getNodeColor(nt,def)); |             d.css("backgroundColor", RED.utils.getNodeColor(nt,def)); | ||||||
|  |  | ||||||
|             if (def.outputs > 0) { |             if (!RED.view.vertical()) { | ||||||
|                 var portOut = document.createElement("div"); |  | ||||||
|                 portOut.className = "red-ui-palette-port red-ui-palette-port-output"; |  | ||||||
|                 d.append(portOut); |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             if (def.inputs > 0) { |                 if (def.outputs > 0) { | ||||||
|                 var portIn = document.createElement("div"); |                     var portOut = document.createElement("div"); | ||||||
|                 portIn.className = "red-ui-palette-port red-ui-palette-port-input"; |                     portOut.className = "red-ui-palette-port red-ui-palette-port-output"; | ||||||
|                 d.append(portIn); |                     d.append(portOut); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 if (def.inputs > 0) { | ||||||
|  |                     var portIn = document.createElement("div"); | ||||||
|  |                     portIn.className = "red-ui-palette-port red-ui-palette-port-input"; | ||||||
|  |                     d.append(portIn); | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             createCategory(nodeCategory,rootCategory,category,(coreCategories.indexOf(rootCategory) !== -1)?"node-red":def.set.id); |             createCategory(nodeCategory,rootCategory,category,(coreCategories.indexOf(rootCategory) !== -1)?"node-red":def.set.id); | ||||||
|   | |||||||
| @@ -384,7 +384,17 @@ RED.typeSearch = (function() { | |||||||
|  |  | ||||||
|     return { |     return { | ||||||
|         show: show, |         show: show, | ||||||
|         refresh: refreshTypeList, |         refresh: function(opts) { | ||||||
|  |             if (opts.x && opts.y) { | ||||||
|  |                 if ($("#red-ui-main-container").height() - opts.y - 150 < 0) { | ||||||
|  |                     opts.y = opts.y - 235; | ||||||
|  |                 } | ||||||
|  |                 dialog.css({left:opts.x+"px",top:opts.y+"px"}).show(); | ||||||
|  |             } | ||||||
|  |             if (opts.filter) { | ||||||
|  |                 refreshTypeList(opts); | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         hide: hide |         hide: hide | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -133,7 +133,8 @@ RED.userSettings = (function() { | |||||||
|         { |         { | ||||||
|             title: "menu.label.other", |             title: "menu.label.other", | ||||||
|             options: [ |             options: [ | ||||||
|                 {setting:"view-show-tips",oldSettings:"menu-menu-item-show-tips",label:"menu.label.showTips",toggle:true,default:true,onchange:"core:toggle-show-tips"} |                 {setting:"view-show-tips",oldSettings:"menu-menu-item-show-tips",label:"menu.label.showTips",toggle:true,default:true,onchange:"core:toggle-show-tips"}, | ||||||
|  |                 {setting:"view-flow-vertical",label:"menu.label.view.flowVertical",toggle:true,default:false,onchange:RED.view.vertical} | ||||||
|             ] |             ] | ||||||
|         } |         } | ||||||
|     ]; |     ]; | ||||||
|   | |||||||
							
								
								
									
										373
									
								
								packages/node_modules/@node-red/editor-client/src/js/ui/view.js
									
									
									
									
										vendored
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										373
									
								
								packages/node_modules/@node-red/editor-client/src/js/ui/view.js
									
									
									
									
										vendored
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -44,6 +44,7 @@ RED.view = (function() { | |||||||
|  |  | ||||||
|     var gridSize = 20; |     var gridSize = 20; | ||||||
|     var snapGrid = false; |     var snapGrid = false; | ||||||
|  |     var vertical = false; | ||||||
|  |  | ||||||
|     var activeSpliceLink; |     var activeSpliceLink; | ||||||
|     var spliceActive = false; |     var spliceActive = false; | ||||||
| @@ -595,6 +596,112 @@ RED.view = (function() { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     function generateLinkPathV(origX,origY, destX, destY, sc) { | ||||||
|  |         var dy = destY-origY; | ||||||
|  |         var dx = destX-origX; | ||||||
|  |         var delta = Math.sqrt(dy*dy+dx*dx); | ||||||
|  |         var scale = lineCurveScale*2; | ||||||
|  |         var fullScale = scale; | ||||||
|  |  | ||||||
|  |         if (dy*sc > 0) { | ||||||
|  |             if (delta < node_height) { | ||||||
|  |                 scale = scale-scale*((node_height-delta)/node_height); | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             scale = 0.4-0.2*(Math.max(0,(node_height-Math.min(Math.abs(dx),Math.abs(dy)))/node_height)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (dy*sc > 0) { | ||||||
|  |             if (delta < (1.5*node_width)) { | ||||||
|  |                 scale = fullScale-fullScale*(((1.5*node_width)-delta)/(1.5*node_width)); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             return "M "+origX+" "+origY+ | ||||||
|  |                 " C "+origX+" "+(origY+sc*node_height*scale)+" "+ | ||||||
|  |                 destX+" "+(destY-sc*scale*node_height)+" "+ | ||||||
|  |                 destX+" "+destY | ||||||
|  |                 // +drawCross(origX,(origY+sc*(node_height*scale))) | ||||||
|  |                 // +drawCross(destX,(destY-sc*scale*node_height)) | ||||||
|  |  | ||||||
|  |         } else { | ||||||
|  |             var scx = dx>0?1:-1; | ||||||
|  |  | ||||||
|  |             var midX = Math.floor(destX-dx/2); | ||||||
|  |             var midY = Math.floor(destY-dy/2); | ||||||
|  |             // | ||||||
|  |             if (Math.abs(dx) < node_width) { | ||||||
|  |                 midX = destX - 1.3*scx*node_width; | ||||||
|  |             } | ||||||
|  |             var cp_width = node_width/2; | ||||||
|  |             var x1 = (destX + midX)/2 | ||||||
|  |             var topY = origY + 2*sc*node_height*scale; | ||||||
|  |             var topX = dx>0?Math.min(x1 - dx/2 , origX+cp_width):Math.max(x1 - dx/2 , origX-cp_width); | ||||||
|  |             var bottomY = destY - 2*sc*node_height*scale; | ||||||
|  |             var bottomX = dx>0?Math.max(x1, destX-cp_width):Math.min(x1, destX+cp_width); | ||||||
|  |             var y1 = (origY+topY)/2; | ||||||
|  |             var cp = [ | ||||||
|  |                 // Orig -> Top | ||||||
|  |                 [origX,y1], | ||||||
|  |                 [dx>0?Math.max(origX, topX-cp_width):Math.min(origX, topX+cp_width),topY], | ||||||
|  |                 // Top -> Mid | ||||||
|  |                 // [Mirror previous cp] | ||||||
|  |                 [dx>0?Math.min(midX, topX+cp_width):Math.max(midX, topX-cp_width),y1], | ||||||
|  |                 // Mid -> Bottom | ||||||
|  |                 // [Mirror previous cp] | ||||||
|  |                 [dx>0?Math.max(midX, bottomX-cp_width):Math.min(midX, bottomX+cp_width), bottomY], | ||||||
|  |                 // Bottom -> Dest | ||||||
|  |                 // [Mirror previous cp] | ||||||
|  |                 [destX, (destY+bottomY)/2] | ||||||
|  |             ]; | ||||||
|  |             // if (cp[2][0] === topX+scx*cp_width) { | ||||||
|  |             //     if (Math.abs(dx) < cp_width*10) { | ||||||
|  |             //         cp[1][0] = topX-scx*cp_width/2; | ||||||
|  |             //         cp[3][0] = bottomX-scx*cp_width/2; | ||||||
|  |             //     } | ||||||
|  |             //     cp[2][1] = topY; | ||||||
|  |             // } | ||||||
|  |             return "M "+origX+" "+origY+ | ||||||
|  |                 " C "+ | ||||||
|  |                    cp[0][0]+" "+cp[0][1]+" "+ | ||||||
|  |                    cp[1][0]+" "+cp[1][1]+" "+ | ||||||
|  |                    topX+" "+topY+ | ||||||
|  |                 " S "+ | ||||||
|  |                    cp[2][0]+" "+cp[2][1]+" "+ | ||||||
|  |                    midX+" "+midY+ | ||||||
|  |                " S "+ | ||||||
|  |                   cp[3][0]+" "+cp[3][1]+" "+ | ||||||
|  |                   bottomX+" "+bottomY+ | ||||||
|  |                 " S "+ | ||||||
|  |                     cp[4][0]+" "+cp[4][1]+" "+ | ||||||
|  |                     destX+" "+destY | ||||||
|  |                     // +drawCross(cp[0][0],cp[0][1]) | ||||||
|  |                     // +drawCross(cp[1][0],cp[1][1]) | ||||||
|  |                     // +drawCross(cp[2][0],cp[2][1]) | ||||||
|  |                     // +drawCross(cp[3][0],cp[3][1]) | ||||||
|  |                     // +drawCross(cp[4][0],cp[4][1]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     function drawCross(x,y,i) { | ||||||
|  |         var res = " M "+(x-4)+" "+y+" h8 M "+x+" "+(y-4)+" v8 "; | ||||||
|  |         // res += " M "+(x-8)+" "+(y-8)+" h2 "; | ||||||
|  |         // if (i>0) res += " M "+(x+8)+" "+(y-8)+" h2 "; | ||||||
|  |         // if (i>1) res += " M "+(x+8)+" "+(y+8)+" h2 "; | ||||||
|  |         // if (i>2) res += " M "+(x-8)+" "+(y+8)+" h2 "; | ||||||
|  |         return res; | ||||||
|  |     } | ||||||
|  |     function drawCircle(x,y,w) { | ||||||
|  |         return " M "+x+" "+y+" m -"+w+" 0 "+ | ||||||
|  |                "a "+w+","+w+" 0 1,0 "+(2*w)+",0 "+ | ||||||
|  |                "a "+w+","+w+" 0 1,0 -"+(2*w)+",0 " | ||||||
|  |     } | ||||||
|  |     function drawLine(x1,y1,x2,y2) { | ||||||
|  |         return " M "+x1+","+y1+" L "+x2+","+y2+" " | ||||||
|  |     } | ||||||
|  |  | ||||||
|     function addNode(type,x,y) { |     function addNode(type,x,y) { | ||||||
|         var m = /^subflow:(.+)$/.exec(type); |         var m = /^subflow:(.+)$/.exec(type); | ||||||
|  |  | ||||||
| @@ -644,8 +751,13 @@ RED.view = (function() { | |||||||
|         nn.changed = true; |         nn.changed = true; | ||||||
|         nn.moved = true; |         nn.moved = true; | ||||||
|  |  | ||||||
|         nn.w = node_width; |         if (vertical) { | ||||||
|         nn.h = Math.max(node_height,(nn.outputs||0) * 15); |             nn.w = Math.max(node_width,(nn.outputs||0) * 15); | ||||||
|  |             nn.h = node_height; | ||||||
|  |         }else{ | ||||||
|  |             nn.w = node_width; | ||||||
|  |             nn.h = Math.max(node_height,(nn.outputs||0) * 15); | ||||||
|  |         } | ||||||
|         nn.resize = true; |         nn.resize = true; | ||||||
|  |  | ||||||
|         var historyEvent = { |         var historyEvent = { | ||||||
| @@ -786,21 +898,32 @@ RED.view = (function() { | |||||||
|             } |             } | ||||||
|             var numOutputs = (quickAddLink.portType === PORT_TYPE_OUTPUT)?(quickAddLink.node.outputs || 1):1; |             var numOutputs = (quickAddLink.portType === PORT_TYPE_OUTPUT)?(quickAddLink.node.outputs || 1):1; | ||||||
|             var sourcePort = quickAddLink.port; |             var sourcePort = quickAddLink.port; | ||||||
|             var portY = -((numOutputs-1)/2)*13 +13*sourcePort; |  | ||||||
|  |             if (vertical) { | ||||||
|  |                 var portX = -((numOutputs-1)/2)*15 +15*sourcePort; | ||||||
|  |             }else{ | ||||||
|  |                 var portY = -((numOutputs-1)/2)*13 +13*sourcePort; | ||||||
|  |             } | ||||||
|             var sc = (quickAddLink.portType === PORT_TYPE_OUTPUT)?1:-1; |             var sc = (quickAddLink.portType === PORT_TYPE_OUTPUT)?1:-1; | ||||||
|             quickAddLink.el.attr("d",generateLinkPath(quickAddLink.node.x+sc*quickAddLink.node.w/2,quickAddLink.node.y+portY,point[0]-sc*node_width/2,point[1],sc)); |             if (vertical) { | ||||||
|  |                 quickAddLink.el.attr("d",generateLinkPathV(quickAddLink.node.x+portX,  quickAddLink.node.y+sc*quickAddLink.node.h/2,point[0],point[1]-(node_height/2),sc)); | ||||||
|  |             }else{ | ||||||
|  |                 quickAddLink.el.attr("d",generateLinkPath(quickAddLink.node.x+sc*quickAddLink.node.w/2,quickAddLink.node.y+portY,point[0]-sc*node_width/2,point[1],sc)); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         if (quickAddLink) { |         if (quickAddLink) { | ||||||
|             rebuildQuickAddLink(); |             rebuildQuickAddLink(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|         var lastAddedX; |         var lastAddedPos; | ||||||
|         var lastAddedWidth; |         var lastAddedWidth; | ||||||
|  |  | ||||||
|  |         var tsX = d3.event.clientX-mainPos.left-node_width/2 - (ox-point[0]); | ||||||
|  |         var tsY = d3.event.clientY-mainPos.top+ node_height/2 + 5 - (oy-point[1]); | ||||||
|         RED.typeSearch.show({ |         RED.typeSearch.show({ | ||||||
|             x:d3.event.clientX-mainPos.left-node_width/2 - (ox-point[0]), |             x:tsX, | ||||||
|             y:d3.event.clientY-mainPos.top+ node_height/2 + 5 - (oy-point[1]), |             y:tsY, | ||||||
|             filter: filter, |             filter: filter, | ||||||
|             move: function(dx,dy) { |             move: function(dx,dy) { | ||||||
|                 if (ghostNode) { |                 if (ghostNode) { | ||||||
| @@ -976,31 +1099,46 @@ RED.view = (function() { | |||||||
|                 updateActiveNodes(); |                 updateActiveNodes(); | ||||||
|                 updateSelection(); |                 updateSelection(); | ||||||
|                 redraw(); |                 redraw(); | ||||||
|                 // At this point the newly added node will have a real width, |                 if (!vertical) { | ||||||
|                 // so check if the position needs nudging |                     // At this point the newly added node will have a real width, | ||||||
|                 if (lastAddedX !== undefined) { |                     // so check if the position needs nudging | ||||||
|                     var lastNodeRHEdge = lastAddedX + lastAddedWidth/2; |                     if (lastAddedPos !== undefined) { | ||||||
|                     var thisNodeLHEdge = nn.x - nn.w/2; |                         var lastNodeRHEdge = lastAddedPos + lastAddedWidth/2; | ||||||
|                     var gap = thisNodeLHEdge - lastNodeRHEdge; |                         var thisNodeLHEdge = nn.x - nn.w/2; | ||||||
|                     if (gap != gridSize *2) { |                         var gap = thisNodeLHEdge - lastNodeRHEdge; | ||||||
|                         nn.x = nn.x + gridSize * 2 - gap; |                         if (gap != gridSize *2) { | ||||||
|                         nn.dirty = true; |                             nn.x = nn.x + gridSize * 2 - gap; | ||||||
|                         nn.x = Math.ceil(nn.x / gridSize) * gridSize; |                             nn.dirty = true; | ||||||
|                         redraw(); |                             nn.x = Math.ceil(nn.x / gridSize) * gridSize; | ||||||
|  |                             redraw(); | ||||||
|  |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (keepAdding) { |                 if (keepAdding) { | ||||||
|                     if (lastAddedX === undefined) { |                     if (lastAddedPos === undefined) { | ||||||
|                         // ghostLink.attr("opacity",1); |                         // ghostLink.attr("opacity",1); | ||||||
|                         setTimeout(function() { |                         setTimeout(function() { | ||||||
|                             RED.typeSearch.refresh({filter:{input:true}}); |                             RED.typeSearch.refresh({filter:{input:true}}); | ||||||
|                         },100); |                         },100); | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                     lastAddedX = nn.x; |                     if (vertical) { | ||||||
|  |                         lastAddedPos = nn.y; | ||||||
|  |                         if ($("#red-ui-main-container").height()-150 < tsY) { | ||||||
|  |                             var delta = tsY - ($("#red-ui-main-container").height()-150); | ||||||
|  |                             var st = $("#red-ui-workspace-chart").scrollTop(); | ||||||
|  |                             $("#red-ui-workspace-chart").scrollTop(st+delta); | ||||||
|  |                             tsY -= delta; | ||||||
|  |                         } | ||||||
|  |                         point[1] = nn.y + nn.h + node_height+gridSize; | ||||||
|  |                         tsY += nn.h + node_height+gridSize; | ||||||
|  |                         RED.typeSearch.refresh({x:tsX,y:tsY}); | ||||||
|  |                     } else { | ||||||
|  |                         lastAddedPos = nn.x; | ||||||
|  |                         point[0] = nn.x + nn.w/2 + node_width/2 + gridSize * 2; | ||||||
|  |                     } | ||||||
|                     lastAddedWidth = nn.w; |                     lastAddedWidth = nn.w; | ||||||
|  |  | ||||||
|                     point[0] = nn.x + nn.w/2 + node_width/2 + gridSize * 2; |  | ||||||
|                     ghostNode.attr('transform','translate('+(point[0] - node_width/2)+','+(point[1] - node_height/2)+')'); |                     ghostNode.attr('transform','translate('+(point[0] - node_width/2)+','+(point[1] - node_height/2)+')'); | ||||||
|                     rebuildQuickAddLink(); |                     rebuildQuickAddLink(); | ||||||
|                 } else { |                 } else { | ||||||
| @@ -1142,10 +1280,18 @@ RED.view = (function() { | |||||||
|                 var drag_line = drag_lines[i]; |                 var drag_line = drag_lines[i]; | ||||||
|                 var numOutputs = (drag_line.portType === PORT_TYPE_OUTPUT)?(drag_line.node.outputs || 1):1; |                 var numOutputs = (drag_line.portType === PORT_TYPE_OUTPUT)?(drag_line.node.outputs || 1):1; | ||||||
|                 var sourcePort = drag_line.port; |                 var sourcePort = drag_line.port; | ||||||
|                 var portY = -((numOutputs-1)/2)*13 +13*sourcePort; |                 if (vertical) { | ||||||
|  |                     var portX = -((numOutputs-1)/2)*15 +15*sourcePort; | ||||||
|  |                 }else{ | ||||||
|  |                     var portY = -((numOutputs-1)/2)*13 +13*sourcePort; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|                 var sc = (drag_line.portType === PORT_TYPE_OUTPUT)?1:-1; |                 var sc = (drag_line.portType === PORT_TYPE_OUTPUT)?1:-1; | ||||||
|                 drag_line.el.attr("d",generateLinkPath(drag_line.node.x+sc*drag_line.node.w/2,drag_line.node.y+portY,mousePos[0],mousePos[1],sc)); |                 if (vertical) { | ||||||
|  |                     drag_line.el.attr("d",generateLinkPathV(drag_line.node.x+portX,drag_line.node.y+sc*drag_line.node.h/2,mousePos[0],mousePos[1],sc)); | ||||||
|  |                 }else{ | ||||||
|  |                     drag_line.el.attr("d",generateLinkPath(drag_line.node.x+sc*drag_line.node.w/2,drag_line.node.y+portY,mousePos[0],mousePos[1],sc)); | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|             d3.event.preventDefault(); |             d3.event.preventDefault(); | ||||||
|         } else if (mouse_mode == RED.state.MOVING) { |         } else if (mouse_mode == RED.state.MOVING) { | ||||||
| @@ -1204,7 +1350,13 @@ RED.view = (function() { | |||||||
|             if (snapGrid != d3.event.shiftKey && moving_set.length > 0) { |             if (snapGrid != d3.event.shiftKey && moving_set.length > 0) { | ||||||
|                 var gridOffset = [0,0]; |                 var gridOffset = [0,0]; | ||||||
|                 node = moving_set[0]; |                 node = moving_set[0]; | ||||||
|                 gridOffset[0] = node.n.x-(gridSize*Math.floor((node.n.x-node.n.w/2)/gridSize)+node.n.w/2); |                 if (vertical) { | ||||||
|  |                     // Align to the centre point of the node | ||||||
|  |                     gridOffset[0] = node.n.x-(gridSize*Math.floor(node.n.x/gridSize)); | ||||||
|  |                 } else { | ||||||
|  |                     // Align to the left edge of the node | ||||||
|  |                     gridOffset[0] = node.n.x-(gridSize*Math.floor((node.n.x-node.n.w/2)/gridSize)+node.n.w/2); | ||||||
|  |                 } | ||||||
|                 gridOffset[1] = node.n.y-(gridSize*Math.floor(node.n.y/gridSize)); |                 gridOffset[1] = node.n.y-(gridSize*Math.floor(node.n.y/gridSize)); | ||||||
|                 if (gridOffset[0] !== 0 || gridOffset[1] !== 0) { |                 if (gridOffset[0] !== 0 || gridOffset[1] !== 0) { | ||||||
|                     for (i = 0; i<moving_set.length; i++) { |                     for (i = 0; i<moving_set.length; i++) { | ||||||
| @@ -2563,8 +2715,8 @@ RED.view = (function() { | |||||||
|                             } |                             } | ||||||
|                             nodeMouseUp.call(this,d); |                             nodeMouseUp.call(this,d); | ||||||
|                     }); |                     }); | ||||||
|  |                 var attr_output_translate = (vertical) ? 'translate(15,-5)' : 'translate(-5,15)'; | ||||||
|                 outGroup.append("g").attr('transform','translate(-5,15)').append("rect").attr("class","red-ui-flow-port").attr("rx",3).attr("ry",3).attr("width",10).attr("height",10) |                 outGroup.append("g").attr('transform',attr_output_translate).append("rect").attr("class","red-ui-flow-port").attr("rx",3).attr("ry",3).attr("width",10).attr("height",10) | ||||||
|                     .on("mousedown", function(d,i){portMouseDown(d,PORT_TYPE_INPUT,0);} ) |                     .on("mousedown", function(d,i){portMouseDown(d,PORT_TYPE_INPUT,0);} ) | ||||||
|                     .on("touchstart", function(d,i){portMouseDown(d,PORT_TYPE_INPUT,0);} ) |                     .on("touchstart", function(d,i){portMouseDown(d,PORT_TYPE_INPUT,0);} ) | ||||||
|                     .on("mouseup", function(d,i){portMouseUp(d,PORT_TYPE_INPUT,0);}) |                     .on("mouseup", function(d,i){portMouseUp(d,PORT_TYPE_INPUT,0);}) | ||||||
| @@ -2606,8 +2758,8 @@ RED.view = (function() { | |||||||
|                             } |                             } | ||||||
|                             nodeMouseUp.call(this,d); |                             nodeMouseUp.call(this,d); | ||||||
|                     }); |                     }); | ||||||
|  |                 var attr_input_translate = (vertical) ? 'translate(15,35)' : 'translate(35,15)'; | ||||||
|                 inGroup.append("g").attr('transform','translate(35,15)').append("rect").attr("class","red-ui-flow-port").attr("rx",3).attr("ry",3).attr("width",10).attr("height",10) |                 inGroup.append("g").attr('transform',attr_input_translate).append("rect").attr("class","red-ui-flow-port").attr("rx",3).attr("ry",3).attr("width",10).attr("height",10) | ||||||
|                     .on("mousedown", function(d,i){portMouseDown(d,PORT_TYPE_OUTPUT,i);} ) |                     .on("mousedown", function(d,i){portMouseDown(d,PORT_TYPE_OUTPUT,i);} ) | ||||||
|                     .on("touchstart", function(d,i){portMouseDown(d,PORT_TYPE_OUTPUT,i);} ) |                     .on("touchstart", function(d,i){portMouseDown(d,PORT_TYPE_OUTPUT,i);} ) | ||||||
|                     .on("mouseup", function(d,i){portMouseUp(d,PORT_TYPE_OUTPUT,i);}) |                     .on("mouseup", function(d,i){portMouseUp(d,PORT_TYPE_OUTPUT,i);}) | ||||||
| @@ -2649,8 +2801,8 @@ RED.view = (function() { | |||||||
|                             } |                             } | ||||||
|                             nodeMouseUp.call(this,d); |                             nodeMouseUp.call(this,d); | ||||||
|                     }); |                     }); | ||||||
|  |                 var attr_status_translate = (vertical) ? 'translate(15,-5)' : 'translate(-5,15)'; | ||||||
|                 statusGroup.append("g").attr('transform','translate(-5,15)').append("rect").attr("class","red-ui-flow-port").attr("rx",3).attr("ry",3).attr("width",10).attr("height",10) |                 statusGroup.append("g").attr('transform', attr_status_translate).append("rect").attr("class","red-ui-flow-port").attr("rx",3).attr("ry",3).attr("width",10).attr("height",10) | ||||||
|                     .on("mousedown", function(d,i){portMouseDown(d,PORT_TYPE_INPUT,0);} ) |                     .on("mousedown", function(d,i){portMouseDown(d,PORT_TYPE_INPUT,0);} ) | ||||||
|                     .on("touchstart", function(d,i){portMouseDown(d,PORT_TYPE_INPUT,0);} ) |                     .on("touchstart", function(d,i){portMouseDown(d,PORT_TYPE_INPUT,0);} ) | ||||||
|                     .on("mouseup", function(d,i){portMouseUp(d,PORT_TYPE_INPUT,0);}) |                     .on("mouseup", function(d,i){portMouseUp(d,PORT_TYPE_INPUT,0);}) | ||||||
| @@ -2710,14 +2862,23 @@ RED.view = (function() { | |||||||
|                     var hideLabel = d.hasOwnProperty('l')?!d.l : isLink; |                     var hideLabel = d.hasOwnProperty('l')?!d.l : isLink; | ||||||
|                     node.attr("id",d.id); |                     node.attr("id",d.id); | ||||||
|                     var l = RED.utils.getNodeLabel(d); |                     var l = RED.utils.getNodeLabel(d); | ||||||
|  |  | ||||||
|                     if (d.resize || d.w === undefined) { |                     if (d.resize || d.w === undefined) { | ||||||
|                         if (hideLabel) { |                         if (hideLabel) { | ||||||
|                             d.w = node_height; |                             d.w = node_height; | ||||||
|                         } else { |                         } else { | ||||||
|                             d.w = Math.max(node_width,20*(Math.ceil((calculateTextWidth(l, "red-ui-flow-node-label", 50)+(d._def.inputs>0?7:0))/20)) ); |                             if (vertical) { | ||||||
|  |                                 d.w = Math.max(node_width,20*(Math.ceil((calculateTextWidth(l, "red-ui-flow-node-label", 50)+(d._def.inputs>0?7:0))/20)),(d.outputs||0) * 16 ); | ||||||
|  |                             }else{ | ||||||
|  |                                 d.w = Math.max(node_width,20*(Math.ceil((calculateTextWidth(l, "red-ui-flow-node-label", 50)+(d._def.inputs>0?7:0))/20)) ); | ||||||
|  |                             } | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                     d.h = Math.max(node_height,(d.outputs||0) * 15); |                     if (vertical) { | ||||||
|  |                         d.h = node_height; | ||||||
|  |                     }else{ | ||||||
|  |                         d.h = Math.max(node_height,(d.outputs||0) * 15); | ||||||
|  |                     } | ||||||
|  |  | ||||||
|                     // if (d._def.badge) { |                     // if (d._def.badge) { | ||||||
|                     //     var badge = node.append("svg:g").attr("class","node_badge_group"); |                     //     var badge = node.append("svg:g").attr("class","node_badge_group"); | ||||||
| @@ -2926,7 +3087,7 @@ RED.view = (function() { | |||||||
|                         .attr("class","red-ui-flow-node-status-label") |                         .attr("class","red-ui-flow-node-status-label") | ||||||
|                         .attr("x",20).attr("y",10); |                         .attr("x",20).attr("y",10); | ||||||
|  |  | ||||||
|                     node.append("g").attr("class","red-ui-flow-node-changed hide").attr("transform","translate(20, -2)").append("circle").attr("r",5); |                     node.append("g").attr("class","red-ui-flow-node-changed hide").attr("transform","translate(20, -2)").append("circle").attr("r",4); | ||||||
|                     var nodeErrorButton = node.append("g").attr("class","red-ui-flow-node-error hide").attr("transform","translate(0, -2)").append("path").attr("d","M -5,4 l 10,0 -5,-8 z"); |                     var nodeErrorButton = node.append("g").attr("class","red-ui-flow-node-error hide").attr("transform","translate(0, -2)").append("path").attr("d","M -5,4 l 10,0 -5,-8 z"); | ||||||
|                     nodeErrorButton.on("mouseenter", function() { |                     nodeErrorButton.on("mouseenter", function() { | ||||||
|                         if (d.validationErrors && d.validationErrors.length > 0) { |                         if (d.validationErrors && d.validationErrors.length > 0) { | ||||||
| @@ -2960,13 +3121,21 @@ RED.view = (function() { | |||||||
|                         if (d.resize) { |                         if (d.resize) { | ||||||
|                             var l = RED.utils.getNodeLabel(d); |                             var l = RED.utils.getNodeLabel(d); | ||||||
|                             var ow = d.w; |                             var ow = d.w; | ||||||
|                             if (hideLabel) { |                             if (vertical) { | ||||||
|                                 d.w = node_height; |                                 if (hideLabel) { | ||||||
|                             } else { |                                     d.w = node_height | ||||||
|                                 d.w = Math.max(node_width,20*(Math.ceil((calculateTextWidth(l, "red-ui-flow-node-label", 50)+(d._def.inputs>0?7:0))/20)) ); |                                 } else { | ||||||
|  |                                     d.w = Math.max(node_width,20*(Math.ceil((calculateTextWidth(l, "red-ui-flow-node-label", 50)+(d._def.inputs>0?7:0))/20)),(d.outputs||0) * 16 ); | ||||||
|  |                                 } | ||||||
|  |                                 d.h = node_height; | ||||||
|  |                             }else{ | ||||||
|  |                                 if (hideLabel) { | ||||||
|  |                                     d.w = node_height; | ||||||
|  |                                 } else { | ||||||
|  |                                     d.w = Math.max(node_width,20*(Math.ceil((calculateTextWidth(l, "red-ui-flow-node-label", 50)+(d._def.inputs>0?7:0))/20)) ); | ||||||
|  |                                 } | ||||||
|  |                                 d.h = Math.max(node_height,(d.outputs||0) * 15); | ||||||
|                             } |                             } | ||||||
|                             // d.w = Math.max(node_width,20*(Math.ceil((calculateTextWidth(l, "red-ui-flow-node-label", 50)+(d._def.inputs>0?7:0))/20)) ); |  | ||||||
|                             d.h = Math.max(node_height,(d.outputs||0) * 15); |  | ||||||
|                             d.x += (d.w-ow)/2; |                             d.x += (d.w-ow)/2; | ||||||
|                             d.resize = false; |                             d.resize = false; | ||||||
|                         } |                         } | ||||||
| @@ -3007,11 +3176,18 @@ RED.view = (function() { | |||||||
|  |  | ||||||
|                                 if (d.type === "link in") { |                                 if (d.type === "link in") { | ||||||
|                                     inputGroupPorts = inputGroup.append("circle") |                                     inputGroupPorts = inputGroup.append("circle") | ||||||
|                                         .attr("cx",-1).attr("cy",5) |                                         .attr("cx",vertical ? 5 : -1).attr("cy",vertical ? -1 : 5) | ||||||
|                                         .attr("r",5) |                                         .attr("r",5) | ||||||
|                                         .attr("class","red-ui-flow-port red-ui-flow-link-port") |                                         .attr("class","red-ui-flow-port red-ui-flow-link-port") | ||||||
|                                 } else { |                                 } else { | ||||||
|                                     inputGroupPorts = inputGroup.append("rect").attr("class","red-ui-flow-port").attr("rx",3).attr("ry",3).attr("width",10).attr("height",10) |                                     if (vertical) { | ||||||
|  |                                         inputGroupPorts = inputGroup.append("path").attr("class","red-ui-flow-port").attr("d","M 0 4.5 v -6 q 0 -3 3 -3 h 4 q 3 0 3 3 v6"); | ||||||
|  |                                     } else { | ||||||
|  |                                         inputGroupPorts = inputGroup.append("rect").attr("class","red-ui-flow-port").attr("rx",3).attr("ry",3).attr("width",10).attr("height",10); | ||||||
|  |                                     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |                                     //.attr("rx",3).attr("ry",3).attr("width",10).attr("height",10).attr("y",vertical?-4:0) | ||||||
|                                 } |                                 } | ||||||
|                                 inputGroupPorts.on("mousedown",function(d){portMouseDown(d,PORT_TYPE_INPUT,0);}) |                                 inputGroupPorts.on("mousedown",function(d){portMouseDown(d,PORT_TYPE_INPUT,0);}) | ||||||
|                                     .on("touchstart",function(d){portMouseDown(d,PORT_TYPE_INPUT,0);}) |                                     .on("touchstart",function(d){portMouseDown(d,PORT_TYPE_INPUT,0);}) | ||||||
| @@ -3031,7 +3207,11 @@ RED.view = (function() { | |||||||
|                                     numOutputs = 0; |                                     numOutputs = 0; | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|                             var y = (d.h/2)-((numOutputs-1)/2)*13; |                             if (vertical) { | ||||||
|  |                                 var x = (d.w/2)-((numOutputs-1)/2)*15; | ||||||
|  |                             }else{ | ||||||
|  |                                 var y = (d.h/2)-((numOutputs-1)/2)*13; | ||||||
|  |                             } | ||||||
|                             d.ports = d.ports || d3.range(numOutputs); |                             d.ports = d.ports || d3.range(numOutputs); | ||||||
|                             d._ports = thisNode.selectAll(".red-ui-flow-port-output").data(d.ports); |                             d._ports = thisNode.selectAll(".red-ui-flow-port-output").data(d.ports); | ||||||
|                             var output_group = d._ports.enter().append("g").attr("class","red-ui-flow-port-output"); |                             var output_group = d._ports.enter().append("g").attr("class","red-ui-flow-port-output"); | ||||||
| @@ -3039,15 +3219,19 @@ RED.view = (function() { | |||||||
|  |  | ||||||
|                             if (d.type === "link out") { |                             if (d.type === "link out") { | ||||||
|                                 output_group_ports = output_group.append("circle") |                                 output_group_ports = output_group.append("circle") | ||||||
|                                     .attr("cx",11).attr("cy",5) |                                     .attr("cx",vertical ? 6 : 11).attr("cy", vertical ? 8 : 6) | ||||||
|                                     .attr("r",5) |                                     .attr("r",5) | ||||||
|                                     .attr("class","red-ui-flow-port red-ui-flow-link-port") |                                     .attr("class","red-ui-flow-port red-ui-flow-link-port") | ||||||
|                             } else { |                             } else { | ||||||
|                                 output_group_ports = output_group.append("rect") |                                 if (vertical) { | ||||||
|                                     .attr("class","red-ui-flow-port") |                                     output_group_ports = output_group.append("path").attr("class","red-ui-flow-port").attr("d","M0 2.5 v 6 q 0 3 3 3 h 4 q 3 0 3 -3 v-6"); | ||||||
|                                     .attr("rx",3).attr("ry",3) |                                 } else { | ||||||
|                                     .attr("width",10) |                                     output_group_ports = output_group.append("rect") | ||||||
|                                     .attr("height",10) |                                         .attr("class","red-ui-flow-port") | ||||||
|  |                                         .attr("rx",3).attr("ry",3) | ||||||
|  |                                         .attr("width",10) | ||||||
|  |                                         .attr("height",10) | ||||||
|  |                                 } | ||||||
|                             } |                             } | ||||||
|  |  | ||||||
|                             output_group_ports.on("mousedown",(function(){var node = d; return function(d,i){portMouseDown(node,PORT_TYPE_OUTPUT,i);}})() ) |                             output_group_ports.on("mousedown",(function(){var node = d; return function(d,i){portMouseDown(node,PORT_TYPE_OUTPUT,i);}})() ) | ||||||
| @@ -3060,11 +3244,21 @@ RED.view = (function() { | |||||||
|                             d._ports.exit().remove(); |                             d._ports.exit().remove(); | ||||||
|                             if (d._ports) { |                             if (d._ports) { | ||||||
|                                 numOutputs = d.outputs || 1; |                                 numOutputs = d.outputs || 1; | ||||||
|                                 y = (d.h/2)-((numOutputs-1)/2)*13; |                                 if (vertical) { | ||||||
|                                 var x = d.w - 5; |                                     x = (d.w/2)-((numOutputs-1)/2)*15; | ||||||
|  |                                     var y = d.h-2; | ||||||
|  |                                 }else{ | ||||||
|  |                                     y = (d.h/2)-((numOutputs-1)/2)*13; | ||||||
|  |                                     var x = d.w - 5; | ||||||
|  |                                 } | ||||||
|                                 d._ports.each(function(d,i) { |                                 d._ports.each(function(d,i) { | ||||||
|                                         var port = d3.select(this); |                                         var port = d3.select(this); | ||||||
|                                         port.attr("transform", function(d) { return "translate("+x+","+((y+13*i)-5)+")";}); |                                         //port.attr("y",(y+13*i)-5).attr("x",x); | ||||||
|  |                                         if (vertical) { | ||||||
|  |                                             port.attr("transform", function(d) { return "translate("+((x+15*i)-5)+","+ y +")";}); | ||||||
|  |                                         }else{ | ||||||
|  |                                             port.attr("transform", function(d) { return "translate("+x+","+((y+13*i)-5)+")";}); | ||||||
|  |                                         } | ||||||
|                                 }); |                                 }); | ||||||
|                             } |                             } | ||||||
|                             thisNode.selectAll("text.red-ui-flow-node-label").text(function(d,i){ |                             thisNode.selectAll("text.red-ui-flow-node-label").text(function(d,i){ | ||||||
| @@ -3117,17 +3311,32 @@ RED.view = (function() { | |||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|  |  | ||||||
|                             thisNode.selectAll(".red-ui-flow-node-changed") |                             if (vertical) { | ||||||
|                                 .attr("transform",function(d){return "translate("+(d.w-10)+", -2)"}) |                                 thisNode.selectAll(".red-ui-flow-node-changed") | ||||||
|                                 .classed("hide",function(d) { return !(d.changed||d.moved); }); |                                     .attr("transform",function(d){return "translate(0, 4)"}) | ||||||
|  |                                     .classed("hide",function(d) { return !(d.changed||d.moved); }); | ||||||
|  |  | ||||||
|  |                                 thisNode.selectAll(".red-ui-flow-node-error") | ||||||
|  |                                     .attr("transform",function(d){ return "translate( 0,"+((d.changed||d.moved)?16:4)+")"}) | ||||||
|  |                                     .classed("hide",function(d) { return d.valid; }); | ||||||
|  |                             } else { | ||||||
|  |                                 thisNode.selectAll(".red-ui-flow-node-changed") | ||||||
|  |                                     .attr("transform",function(d){return "translate("+(d.w-10)+", -2)"}) | ||||||
|  |                                     .classed("hide",function(d) { return !(d.changed||d.moved); }); | ||||||
|  |  | ||||||
|  |                                 thisNode.selectAll(".red-ui-flow-node-error") | ||||||
|  |                                     .attr("transform",function(d){ return "translate("+(d.w-10-((d.changed||d.moved)?14:0))+", -2)"}) | ||||||
|  |                                     .classed("hide",function(d) { return d.valid; }); | ||||||
|  |                             } | ||||||
|  |  | ||||||
|                             thisNode.selectAll(".red-ui-flow-node-error") |  | ||||||
|                                 .attr("transform",function(d){ return "translate("+(d.w-10-((d.changed||d.moved)?14:0))+", -2)"}) |  | ||||||
|                                 .classed("hide",function(d) { return d.valid; }); |  | ||||||
|  |  | ||||||
|                             thisNode.selectAll(".red-ui-flow-port-input").each(function(d,i) { |                             thisNode.selectAll(".red-ui-flow-port-input").each(function(d,i) { | ||||||
|                                 var port = d3.select(this); |                                     var port = d3.select(this); | ||||||
|                                 port.attr("transform",function(d){return "translate(-5,"+((d.h/2)-5)+")";}) |                                     if (vertical) { | ||||||
|  |                                         port.attr("transform",function(d){return "translate("+((d.w/2)-5)+", -5)";}) | ||||||
|  |                                     }else{ | ||||||
|  |                                         port.attr("transform",function(d){return "translate(-5,"+((d.h/2)-5)+")";}) | ||||||
|  |                                     } | ||||||
|                             }); |                             }); | ||||||
|  |  | ||||||
|                             thisNode.selectAll(".red-ui-flow-node-icon").attr("y",function(d){return (d.h-d3.select(this).attr("height"))/2;}); |                             thisNode.selectAll(".red-ui-flow-node-icon").attr("y",function(d){return (d.h-d3.select(this).attr("height"))/2;}); | ||||||
| @@ -3192,9 +3401,17 @@ RED.view = (function() { | |||||||
|                                 var fill = status_colours[d.status.fill]; // Only allow our colours for now |                                 var fill = status_colours[d.status.fill]; // Only allow our colours for now | ||||||
|                                 if (d.status.shape == null && fill == null) { |                                 if (d.status.shape == null && fill == null) { | ||||||
|                                     thisNode.selectAll(".red-ui-flow-node-status").style("display","none"); |                                     thisNode.selectAll(".red-ui-flow-node-status").style("display","none"); | ||||||
|                                     thisNode.selectAll(".red-ui-flow-node-status-group").attr("transform","translate(-14,"+(d.h+3)+")"); |                                     if (vertical) { | ||||||
|  |                                         thisNode.selectAll(".red-ui-flow-node-status-group").attr("transform","translate(" + (-12+d.w/2) + ","+(-13)+")"); | ||||||
|  |                                     } else { | ||||||
|  |                                         thisNode.selectAll(".red-ui-flow-node-status-group").attr("transform","translate(-14,"+(d.h+3)+")"); | ||||||
|  |                                     } | ||||||
|                                 } else { |                                 } else { | ||||||
|                                     thisNode.selectAll(".red-ui-flow-node-status-group").attr("transform","translate(3,"+(d.h+3)+")"); |                                     if (vertical) { | ||||||
|  |                                         thisNode.selectAll(".red-ui-flow-node-status-group").attr("transform","translate(" + (5 + d.w/2) + ","+(-13)+")"); | ||||||
|  |                                     } else { | ||||||
|  |                                         thisNode.selectAll(".red-ui-flow-node-status-group").attr("transform","translate(3,"+(d.h+3)+")"); | ||||||
|  |                                     } | ||||||
|                                     var statusClass = "red-ui-flow-node-status-"+(d.status.shape||"dot")+"-"+d.status.fill; |                                     var statusClass = "red-ui-flow-node-status-"+(d.status.shape||"dot")+"-"+d.status.fill; | ||||||
|                                     thisNode.selectAll(".red-ui-flow-node-status").style("display","inline").attr("class","red-ui-flow-node-status "+statusClass); |                                     thisNode.selectAll(".red-ui-flow-node-status").style("display","inline").attr("class","red-ui-flow-node-status "+statusClass); | ||||||
|                                 } |                                 } | ||||||
| @@ -3279,17 +3496,23 @@ RED.view = (function() { | |||||||
|                     link.attr("d",function(d){ |                     link.attr("d",function(d){ | ||||||
|                         var numOutputs = d.source.outputs || 1; |                         var numOutputs = d.source.outputs || 1; | ||||||
|                         var sourcePort = d.sourcePort || 0; |                         var sourcePort = d.sourcePort || 0; | ||||||
|                         var y = -((numOutputs-1)/2)*13 +13*sourcePort; |                         var path; | ||||||
|                         d.x1 = d.source.x+d.source.w/2; |                         if (vertical) { | ||||||
|                         d.y1 = d.source.y+y; |                             var x = -((numOutputs-1)/2)*15 +15*sourcePort; | ||||||
|                         d.x2 = d.target.x-d.target.w/2; |                             d.x1 = d.source.x+x; | ||||||
|                         d.y2 = d.target.y; |                             d.y1 = d.source.y+d.source.h/2; | ||||||
|  |                             d.x2 = d.target.x; | ||||||
|  |                             d.y2 = d.target.y-d.target.h/2; | ||||||
|  |                             path = generateLinkPathV(d.x1,d.y1,d.x2,d.y2,1); | ||||||
|  |                         }else{ | ||||||
|  |                             var y = -((numOutputs-1)/2)*13 +13*sourcePort; | ||||||
|  |                             d.x1 = d.source.x+d.source.w/2; | ||||||
|  |                             d.y1 = d.source.y+y; | ||||||
|  |                             d.x2 = d.target.x-d.target.w/2; | ||||||
|  |                             d.y2 = d.target.y; | ||||||
|  |                             path = generateLinkPath(d.x1,d.y1,d.x2,d.y2,1); | ||||||
|  |                         } | ||||||
|  |  | ||||||
|                         // return "M "+d.x1+" "+d.y1+ |  | ||||||
|                         //     " C "+(d.x1+scale*node_width)+" "+(d.y1+scaleY*node_height)+" "+ |  | ||||||
|                         //     (d.x2-scale*node_width)+" "+(d.y2-scaleY*node_height)+" "+ |  | ||||||
|                         //     d.x2+" "+d.y2; |  | ||||||
|                         var path = generateLinkPath(d.x1,d.y1,d.x2,d.y2,1); |  | ||||||
|                         if (/NaN/.test(path)) { |                         if (/NaN/.test(path)) { | ||||||
|                             return "" |                             return "" | ||||||
|                         } |                         } | ||||||
| @@ -3780,6 +4003,14 @@ RED.view = (function() { | |||||||
|                 updateGrid(); |                 updateGrid(); | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |         vertical: function(v) { | ||||||
|  |             if (v === undefined) { | ||||||
|  |                 return vertical; | ||||||
|  |             } else { | ||||||
|  |                 vertical = v; | ||||||
|  |                 RED.view.redraw(); | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         getActiveNodes: function() { |         getActiveNodes: function() { | ||||||
|             return activeNodes; |             return activeNodes; | ||||||
|         }, |         }, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user