#include <config.h>
-
#include "insetcollapsable.h"
#include "insettext.h"
#include "BufferView.h"
#include "debug.h"
+#include "dimension.h"
#include "gettext.h"
#include "lyxfont.h"
#include "lyxlex.h"
#include "support/LAssert.h"
#include "support/LOstream.h"
-#include "support/lstrings.h"
using std::vector;
using std::ostream;
using std::max;
-class LyXText;
-
-
InsetCollapsable::InsetCollapsable(BufferParams const & bp, bool collapsed)
: UpdatableInset(), collapsed_(collapsed), inset(bp),
button_length(0), button_top_y(0), button_bottom_y(0),
void InsetCollapsable::write(Buffer const * buf, ostream & os) const
{
- os << "collapsed " << tostr(collapsed_) << "\n";
+ os << "collapsed " << (collapsed_ ? "true" : "false") << "\n";
inset.writeParagraphData(buf, os);
}
-
void InsetCollapsable::read(Buffer const * buf, LyXLex & lex)
{
if (lex.isOK()) {
}
-int InsetCollapsable::ascent_collapsed() const
-{
- int width = 0;
- int ascent = 0;
- int descent = 0;
- font_metrics::buttonText(label, labelfont, width, ascent, descent);
- return ascent;
-}
-
-
-int InsetCollapsable::descent_collapsed() const
-{
- int width = 0;
- int ascent = 0;
- int descent = 0;
- font_metrics::buttonText(label, labelfont, width, ascent, descent);
- return descent;
-}
-
-
-//int InsetCollapsable::width_collapsed(Painter & pain) const
-int InsetCollapsable::width_collapsed() const
-{
- int width;
- int ascent;
- int descent;
- font_metrics::buttonText(label, labelfont, width, ascent, descent);
- return width + 2 * TEXT_TO_INSET_OFFSET;
-}
-
-
-int InsetCollapsable::ascent(BufferView * /*bv*/, LyXFont const &) const
+void InsetCollapsable::dimension_collapsed(Dimension & dim) const
{
- return ascent_collapsed();
+ font_metrics::buttonText(label, labelfont, dim.w, dim.a, dim.d);
+ dim.w += 2 * TEXT_TO_INSET_OFFSET;
}
-int InsetCollapsable::descent(BufferView * bv, LyXFont const & font) const
+int InsetCollapsable::height_collapsed() const
{
- if (collapsed_)
- return descent_collapsed();
-
- return descent_collapsed()
- + inset.descent(bv, font)
- + inset.ascent(bv, font)
- + TEXT_TO_BOTTOM_OFFSET;
+ Dimension dim;
+ font_metrics::buttonText(label, labelfont, dim.w, dim.a, dim.d);
+ return dim.a + dim.d;
}
-int InsetCollapsable::width(BufferView * bv, LyXFont const & font) const
+void InsetCollapsable::dimension(BufferView * bv, LyXFont const & font,
+ Dimension & dim) const
{
+ dimension_collapsed(dim);
if (collapsed_)
- return width_collapsed();
-
- int const collapsed_width = width_collapsed();
- int const contents_width = inset.width(bv, font);
-
- return max(collapsed_width, contents_width);
+ return;
+ Dimension insetdim;
+ inset.dimension(bv, font, insetdim);
+ dim.d += insetdim.height() + TEXT_TO_BOTTOM_OFFSET;
+ dim.w = max(dim.w, insetdim.width());
}
{
pain.buttonText(int(x) + TEXT_TO_INSET_OFFSET,
baseline, label, labelfont);
- x += width_collapsed();
+ Dimension dim;
+ dimension_collapsed(dim);
+ x += dim.w;
}
if (nodraw())
return;
+ Dimension dim_collapsed;
+ dimension_collapsed(dim_collapsed);
+
Painter & pain = bv->painter();
- button_length = width_collapsed();
- button_top_y = -ascent(bv, f);
- button_bottom_y = -ascent(bv, f) + ascent_collapsed() +
- descent_collapsed();
+ button_length = dim_collapsed.width();
+ button_top_y = -ascent(bv, f);
+ button_bottom_y = -ascent(bv, f) + dim_collapsed.height();
if (!isOpen()) {
draw_collapsed(pain, baseline, x);
top_x = int(x);
top_baseline = baseline;
- int const bl = baseline - ascent(bv, f) + ascent_collapsed();
+ int const bl = baseline - ascent(bv, f) + dim_collapsed.ascent();
if (inlined) {
inset.draw(bv, f, baseline, x);
} else {
draw_collapsed(pain, bl, old_x);
- inset.draw(bv, f, bl + descent_collapsed() + inset.ascent(bv, f), x);
+ int const yy = bl + dim_collapsed.descent() + inset.ascent(bv, f);
+ inset.draw(bv, f, yy, x);
// contained inset may be shorter than the button
- if (x < (top_x + button_length + TEXT_TO_INSET_OFFSET))
+ if (x < top_x + button_length + TEXT_TO_INSET_OFFSET)
x = top_x + button_length + TEXT_TO_INSET_OFFSET;
}
}
}
-void InsetCollapsable::edit(BufferView * bv, int xp, int yp,
- mouse_button::state button)
-{
-#ifdef WITH_WARNINGS
-#warning Fix this properly in BufferView_pimpl::workAreaButtonRelease
-#endif
- if (button == mouse_button::button3)
- return;
-
- UpdatableInset::edit(bv, xp, yp, button);
-
- if (collapsed_) {
- collapsed_ = false;
- // set this only here as it should be recollapsed only if
- // it was already collapsed!
- first_after_edit = true;
- if (!bv->lockInset(this))
- return;
- bv->updateInset(this);
- bv->buffer()->markDirty();
- inset.edit(bv);
- } else {
- if (!bv->lockInset(this))
- return;
- if (yp <= button_bottom_y) {
- inset.edit(bv, xp, 0, button);
- } else {
- LyXFont font(LyXFont::ALL_SANE);
- int yy = ascent(bv, font) + yp -
- (ascent_collapsed() +
- descent_collapsed() +
- inset.ascent(bv, font));
- inset.edit(bv, xp, yy, button);
- }
- }
-}
-
-
-void InsetCollapsable::edit(BufferView * bv, bool front)
-{
- UpdatableInset::edit(bv, front);
-
- if (collapsed_) {
- collapsed_ = false;
- if (!bv->lockInset(this))
- return;
- inset.setUpdateStatus(bv, InsetText::FULL);
- bv->updateInset(this);
- bv->buffer()->markDirty();
- inset.edit(bv, front);
- first_after_edit = true;
- } else {
- if (!bv->lockInset(this))
- return;
- inset.edit(bv, front);
- }
-}
-
-
Inset::EDITABLE InsetCollapsable::editable() const
{
- if (collapsed_)
- return IS_EDITABLE;
- return HIGHLY_EDITABLE;
+ return collapsed_ ? IS_EDITABLE : HIGHLY_EDITABLE;
}
}
-void InsetCollapsable::lfunMousePress(FuncRequest const & cmd)
+FuncRequest InsetCollapsable::adjustCommand(FuncRequest const & cmd)
{
- if (!collapsed_ && (cmd.y > button_bottom_y)) {
- LyXFont font(LyXFont::ALL_SANE);
- FuncRequest cmd1 = cmd;
- cmd1.y = ascent(cmd.view(), font) + cmd.y -
- (ascent_collapsed() +
- descent_collapsed() +
- inset.ascent(cmd.view(), font));
- inset.localDispatch(cmd1);
- }
+ LyXFont font(LyXFont::ALL_SANE);
+ FuncRequest cmd1 = cmd;
+ cmd1.y = ascent(cmd.view(), font) + cmd.y -
+ (height_collapsed() + inset.ascent(cmd.view(), font));
+ return cmd1;
}
-bool InsetCollapsable::lfunMouseRelease(FuncRequest const & cmd)
+void InsetCollapsable::lfunMouseRelease(FuncRequest const & cmd)
{
bool ret = false;
BufferView * bv = cmd.view();
+
+ if (collapsed_ && cmd.button() != mouse_button::button3) {
+ collapsed_ = false;
+ inset.setUpdateStatus(bv, InsetText::FULL);
+ bv->updateInset(this);
+ bv->buffer()->markDirty();
+ return;
+ }
+
if ((cmd.button() != mouse_button::button3) && (cmd.x < button_length) &&
(cmd.y >= button_top_y) && (cmd.y <= button_bottom_y))
{
if (collapsed_) {
collapsed_ = false;
-// should not be called on inset open!
-// inset.insetButtonRelease(bv, 0, 0, button);
inset.setUpdateStatus(bv, InsetText::FULL);
bv->updateInset(this);
bv->buffer()->markDirty();
bv->buffer()->markDirty();
}
} else if (!collapsed_ && (cmd.y > button_bottom_y)) {
- LyXFont font(LyXFont::ALL_SANE);
- FuncRequest cmd1 = cmd;
- cmd1.y = ascent(cmd.view(), font) + cmd.y -
- (ascent_collapsed() +
- descent_collapsed() +
- inset.ascent(cmd.view(), font));
- ret = (inset.localDispatch(cmd1) == DISPATCHED);
+ ret = (inset.localDispatch(adjustCommand(cmd)) == DISPATCHED);
}
if (cmd.button() == mouse_button::button3 && !ret)
- return showInsetDialog(bv);
- return ret;
-}
-
-
-void InsetCollapsable::lfunMouseMotion(FuncRequest const & cmd)
-{
- if (cmd.y > button_bottom_y) {
- LyXFont font(LyXFont::ALL_SANE);
- FuncRequest cmd1 = cmd;
- cmd1.y = ascent(cmd.view(), font) + cmd.y -
- (ascent_collapsed() +
- descent_collapsed() +
- inset.ascent(cmd.view(), font));
- inset.localDispatch(cmd1);
- }
+ showInsetDialog(bv);
}
int InsetCollapsable::latex(Buffer const * buf, ostream & os,
- bool fragile, bool free_spc) const
+ LatexRunParams const & runparams) const
{
- return inset.latex(buf, os, fragile, free_spc);
+ return inset.latex(buf, os, runparams);
}
Inset::RESULT InsetCollapsable::localDispatch(FuncRequest const & cmd)
{
+ //lyxerr << "InsetCollapsable::localDispatch: " << cmd.action << "\n";
+ BufferView * bv = cmd.view();
switch (cmd.action) {
+ case LFUN_INSET_EDIT: {
+ if (!cmd.argument.empty()) {
+ UpdatableInset::localDispatch(cmd);
+ if (collapsed_) {
+ collapsed_ = false;
+ if (bv->lockInset(this)) {
+ inset.setUpdateStatus(bv, InsetText::FULL);
+ bv->updateInset(this);
+ bv->buffer()->markDirty();
+ inset.localDispatch(cmd);
+ first_after_edit = true;
+ }
+ } else {
+ if (bv->lockInset(this))
+ inset.localDispatch(cmd);
+ }
+ return DISPATCHED;
+ }
+
+#ifdef WITH_WARNINGS
+#warning Fix this properly in BufferView_pimpl::workAreaButtonRelease
+#endif
+ if (cmd.button() == mouse_button::button3)
+ return DISPATCHED;
+
+ UpdatableInset::localDispatch(cmd);
+
+ if (collapsed_) {
+ collapsed_ = false;
+ // set this only here as it should be recollapsed only if
+ // it was already collapsed!
+ first_after_edit = true;
+ if (!bv->lockInset(this))
+ return DISPATCHED;
+ bv->updateInset(this);
+ bv->buffer()->markDirty();
+ inset.localDispatch(cmd);
+ } else {
+ FuncRequest cmd1 = cmd;
+ if (!bv->lockInset(this))
+ return DISPATCHED;
+ if (cmd.y <= button_bottom_y) {
+ cmd1.y = 0;
+ } else {
+ LyXFont font(LyXFont::ALL_SANE);
+ cmd1.y = ascent(bv, font) + cmd.y -
+ (height_collapsed() + inset.ascent(bv, font));
+ }
+ inset.localDispatch(cmd);
+ }
+ return DISPATCHED;
+ }
case LFUN_MOUSE_PRESS:
- lfunMousePress(cmd);
+ if (!collapsed_ && cmd.y > button_bottom_y)
+ inset.localDispatch(adjustCommand(cmd));
return DISPATCHED;
case LFUN_MOUSE_MOTION:
- lfunMouseMotion(cmd);
+ if (!collapsed_ && cmd.y > button_bottom_y)
+ inset.localDispatch(adjustCommand(cmd));
return DISPATCHED;
case LFUN_MOUSE_RELEASE:
default:
UpdatableInset::RESULT result = inset.localDispatch(cmd);
if (result >= FINISHED)
- cmd.view()->unlockInset(this);
+ bv->unlockInset(this);
first_after_edit = false;
return result;
}
- return UNDISPATCHED;
}
}
-Paragraph * InsetCollapsable::firstParagraph() const
-{
- return inset.firstParagraph();
-}
-
-
-Paragraph * InsetCollapsable::getFirstParagraph(int i) const
+ParagraphList * InsetCollapsable::getParagraphs(int i) const
{
- return inset.getFirstParagraph(i);
+ return inset.getParagraphs(i);
}