X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsetcollapsable.h;h=4a4f2fec1975ec54032431f4d9d3c762db02ff0d;hb=e28331ed63062dea10d0a21b9ec12034b4b17b9a;hp=67c0beb12858bf80b173a908b865c7ccc9ae8870;hpb=ccce6b9662e3a753d8864b1832d766a8f4ceef02;p=lyx.git diff --git a/src/insets/insetcollapsable.h b/src/insets/insetcollapsable.h index 67c0beb128..4a4f2fec19 100644 --- a/src/insets/insetcollapsable.h +++ b/src/insets/insetcollapsable.h @@ -8,7 +8,7 @@ * \author Jürgen Vigna * \author Lars Gullik Bjønnes * - * Full author contact details are available in file CREDITS + * Full author contact details are available in file CREDITS. */ #ifndef INSETCOLLAPSABLE_H @@ -16,215 +16,120 @@ #include "inset.h" #include "insettext.h" + +#include "box.h" #include "lyxfont.h" -#include "funcrequest.h" // for adjustCommand -#include "LColor.h" -#include +#include + +namespace lyx { -class Painter; class LyXText; class Paragraph; -class LyXCursor; +class CursorSlice; + +namespace frontend { class Painter; } /** A collapsable text inset */ -class InsetCollapsable : public UpdatableInset { +class InsetCollapsable : public InsetText { public: /// static int const TEXT_TO_TOP_OFFSET = 2; /// static int const TEXT_TO_BOTTOM_OFFSET = 2; - /// inset is initially collapsed if bool = true - InsetCollapsable(BufferParams const &, bool = false); - /// - InsetCollapsable(InsetCollapsable const & in, bool same_id = false); - /// - void read(Buffer const *, LyXLex &); - /// - void write(Buffer const *, std::ostream &) const; - /// - void dimension(BufferView *, LyXFont const &, Dimension &) const; - /// - void draw(BufferView *, const LyXFont &, int, float &) const; - /// draw, either inlined (no button) or collapsed/open - void draw(BufferView * bv, LyXFont const & f, - int baseline, float & x, bool inlined) const; - /// - void update(BufferView *, bool = false); - /// - EDITABLE editable() const; - /// - bool insertInset(BufferView *, Inset * inset); - /// - virtual bool insetAllowed(Inset::Code code) const { - return inset.insetAllowed(code); - } - /// - bool isTextInset() const { return true; } - /// - void insetUnlock(BufferView *); /// - bool needFullRow() const { return isOpen(); } + InsetCollapsable(BufferParams const &, CollapseStatus status = Open); /// - bool lockInsetInInset(BufferView *, UpdatableInset *); + InsetCollapsable(InsetCollapsable const & rhs); /// - bool unlockInsetInInset(BufferView *, UpdatableInset *, - bool lr = false); + void read(Buffer const &, LyXLex &); /// - bool updateInsetInInset(BufferView *, Inset *); - /// - int insetInInsetY() const; - /// - RESULT localDispatch(FuncRequest const &); - /// - int latex(Buffer const *, std::ostream &, LatexRunParams const &, - bool fragile, bool free_spc) const; - /// - int ascii(Buffer const *, std::ostream &, int) const; - /// - int linuxdoc(Buffer const *, std::ostream &) const; - /// - int docbook(Buffer const *, std::ostream &, bool mixcont) const; - /// - void validate(LaTeXFeatures & features) const; - /// FIXME, document - void getCursorPos(BufferView *, int & x, int & y) const; - /// Get the absolute document x,y of the cursor - virtual void getCursor(BufferView &, int &, int &) const; - /// - void fitInsetCursor(BufferView * bv) const { - inset.fitInsetCursor(bv); - } - UpdatableInset * getLockingInset() const; - /// - UpdatableInset * getFirstLockingInsetOfType(Inset::Code); - /// - void setFont(BufferView *, LyXFont const &, bool toggleall = false, - bool selectall = false); - /// - void setLabel(string const & l) const; - /// - void setLabelFont(LyXFont & f) { labelfont = f; } -#if 0 - /// - void setAutoCollapse(bool f) { autocollapse = f; } -#endif + void write(Buffer const &, std::ostream &) const; /// - LyXText * getLyXText(BufferView const *, bool const recursive) const; + bool metrics(MetricsInfo &, Dimension &) const; /// - void deleteLyXText(BufferView *, bool recursive=true) const; + void draw(PainterInfo & pi, int x, int y) const; /// - void resizeLyXText(BufferView *, bool force = false) const; + void drawSelection(PainterInfo & pi, int x, int y) const; + /// return x,y of given position relative to the inset's baseline + void cursorPos(BufferView const & bv, CursorSlice const & sl, + bool boundary, int & x, int & y) const; /// - std::vector const getLabelList() const; + bool hitButton(FuncRequest const &) const; /// - bool nodraw() const; + docstring const getNewLabel(docstring const & l) const; /// - int scroll(bool recursive=true) const; - /// - void scroll(BufferView *bv, float sx) const { - UpdatableInset::scroll(bv, sx); - } - /// - void scroll(BufferView *bv, int offset) const { - UpdatableInset::scroll(bv, offset); - } - /// - Inset * getInsetFromID(int id) const; - /// - ParagraphList * getParagraphs(int) const; + EDITABLE editable() const; + /// can we go further down on mouse click? + bool descendable() const; /// - LyXCursor const & cursor(BufferView *) const; + void setLabel(docstring const & l); /// - bool isOpen() const { return !collapsed_; } + virtual void setButtonLabel() {} /// - void open(BufferView *); + void setLabelFont(LyXFont & f); /// - void close(BufferView *) const; + bool isOpen() const { return status_ == Open || status_ == Inlined; } /// - bool allowSpellcheck() const { return inset.allowSpellcheck(); } + bool inlined() const { return status_ == Inlined; } /// - WordLangTuple const - selectNextWordToSpellcheck(BufferView *, float &) const; + CollapseStatus status() const; /// - void selectSelectedWord(BufferView * bv) { - inset.selectSelectedWord(bv); - } + bool allowSpellCheck() const { return true; } /// - void toggleSelection(BufferView * bv, bool kill_selection) { - inset.toggleSelection(bv, kill_selection); - } - - void markErased(); - - bool nextChange(BufferView * bv, lyx::pos_type & length); - + bool getStatus(LCursor &, FuncRequest const &, FuncStatus &) const; /// - bool searchForward(BufferView * bv, string const & str, - bool = true, bool = false); - bool searchBackward(BufferView * bv, string const & str, - bool = true, bool = false); - + void setStatus(LCursor & cur, CollapseStatus st); /// - void addPreview(grfx::PreviewLoader &) const; + bool setMouseHover(bool mouse_hover); protected: /// - virtual void cache(BufferView *) const; + virtual void doDispatch(LCursor & cur, FuncRequest & cmd); /// - virtual BufferView * view() const; - - /// - void dimension_collapsed(Dimension &) const; + Dimension dimensionCollapsed() const; /// - int height_collapsed() const; + Box const & buttonDim() const; /// - void draw_collapsed(Painter & pain, int, float &) const; - /// - int getMaxTextWidth(Painter & pain, UpdatableInset const *) const; - + void edit(LCursor & cur, bool left); /// - mutable bool collapsed_; + InsetBase * editXY(LCursor & cur, int x, int y); /// - LColor::color framecolor; + void setInlined() { status_ = Inlined; } + /// Is the width forced to some value? + virtual bool hasFixedWidth() const { return false; } /// - LyXFont labelfont; -public: - /// - mutable InsetText inset; + docstring floatName(std::string const & type, BufferParams const &); + protected: /// - mutable int button_length; + LyXFont labelfont_; /// - mutable int button_top_y; - /// - mutable int button_bottom_y; + mutable Box button_dim; /// mutable int topx; - mutable int topbaseline; - -private: - /// - void lfunMouseRelease(FuncRequest const &); - /// - FuncRequest adjustCommand(FuncRequest const &); - /// - mutable string label; -#if 0 - /// - bool autocollapse; -#endif - /// - mutable int oldWidth; + mutable int topbaseline; /// - bool in_update; + mutable docstring label; +private: /// - mutable bool first_after_edit; + mutable CollapseStatus status_; + /// a substatus of the Open status, determined automatically in metrics + mutable bool openinlined_; + /// the inset will automatically open when the cursor is inside + mutable bool autoOpen_; /// - mutable boost::weak_ptr view_; + mutable Dimension textdim_; + /// changes color when mouse enters/leaves this inset + bool mouse_hover_; }; +// A helper function that pushes the cursor out of the inset. +void leaveInset(LCursor & cur, InsetBase const & in); + +} // namespace lyx + #endif