]> git.lyx.org Git - features.git/blobdiff - src/insets/InsetIndex.h
Finally make the label color of multiple index entries work.
[features.git] / src / insets / InsetIndex.h
index 58d9c1269b103fb016ab6c7447b7c0efe7eb7e5e..c66be3004913b67d37f753923ba8f5bed1c314c6 100644 (file)
 
 namespace lyx {
 
+class InsetIndexParams {
+public:
+       ///
+       explicit InsetIndexParams(docstring const & b = docstring())
+               : index(b) {}
+       ///
+       void write(std::ostream & os) const;
+       ///
+       void read(Lexer & lex);
+       ///
+       docstring index;
+};
+
+
 /** Used to insert index labels
   */
 class InsetIndex : public InsetCollapsable {
 public:
        ///
-       InsetIndex(Buffer const &);
+       InsetIndex(Buffer const &, InsetIndexParams const &);
+       ///
+       static std::string params2string(InsetIndexParams const &);
+       ///
+       static void string2params(std::string const &, InsetIndexParams &);
 private:
        ///
-       EDITABLE editable() const { return HIGHLY_EDITABLE; }
+       bool hasSettings() const;
        ///
        InsetCode lyxCode() const { return INDEX_CODE; }
        ///
        docstring name() const { return from_ascii("Index"); }
        ///
+       ColorCode labelColor() const;
+       ///
        void write(std::ostream & os) const;
        ///
+       void read(Lexer & lex);
+       ///
        int docbook(odocstream &, OutputParams const &) const;
+       /// At the moment, this does nothing. See development/HTML.notes
+       /// for some remarks on what could be done.
+       docstring xhtml(odocstream &, OutputParams const &) const;
        ///
        int latex(odocstream &, OutputParams const &) const;
+       ///
+       bool showInsetDialog(BufferView *) const;
+       ///
+       bool getStatus(Cursor &, FuncRequest const &, FuncStatus &) const;
+       ///
+       void doDispatch(Cursor & cur, FuncRequest & cmd);
        /// should paragraph indendation be omitted in any case?
        bool neverIndent() const { return true; }
-       /// should paragraphs be forced to use the empty layout?
-       virtual bool forcePlainLayout(idx_type = 0) const { return true; }
-       /// should the user be allowed to customize alignment, etc.?
-       virtual bool allowParagraphCustomization(idx_type = 0) const { return false; }
        ///
        void addToToc(DocIterator const &);
        ///
+       docstring const buttonLabel(BufferView const & bv) const;
+       ///
+       docstring toolTip(BufferView const & bv, int x, int y) const;
+       /// Updates needed features for this inset.
+       void validate(LaTeXFeatures & features) const;
+       ///
+       docstring contextMenu(BufferView const & bv, int x, int y) const;
+       ///
        Inset * clone() const { return new InsetIndex(*this); }
+
+       ///
+       friend class InsetIndexParams;
+       ///
+       InsetIndexParams params_;
 };
 
 
@@ -55,21 +95,31 @@ class InsetPrintIndex : public InsetCommand {
 public:
        ///
        InsetPrintIndex(InsetCommandParams const &);
+       ///
+       InsetCode lyxCode() const { return INDEX_PRINT_CODE; }
 
        ///
        static ParamInfo const & findInfo(std::string const &);
        ///
        static std::string defaultCommand() { return "printindex"; };
        ///
-       static bool isCompatibleCommand(std::string const & s) 
-               { return s == "printindex"; }
+       static bool isCompatibleCommand(std::string const & s);
+       ///
+       int latex(odocstream &, OutputParams const &) const;
+       /// Does nothing yet.
+       docstring xhtml(odocstream &, OutputParams const &) const;
+       ///
+       void doDispatch(Cursor & cur, FuncRequest & cmd);
+       ///
+       bool getStatus(Cursor &, FuncRequest const &, FuncStatus &) const;
+       ///
+       virtual docstring contextMenu(BufferView const & bv, int x, int y) const;
 private:
        /// Updates needed features for this inset.
        void validate(LaTeXFeatures & features) const;
        ///
-       EDITABLE editable() const { return NOT_EDITABLE; }
-       ///
-       InsetCode lyxCode() const;
+       bool hasSettings() const;
+
        ///
        DisplayType display() const { return AlignCenter; }
        ///