+
+
+void InsetNote::read(Buffer const & buf, LyXLex & lex)
+{
+ params_.read(lex);
+ InsetCollapsable::read(buf, lex);
+ setButtonLabel();
+}
+
+
+void InsetNote::setButtonLabel()
+{
+ docstring const label = notetranslator_loc().find(params_.type);
+ setLabel(label);
+
+ LyXFont font(LyXFont::ALL_SANE);
+ font.decSize();
+ font.decSize();
+
+ switch (params_.type) {
+ case InsetNoteParams::Note:
+ font.setColor(LColor::note);
+ setBackgroundColor(LColor::notebg);
+ break;
+ case InsetNoteParams::Comment:
+ font.setColor(LColor::comment);
+ setBackgroundColor(LColor::commentbg);
+ break;
+ case InsetNoteParams::Greyedout:
+ font.setColor(LColor::greyedout);
+ setBackgroundColor(LColor::greyedoutbg);
+ break;
+ case InsetNoteParams::Framed:
+ font.setColor(LColor::greyedout);
+ setBackgroundColor(LColor::greyedoutbg);
+ break;
+ case InsetNoteParams::Shaded:
+ font.setColor(LColor::greyedout);
+ setBackgroundColor(LColor::shadedbg);
+ break;
+ }
+ setLabelFont(font);
+}
+
+
+bool InsetNote::showInsetDialog(BufferView * bv) const
+{
+ InsetNoteMailer(const_cast<InsetNote &>(*this)).showDialog(bv);
+ return true;
+}
+
+
+void InsetNote::doDispatch(LCursor & cur, FuncRequest & cmd)
+{
+ switch (cmd.action) {
+
+ case LFUN_INSET_MODIFY:
+ InsetNoteMailer::string2params(to_utf8(cmd.argument()), params_);
+ setButtonLabel();
+ break;
+
+ case LFUN_INSET_DIALOG_UPDATE:
+ InsetNoteMailer(*this).updateDialog(&cur.bv());
+ break;
+
+ case LFUN_MOUSE_RELEASE:
+ if (cmd.button() == mouse_button::button3 && hitButton(cmd))
+ InsetNoteMailer(*this).showDialog(&cur.bv());
+ else
+ InsetCollapsable::doDispatch(cur, cmd);
+ break;
+
+ default:
+ InsetCollapsable::doDispatch(cur, cmd);
+ break;
+ }
+}
+
+
+bool InsetNote::getStatus(LCursor & cur, FuncRequest const & cmd,
+ FuncStatus & flag) const
+{
+ switch (cmd.action) {
+
+ case LFUN_INSET_MODIFY:
+ case LFUN_INSET_DIALOG_UPDATE:
+ flag.enabled(true);
+ return true;
+
+ default:
+ return InsetCollapsable::getStatus(cur, cmd, flag);
+ }
+}
+
+
+int InsetNote::latex(Buffer const & buf, odocstream & os,
+ OutputParams const & runparams_in) const
+{
+ if (params_.type == InsetNoteParams::Note)
+ return 0;
+
+ OutputParams runparams(runparams_in);
+ string type;
+ if (params_.type == InsetNoteParams::Comment) {
+ type = "comment";
+ runparams.inComment = true;
+ // Ignore files that are exported inside a comment
+ runparams.exportdata.reset(new ExportData);
+ } else if (params_.type == InsetNoteParams::Greyedout)
+ type = "lyxgreyedout";
+ else if (params_.type == InsetNoteParams::Framed)
+ type = "framed";
+ else if (params_.type == InsetNoteParams::Shaded)
+ type = "shaded";
+
+ odocstringstream ss;
+ ss << "%\n\\begin{" << from_ascii(type) << "}\n";
+ InsetText::latex(buf, ss, runparams);
+ ss << "\n\\end{" << from_ascii(type) << "}\n";
+ // the space after the comment in 'a[comment] b' will be eaten by the
+ // comment environment since the space before b is ignored with the
+ // following latex output:
+ //
+ // a%
+ // \begin{comment}
+ // comment
+ // \end{comment}
+ // b
+ //
+ // Adding {} before ' b' fixes this.
+ if (params_.type == InsetNoteParams::Comment)
+ ss << "{}";
+
+ docstring const str = ss.str();
+ os << str;
+ // Return how many newlines we issued.
+ return int(lyx::count(str.begin(), str.end(), '\n'));
+}
+
+
+int InsetNote::docbook(Buffer const & buf, odocstream & os,
+ OutputParams const & runparams_in) const
+{
+ if (params_.type == InsetNoteParams::Note)
+ return 0;
+
+ OutputParams runparams(runparams_in);
+ if (params_.type == InsetNoteParams::Comment) {
+ os << "<remark>\n";
+ runparams.inComment = true;
+ // Ignore files that are exported inside a comment
+ runparams.exportdata.reset(new ExportData);
+ }
+
+ int const n = InsetText::docbook(buf, os, runparams);
+
+ if (params_.type == InsetNoteParams::Comment)
+ os << "\n</remark>\n";
+
+ // Return how many newlines we issued.
+ //return int(count(str.begin(), str.end(), '\n'));
+ return n + 1 + 2;
+}
+
+
+int InsetNote::plaintext(Buffer const & buf, odocstream & os,
+ OutputParams const & runparams_in) const
+{
+ if (params_.type == InsetNoteParams::Note)
+ return 0;
+
+ OutputParams runparams(runparams_in);
+ if (params_.type == InsetNoteParams::Comment) {
+ runparams.inComment = true;
+ // Ignore files that are exported inside a comment
+ runparams.exportdata.reset(new ExportData);
+ }
+ os << "[";
+ int const nlines = InsetText::plaintext(buf, os, runparams);
+ os << "]";
+
+ // Return how many newlines we issued.
+ return nlines;
+}
+
+
+void InsetNote::validate(LaTeXFeatures & features) const
+{
+ if (params_.type == InsetNoteParams::Comment)
+ features.require("verbatim");
+ if (params_.type == InsetNoteParams::Greyedout) {
+ features.require("color");
+ features.require("lyxgreyedout");
+ }
+ if (params_.type == InsetNoteParams::Shaded) {
+ features.require("color");
+ features.require("framed");
+ }
+ if (params_.type == InsetNoteParams::Framed)
+ features.require("framed");
+ InsetText::validate(features);
+}
+
+
+
+string const InsetNoteMailer::name_("note");
+
+InsetNoteMailer::InsetNoteMailer(InsetNote & inset)
+ : inset_(inset)
+{}
+
+
+string const InsetNoteMailer::inset2string(Buffer const &) const
+{
+ return params2string(inset_.params());
+}
+
+
+string const InsetNoteMailer::params2string(InsetNoteParams const & params)
+{
+ ostringstream data;
+ data << name_ << ' ';
+ params.write(data);
+ return data.str();
+}
+
+
+void InsetNoteMailer::string2params(string const & in,
+ InsetNoteParams & params)
+{
+ params = InsetNoteParams();
+
+ if (in.empty())
+ return;
+
+ istringstream data(in);
+ LyXLex lex(0,0);
+ lex.setStream(data);
+
+ string name;
+ lex >> name;
+ if (!lex || name != name_)
+ return print_mailer_error("InsetNoteMailer", in, 1, name_);
+
+ // This is part of the inset proper that is usually swallowed
+ // by LyXText::readInset
+ string id;
+ lex >> id;
+ if (!lex || id != "Note")
+ return print_mailer_error("InsetBoxMailer", in, 2, "Note");
+
+ params.read(lex);
+}
+
+
+} // namespace lyx