]> git.lyx.org Git - lyx.git/blobdiff - src/insets/insetcollapsable.C
several changes and some new insets, read the Changelog
[lyx.git] / src / insets / insetcollapsable.C
index a8d0254882d488384021dc55876cf6a908c105c1..3bc130945558ae3f71fca171c33886faac1d035e 100644 (file)
 #include "lyxfont.h"
 #include "BufferView.h"
 #include "Painter.h"
+#include "support/LOstream.h"
+#include "support/lstrings.h"
 
+using std::ostream;
 
-InsetCollapsable::InsetCollapsable(Buffer * bf)
-               : InsetText(bf)
+InsetCollapsable::InsetCollapsable() : InsetText()
 {
     collapsed = true;
     label = "Label";
-    autocolapse = true;
+    autocollapse = true;
     autoBreakRows = true;
     framecolor = LColor::footnoteframe;
-    widthOffset = 10;
-    button_x = button_top_y = button_bottom_y = top_x = -1;
+    widthOffset = 2 * TEXT_TO_INSET_OFFSET + 2; // 1+1 (frame)
+    button_length = button_top_y = button_bottom_y = 0;
+    setInsetName("Collapsable");
 }
 
 
 Inset * InsetCollapsable::Clone() const
 {
-    InsetCollapsable * result = new InsetCollapsable(buffer);
-    result->init(buffer, par);
+    InsetCollapsable * result = new InsetCollapsable();
+    result->init(this);
 
     result->collapsed = collapsed;
     return result;
 }
 
+
+void InsetCollapsable::Write(Buffer const * buf, ostream & os) const
+{
+       os << "collapsed " << tostr(!display()) << "\n";
+       WriteParagraphData(buf, os);
+}
+
+
+void InsetCollapsable::Read(Buffer const * buf, LyXLex & lex)
+{
+    if (lex.IsOK()) {
+       lex.next();
+        string token = lex.GetString();
+       if (token == "collapsed") {
+           lex.next();
+           collapsed = lex.GetBool();
+       }
+    }
+    InsetText::Read(buf, lex);
+}
+
+
 int InsetCollapsable::ascent_collapsed(Painter & pain, LyXFont const &) const
 {
     int width = 0, ascent = 0, descent = 0;
@@ -92,58 +117,57 @@ int InsetCollapsable::width(Painter & pain, LyXFont const & font) const
     if (collapsed) 
        return width_collapsed(pain, font);
 
-    return getMaxWidth(pain) - widthOffset + 2;
+    return InsetText::width(pain, font) + width_collapsed(pain,font) +
+           widthOffset;
 }
 
 
-void InsetCollapsable::draw_collapsed(Painter & pain, LyXFont const &,
+void InsetCollapsable::draw_collapsed(Painter & pain, LyXFont const & font,
                                      int baseline, float & x) const
 {
     int width = 0;
-    pain.buttonText(int(x) + TEXT_TO_INSET_OFFSET, baseline,
+    pain.buttonText(int(x) + TEXT_TO_INSET_OFFSET,
+                   baseline-ascent(pain, font)+ascent_collapsed(pain, font),
                    label.c_str(), labelfont, true, width);
     x += width + (2 * TEXT_TO_INSET_OFFSET);
 }
 
 
-void InsetCollapsable::draw(Painter & pain, LyXFont const & f, 
-                           int baseline, float & x) const
+void InsetCollapsable::draw(BufferView * bv, LyXFont const & f, 
+                           int baseline, float & x, bool cleared) const
 {
+    Painter & pain = bv->painter();
+
+    button_length = width_collapsed(pain, labelfont) + 2;
+    button_top_y = -ascent_collapsed(pain, f);
+    button_bottom_y = descent_collapsed(pain, f);
+    top_x = int(x);
+    top_baseline = baseline;
     if (collapsed) {
        draw_collapsed(pain, f, baseline, x);
        return;
     }
-    top_x = int(x);
-    top_baseline = baseline;
-    draw_collapsed(pain, f, baseline, x);
-    button_x = int(x);
-    button_top_y = -ascent_collapsed(pain, f);
-    button_bottom_y = descent_collapsed(pain, f);
-    
-    maxWidth = getMaxWidth(pain) - button_x;
-    x += 2;
-    int
-       w = maxWidth - widthOffset,
-       h = ascent(pain,f) + descent(pain,f);
-    
-    pain.rectangle(int(x), baseline - ascent(pain, f), w, h, framecolor);
 
-    x += 4;
-    top_x = int(x - top_x);
-    InsetText::draw(pain, f, baseline, x);
+    draw_collapsed(pain, f, baseline, x);
+    x -= TEXT_TO_INSET_OFFSET;
+
+    int w =  InsetText::width(pain, f) + (2 * TEXT_TO_INSET_OFFSET);
+    int h = ascent(pain,f) + descent(pain, f);
+    int save_x = static_cast<int>(x);
+    x += TEXT_TO_INSET_OFFSET;
+    InsetText::draw(bv, f, baseline, x, cleared);
+    pain.rectangle(save_x, baseline - ascent(pain, f), w, h, framecolor);
 }
 
 
-void InsetCollapsable::Edit(BufferView *bv, int x, int y, unsigned int button)
+void InsetCollapsable::Edit(BufferView * bv, int x, int y, unsigned int button)
 {
-    if (collapsed) {
+    if (collapsed && autocollapse) {
        collapsed = false;
-       UpdateLocal(bv, true);
+       UpdateLocal(bv, FULL, false);
        InsetText::Edit(bv, 0, 0, button);
-    } else if (button && (x < button_x)) {
-       return;
-    } else {
-       InsetText::Edit(bv, x-top_x, y, button);
+    } else if (!collapsed) {
+       InsetText::Edit(bv, x, y, button);
     }
 }
 
@@ -155,47 +179,80 @@ Inset::EDITABLE InsetCollapsable::Editable() const
        return HIGHLY_EDITABLE;
 }
 
-void InsetCollapsable::InsetUnlock(BufferView *bv)
+
+void InsetCollapsable::InsetUnlock(BufferView * bv)
 {
-    if (autocolapse) {
+    if (autocollapse) {
        collapsed = true;
     }
     InsetText::InsetUnlock(bv);
-    UpdateLocal(bv, true);
+    UpdateLocal(bv, FULL, false);
 }
 
 
-void InsetCollapsable::UpdateLocal(BufferView * bv, bool flag)
+void InsetCollapsable::InsetButtonPress(BufferView * bv,int x,int y,int button)
 {
-    maxWidth = getMaxWidth(bv->painter()) -
-       width_collapsed(bv->painter(), labelfont);
-    InsetText::UpdateLocal(bv, flag);
+    if (!collapsed && (x >= button_length)) {
+       InsetText::InsetButtonPress(bv, x, y, button);
+    }
 }
 
 
-void InsetCollapsable::InsetButtonPress(BufferView *bv,int x,int y,int button)
+void InsetCollapsable::InsetButtonRelease(BufferView * bv,
+                                         int x, int y, int button)
 {
-    if ((x >= button_x) && (y >= button_top_y)) {
-       InsetText::InsetButtonPress(bv, x-top_x, y, button);
+    if ((x >= 0)  && (x < button_length) &&
+       (y >= button_top_y) &&  (y < button_bottom_y)) {
+       if (collapsed) {
+           collapsed = false;
+           InsetText::InsetButtonRelease(bv, 0, 0, button);
+           UpdateLocal(bv, FULL, false);
+       } else {
+           collapsed = true;
+           UpdateLocal(bv, FULL, false);
+           bv->unlockInset(this);
+       }
+    } else if (!collapsed && (x >= button_length) && (y >= button_top_y)) {
+       InsetText::InsetButtonRelease(bv, x, y, button);
     }
 }
 
 
-void InsetCollapsable::InsetButtonRelease(BufferView *bv, int x, int y, int button)
+void InsetCollapsable::InsetMotionNotify(BufferView * bv,
+                                        int x, int y, int state)
 {
-    if ((x < button_x)  && (y >= button_top_y) && (y <= button_bottom_y)) {
-       collapsed = true;
-       UpdateLocal(bv, false);
-        bv->unlockInset(this);
-    } else if ((x >= button_x) && (y >= button_top_y)) {
-       InsetText::InsetButtonRelease(bv, x-top_x, y, button);
+    if (x >= button_length) {
+       InsetText::InsetMotionNotify(bv, x, y, state);
     }
 }
 
 
-void InsetCollapsable::InsetMotionNotify(BufferView *bv, int x, int y, int button)
+int InsetCollapsable::getMaxWidth(Painter & pain,
+                                 UpdatableInset const * inset) const
 {
-    if ((x >= button_x) && (y >= button_top_y)) {
-       InsetText::InsetMotionNotify(bv, x-top_x, y, button);
-    }
+    if ((this == inset) && !owner())
+       return pain.paperWidth();
+    if (this == inset)
+        return static_cast<UpdatableInset*>(owner())->getMaxWidth(pain,inset);
+    if (owner())
+        return static_cast<UpdatableInset*>(owner())->getMaxWidth(pain,inset)-
+               width_collapsed(pain, labelfont) - widthOffset;
+
+    return pain.paperWidth()-width_collapsed(pain, labelfont) - widthOffset;
+}
+
+
+int InsetCollapsable::getMaxTextWidth(Painter & pain,
+                                     UpdatableInset const * inset) const
+{
+    return getMaxWidth(pain, inset) -
+       width_collapsed(pain, labelfont) - widthOffset;
+}
+
+
+void InsetCollapsable::update(BufferView * bv,
+                             LyXFont const & font, bool dodraw)
+{
+    drawTextXOffset = width_collapsed(bv->painter(), font);
+    InsetText::update(bv, font, dodraw);
 }