From: John Levon Date: Sun, 26 Aug 2001 17:49:42 +0000 (+0000) Subject: character dialog with auto-apply ... X-Git-Tag: 1.6.10~20755 X-Git-Url: https://git.lyx.org/gitweb/?a=commitdiff_plain;h=3c7fe2f40779681c11a28ea639d069114f28de7a;p=features.git character dialog with auto-apply ... git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@2590 a592a061-630c-0410-9148-cb99ea01b6c8 --- diff --git a/src/frontends/qt2/ChangeLog b/src/frontends/qt2/ChangeLog index 762a22e1f0..c54870554e 100644 --- a/src/frontends/qt2/ChangeLog +++ b/src/frontends/qt2/ChangeLog @@ -1,3 +1,11 @@ +2001-08-26 John Levon + + * Dialogs.C: + * QCharacter.[Ch]: + * QCharacterDialog.[Ch]: + * ui/QcharacterDialog.ui: make work again, + add auto-apply feature + 2001-08-26 John Levon * Dialogs.C: diff --git a/src/frontends/qt2/Dialogs.C b/src/frontends/qt2/Dialogs.C index ec8556dc43..8534d880fc 100644 --- a/src/frontends/qt2/Dialogs.C +++ b/src/frontends/qt2/Dialogs.C @@ -15,6 +15,7 @@ #include "QAboutDialog.h" #include "QBibitemDialog.h" #include "QBibtexDialog.h" +#include "QCharacterDialog.h" #include "QCitationDialog.h" #include "QIndexDialog.h" #include "QRefDialog.h" @@ -44,6 +45,7 @@ #include "controllers/ControlAboutlyx.h" #include "controllers/ControlBibitem.h" #include "controllers/ControlBibtex.h" +#include "controllers/ControlCharacter.h" #include "controllers/ControlCitation.h" #include "controllers/ControlIndex.h" #include "controllers/ControlRef.h" @@ -51,7 +53,6 @@ #include "controllers/ControlUrl.h" #if 0 #include "controllers/ControlButtons.h" -#include "controllers/ControlCharacter.h" #include "controllers/ControlCitation.h" #include "controllers/ControlERT.h" #include "controllers/ControlError.h" @@ -88,6 +89,7 @@ Dialogs::Dialogs(LyXView * lv) add(new GUIAboutlyx(*lv, *this)); add(new GUIBibitem(*lv, *this)); add(new GUIBibtex(*lv, *this)); + add(new GUICharacter(*lv, *this)); add(new GUIIndex(*lv, *this)); add(new GUIRef(*lv, *this)); add(new GUIUrl(*lv, *this)); diff --git a/src/frontends/qt2/QCharacter.C b/src/frontends/qt2/QCharacter.C index 07f38fb81a..5563535ef1 100644 --- a/src/frontends/qt2/QCharacter.C +++ b/src/frontends/qt2/QCharacter.C @@ -1,104 +1,141 @@ /** * \file QCharacter.C - * Copyright 2001 The LyX Team. - * See the file COPYING. + * Copyright 2001 the LyX Team + * Read the file COPYING * * \author Edwin Leuven, leuven@fee.uva.nl + * \author John Levon */ #include #include "gettext.h" -#include "QCharacterDialog.h" -#include "QCharacter.h" -#include "bufferview_funcs.h" -#include "Dialogs.h" -#include "Liason.h" -#include "QtLyXView.h" -#include "buffer.h" -#include "lyxtext.h" -#include "language.h" #include "support/lstrings.h" -#include "BufferView.h" -using SigC::slot; -using Liason::setMinibuffer; +#include "ControlCharacter.h" +#include "QCharacterDialog.h" +#include "QCharacter.h" +#include "Qt2BC.h" +#include +#include +#include -QCharacter::QCharacter(LyXView *v, Dialogs *d) - : dialog_(0), lv_(v), d_(d), h_(0), u_(0) +using namespace character; +using std::vector; + +typedef Qt2CB > base_class; + +QCharacter::QCharacter(ControlCharacter & c) + : base_class(c, _("Character")) { - d->showCharacter.connect(slot(this, &QCharacter::show)); - // for LFUN_FREE - d->setUserFreeFont.connect(slot(this, &QCharacter::apply)); } -QCharacter::~QCharacter() +void QCharacter::build_dialog() { - delete dialog_; + dialog_.reset(new QCharacterDialog(this)); + + family = getFamilyData(); + series = getSeriesData(); + shape = getShapeData(); + size = getSizeData(); + bar = getBarData(); + color = getColorData(); + language = getLanguageData(); + + for (vector::const_iterator cit = family.begin(); + cit != family.end(); ++cit) { + dialog_->familyCO->insertItem(cit->first.c_str(), -1); + } + for (vector::const_iterator cit = series.begin(); + cit != series.end(); ++cit) { + dialog_->seriesCO->insertItem(cit->first.c_str(), -1); + } + for (vector::const_iterator cit = shape.begin(); + cit != shape.end(); ++cit) { + dialog_->shapeCO->insertItem(cit->first.c_str(), -1); + } + for (vector::const_iterator cit = size.begin(); + cit != size.end(); ++cit) { + dialog_->sizeCO->insertItem(cit->first.c_str(), -1); + } + for (vector::const_iterator cit = bar.begin(); + cit != bar.end(); ++cit) { + dialog_->miscCO->insertItem(cit->first.c_str(), -1); + } + for (vector::const_iterator cit = color.begin(); + cit != color.end(); ++cit) { + dialog_->colorCO->insertItem(cit->first.c_str(), -1); + } + for (vector::const_iterator cit = language.begin(); + cit != language.end(); ++cit) { + dialog_->langCO->insertItem(cit->c_str(), -1); + } + + bc().setOK(dialog_->okPB); + bc().setApply(dialog_->applyPB); + bc().setCancel(dialog_->closePB); + bc().addReadOnly(dialog_->familyCO); + bc().addReadOnly(dialog_->seriesCO); + bc().addReadOnly(dialog_->sizeCO); + bc().addReadOnly(dialog_->shapeCO); + bc().addReadOnly(dialog_->miscCO); + bc().addReadOnly(dialog_->langCO); + bc().addReadOnly(dialog_->colorCO); + bc().addReadOnly(dialog_->toggleallCB); + bc().addReadOnly(dialog_->autoapplyCB); } -void QCharacter::apply() +namespace { + +template +int findPos2nd(vector > const & vec, B const & val) { - if (!lv_->view()->available() || !dialog_) - return; - - LyXFont font = dialog_->getChar(); - - if (dialog_->langItem()==1) - font.setLanguage(lv_->buffer()->params.language); - - toggleAndShow(lv_->view(), font, dialog_->toggleAll()); - lv_->view()->setState(); - lv_->buffer()->markDirty(); - setMinibuffer(lv_, _("Character set")); + vector >::const_iterator cit = vec.begin(); + for (; cit != vec.end(); ++cit) { + if (cit->second == val) + return int(cit - vec.begin()); + } + return 0; } - -void QCharacter::show() +} // namespace anon + + +void QCharacter::update_contents() { - if (!dialog_) { - dialog_ = new QCharacterDialog(this, 0, _("Character Settings"), false); + dialog_->familyCO->setCurrentItem(findPos2nd(family, controller().getFamily())); + dialog_->seriesCO->setCurrentItem(findPos2nd(series, controller().getSeries())); + dialog_->shapeCO->setCurrentItem(findPos2nd(shape, controller().getShape())); + dialog_->sizeCO->setCurrentItem(findPos2nd(size, controller().getSize())); + dialog_->miscCO->setCurrentItem(findPos2nd(bar, controller().getBar())); + dialog_->colorCO->setCurrentItem(findPos2nd(color, controller().getColor())); + + dialog_->toggleallCB->setChecked(controller().getToggleAll()); - // add languages - for (Languages::const_iterator cit = languages.begin(); - cit != languages.end(); ++cit) { - string const language = cit->second.lang(); - dialog_->lang->insertItem(tostr(language).c_str(), -1); + string const thelanguage(controller().getLanguage()); + int i = 0; + for (vector::const_iterator cit = language.begin(); + cit != language.end(); ++i, ++cit) { + if (*cit == thelanguage) { + dialog_->langCO->setCurrentItem(i); + break; } } - - if (!dialog_->isVisible()) { - h_ = d_->hideBufferDependent.connect(slot(this, &QCharacter::hide)); - u_ = d_->updateBufferDependent.connect(slot(this, &QCharacter::update)); - } - - dialog_->raise(); - dialog_->setActiveWindow(); - update(); - dialog_->show(); } -void QCharacter::close() -{ - h_.disconnect(); - u_.disconnect(); -} - - -void QCharacter::hide() -{ - dialog_->hide(); - close(); -} - - -void QCharacter::update(bool) +void QCharacter::apply() { - if (!lv_->view()->available()) - return; - - dialog_->setReadOnly(lv_->buffer()->isReadonly()); + controller().setFamily(family[dialog_->familyCO->currentItem()].second); + controller().setSeries(series[dialog_->seriesCO->currentItem()].second); + controller().setShape(shape[dialog_->shapeCO->currentItem()].second); + controller().setSize(size[dialog_->sizeCO->currentItem()].second); + controller().setBar(bar[dialog_->miscCO->currentItem()].second); + controller().setColor(color[dialog_->colorCO->currentItem()].second); + + controller().setLanguage(dialog_->langCO->currentText().latin1()); + + controller().setToggleAll(dialog_->toggleallCB->isChecked()); } diff --git a/src/frontends/qt2/QCharacter.h b/src/frontends/qt2/QCharacter.h index 7bee61c4a9..ec23cc4f28 100644 --- a/src/frontends/qt2/QCharacter.h +++ b/src/frontends/qt2/QCharacter.h @@ -1,61 +1,50 @@ // -*- C++ -*- /** * \file QCharacter.h - * Copyright 2001 The LyX Team. - * See the file COPYING. + * Copyright 2001 the LyX Team + * Read the file COPYING * - * \author Edwin Leuven + * \author Edwin Leuven, leuven@fee.uva.nl + * \author John Levon */ #ifndef QCHARACTER_H #define QCHARACTER_H -#include "DialogBase.h" +#include +#include + +#include "LString.h" +#include "Qt2Base.h" +#include "controllers/character.h" + -class LyXView; -class Dialogs; +class ControlCharacter; class QCharacterDialog; -class QCharacter : public DialogBase { -public: - /// - QCharacter(LyXView *, Dialogs *); - /// - ~QCharacter(); - - /// Apply changes. - void apply(); - /// Close connections. - void close(); - -private: - - /// Show the dialog. - void show(); - /// Hide the dialog. - void hide(); - /// Update the dialog. - void update(bool switched = false); - - /// Real GUI implementation. - QCharacterDialog * dialog_; - - /// the LyXView we belong to. - LyXView * lv_; - - /** Which Dialogs do we belong to? - * Used so we can get at the signals we have to connect to. - */ - Dialogs * d_; - - /// is the buffer readonly? - bool readonly; - - /// Hide connection. - SigC::Connection h_; - - /// Update connection. - SigC::Connection u_; +class QCharacter : + public Qt2CB > +{ + friend class QCharacterDialog; + +public: + QCharacter(ControlCharacter &); + +private: + /// Apply changes + virtual void apply(); + /// update + virtual void update_contents(); + /// build the dialog + virtual void build_dialog(); + + std::vector family; + std::vector series; + std::vector shape; + std::vector size; + std::vector bar; + std::vector color; + std::vector language; }; #endif // QCHARACTER_H diff --git a/src/frontends/qt2/QCharacterDialog.C b/src/frontends/qt2/QCharacterDialog.C index e76d3e4fc1..254c48d3d7 100644 --- a/src/frontends/qt2/QCharacterDialog.C +++ b/src/frontends/qt2/QCharacterDialog.C @@ -7,125 +7,49 @@ */ #include "QCharacterDialog.h" -#include "lyxtext.h" -#include "language.h" #include #include #include #include -QCharacterDialog::QCharacterDialog(QCharacter * form, QWidget * parent, const char * name, bool modal, WFlags fl) - : QCharacterDialogBase(parent, name, modal, fl), form_(form) +QCharacterDialog::QCharacterDialog(QCharacter * form) + : QCharacterDialogBase(0, 0, false, 0), + form_(form) { - setCaption(name); + connect(okPB, SIGNAL(clicked()), + form_, SLOT(slotOK())); + connect(applyPB, SIGNAL(clicked()), + form_, SLOT(slotApply())); + connect(closePB, SIGNAL(clicked()), + form_, SLOT(slotClose())); } -QCharacterDialog::~QCharacterDialog() +void QCharacterDialog::change_adaptor() { -} + form_->changed(); - -LyXFont QCharacterDialog::getChar() -{ - LyXFont font(LyXFont::ALL_IGNORE); - - switch (family->currentItem()) { - case 0: font.setFamily(LyXFont::IGNORE_FAMILY); break; - case 1: font.setFamily(LyXFont::INHERIT_FAMILY); break; - case 2: font.setFamily(LyXFont::ROMAN_FAMILY); break; - case 3: font.setFamily(LyXFont::SANS_FAMILY); break; - case 4: font.setFamily(LyXFont::TYPEWRITER_FAMILY); break; - } - - switch (series->currentItem()) { - case 0: font.setSeries(LyXFont::IGNORE_SERIES); break; - case 1: font.setSeries(LyXFont::INHERIT_SERIES); break; - case 2: font.setSeries(LyXFont::MEDIUM_SERIES); break; - case 3: font.setSeries(LyXFont::BOLD_SERIES); break; - } - - switch (shape->currentItem()) { - case 0: font.setShape(LyXFont::IGNORE_SHAPE); break; - case 1: font.setShape(LyXFont::INHERIT_SHAPE); break; - case 2: font.setShape(LyXFont::UP_SHAPE); break; - case 3: font.setShape(LyXFont::ITALIC_SHAPE); break; - case 4: font.setShape(LyXFont::SLANTED_SHAPE); break; - case 5: font.setShape(LyXFont::SMALLCAPS_SHAPE); break; - } - - switch (size->currentItem()) { - case 0: font.setSize(LyXFont::IGNORE_SIZE); break; - case 1: font.setSize(LyXFont::INHERIT_SIZE); break; - case 2: font.setSize(LyXFont::SIZE_TINY); break; - case 3: font.setSize(LyXFont::SIZE_SCRIPT); break; - case 4: font.setSize(LyXFont::SIZE_FOOTNOTE); break; - case 5: font.setSize(LyXFont::SIZE_SMALL); break; - case 6: font.setSize(LyXFont::SIZE_NORMAL); break; - case 7: font.setSize(LyXFont::SIZE_LARGE); break; - case 8: font.setSize(LyXFont::SIZE_LARGER); break; - case 9: font.setSize(LyXFont::SIZE_LARGEST); break; - case 10: font.setSize(LyXFont::SIZE_HUGE); break; - case 11: font.setSize(LyXFont::SIZE_HUGER); break; - case 12: font.setSize(LyXFont::INCREASE_SIZE); break; - case 13: font.setSize(LyXFont::DECREASE_SIZE); break; - } - - switch (misc->currentItem()) { - case 0: font.setEmph(LyXFont::IGNORE); - font.setUnderbar(LyXFont::IGNORE); - font.setNoun(LyXFont::IGNORE); - // FIXME font.setLatex(LyXFont::IGNORE); - break; - case 1: font.setEmph(LyXFont::INHERIT); - font.setUnderbar(LyXFont::INHERIT); - font.setNoun(LyXFont::INHERIT); - // FIXME font.setLatex(LyXFont::INHERIT); - break; - case 2: font.setEmph(LyXFont::TOGGLE); break; - case 3: font.setUnderbar(LyXFont::TOGGLE); break; - case 4: font.setNoun(LyXFont::TOGGLE); break; - case 5: break; // FIXMEfont.setLatex(LyXFont::TOGGLE); break; - } - - switch (color->currentItem()) { - case 0: font.setColor(LColor::ignore); break; - case 1: font.setColor(LColor::inherit); break; - case 2: font.setColor(LColor::none); break; - case 3: font.setColor(LColor::black); break; - case 4: font.setColor(LColor::white); break; - case 5: font.setColor(LColor::red); break; - case 6: font.setColor(LColor::green); break; - case 7: font.setColor(LColor::blue); break; - case 8: font.setColor(LColor::cyan); break; - case 9: font.setColor(LColor::magenta); break; - case 10: font.setColor(LColor::yellow); break; - } - - int const pos = lang->currentItem(); - if (pos == 0) { - font.setLanguage(ignore_language); - } else if (pos != 1) { - font.setLanguage(languages.getLanguage(lang->currentText().latin1())); - }; - - return font; + if (!autoapplyCB->isChecked()) + return; + + // to be really good here, we should set the combos to the values of + // the current text, and make it appear as "no change" if the values + // stay the same between applys. Might be difficult though wrt to a + // moved cursor - jbl + form_->slotApply(); + familyCO->setCurrentItem(0); + seriesCO->setCurrentItem(0); + sizeCO->setCurrentItem(0); + shapeCO->setCurrentItem(0); + miscCO->setCurrentItem(0); + langCO->setCurrentItem(0); + colorCO->setCurrentItem(0); } void QCharacterDialog::closeEvent(QCloseEvent * e) { - form_->close(); + form_->slotWMHide(); e->accept(); } - - -void QCharacterDialog::setReadOnly(bool readonly) -{ - sizeGB->setEnabled(!readonly); - charGB->setEnabled(!readonly); - miscGB->setEnabled(!readonly); - okPB->setEnabled(!readonly); - applyPB->setEnabled(!readonly); -} diff --git a/src/frontends/qt2/QCharacterDialog.h b/src/frontends/qt2/QCharacterDialog.h index 235f2f2c26..9b755430e8 100644 --- a/src/frontends/qt2/QCharacterDialog.h +++ b/src/frontends/qt2/QCharacterDialog.h @@ -4,6 +4,7 @@ * see the file COPYING * * \author Edwin Leuven + * \author John Levon */ #ifndef QCHARACTERDIALOG_H @@ -24,24 +25,7 @@ class QCharacterDialog : public QCharacterDialogBase { Q_OBJECT public: - QCharacterDialog(QCharacter * form, QWidget * parent = 0, const char * name = 0, bool modal = FALSE, WFlags fl = 0); - ~QCharacterDialog(); - - /// FIXME - LyXFont getChar(); - - /// return the currently selected language item - int langItem() { - return lang->currentItem(); - }; - - /// return true if toggle all is selected - bool toggleAll() { - return toggleall->isChecked(); - }; - - /// set dialog read only - void setReadOnly(bool); + QCharacterDialog(QCharacter * form); protected: void closeEvent(QCloseEvent * e); @@ -50,22 +34,7 @@ private: QCharacter * form_; protected slots: - - void apply_adaptor() { - form_->apply(); - } - - void cancel_adaptor() { - form_->close(); - hide(); - } - - void close_adaptor() { - form_->apply(); - form_->close(); - hide(); - } - + void change_adaptor(); }; #endif // QCHARACTERDIALOG_H diff --git a/src/frontends/qt2/ui/QCharacterDialog.ui b/src/frontends/qt2/ui/QCharacterDialog.ui index ab6c127193..a555aece52 100644 --- a/src/frontends/qt2/ui/QCharacterDialog.ui +++ b/src/frontends/qt2/ui/QCharacterDialog.ui @@ -11,8 +11,8 @@ 0 0 - 412 - 291 + 372 + 256 @@ -29,7 +29,7 @@ layoutSpacing - + margin 11 @@ -38,561 +38,410 @@ spacing 6 - - QGroupBox + + QLayoutWidget name - sizeGB - - - title - Never toggled - - - layoutMargin + Layout6 margin - 11 + 0 spacing 6 - QLabel + QGroupBox name - sizeL + charGB - text - Size: + title + Character - - - QComboBox - - - text - No Change - - - - - text - Reset - - - - - text - Tiny - - - - - text - Smallest - - - - - text - Smaller - - - - - text - Small - - - - - text - Normal - - - - - text - Large - - - - - text - Larger - - - - - text - Largest - - - - - text - Huge - - - - - text - Huger - - - - - text - Increase - - - - - text - Decrease - - - name - size - - - - - - QGroupBox - - name - miscGB - - - title - Always toggled - - - layoutMargin - - - - margin - 11 - - - spacing - 6 - - - QLabel - - name - always_toggledL - - - text - Misc: + sizePolicy + + 5 + 5 + + + layoutMargin + + + + margin + 11 + + + spacing + 6 + + + QLabel + + name + familyLA + + + text + &Family: + + + buddy + familyCO + + + toolTip + Font family + + + + QComboBox + + name + familyCO + + + toolTip + Font family + + + + QLabel + + name + seriesLA + + + text + &Series: + + + buddy + seriesCO + + + toolTip + Font series + + + + QLabel + + name + langLA + + + text + &Language: + + + buddy + langCO + + + toolTip + Language + + + + QComboBox + + name + shapeCO + + + toolTip + Font shape + + + + QComboBox + + name + colorCO + + + toolTip + Font color + + + + QLabel + + name + shapeLA + + + text + S&hape: + + + buddy + shapeCO + + + toolTip + Font shape + + + + QComboBox + + name + seriesCO + + + toolTip + Font series + + + + QLabel + + name + colorLA + + + enabled + true + + + text + &Color: + + + buddy + colorCO + + + toolTip + Font color + + + + QComboBox + + name + langCO + + + toolTip + Language + + + + QCheckBox + + name + toggleallCB + + + text + &Toggle all + + + toolTip + toggle font on all of the above + + + + + name + Spacer2 + + + orientation + Vertical + + + sizeType + Expanding + + + sizeHint + + 20 + 20 + + + + - QComboBox - - - text - No Change - - - - - text - Reset - - - - - text - Emph - - - - - text - Underbar - - - - - text - Noun - - - - - text - LaTeX Mode - - + QLayoutWidget name - misc - + Layout5 + + + + margin + 0 + + + spacing + 6 + + + QGroupBox + + name + sizeGB + + + title + Never toggled + + + layoutMargin + + + + margin + 11 + + + spacing + 6 + + + QLabel + + name + sizeLA + + + text + Si&ze: + + + buddy + sizeCO + + + toolTip + Font size + + + + QComboBox + + name + sizeCO + + + toolTip + Font size + + + + + + QGroupBox + + name + miscGB + + + title + Always toggled + + + layoutMargin + + + toolTip + Other font settings + + + + margin + 11 + + + spacing + 6 + + + QLabel + + name + miscLA + + + text + &Misc: + + + buddy + miscCO + + + + QComboBox + + name + miscCO + + + toolTip + Other font settings + + + + + + QCheckBox + + name + autoapplyCB + + + text + Auto apply + + + toolTip + Apply each change automatically + + + + + name + Spacer3 + + + orientation + Vertical + + + sizeType + Expanding + + + sizeHint + + 20 + 20 + + + + - - QGroupBox - - name - charGB - - - title - Character - - - sizePolicy - - 5 - 5 - - - - layoutMargin - - - - margin - 11 - - - spacing - 6 - - - QLabel - - name - familyL - - - text - Family: - - - - QComboBox - - - text - No Change - - - - - text - Reset - - - - - text - Roman - - - - - text - Sans Serif - - - - - text - Typewriter - - - - name - family - - - - QLabel - - name - seriesL - - - text - Series: - - - - QLabel - - name - langL - - - text - Language: - - - - QComboBox - - - text - No Change - - - - - text - Reset - - - - - text - Upright - - - - - text - Italic - - - - - text - Slanted - - - - - text - Small Caps - - - - name - shape - - - - QComboBox - - - text - No Change - - - - - text - Reset - - - - - text - No Color - - - - - text - Black - - - - - text - White - - - - - text - Red - - - - - text - Green - - - - - text - Blue - - - - - text - Cyan - - - - - text - Yellow - - - - - text - Magenta - - - - name - color - - - - QLabel - - name - shapeL - - - text - Shape: - - - - QComboBox - - - text - No Change - - - - - text - Reset - - - - - text - Medium - - - - - text - Bold - - - - name - series - - - - QLabel - - name - colorL - - - enabled - true - - - text - Color: - - - - QComboBox - - - text - No Change - - - - - text - Reset - - - - name - lang - - - - QCheckBox - - name - toggleall - - - text - Toggle all - - - - - name - Spacer2 - - - orientation - Vertical - - - sizeType - Expanding - - - sizeHint - - 20 - 20 - - - - - - - - name - Spacer3 - - - orientation - Vertical - - - sizeType - Expanding - - - sizeHint - - 20 - 20 - - - - + QLayoutWidget name - Layout9 + Layout2 @@ -628,33 +477,33 @@ QPushButton name - applyPB + okPB text - &Apply + &OK QPushButton name - okPB + applyPB text - &OK + &Apply QPushButton name - cancelPB + closePB text - &Cancel + &Close default @@ -663,42 +512,70 @@ - + - cancelPB - clicked() + miscCO + activated(int) + QCharacterDialogBase + change_adaptor() + + + sizeCO + activated(int) + QCharacterDialogBase + change_adaptor() + + + familyCO + activated(int) + QCharacterDialogBase + change_adaptor() + + + seriesCO + activated(int) + QCharacterDialogBase + change_adaptor() + + + shapeCO + activated(int) + QCharacterDialogBase + change_adaptor() + + + colorCO + activated(int) QCharacterDialogBase - cancel_adaptor() + change_adaptor() - okPB - clicked() + langCO + activated(int) QCharacterDialogBase - close_adaptor() + change_adaptor() - applyPB - clicked() + toggleallCB + toggled(bool) QCharacterDialogBase - apply_adaptor() + change_adaptor() - apply_adaptor() - cancel_adaptor() - close_adaptor() + change_adaptor() - family - series - shape - color - lang - toggleall - size - misc + familyCO + seriesCO + shapeCO + colorCO + langCO + toggleallCB + sizeCO + miscCO applyPB okPB - cancelPB + closePB