mirror of
https://github.com/node-red/node-red.git
synced 2023-10-10 13:36:53 +02:00
Add quick resize buttons to tray
This commit is contained in:
parent
a9feeaa1c9
commit
0efccc4758
@ -26,6 +26,9 @@ RED.tray = (function() {
|
|||||||
var body = $('<div class="editor-tray-body"></div>').appendTo(el);
|
var body = $('<div class="editor-tray-body"></div>').appendTo(el);
|
||||||
var footer = $('<div class="editor-tray-footer"></div>').appendTo(el);
|
var footer = $('<div class="editor-tray-footer"></div>').appendTo(el);
|
||||||
var resizer = $('<div class="editor-tray-resize-handle"></div>').appendTo(el);
|
var resizer = $('<div class="editor-tray-resize-handle"></div>').appendTo(el);
|
||||||
|
var growButton = $('<a class="editor-tray-resize-button" style="cursor: w-resize;"><i class="fa fa-angle-left"></i></a>').appendTo(resizer);
|
||||||
|
var shrinkButton = $('<a class="editor-tray-resize-button" style="cursor: e-resize;"><i style="margin-left: 1px;" class="fa fa-angle-right"></i></a>').appendTo(resizer);
|
||||||
|
|
||||||
if (options.buttons) {
|
if (options.buttons) {
|
||||||
for (var i=0;i<options.buttons.length;i++) {
|
for (var i=0;i<options.buttons.length;i++) {
|
||||||
var button = options.buttons[i];
|
var button = options.buttons[i];
|
||||||
@ -60,13 +63,14 @@ RED.tray = (function() {
|
|||||||
el.width('auto');
|
el.width('auto');
|
||||||
},
|
},
|
||||||
drag: function(event,ui) {
|
drag: function(event,ui) {
|
||||||
if (ui.position.left > -501) {
|
if (ui.position.left > -tray.preferredWidth-1) {
|
||||||
ui.position.left = -501;
|
ui.position.left = -tray.preferredWidth-1;
|
||||||
} else if (tray.options.resize) {
|
} else if (tray.options.resize) {
|
||||||
setTimeout(function() {
|
setTimeout(function() {
|
||||||
tray.options.resize({width: -ui.position.left});
|
tray.options.resize({width: -ui.position.left});
|
||||||
},0);
|
},0);
|
||||||
}
|
}
|
||||||
|
tray.width = -ui.position.left;
|
||||||
},
|
},
|
||||||
stop:function(event,ui) {
|
stop:function(event,ui) {
|
||||||
el.width(-ui.position.left);
|
el.width(-ui.position.left);
|
||||||
@ -74,6 +78,7 @@ RED.tray = (function() {
|
|||||||
if (tray.options.resize) {
|
if (tray.options.resize) {
|
||||||
tray.options.resize({width: -ui.position.left});
|
tray.options.resize({width: -ui.position.left});
|
||||||
}
|
}
|
||||||
|
tray.width = -ui.position.left;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -83,9 +88,12 @@ RED.tray = (function() {
|
|||||||
|
|
||||||
$("#header-shade").show();
|
$("#header-shade").show();
|
||||||
$("#editor-shade").show();
|
$("#editor-shade").show();
|
||||||
|
|
||||||
|
tray.preferredWidth = el.width();
|
||||||
if (options.width) {
|
if (options.width) {
|
||||||
el.width(options.width);
|
el.width(options.width);
|
||||||
}
|
}
|
||||||
|
tray.width = el.width();
|
||||||
el.css({
|
el.css({
|
||||||
right: -(el.width()+10)+"px",
|
right: -(el.width()+10)+"px",
|
||||||
transition: "right 0.2s ease"
|
transition: "right 0.2s ease"
|
||||||
@ -99,6 +107,7 @@ RED.tray = (function() {
|
|||||||
|
|
||||||
setTimeout(function() {
|
setTimeout(function() {
|
||||||
setTimeout(function() {
|
setTimeout(function() {
|
||||||
|
el.width(tray.preferredWidth);
|
||||||
if (options.resize) {
|
if (options.resize) {
|
||||||
options.resize({width:el.width()});
|
options.resize({width:el.width()});
|
||||||
}
|
}
|
||||||
@ -108,22 +117,51 @@ RED.tray = (function() {
|
|||||||
},150);
|
},150);
|
||||||
el.css({right:0});
|
el.css({right:0});
|
||||||
},0);
|
},0);
|
||||||
|
|
||||||
|
growButton.click(function(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
tray.lastWidth = tray.width;
|
||||||
|
tray.width = $("#editor-stack").position().left-8;
|
||||||
|
el.width(tray.width);
|
||||||
|
if (options.resize) {
|
||||||
|
options.resize({width:tray.width});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
shrinkButton.click(function(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
if (tray.lastWidth && tray.width > tray.lastWidth) {
|
||||||
|
tray.width = tray.lastWidth;
|
||||||
|
} else if (tray.width > tray.preferredWidth) {
|
||||||
|
tray.width = tray.preferredWidth;
|
||||||
|
}
|
||||||
|
el.width(tray.width);
|
||||||
|
if (options.resize) {
|
||||||
|
options.resize({width:tray.width});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
function handleWindowResize() {
|
||||||
init: function init() {
|
|
||||||
$( window ).resize(function() {
|
|
||||||
if (stack.length > 0) {
|
if (stack.length > 0) {
|
||||||
var tray = stack[stack.length-1];
|
var tray = stack[stack.length-1];
|
||||||
var trayHeight = tray.tray.height()-tray.header.outerHeight()-tray.footer.outerHeight();
|
var trayHeight = tray.tray.height()-tray.header.outerHeight()-tray.footer.outerHeight();
|
||||||
tray.body.height(trayHeight-40);
|
tray.body.height(trayHeight-40);
|
||||||
|
|
||||||
|
if (tray.width > $("#editor-stack").position().left-8) {
|
||||||
|
tray.width = Math.max(tray.preferredWidth,$("#editor-stack").position().left-8);
|
||||||
|
tray.tray.width(tray.width);
|
||||||
|
}
|
||||||
if (tray.options.resize) {
|
if (tray.options.resize) {
|
||||||
tray.options.resize({width:tray.tray.width()});
|
tray.options.resize({width:tray.width});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
||||||
|
return {
|
||||||
|
init: function init() {
|
||||||
|
$(window).resize(handleWindowResize);
|
||||||
|
RED.events.on("sidebar:resize",handleWindowResize);
|
||||||
},
|
},
|
||||||
show: function show(options) {
|
show: function show(options) {
|
||||||
if (stack.length > 0) {
|
if (stack.length > 0) {
|
||||||
@ -155,6 +193,7 @@ RED.tray = (function() {
|
|||||||
var oldTray = stack[stack.length-1];
|
var oldTray = stack[stack.length-1];
|
||||||
oldTray.tray.appendTo("#editor-stack");
|
oldTray.tray.appendTo("#editor-stack");
|
||||||
setTimeout(function() {
|
setTimeout(function() {
|
||||||
|
handleWindowResize();
|
||||||
oldTray.tray.css({right:0});
|
oldTray.tray.css({right:0});
|
||||||
if (oldTray.options.show) {
|
if (oldTray.options.show) {
|
||||||
oldTray.options.show();
|
oldTray.options.show();
|
||||||
|
@ -79,7 +79,16 @@
|
|||||||
border-left: 1px solid $primary-border-color;
|
border-left: 1px solid $primary-border-color;
|
||||||
box-shadow: -1px 0 6px rgba(0,0,0,0.1);
|
box-shadow: -1px 0 6px rgba(0,0,0,0.1);
|
||||||
}
|
}
|
||||||
|
.editor-tray-resize-button {
|
||||||
|
@include workspace-button;
|
||||||
|
display: block;
|
||||||
|
height: 20px;
|
||||||
|
border: none;
|
||||||
|
border-bottom: 1px solid $secondary-border-color;
|
||||||
|
margin: 0;
|
||||||
|
background: $background-color;
|
||||||
|
color: $workspace-button-color-disabled;
|
||||||
|
}
|
||||||
#editor-shade, #header-shade {
|
#editor-shade, #header-shade {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top:0;
|
top:0;
|
||||||
|
Loading…
Reference in New Issue
Block a user