mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-05 11:04:42 +03:00
Ticket #3060: live update the panels size when editing layout.
Update the panel split display while adjusting the layout dialog, because the user should not be expected to know what number of columns or rows is reasonable without being able to see the effects. Cancel reverts previous settings. Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
parent
eb7388db20
commit
a8101d8403
@ -10,6 +10,7 @@
|
|||||||
Miguel de Icaza, 1995
|
Miguel de Icaza, 1995
|
||||||
Andrew Borodin <aborodin@vmail.ru>, 2011, 2012, 2013
|
Andrew Borodin <aborodin@vmail.ru>, 2011, 2012, 2013
|
||||||
Slava Zanko <slavazanko@gmail.com>, 2013
|
Slava Zanko <slavazanko@gmail.com>, 2013
|
||||||
|
Avi Kelman <patcherton.fixesthings@gmail.com>, 2013
|
||||||
|
|
||||||
This file is part of the Midnight Commander.
|
This file is part of the Midnight Commander.
|
||||||
|
|
||||||
@ -146,7 +147,6 @@ static panels_layout_t old_layout;
|
|||||||
static int old_output_lines;
|
static int old_output_lines;
|
||||||
|
|
||||||
/* Internal variables */
|
/* Internal variables */
|
||||||
panels_layout_t _panels_layout;
|
|
||||||
static int equal_split;
|
static int equal_split;
|
||||||
static int _menubar_visible;
|
static int _menubar_visible;
|
||||||
static int _output_lines;
|
static int _output_lines;
|
||||||
@ -227,28 +227,27 @@ update_split (const WDialog * h)
|
|||||||
{
|
{
|
||||||
/* Check split has to be done before testing if it changed, since
|
/* Check split has to be done before testing if it changed, since
|
||||||
it can change due to calling check_split() as well */
|
it can change due to calling check_split() as well */
|
||||||
check_split (&_panels_layout);
|
check_split (&panels_layout);
|
||||||
old_layout = _panels_layout;
|
|
||||||
|
|
||||||
if (_panels_layout.horizontal_split)
|
if (panels_layout.horizontal_split)
|
||||||
check_options[0].widget->state = _panels_layout.horizontal_equal ? 1 : 0;
|
check_options[0].widget->state = panels_layout.horizontal_equal ? 1 : 0;
|
||||||
else
|
else
|
||||||
check_options[0].widget->state = _panels_layout.vertical_equal ? 1 : 0;
|
check_options[0].widget->state = panels_layout.vertical_equal ? 1 : 0;
|
||||||
widget_redraw (WIDGET (check_options[0].widget));
|
widget_redraw (WIDGET (check_options[0].widget));
|
||||||
|
|
||||||
tty_setcolor (check_options[0].widget->state & C_BOOL ? DISABLED_COLOR : COLOR_NORMAL);
|
tty_setcolor (check_options[0].widget->state & C_BOOL ? DISABLED_COLOR : COLOR_NORMAL);
|
||||||
|
|
||||||
widget_move (h, 6, 5);
|
widget_move (h, 6, 5);
|
||||||
if (_panels_layout.horizontal_split)
|
if (panels_layout.horizontal_split)
|
||||||
tty_printf ("%03d", _panels_layout.top_panel_size);
|
tty_printf ("%03d", panels_layout.top_panel_size);
|
||||||
else
|
else
|
||||||
tty_printf ("%03d", _panels_layout.left_panel_size);
|
tty_printf ("%03d", panels_layout.left_panel_size);
|
||||||
|
|
||||||
widget_move (h, 6, 17);
|
widget_move (h, 6, 17);
|
||||||
if (_panels_layout.horizontal_split)
|
if (panels_layout.horizontal_split)
|
||||||
tty_printf ("%03d", height - _panels_layout.top_panel_size);
|
tty_printf ("%03d", height - panels_layout.top_panel_size);
|
||||||
else
|
else
|
||||||
tty_printf ("%03d", COLS - _panels_layout.left_panel_size);
|
tty_printf ("%03d", COLS - panels_layout.left_panel_size);
|
||||||
|
|
||||||
widget_move (h, 6, 12);
|
widget_move (h, 6, 12);
|
||||||
tty_print_char ('=');
|
tty_print_char ('=');
|
||||||
@ -263,20 +262,22 @@ b_left_right_cback (WButton * button, int action)
|
|||||||
|
|
||||||
if (button == bleft_widget)
|
if (button == bleft_widget)
|
||||||
{
|
{
|
||||||
if (_panels_layout.horizontal_split)
|
if (panels_layout.horizontal_split)
|
||||||
_panels_layout.top_panel_size++;
|
panels_layout.top_panel_size++;
|
||||||
else
|
else
|
||||||
_panels_layout.left_panel_size++;
|
panels_layout.left_panel_size++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (_panels_layout.horizontal_split)
|
if (panels_layout.horizontal_split)
|
||||||
_panels_layout.top_panel_size--;
|
panels_layout.top_panel_size--;
|
||||||
else
|
else
|
||||||
_panels_layout.left_panel_size--;
|
panels_layout.left_panel_size--;
|
||||||
}
|
}
|
||||||
|
|
||||||
update_split (WIDGET (button)->owner);
|
update_split (WIDGET (button)->owner);
|
||||||
|
layout_change ();
|
||||||
|
do_refresh ();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -320,10 +321,6 @@ layout_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *
|
|||||||
update everything */
|
update everything */
|
||||||
dlg_default_repaint (h);
|
dlg_default_repaint (h);
|
||||||
|
|
||||||
old_layout.horizontal_split = -1;
|
|
||||||
old_layout.left_panel_size = -1;
|
|
||||||
old_layout.top_panel_size = -1;
|
|
||||||
|
|
||||||
old_output_lines = -1;
|
old_output_lines = -1;
|
||||||
|
|
||||||
update_split (h);
|
update_split (h);
|
||||||
@ -355,7 +352,7 @@ layout_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *
|
|||||||
_output_lines = 0;
|
_output_lines = 0;
|
||||||
height = LINES - _keybar_visible - (_command_prompt ? 1 : 0) -
|
height = LINES - _keybar_visible - (_command_prompt ? 1 : 0) -
|
||||||
_menubar_visible - _output_lines - _message_visible;
|
_menubar_visible - _output_lines - _message_visible;
|
||||||
minimum = MINHEIGHT * (1 + _panels_layout.horizontal_split);
|
minimum = MINHEIGHT * (1 + panels_layout.horizontal_split);
|
||||||
if (height < minimum)
|
if (height < minimum)
|
||||||
{
|
{
|
||||||
_output_lines -= minimum - height;
|
_output_lines -= minimum - height;
|
||||||
@ -378,23 +375,27 @@ layout_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *
|
|||||||
case MSG_ACTION:
|
case MSG_ACTION:
|
||||||
if (sender == WIDGET (radio_widget))
|
if (sender == WIDGET (radio_widget))
|
||||||
{
|
{
|
||||||
if (_panels_layout.horizontal_split != radio_widget->sel)
|
if (panels_layout.horizontal_split != radio_widget->sel)
|
||||||
{
|
{
|
||||||
_panels_layout.horizontal_split = radio_widget->sel;
|
panels_layout.horizontal_split = radio_widget->sel;
|
||||||
|
|
||||||
if (_panels_layout.horizontal_split)
|
if (panels_layout.horizontal_split)
|
||||||
{
|
{
|
||||||
if (_panels_layout.horizontal_equal)
|
if (panels_layout.horizontal_equal)
|
||||||
_panels_layout.top_panel_size = height / 2;
|
panels_layout.top_panel_size = height / 2;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (_panels_layout.vertical_equal)
|
if (panels_layout.vertical_equal)
|
||||||
_panels_layout.left_panel_size = COLS / 2;
|
panels_layout.left_panel_size = COLS / 2;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
update_split (h);
|
update_split (h);
|
||||||
|
layout_change ();
|
||||||
|
do_refresh ();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
update_split (h);
|
||||||
|
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
}
|
}
|
||||||
@ -403,21 +404,23 @@ layout_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *
|
|||||||
{
|
{
|
||||||
int eq;
|
int eq;
|
||||||
|
|
||||||
if (_panels_layout.horizontal_split)
|
if (panels_layout.horizontal_split)
|
||||||
{
|
{
|
||||||
_panels_layout.horizontal_equal = check_options[0].widget->state & C_BOOL;
|
panels_layout.horizontal_equal = check_options[0].widget->state & C_BOOL;
|
||||||
eq = _panels_layout.horizontal_equal;
|
eq = panels_layout.horizontal_equal;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_panels_layout.vertical_equal = check_options[0].widget->state & C_BOOL;
|
panels_layout.vertical_equal = check_options[0].widget->state & C_BOOL;
|
||||||
eq = _panels_layout.vertical_equal;
|
eq = panels_layout.vertical_equal;
|
||||||
}
|
}
|
||||||
|
|
||||||
widget_disable (WIDGET (bleft_widget), eq);
|
widget_disable (WIDGET (bleft_widget), eq);
|
||||||
widget_disable (WIDGET (bright_widget), eq);
|
widget_disable (WIDGET (bright_widget), eq);
|
||||||
|
|
||||||
update_split (h);
|
update_split (h);
|
||||||
|
layout_change ();
|
||||||
|
do_refresh ();
|
||||||
|
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
}
|
}
|
||||||
@ -454,18 +457,12 @@ init_layout (void)
|
|||||||
output_lines_label = _("Output lines:");
|
output_lines_label = _("Output lines:");
|
||||||
|
|
||||||
/* save old params */
|
/* save old params */
|
||||||
_panels_layout = panels_layout;
|
|
||||||
_menubar_visible = menubar_visible;
|
_menubar_visible = menubar_visible;
|
||||||
_command_prompt = command_prompt;
|
_command_prompt = command_prompt;
|
||||||
_keybar_visible = mc_global.keybar_visible;
|
_keybar_visible = mc_global.keybar_visible;
|
||||||
_message_visible = mc_global.message_visible;
|
_message_visible = mc_global.message_visible;
|
||||||
_xterm_title = xterm_title;
|
_xterm_title = xterm_title;
|
||||||
_free_space = free_space;
|
_free_space = free_space;
|
||||||
|
|
||||||
old_layout.horizontal_split = -1;
|
|
||||||
old_layout.left_panel_size = -1;
|
|
||||||
old_layout.top_panel_size = -1;
|
|
||||||
|
|
||||||
old_output_lines = -1;
|
old_output_lines = -1;
|
||||||
_output_lines = output_lines;
|
_output_lines = output_lines;
|
||||||
|
|
||||||
@ -642,8 +639,9 @@ void
|
|||||||
layout_box (void)
|
layout_box (void)
|
||||||
{
|
{
|
||||||
WDialog *layout_dlg;
|
WDialog *layout_dlg;
|
||||||
gboolean layout_do_change = FALSE;
|
|
||||||
|
|
||||||
|
old_layout = panels_layout;
|
||||||
|
old_output_lines = output_lines;
|
||||||
layout_dlg = init_layout ();
|
layout_dlg = init_layout ();
|
||||||
|
|
||||||
if (dlg_run (layout_dlg) == B_ENTER)
|
if (dlg_run (layout_dlg) == B_ENTER)
|
||||||
@ -653,25 +651,18 @@ layout_box (void)
|
|||||||
for (i = 0; i < (size_t) LAYOUT_OPTIONS_COUNT; i++)
|
for (i = 0; i < (size_t) LAYOUT_OPTIONS_COUNT; i++)
|
||||||
if (check_options[i].widget != NULL)
|
if (check_options[i].widget != NULL)
|
||||||
*check_options[i].variable = check_options[i].widget->state & C_BOOL;
|
*check_options[i].variable = check_options[i].widget->state & C_BOOL;
|
||||||
|
|
||||||
panels_layout.horizontal_split = radio_widget->sel;
|
|
||||||
if (panels_layout.horizontal_split)
|
|
||||||
{
|
|
||||||
panels_layout.horizontal_equal = *check_options[0].variable;
|
|
||||||
panels_layout.top_panel_size = _panels_layout.top_panel_size;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
panels_layout.vertical_equal = *check_options[0].variable;
|
/* restore layout */
|
||||||
panels_layout.left_panel_size = _panels_layout.left_panel_size;
|
panels_layout = old_layout;
|
||||||
}
|
output_lines = old_output_lines;
|
||||||
output_lines = _output_lines;
|
update_split (layout_dlg);
|
||||||
layout_do_change = TRUE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
dlg_destroy (layout_dlg);
|
dlg_destroy (layout_dlg);
|
||||||
if (layout_do_change)
|
|
||||||
layout_change ();
|
layout_change ();
|
||||||
|
do_refresh ();
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
Loading…
Reference in New Issue
Block a user