#include "insets/InsetTabular.h"
+#include "support/convert.h"
#include "support/debug.h"
#include <QCheckBox>
setupUi(this);
tabularWidthED->setValidator(unsignedLengthValidator(tabularWidthED));
- widthED->setValidator(unsignedLengthValidator(widthED));
+ columnWidthED->setValidator(unsignedLengthValidator(columnWidthED));
multirowOffsetED->setValidator(new LengthValidator(multirowOffsetED));
topspaceED->setValidator(new LengthValidator(topspaceED));
bottomspaceED->setValidator(new LengthValidator(bottomspaceED));
interlinespaceED->setValidator(new LengthValidator(interlinespaceED));
- tabularWidthUnitCB->setCurrentItem(Length::defaultUnit());
- widthUnitCB->setCurrentItem(Length::defaultUnit());
- multirowOffsetUnitCB->setCurrentItem(Length::defaultUnit());
- topspaceUnitCB->setCurrentItem(Length::defaultUnit());
- bottomspaceUnitCB->setCurrentItem(Length::defaultUnit());
- interlinespaceUnitCB->setCurrentItem(Length::defaultUnit());
+ tabularWidthUnitLC->setCurrentItem(Length::defaultUnit());
+ columnWidthUnitLC->setCurrentItem(Length::defaultUnit());
+ multirowOffsetUnitLC->setCurrentItem(Length::defaultUnit());
+ topspaceUnitLC->setCurrentItem(Length::defaultUnit());
+ bottomspaceUnitLC->setCurrentItem(Length::defaultUnit());
+ interlinespaceUnitLC->setCurrentItem(Length::defaultUnit());
- connect(topspaceED, SIGNAL(editingFinished()),
+ connect(topspaceED, SIGNAL(textEdited(const QString &)),
this, SLOT(checkEnabled()));
- connect(topspaceUnitCB, SIGNAL(selectionChanged(lyx::Length::UNIT)),
+ connect(topspaceUnitLC, SIGNAL(selectionChanged(lyx::Length::UNIT)),
this, SLOT(checkEnabled()));
- connect(bottomspaceED, SIGNAL(editingFinished()),
+ connect(bottomspaceED, SIGNAL(textEdited(const QString &)),
this, SLOT(checkEnabled()));
- connect(bottomspaceUnitCB, SIGNAL(selectionChanged(lyx::Length::UNIT)),
+ connect(bottomspaceUnitLC, SIGNAL(selectionChanged(lyx::Length::UNIT)),
this, SLOT(checkEnabled()));
- connect(interlinespaceED, SIGNAL(editingFinished()),
+ connect(interlinespaceED, SIGNAL(textEdited(const QString &)),
this, SLOT(checkEnabled()));
- connect(interlinespaceUnitCB, SIGNAL(selectionChanged(lyx::Length::UNIT)),
+ connect(interlinespaceUnitLC, SIGNAL(selectionChanged(lyx::Length::UNIT)),
this, SLOT(checkEnabled()));
connect(booktabsRB, SIGNAL(clicked(bool)),
this, SLOT(checkEnabled()));
this, SLOT(borderSet_clicked()));
connect(borderUnsetPB, SIGNAL(clicked()),
this, SLOT(borderUnset_clicked()));
- connect(hAlignCB, SIGNAL(activated(int)),
+ connect(hAlignCO, SIGNAL(activated(int)),
this, SLOT(checkEnabled()));
- connect(vAlignCB, SIGNAL(activated(int)),
+ connect(vAlignCO, SIGNAL(activated(int)),
this, SLOT(checkEnabled()));
connect(multicolumnCB, SIGNAL(clicked()),
this, SLOT(checkEnabled()));
connect(multirowCB, SIGNAL(clicked()),
this, SLOT(checkEnabled()));
- connect(multirowOffsetED, SIGNAL(editingFinished()),
+ connect(multirowOffsetED, SIGNAL(textEdited(const QString &)),
this, SLOT(checkEnabled()));
- connect(multirowOffsetUnitCB, SIGNAL(selectionChanged(lyx::Length::UNIT)),
+ connect(multirowOffsetUnitLC, SIGNAL(selectionChanged(lyx::Length::UNIT)),
this, SLOT(checkEnabled()));
connect(newpageCB, SIGNAL(clicked()),
this, SLOT(checkEnabled()));
this, SLOT(checkEnabled()));
connect(captionStatusCB, SIGNAL(clicked()),
this, SLOT(checkEnabled()));
- connect(specialAlignmentED, SIGNAL(editingFinished()),
+ connect(specialAlignmentED, SIGNAL(textEdited(const QString &)),
this, SLOT(checkEnabled()));
- connect(widthED, SIGNAL(editingFinished()),
+ connect(columnWidthED, SIGNAL(textEdited(const QString &)),
this, SLOT(checkEnabled()));
- connect(widthUnitCB, SIGNAL(selectionChanged(lyx::Length::UNIT)),
+ connect(columnWidthUnitLC, SIGNAL(selectionChanged(lyx::Length::UNIT)),
this, SLOT(checkEnabled()));
connect(borders, SIGNAL(topSet(bool)),
this, SLOT(checkEnabled()));
this, SLOT(checkEnabled()));
connect(rotateTabularCB, SIGNAL(clicked()),
this, SLOT(checkEnabled()));
+ connect(rotateTabularAngleSB, SIGNAL(valueChanged(int)),
+ this, SLOT(checkEnabled()));
connect(rotateCellCB, SIGNAL(clicked()),
this, SLOT(checkEnabled()));
- connect(TableAlignCB, SIGNAL(activated(int)),
+ connect(rotateCellAngleSB, SIGNAL(valueChanged(int)),
+ this, SLOT(checkEnabled()));
+ connect(TableAlignCO, SIGNAL(activated(int)),
this, SLOT(checkEnabled()));
connect(longTabularCB, SIGNAL(clicked()),
this, SLOT(checkEnabled()));
connect(tabularWidthED, SIGNAL(textEdited(const QString &)),
this, SLOT(checkEnabled()));
- decimalPointLE->setInputMask("X; ");
- decimalPointLE->setMaxLength(1);
+ decimalPointED->setInputMask("X; ");
+ decimalPointED->setMaxLength(1);
// initialize the length validator
- addCheckedWidget(widthED, fixedWidthColLA);
+ addCheckedWidget(columnWidthED, columnWidthLA);
addCheckedWidget(multirowOffsetED, multirowOffsetLA);
addCheckedWidget(topspaceED, topspaceLA);
addCheckedWidget(bottomspaceED, bottomspaceLA);
addCheckedWidget(interlinespaceED, interlinespaceLA);
+ addCheckedWidget(tabularWidthED, tabularWidthLA);
}
{
bool const enable = (index == 2);
topspaceED->setEnabled(enable);
- topspaceUnitCB->setEnabled(enable);
+ topspaceUnitLC->setEnabled(enable);
}
{
bool const enable = (index == 2);
bottomspaceED->setEnabled(enable);
- bottomspaceUnitCB->setEnabled(enable);
+ bottomspaceUnitLC->setEnabled(enable);
}
{
bool const enable = (index == 2);
interlinespaceED->setEnabled(enable);
- interlinespaceUnitCB->setEnabled(enable);
+ interlinespaceUnitLC->setEnabled(enable);
}
-void GuiTabular::checkEnabled()
+void GuiTabular::enableWidgets() const
{
// if there is a LaTeX argument, the width and alignment will be overwritten
// therefore disable them in this case
- widthED->setEnabled(specialAlignmentED->text().isEmpty());
+ columnWidthED->setEnabled(specialAlignmentED->text().isEmpty());
+ columnWidthUnitLC->setEnabled(specialAlignmentED->text().isEmpty());
// if the column has a width, multirows are always left-aligned
// therefore disable hAlignCB in this case
- hAlignCB->setEnabled(!(multirowCB->isChecked()
- && !widgetsToLength(widthED, widthUnitCB).empty())
+ hAlignCO->setEnabled(!(multirowCB->isChecked()
+ && !widgetsToLength(columnWidthED, columnWidthUnitLC).empty())
&& specialAlignmentED->text().isEmpty());
- bool const dalign =
- hAlignCB->itemData(hAlignCB->currentIndex()).toString() == QString("decimal");
- decimalPointLE->setEnabled(dalign);
- decimalL->setEnabled(dalign);
-
- bool const setwidth = TableAlignCB->currentText() == qt_("Middle")
- && !longTabularCB->isChecked() && !rotateTabularCB->isChecked();
- tabularWidthL->setEnabled(setwidth);
+ // decimal alignment is only possible for non-multicol and non-multirow cells
+ if ((multicolumnCB->isChecked() || multirowCB->isChecked())
+ && hAlignCO->findData(toqstr("decimal")))
+ hAlignCO->removeItem(hAlignCO->findData(toqstr("decimal")));
+ else if (!multicolumnCB->isChecked() && !multirowCB->isChecked()
+ && hAlignCO->findData(toqstr("decimal")) == -1)
+ hAlignCO->addItem(qt_("At Decimal Separator"), toqstr("decimal"));
+ bool const dalign =
+ hAlignCO->itemData(hAlignCO->currentIndex()).toString() == QString("decimal");
+ decimalPointED->setEnabled(dalign);
+ decimalLA->setEnabled(dalign);
+
+ bool const setwidth = TableAlignCO->currentText() == qt_("Middle")
+ && !longTabularCB->isChecked();
+ tabularWidthLA->setEnabled(setwidth);
tabularWidthED->setEnabled(setwidth);
- tabularWidthUnitCB->setEnabled(setwidth);
+ tabularWidthUnitLC->setEnabled(setwidth);
- bool const is_tabular_star = !tabularWidthED->text().isEmpty();
- rotateTabularCB->setDisabled(is_tabular_star);
+ rotateTabularAngleSB->setEnabled(rotateTabularCB->isChecked());
+ rotateCellAngleSB->setEnabled(rotateCellCB->isChecked());
- vAlignCB->setEnabled(!multirowCB->isChecked()
- && !widgetsToLength(widthED, widthUnitCB).empty()
- && specialAlignmentED->text().isEmpty());
+ bool const enable_valign =
+ !multirowCB->isChecked()
+ && !widgetsToLength(columnWidthED, columnWidthUnitLC).empty()
+ && specialAlignmentED->text().isEmpty();
+ vAlignCO->setEnabled(enable_valign);
+ vAlignLA->setEnabled(enable_valign);
topspaceED->setEnabled(topspaceCO->currentIndex() == 2);
topspaceED->setEnabled(topspaceCO->currentIndex() == 2);
- topspaceUnitCB->setEnabled(topspaceCO->currentIndex() == 2);
+ topspaceUnitLC->setEnabled(topspaceCO->currentIndex() == 2);
bottomspaceED->setEnabled(bottomspaceCO->currentIndex() == 2);
- bottomspaceUnitCB->setEnabled(bottomspaceCO->currentIndex() == 2);
+ bottomspaceUnitLC->setEnabled(bottomspaceCO->currentIndex() == 2);
interlinespaceED->setEnabled(interlinespaceCO->currentIndex() == 2);
- interlinespaceUnitCB->setEnabled(interlinespaceCO->currentIndex() == 2);
+ interlinespaceUnitLC->setEnabled(interlinespaceCO->currentIndex() == 2);
// setting as longtable is not allowed when table is inside a float
+ bool const is_tabular_star = !tabularWidthED->text().isEmpty();
longTabularCB->setEnabled(!is_tabular_star && funcEnabled(Tabular::SET_LONGTABULAR));
bool const longtabular = longTabularCB->isChecked();
longtableGB->setEnabled(true);
newpageCB->setEnabled(longtabular);
alignmentGB->setEnabled(longtabular);
// longtables and tabular* cannot have a vertical alignment
- TableAlignCB->setDisabled(is_tabular_star || longtabular);
+ TableAlignLA->setDisabled(is_tabular_star || longtabular);
TableAlignCO->setDisabled(is_tabular_star || longtabular);
- TableAlignCB->setDisabled(is_tabular_star || longtabular);
// FIXME: This Dialog is really horrible, disabling/enabling a checkbox
// depending on the cursor position is very very unintuitive...
// We need some edit boxes to show which rows are header/footer/etc
// without having to move the cursor first.
- headerStatusCB->setEnabled(longtabular);
+ headerStatusCB->setEnabled(longtabular
+ && (headerStatusCB->isChecked() ?
+ funcEnabled(Tabular::UNSET_LTHEAD) :
+ funcEnabled(Tabular::SET_LTHEAD)));
headerBorderAboveCB->setEnabled(longtabular
&& headerStatusCB->isChecked());
headerBorderBelowCB->setEnabled(longtabular
// check if setting a first header is allowed
// additionally check firstheaderNoContentsCB because when this is
// the case a first header makes no sense
- firstheaderStatusCB->setEnabled(funcEnabled(Tabular::SET_LTFIRSTHEAD)
+ firstheaderStatusCB->setEnabled((firstheaderStatusCB->isChecked() ?
+ funcEnabled(Tabular::UNSET_LTFIRSTHEAD) :
+ funcEnabled(Tabular::SET_LTFIRSTHEAD))
&& longtabular && !firstheaderNoContentsCB->isChecked());
firstheaderBorderAboveCB->setEnabled(longtabular
&& firstheaderStatusCB->isChecked());
firstheaderBorderBelowCB->setEnabled(longtabular
&& firstheaderStatusCB->isChecked());
- footerStatusCB->setEnabled(longtabular);
+ footerStatusCB->setEnabled(longtabular
+ && (footerStatusCB->isChecked() ?
+ funcEnabled(Tabular::UNSET_LTFOOT) :
+ funcEnabled(Tabular::SET_LTFOOT)));
footerBorderAboveCB->setEnabled(longtabular
&& footerBorderAboveCB->isChecked());
footerBorderBelowCB->setEnabled(longtabular
// check if setting a last footer is allowed
// additionally check lastfooterNoContentsCB because when this is
// the case a last footer makes no sense
- lastfooterStatusCB->setEnabled(funcEnabled(Tabular::SET_LTLASTFOOT)
+ lastfooterStatusCB->setEnabled((lastfooterStatusCB->isChecked() ?
+ funcEnabled(Tabular::UNSET_LTLASTFOOT) :
+ funcEnabled(Tabular::SET_LTLASTFOOT))
&& longtabular && !lastfooterNoContentsCB->isChecked());
lastfooterBorderAboveCB->setEnabled(longtabular
&& lastfooterBorderAboveCB->isChecked());
captionStatusCB->setEnabled(funcEnabled(Tabular::TOGGLE_LTCAPTION)
&& longtabular);
- multicolumnCB->setEnabled(funcEnabled(Tabular::MULTICOLUMN));
- multirowCB->setEnabled(funcEnabled(Tabular::MULTIROW));
- multirowOffsetED->setEnabled(multirowCB->isChecked());
- multirowOffsetUnitCB->setEnabled(multirowCB->isChecked());
+ multicolumnCB->setEnabled(funcEnabled(Tabular::MULTICOLUMN)
+ && !dalign && !multirowCB->isChecked());
+ multirowCB->setEnabled(funcEnabled(Tabular::MULTIROW)
+ && !dalign && !multicolumnCB->isChecked());
+ bool const enable_mr = multirowCB->isChecked();
+ multirowOffsetLA->setEnabled(enable_mr);
+ multirowOffsetED->setEnabled(enable_mr);
+ multirowOffsetUnitLC->setEnabled(enable_mr);
+
+ // Vertical lines cannot be set in formal tables
+ borders->setLeftEnabled(!booktabsRB->isChecked());
+ borders->setRightEnabled(!booktabsRB->isChecked());
+}
+
+void GuiTabular::checkEnabled()
+{
+ enableWidgets();
changed();
}
Tabular::Feature num = Tabular::ALIGN_LEFT;
Tabular::Feature multi_num = Tabular::M_ALIGN_LEFT;
string const align =
- fromqstr(hAlignCB->itemData(hAlignCB->currentIndex()).toString());
+ fromqstr(hAlignCO->itemData(hAlignCO->currentIndex()).toString());
if (align == "left") {
num = Tabular::ALIGN_LEFT;
multi_num = Tabular::M_ALIGN_LEFT;
void GuiTabular::setVAlign(string & param_str) const
{
- int const align = vAlignCB->currentIndex();
+ int const align = vAlignCO->currentIndex();
enum VALIGN { TOP, MIDDLE, BOTTOM };
VALIGN v = TOP;
void GuiTabular::setTableAlignment(string & param_str) const
{
- int const align = TableAlignCB->currentIndex();
+ int const align = TableAlignCO->currentIndex();
switch (align) {
case 0: setParam(param_str, Tabular::TABULAR_VALIGN_TOP);
break;
docstring GuiTabular::dialogToParams() const
{
// FIXME: We should use Tabular directly.
- string param_str = "tabular";
+ string param_str = "tabular from-dialog";
// table width
- string tabwidth = widgetsToLength(tabularWidthED, tabularWidthUnitCB);
+ string tabwidth = widgetsToLength(tabularWidthED, tabularWidthUnitLC);
if (tabwidth.empty())
tabwidth = "0pt";
setParam(param_str, Tabular::SET_TABULAR_WIDTH, tabwidth);
// apply the fixed width values
// this must be done before applying the column alignment
// because its value influences the alignment of multirow cells
- string width = widgetsToLength(widthED, widthUnitCB);
+ string width = widgetsToLength(columnWidthED, columnWidthUnitLC);
if (width.empty())
width = "0pt";
if (multicolumnCB->isChecked())
setParam(param_str, Tabular::SET_PWIDTH, width);
// apply the column alignment
- setHAlign(param_str);
+ // multirows inherit the alignment from the column; if a column width
+ // is set, multirows are always left-aligned so that in this case
+ // its alignment must not be applied (see bug #8084)
+ if (!(multirowCB->isChecked() && width != "0pt"))
+ setHAlign(param_str);
// SET_DECIMAL_POINT must come after setHAlign() (ALIGN_DECIMAL)
- string decimal_point = fromqstr(decimalPointLE->text());
+ string decimal_point = fromqstr(decimalPointED->text());
if (decimal_point.empty())
decimal_point = lyxrc.default_decimal_point;
setParam(param_str, Tabular::SET_DECIMAL_POINT, decimal_point);
case 2:
if (!topspaceED->text().isEmpty())
setParam(param_str, Tabular::SET_TOP_SPACE,
- widgetsToLength(topspaceED, topspaceUnitCB));
+ widgetsToLength(topspaceED, topspaceUnitLC));
break;
}
if (!bottomspaceED->text().isEmpty())
setParam(param_str, Tabular::SET_BOTTOM_SPACE,
widgetsToLength(bottomspaceED,
- bottomspaceUnitCB));
+ bottomspaceUnitLC));
break;
}
if (!interlinespaceED->text().isEmpty())
setParam(param_str, Tabular::SET_INTERLINE_SPACE,
widgetsToLength(interlinespaceED,
- interlinespaceUnitCB));
+ interlinespaceUnitLC));
break;
}
setParam(param_str, Tabular::UNSET_MULTICOLUMN);
// apply the multirow offset
- string mroffset = widgetsToLength(multirowOffsetED, multirowOffsetUnitCB);
+ string mroffset = widgetsToLength(multirowOffsetED, multirowOffsetUnitLC);
if (mroffset.empty())
mroffset = "0pt";
if (multirowCB->isChecked())
setParam(param_str, Tabular::SET_MULTIROW);
else
setParam(param_str, Tabular::UNSET_MULTIROW);
- //
+ // store the table rotation angle
+ string const tabular_angle = convert<string>(rotateTabularAngleSB->value());
if (rotateTabularCB->isChecked())
- setParam(param_str, Tabular::SET_ROTATE_TABULAR);
+ setParam(param_str, Tabular::SET_ROTATE_TABULAR, tabular_angle);
else
- setParam(param_str, Tabular::UNSET_ROTATE_TABULAR);
- //
+ setParam(param_str, Tabular::UNSET_ROTATE_TABULAR, tabular_angle);
+ // store the cell rotation angle
+ string const cell_angle = convert<string>(rotateCellAngleSB->value());
if (rotateCellCB->isChecked())
- setParam(param_str, Tabular::SET_ROTATE_CELL);
+ setParam(param_str, Tabular::SET_ROTATE_CELL, cell_angle);
else
- setParam(param_str, Tabular::UNSET_ROTATE_CELL);
+ setParam(param_str, Tabular::UNSET_ROTATE_CELL, cell_angle);
//
if (longTabularCB->isChecked())
setParam(param_str, Tabular::SET_LONGTABULAR);
//
if (newpageCB->isChecked())
setParam(param_str, Tabular::SET_LTNEWPAGE);
+ else
+ setParam(param_str, Tabular::UNSET_LTNEWPAGE);
//
if (captionStatusCB->isChecked())
setParam(param_str, Tabular::SET_LTCAPTION);
bool const multirow = tabular.isMultiRow(cell);
multirowCB->setChecked(multirow);
- rotateCellCB->setChecked(tabular.getRotateCell(cell));
- rotateTabularCB->setChecked(tabular.rotate);
+ rotateCellCB->setChecked(tabular.getRotateCell(cell) != 0);
+ if (rotateCellCB->isChecked()) {
+ if (tabular.getRotateCell(cell) != 0)
+ rotateCellAngleSB->setValue(tabular.getRotateCell(cell));
+ else
+ rotateCellAngleSB->setValue(90);
+ }
+
+ rotateTabularCB->setChecked(tabular.rotate != 0);
+ if (rotateTabularCB->isChecked())
+ rotateTabularAngleSB->setValue(tabular.rotate != 0 ? tabular.rotate : 90);
longTabularCB->setChecked(tabular.is_long_tabular);
// Set width and alignment
Length const tabwidth = tabular.tabularWidth();
- if (tabwidth.zero())
+ if (tabwidth.zero()
+ && !(tabularWidthED->hasFocus() && tabularWidthED->text() == "0"))
tabularWidthED->clear();
else
- lengthToWidgets(widthED, widthUnitCB,
+ lengthToWidgets(tabularWidthED, tabularWidthUnitLC,
tabwidth.asString(), default_unit);
Length pwidth;
pwidth = getColumnPWidth(tabular, cell);
}
string colwidth;
- if (pwidth.zero())
- widthED->clear();
+ if (pwidth.zero()
+ && !(columnWidthED->hasFocus() && columnWidthED->text() == "0"))
+ columnWidthED->clear();
else {
colwidth = pwidth.asString();
- lengthToWidgets(widthED, widthUnitCB,
+ lengthToWidgets(columnWidthED, columnWidthUnitLC,
colwidth, default_unit);
}
Length mroffset;
if (multirow)
mroffset = getMROffset(tabular, cell);
string offset;
- if (mroffset.zero())
+ if (mroffset.zero()
+ && !(multirowOffsetED->hasFocus() && multirowOffsetED->text() == "0"))
multirowOffsetED->clear();
else {
offset = mroffset.asString();
- lengthToWidgets(multirowOffsetED, multirowOffsetUnitCB,
+ lengthToWidgets(multirowOffsetED, multirowOffsetUnitLC,
offset, default_unit);
}
specialAlignmentED->setText(toqstr(special));
} else {
topspaceCO->setCurrentIndex(2);
lengthToWidgets(topspaceED,
- topspaceUnitCB,
+ topspaceUnitLC,
tabular.row_info[row].top_space.asString(),
default_unit);
}
} else {
bottomspaceCO->setCurrentIndex(2);
lengthToWidgets(bottomspaceED,
- bottomspaceUnitCB,
+ bottomspaceUnitLC,
tabular.row_info[row].bottom_space.asString(),
default_unit);
}
} else {
interlinespaceCO->setCurrentIndex(2);
lengthToWidgets(interlinespaceED,
- interlinespaceUnitCB,
+ interlinespaceUnitLC,
tabular.row_info[row].interline_space.asString(),
default_unit);
}
- hAlignCB->clear();
- hAlignCB->addItem(qt_("Left"), toqstr("left"));
- hAlignCB->addItem(qt_("Center"), toqstr("center"));
- hAlignCB->addItem(qt_("Right"), toqstr("right"));
+ hAlignCO->clear();
+ hAlignCO->addItem(qt_("Left"), toqstr("left"));
+ hAlignCO->addItem(qt_("Center"), toqstr("center"));
+ hAlignCO->addItem(qt_("Right"), toqstr("right"));
if (!multicol && !pwidth.zero())
- hAlignCB->addItem(qt_("Justified"), toqstr("justified"));
- if (!multicol)
- hAlignCB->addItem(qt_("At Decimal Separator"), toqstr("decimal"));
+ hAlignCO->addItem(qt_("Justified"), toqstr("justified"));
+ if (!multicol && !multirow)
+ hAlignCO->addItem(qt_("At Decimal Separator"), toqstr("decimal"));
string align;
switch (tabular.getAlignment(cell)) {
}
case LYX_ALIGN_DECIMAL:
{
- if (!multicol)
+ if (!multicol && !multirow)
align = "decimal";
break;
}
// we should never end up here
break;
}
- hAlignCB->setCurrentIndex(hAlignCB->findData(toqstr(align)));
+ hAlignCO->setCurrentIndex(hAlignCO->findData(toqstr(align)));
//
QString decimal_point = toqstr(tabular.column_info[col].decimal_point);
if (decimal_point.isEmpty())
decimal_point = toqstr(from_utf8(lyxrc.default_decimal_point));
- decimalPointLE->setText(decimal_point);
+ decimalPointED->setText(decimal_point);
int valign = 0;
switch (tabular.getVAlignment(cell)) {
}
if (pwidth.zero())
valign = 0;
- vAlignCB->setCurrentIndex(valign);
+ vAlignCO->setCurrentIndex(valign);
int tableValign = 1;
switch (tabular.tabular_valignment) {
tableValign = 0;
break;
}
- TableAlignCB->setCurrentIndex(tableValign);
+ TableAlignCO->setCurrentIndex(tableValign);
if (!tabular.is_long_tabular) {
headerStatusCB->setChecked(false);
return;
} else {
// longtables cannot have a vertical alignment
- TableAlignCB->setCurrentIndex(Tabular::LYX_VALIGN_MIDDLE);
+ TableAlignCO->setCurrentIndex(Tabular::LYX_VALIGN_MIDDLE);
}
switch (tabular.longtabular_alignment) {
case Tabular::LYX_LONGTABULAR_ALIGN_LEFT:
}
+bool GuiTabular::checkWidgets(bool readonly) const
+{
+ tabularRowED->setReadOnly(readonly);
+ tabularColumnED->setReadOnly(readonly);
+ tabularWidthED->setReadOnly(readonly);
+ specialAlignmentED->setReadOnly(readonly);
+ columnWidthED->setReadOnly(readonly);
+ multirowOffsetED->setReadOnly(readonly);
+ decimalPointED->setReadOnly(readonly);
+
+ if (readonly) {
+ multicolumnCB->setEnabled(false);
+ multirowCB->setEnabled(false);
+ rotateCellCB->setEnabled(false);
+ rotateCellAngleSB->setEnabled(false);
+ rotateTabularCB->setEnabled(false);
+ rotateTabularAngleSB->setEnabled(false);
+ longTabularCB->setEnabled(false);
+ borders->setEnabled(false);
+ tabularWidthUnitLC->setEnabled(false);
+ columnWidthUnitLC->setEnabled(false);
+ multirowOffsetUnitLC->setEnabled(false);
+ setBordersGB->setEnabled(false);
+ allBordersGB->setEnabled(false);
+ borderStyleGB->setEnabled(false);
+ booktabsRB->setEnabled(false);
+ topspaceCO->setEnabled(false);
+ topspaceUnitLC->setEnabled(false);
+ bottomspaceCO->setEnabled(false);
+ bottomspaceUnitLC->setEnabled(false);
+ interlinespaceCO->setEnabled(false);
+ interlinespaceUnitLC->setEnabled(false);
+ hAlignCO->setEnabled(false);
+ vAlignCO->setEnabled(false);
+ TableAlignCO->setEnabled(false);
+ longtableGB->setEnabled(false);
+ alignmentGB->setEnabled(false);
+ } else
+ enableWidgets();
+
+ return InsetParamsWidget::checkWidgets();
+}
+
+
bool GuiTabular::funcEnabled(Tabular::Feature f) const
{
string cmd = "tabular " + featureAsString(f);