-/* This file is part of
- * ======================================================
- *
- * LyX, The Document Processor
- *
- * Copyright 2000-2001 The LyX Team.
+/**
+ * \file FormParagraph.C
+ * Copyright 2000-2001 The LyX Team.
+ * See the file COPYING.
*
- * @author Jürgen Vigna
- *
- *======================================================*/
+ * \author Jürgen Vigna, jug@sad.it
+ */
#include <config.h>
#include "buffer.h"
#include "lyxtext.h"
#include "xforms_helpers.h"
+#include "lyxrc.h" // to set the deafult length values
+#include "BufferView.h"
+#include "lyxtextclasslist.h"
+#include "Spacing.h"
+#include "ParagraphParameters.h"
+#include "input_validators.h"
+#include "helper_funcs.h"
+
+#include "support/lstrings.h"
+
+#include <functional>
using Liason::setMinibuffer;
using SigC::slot;
+using std::vector;
+using std::bind2nd;
+using std::remove_if;
FormParagraph::FormParagraph(LyXView * lv, Dialogs * d)
- : FormBaseBD(lv, d, _("Paragraph Layout"))
+ : FormBaseBD(lv, d, _("Paragraph Layout")), par_(0)
{
// let the dialog be shown
// This is a permanent connection so we won't bother
// storing a copy because we won't be disconnecting.
- d->showLayoutParagraph.connect(slot(this, &FormParagraph::show));
+ d->showParagraph.connect(slot(this, &FormParagraph::show));
}
-void FormParagraph::redraw()
+void FormParagraph::connect()
+{
+ cp_ = d_->updateParagraph
+ .connect(slot(this, &FormParagraph::changedParagraph));
+ FormBaseBD::connect();
+}
+
+
+void FormParagraph::disconnect()
+{
+ cp_.disconnect();
+ FormBaseBD::disconnect();
+}
+
+
+Paragraph const * FormParagraph::getCurrentParagraph() const
+{
+ return lv_->view()->getLyXText()->cursor.par();
+}
+
+
+void FormParagraph::changedParagraph()
{
- if( form() && form()->visible )
- fl_redraw_form( form() );
- else
+ /// Record the paragraph
+ Paragraph const * const p = getCurrentParagraph();
+ if (p == 0 || p == par_)
return;
- FL_FORM * outer_form = fl_get_active_folder(dialog_->tabbed_folder);
- if (outer_form && outer_form->visible)
- fl_redraw_form( outer_form );
+ // OBS FIX LOOK HERE
+
+ // shouldn't we chage the par_ pointer too?
+ // anyway for me the below function does just nothing!
+ // (Jug 20020108)
+
+ // For now don't bother checking if the params are different,
+ // just activate the Apply button
+ bc().valid();
+}
+
+
+void FormParagraph::redraw()
+{
+ if (form() && form()->visible)
+ fl_redraw_form(form());
}
void FormParagraph::build()
{
// the tabbed folder
- dialog_.reset(build_tabbed_paragraph());
+ dialog_.reset(build_paragraph());
+
+ fl_addto_choice(dialog_->choice_space_above,
+ _(" None | Defskip | Smallskip "
+ "| Medskip | Bigskip | VFill | Length "));
+ fl_addto_choice(dialog_->choice_space_below,
+ _(" None | Defskip | Smallskip "
+ "| Medskip | Bigskip | VFill | Length "));
+
+ fl_addto_choice(dialog_->choice_linespacing,
+ _(" Default | Single | OneHalf | Double | Other "));
+
+ fl_set_input_return(dialog_->input_space_above, FL_RETURN_CHANGED);
+ fl_set_input_return(dialog_->input_space_below, FL_RETURN_CHANGED);
+ fl_set_input_return(dialog_->input_labelwidth, FL_RETURN_CHANGED);
+ fl_set_input_return(dialog_->input_linespacing, FL_RETURN_CHANGED);
+ fl_set_input_filter(dialog_->input_linespacing, fl_unsigned_float_filter);
+
+ setPrehandler(dialog_->input_space_above);
+ setPrehandler(dialog_->input_space_below);
+ setPrehandler(dialog_->input_labelwidth);
+ setPrehandler(dialog_->input_linespacing);
+
+ // Create the contents of the unit choices
+ // Don't include the "%" terms...
+ vector<string> units_vec = getLatexUnits();
+#if 0
+ for (vector<string>::iterator it = units_vec.begin();
+ it != units_vec.end(); ++it) {
+ if (contains(*it, "%"))
+ it = units_vec.erase(it, it+1) - 1;
+ }
+#else
+ // Something similar to this is a better way to erase
+ vector<string>::iterator del =
+ remove_if(units_vec.begin(), units_vec.end(),
+ bind2nd(contains_functor(), "%"));
+ units_vec.erase(del, units_vec.end());
+#endif
+
+ string units = getStringFromVector(units_vec, "|");
+
+ fl_addto_choice(dialog_->choice_value_space_above, units.c_str());
+ fl_addto_choice(dialog_->choice_value_space_below, units.c_str());
// Manage the ok, apply, restore and cancel/close buttons
bc_.setOK(dialog_->button_ok);
bc_.setCancel(dialog_->button_cancel);
bc_.setRestore(dialog_->button_restore);
- // the general paragraph data form
- general_.reset(build_paragraph_general());
-
- fl_addto_choice(general_->choice_space_above,
- _(" None | Defskip | Smallskip "
- "| Medskip | Bigskip | VFill | Length "));
- fl_addto_choice(general_->choice_space_below,
- _(" None | Defskip | Smallskip "
- "| Medskip | Bigskip | VFill | Length "));
-
- fl_set_input_return(general_->input_space_above, FL_RETURN_CHANGED);
- fl_set_input_return(general_->input_space_below, FL_RETURN_CHANGED);
- fl_set_input_return(general_->input_labelwidth, FL_RETURN_CHANGED);
-
- bc_.addReadOnly (general_->radio_align_right);
- bc_.addReadOnly (general_->radio_align_left);
- bc_.addReadOnly (general_->radio_align_block);
- bc_.addReadOnly (general_->radio_align_center);
- bc_.addReadOnly (general_->check_lines_top);
- bc_.addReadOnly (general_->check_lines_bottom);
- bc_.addReadOnly (general_->check_pagebreaks_top);
- bc_.addReadOnly (general_->check_pagebreaks_bottom);
- bc_.addReadOnly (general_->choice_space_above);
- bc_.addReadOnly (general_->input_space_above);
- bc_.addReadOnly (general_->check_space_above);
- bc_.addReadOnly (general_->choice_space_below);
- bc_.addReadOnly (general_->input_space_below);
- bc_.addReadOnly (general_->check_space_below);
- bc_.addReadOnly (general_->check_noindent);
- bc_.addReadOnly (general_->input_labelwidth);
-
- // now make them fit together
- fl_addto_tabfolder(dialog_->tabbed_folder,_("General"), general_->form);
+ bc_.addReadOnly (dialog_->group_radio_alignment);
+ // bc_.addReadOnly (dialog_->radio_align_right);
+ // bc_.addReadOnly (dialog_->radio_align_left);
+ // bc_.addReadOnly (dialog_->radio_align_block);
+ // bc_.addReadOnly (dialog_->radio_align_center);
+ bc_.addReadOnly (dialog_->check_lines_top);
+ bc_.addReadOnly (dialog_->check_lines_bottom);
+ bc_.addReadOnly (dialog_->check_pagebreaks_top);
+ bc_.addReadOnly (dialog_->check_pagebreaks_bottom);
+ bc_.addReadOnly (dialog_->choice_space_above);
+ bc_.addReadOnly (dialog_->input_space_above);
+ bc_.addReadOnly (dialog_->check_space_above);
+ bc_.addReadOnly (dialog_->choice_space_below);
+ bc_.addReadOnly (dialog_->input_space_below);
+ bc_.addReadOnly (dialog_->check_space_below);
+ bc_.addReadOnly (dialog_->choice_linespacing);
+ bc_.addReadOnly (dialog_->input_linespacing);
+ bc_.addReadOnly (dialog_->check_noindent);
+ bc_.addReadOnly (dialog_->input_labelwidth);
}
if (!lv_->view()->available() || !dialog_.get())
return;
- general_apply();
-
- lv_->view()->update(lv_->view()->text,
- BufferView::SELECT | BufferView::FITCUR | BufferView::CHANGE);
- lv_->buffer()->markDirty();
- setMinibuffer(lv_, _("Paragraph layout set"));
-}
-
-
-void FormParagraph::update()
-{
- if (!dialog_.get())
- return;
-
- // Do this first; some objects may be de/activated subsequently.
- bc_.readOnly(lv_->buffer()->isReadonly());
-
- general_update();
-}
-
-
-void FormParagraph::general_apply()
-{
VSpace space_top, space_bottom;
LyXAlignment align;
string labelwidthstring;
// If a vspace kind is "Length" but there's no text in
// the input field, reset the kind to "None".
- if ((fl_get_choice (general_->choice_space_above) == 7) &&
- !*(fl_get_input (general_->input_space_above)))
+ if ((fl_get_choice (dialog_->choice_space_above) == 7) &&
+ !*(fl_get_input (dialog_->input_space_above)))
{
- fl_set_choice (general_->choice_space_above, 1);
+ fl_set_choice (dialog_->choice_space_above, 1);
}
- if ((fl_get_choice (general_->choice_space_below) == 7) &&
- !*(fl_get_input (general_->input_space_below)))
+ if ((fl_get_choice (dialog_->choice_space_below) == 7) &&
+ !*(fl_get_input (dialog_->input_space_below)))
{
- fl_set_choice (general_->choice_space_below, 1);
+ fl_set_choice (dialog_->choice_space_below, 1);
}
- bool line_top = fl_get_button(general_->check_lines_top);
- bool line_bottom = fl_get_button(general_->check_lines_bottom);
- bool pagebreak_top = fl_get_button(general_->check_pagebreaks_top);
- bool pagebreak_bottom = fl_get_button(general_->check_pagebreaks_bottom);
+ bool line_top = fl_get_button(dialog_->check_lines_top);
+ bool line_bottom = fl_get_button(dialog_->check_lines_bottom);
+ bool pagebreak_top = fl_get_button(dialog_->check_pagebreaks_top);
+ bool pagebreak_bottom = fl_get_button(dialog_->check_pagebreaks_bottom);
- switch (fl_get_choice (general_->choice_space_above)) {
+ switch (fl_get_choice (dialog_->choice_space_above)) {
case 1:
space_top = VSpace(VSpace::NONE);
break;
space_top = VSpace(VSpace::VFILL);
break;
case 7:
+ {
+ string const length =
+ getLengthFromWidgets(dialog_->input_space_above,
+ dialog_->choice_value_space_above);
space_top =
- VSpace(LyXGlueLength(fl_get_input(general_->input_space_above)));
+ VSpace(LyXGlueLength(length));
break;
}
- if (fl_get_button (general_->check_space_above))
+ }
+
+ if (fl_get_button (dialog_->check_space_above))
space_top.setKeep (true);
- switch (fl_get_choice (general_->choice_space_below)) {
+ switch (fl_get_choice (dialog_->choice_space_below)) {
case 1:
space_bottom = VSpace(VSpace::NONE);
break;
space_bottom = VSpace(VSpace::VFILL);
break;
case 7:
- space_bottom =
- VSpace(LyXGlueLength(fl_get_input(general_->input_space_below)));
+ string const length =
+ getLengthFromWidgets(dialog_->input_space_below,
+ dialog_->choice_value_space_below);
+ space_bottom = VSpace(LyXGlueLength(length));
break;
}
- if (fl_get_button (general_->check_space_below))
+ if (fl_get_button (dialog_->check_space_below))
space_bottom.setKeep (true);
- if (fl_get_button(general_->radio_align_left))
+ if (fl_get_button(dialog_->radio_align_left))
align = LYX_ALIGN_LEFT;
- else if (fl_get_button(general_->radio_align_right))
+ else if (fl_get_button(dialog_->radio_align_right))
align = LYX_ALIGN_RIGHT;
- else if (fl_get_button(general_->radio_align_center))
+ else if (fl_get_button(dialog_->radio_align_center))
align = LYX_ALIGN_CENTER;
else
align = LYX_ALIGN_BLOCK;
- labelwidthstring = fl_get_input(general_->input_labelwidth);
- noindent = fl_get_button(general_->check_noindent);
-
- LyXText * text = 0;
- if (lv_->view()->theLockingInset())
- text = lv_->view()->theLockingInset()->getLyXText(lv_->view());
- if (!text)
- text = lv_->view()->text;
- text->SetParagraph(lv_->view(), line_top, line_bottom, pagebreak_top,
- pagebreak_bottom, space_top, space_bottom, align,
- labelwidthstring, noindent);
+ labelwidthstring = fl_get_input(dialog_->input_labelwidth);
+ noindent = fl_get_button(dialog_->check_noindent);
+ Spacing::Space linespacing = Spacing::Default;
+ string other_linespacing;
+ switch (fl_get_choice(dialog_->choice_linespacing)) {
+ case 1: linespacing = Spacing::Default; break;
+ case 2: linespacing = Spacing::Single; break;
+ case 3: linespacing = Spacing::Onehalf; break;
+ case 4: linespacing = Spacing::Double; break;
+ case 5:
+ linespacing = Spacing::Other;
+ other_linespacing = fl_get_input(dialog_->input_linespacing);
+ break;
+ }
+
+ Spacing const spacing(linespacing, other_linespacing);
+ LyXText * text(lv_->view()->getLyXText());
+ text->setParagraph(lv_->view(), line_top, line_bottom, pagebreak_top,
+ pagebreak_bottom, space_top, space_bottom, spacing,
+ align, labelwidthstring, noindent);
+
+
+ // Actually apply these settings
+ lv_->view()->update(text,
+ BufferView::SELECT | BufferView::FITCUR | BufferView::CHANGE);
+ lv_->buffer()->markDirty();
+ setMinibuffer(lv_, _("Paragraph layout set"));
}
-void FormParagraph::general_update()
+void FormParagraph::update()
{
- if (!general_.get())
+ if (!dialog_.get())
return;
+ // Do this first; some objects may be de/activated subsequently.
+ bc_.readOnly(lv_->buffer()->isReadonly());
+
Buffer * buf = lv_->view()->buffer();
- LyXText * text = 0;
- if (lv_->view()->theLockingInset())
- text = lv_->view()->theLockingInset()->getLyXText(lv_->view());
- if (!text)
- text = lv_->view()->text;
+ /// Record the paragraph
+ par_ = getCurrentParagraph();
- fl_set_input(general_->input_labelwidth,
- text->cursor.par()->GetLabelWidthString().c_str());
- fl_set_button(general_->radio_align_right, 0);
- fl_set_button(general_->radio_align_left, 0);
- fl_set_button(general_->radio_align_center, 0);
- fl_set_button(general_->radio_align_block, 0);
+ fl_set_input(dialog_->input_labelwidth,
+ par_->getLabelWidthString().c_str());
+ setEnabled(dialog_->input_labelwidth,
+ (par_->getLabelWidthString() != _("Senseless with this layout!")));
- int align = text->cursor.par()->GetAlign();
+ fl_set_button(dialog_->radio_align_right, 0);
+ fl_set_button(dialog_->radio_align_left, 0);
+ fl_set_button(dialog_->radio_align_center, 0);
+ fl_set_button(dialog_->radio_align_block, 0);
+
+ LyXTextClass const & tclass = textclasslist[buf->params.textclass];
+
+ int align = par_->getAlign();
if (align == LYX_ALIGN_LAYOUT)
- align = textclasslist.Style(buf->params.textclass,
- text->cursor.par()->GetLayout()).align;
+ align = tclass[par_->layout()].align;
switch (align) {
case LYX_ALIGN_RIGHT:
- fl_set_button(general_->radio_align_right, 1);
+ fl_set_button(dialog_->radio_align_right, 1);
break;
case LYX_ALIGN_LEFT:
- fl_set_button(general_->radio_align_left, 1);
+ fl_set_button(dialog_->radio_align_left, 1);
break;
case LYX_ALIGN_CENTER:
- fl_set_button(general_->radio_align_center, 1);
+ fl_set_button(dialog_->radio_align_center, 1);
break;
default:
- fl_set_button(general_->radio_align_block, 1);
+ fl_set_button(dialog_->radio_align_block, 1);
break;
}
- LyXAlignment alignpos =
- textclasslist.Style(buf->params.textclass,
- text->cursor.par()->GetLayout()).alignpossible;
+ LyXAlignment alignpos = tclass[par_->layout()].alignpossible;
- setEnabled(general_->radio_align_block, bool(alignpos & LYX_ALIGN_BLOCK));
- setEnabled(general_->radio_align_center, bool(alignpos & LYX_ALIGN_CENTER));
- setEnabled(general_->radio_align_left, bool(alignpos & LYX_ALIGN_LEFT));
- setEnabled(general_->radio_align_right, bool(alignpos & LYX_ALIGN_RIGHT));
+ setEnabled(dialog_->radio_align_block, bool(alignpos & LYX_ALIGN_BLOCK));
+ setEnabled(dialog_->radio_align_center, bool(alignpos & LYX_ALIGN_CENTER));
+ setEnabled(dialog_->radio_align_left, bool(alignpos & LYX_ALIGN_LEFT));
+ setEnabled(dialog_->radio_align_right, bool(alignpos & LYX_ALIGN_RIGHT));
- fl_set_button(general_->check_lines_top,
- text->cursor.par()->params.lineTop());
- fl_set_button(general_->check_lines_bottom,
- text->cursor.par()->params.lineBottom());
- fl_set_button(general_->check_pagebreaks_top,
- text->cursor.par()->params.pagebreakTop());
- fl_set_button(general_->check_pagebreaks_bottom,
- text->cursor.par()->params.pagebreakBottom());
- fl_set_button(general_->check_noindent,
- text->cursor.par()->params.noindent());
-
- fl_set_input (general_->input_space_above, "");
-
- switch (text->cursor.par()->params.spaceTop().kind()) {
+ // no inset-text-owned paragraph may have pagebreaks
+ setEnabled(dialog_->check_pagebreaks_top, !par_->inInset());
+ setEnabled(dialog_->check_pagebreaks_bottom, !par_->inInset());
+
+ fl_set_button(dialog_->check_lines_top,
+ par_->params().lineTop());
+ fl_set_button(dialog_->check_lines_bottom,
+ par_->params().lineBottom());
+ fl_set_button(dialog_->check_pagebreaks_top,
+ par_->params().pagebreakTop());
+ fl_set_button(dialog_->check_pagebreaks_bottom,
+ par_->params().pagebreakBottom());
+ fl_set_button(dialog_->check_noindent,
+ par_->params().noindent());
+
+ int linespacing;
+ Spacing const space = par_->params().spacing();
+
+ switch (space.getSpace()) {
+ default: linespacing = 1; break;
+ case Spacing::Single: linespacing = 2; break;
+ case Spacing::Onehalf: linespacing = 3; break;
+ case Spacing::Double: linespacing = 4; break;
+ case Spacing::Other: linespacing = 5; break;
+ }
+
+ fl_set_choice(dialog_->choice_linespacing, linespacing);
+ if (space.getSpace() == Spacing::Other) {
+ string const sp = tostr(space.getValue());
+ fl_set_input(dialog_->input_linespacing, sp.c_str());
+ setEnabled(dialog_->input_linespacing, true);
+ } else {
+ fl_set_input(dialog_->input_linespacing, "");
+ setEnabled(dialog_->input_linespacing, false);
+ }
+
+ fl_set_input (dialog_->input_space_above, "");
+
+ setEnabled(dialog_->input_space_above, false);
+ setEnabled(dialog_->choice_value_space_above, false);
+ switch (par_->params().spaceTop().kind()) {
case VSpace::NONE:
- fl_set_choice (general_->choice_space_above, 1);
+ fl_set_choice (dialog_->choice_space_above, 1);
break;
case VSpace::DEFSKIP:
- fl_set_choice (general_->choice_space_above, 2);
+ fl_set_choice (dialog_->choice_space_above, 2);
break;
case VSpace::SMALLSKIP:
- fl_set_choice (general_->choice_space_above, 3);
+ fl_set_choice (dialog_->choice_space_above, 3);
break;
case VSpace::MEDSKIP:
- fl_set_choice (general_->choice_space_above, 4);
+ fl_set_choice (dialog_->choice_space_above, 4);
break;
case VSpace::BIGSKIP:
- fl_set_choice (general_->choice_space_above, 5);
+ fl_set_choice (dialog_->choice_space_above, 5);
break;
case VSpace::VFILL:
- fl_set_choice (general_->choice_space_above, 6);
+ fl_set_choice (dialog_->choice_space_above, 6);
break;
case VSpace::LENGTH:
- fl_set_choice (general_->choice_space_above, 7);
- fl_set_input(general_->input_space_above, text->cursor.par()->
- params.spaceTop().length().asString().c_str());
+ {
+ fl_set_choice (dialog_->choice_space_above, 7);
+ setEnabled(dialog_->input_space_above, true);
+ setEnabled(dialog_->choice_value_space_above, true);
+ bool const metric = lyxrc.default_papersize > 3;
+ string const default_unit = metric ? "cm" : "in";
+ string const length = par_->params().spaceTop().length().asString();
+ updateWidgetsFromLengthString(dialog_->input_space_above,
+ dialog_->choice_value_space_above,
+ length, default_unit);
break;
}
+ }
- fl_set_button (general_->check_space_above,
- text->cursor.par()->params.spaceTop().keep());
- fl_set_input (general_->input_space_below, "");
+ fl_set_button (dialog_->check_space_above,
+ par_->params().spaceTop().keep());
+ fl_set_input (dialog_->input_space_below, "");
- switch (text->cursor.par()->params.spaceBottom().kind()) {
+ setEnabled(dialog_->input_space_below, false);
+ setEnabled(dialog_->choice_value_space_below, false);
+ switch (par_->params().spaceBottom().kind()) {
case VSpace::NONE:
- fl_set_choice (general_->choice_space_below, 1);
+ fl_set_choice (dialog_->choice_space_below, 1);
break;
case VSpace::DEFSKIP:
- fl_set_choice (general_->choice_space_below, 2);
+ fl_set_choice (dialog_->choice_space_below, 2);
break;
case VSpace::SMALLSKIP:
- fl_set_choice (general_->choice_space_below, 3);
+ fl_set_choice (dialog_->choice_space_below, 3);
break;
case VSpace::MEDSKIP:
- fl_set_choice (general_->choice_space_below, 4);
+ fl_set_choice (dialog_->choice_space_below, 4);
break;
case VSpace::BIGSKIP:
- fl_set_choice (general_->choice_space_below, 5);
+ fl_set_choice (dialog_->choice_space_below, 5);
break;
case VSpace::VFILL:
- fl_set_choice (general_->choice_space_below, 6);
+ fl_set_choice (dialog_->choice_space_below, 6);
break;
case VSpace::LENGTH:
- fl_set_choice (general_->choice_space_below, 7);
- fl_set_input(general_->input_space_below, text->cursor.par()->
- params.spaceBottom().length().asString().c_str());
+ {
+ fl_set_choice (dialog_->choice_space_below, 7);
+ setEnabled(dialog_->input_space_below, true);
+ setEnabled(dialog_->choice_value_space_below, true);
+ bool const metric = lyxrc.default_papersize > 3;
+ string const default_unit = metric ? "cm" : "in";
+ string const length =
+ par_->params().spaceBottom().length().asString();
+ updateWidgetsFromLengthString(dialog_->input_space_below,
+ dialog_->choice_value_space_below,
+ length, default_unit);
break;
}
- fl_set_button(general_->check_space_below,
- text->cursor.par()->params.spaceBottom().keep());
- fl_set_button(general_->check_noindent,
- text->cursor.par()->params.noindent());
+ }
+
+ fl_set_button(dialog_->check_space_below,
+ par_->params().spaceBottom().keep());
+ fl_set_button(dialog_->check_noindent,
+ par_->params().noindent());
}
bool FormParagraph::input(FL_OBJECT * ob, long)
{
- bool ret = true;
+ bool valid = true;
fl_hide_object(dialog_->text_warning);
// First check the buttons which are exclusive and you have to
// check only the actuall de/activated button.
//
- // general form first
- //
// "Synchronize" the choices and input fields, making it
// impossible to commit senseless data.
- if (fl_get_choice (general_->choice_space_above) != 7)
- fl_set_input (general_->input_space_above, "");
-
- if (fl_get_choice (general_->choice_space_below) != 7)
- fl_set_input (general_->input_space_below, "");
-
+ if (ob == dialog_->choice_space_above) {
+ if (fl_get_choice (dialog_->choice_space_above) != 7) {
+ fl_set_input (dialog_->input_space_above, "");
+ setEnabled (dialog_->input_space_above, false);
+ setEnabled (dialog_->choice_value_space_above, false);
+ } else {
+ setEnabled (dialog_->input_space_above, !lv_->buffer()->isReadonly());
+ setEnabled (dialog_->choice_value_space_above, !lv_->buffer()->isReadonly());
+ bool const metric = lyxrc.default_papersize > 3;
+ int const default_unit = metric ? 8 : 9;
+ if (strip(fl_get_input(dialog_->input_space_above)).empty())
+ fl_set_choice(dialog_->choice_value_space_above,
+ default_unit);
+ }
+ }
+ if (ob == dialog_->choice_space_below) {
+ if (fl_get_choice (dialog_->choice_space_below) != 7) {
+ fl_set_input (dialog_->input_space_below, "");
+ setEnabled (dialog_->input_space_below, false);
+ setEnabled (dialog_->choice_value_space_below, false);
+ } else {
+ setEnabled (dialog_->input_space_below, !lv_->buffer()->isReadonly());
+ setEnabled (dialog_->choice_value_space_below, !lv_->buffer()->isReadonly());
+ bool const metric = lyxrc.default_papersize > 3;
+ int const default_unit = metric ? 8 : 9;
+ if (strip(fl_get_input(dialog_->input_space_below)).empty())
+ fl_set_choice(dialog_->choice_value_space_below,
+ default_unit);
+ }
+ }
+
//
- // first the general form
+ // warnings if input is senseless
//
- string input = fl_get_input (general_->input_space_above);
+ string input = fl_get_input (dialog_->input_space_above);
bool invalid = false;
-
- if (fl_get_choice(general_->choice_space_above)==7)
- invalid = !input.empty() && !isValidGlueLength(input);
- input = fl_get_input (general_->input_space_below);
+ if (fl_get_choice(dialog_->choice_space_above)==7)
+ invalid = !input.empty() && !isValidGlueLength(input) && !isStrDbl(input);
- if (fl_get_choice(general_->choice_space_below)==7)
- invalid = invalid || (!input.empty() && !isValidGlueLength(input));
-
- if (ob == general_->input_space_above || ob == general_->input_space_below) {
- if (invalid) {
+ input = fl_get_input (dialog_->input_space_below);
+
+ if (fl_get_choice(dialog_->choice_space_below)==7)
+ invalid = invalid
+ || (!input.empty() && !isValidGlueLength(input) && !isStrDbl(input));
+
+ if (ob == dialog_->input_space_above || ob == dialog_->input_space_below) {
+ if (invalid) {
fl_set_object_label(dialog_->text_warning,
_("Warning: Invalid Length (valid example: 10mm)"));
fl_show_object(dialog_->text_warning);
}
}
- return ret;
-}
+ if (fl_get_choice (dialog_->choice_linespacing) == 5)
+ setEnabled (dialog_->input_linespacing, true);
+ else {
+ setEnabled (dialog_->input_linespacing, false);
+ fl_set_input (dialog_->input_linespacing, "");
+ }
+ double spacing(strToDbl(fl_get_input(dialog_->input_linespacing)));
+
+ if (fl_get_choice (dialog_->choice_linespacing) == 5
+ && int(spacing) == 0)
+ valid = false;
+
+ return valid;
+}