#include "metricsinfo.h"
#include "paragraph.h"
-#include "support/std_sstream.h"
+#include "frontends/font_metrics.h"
+#include "frontends/Painter.h"
+
+#include <sstream>
using std::string;
void InsetCharStyle::init()
{
setInsetName("CharStyle");
- setButtonLabel();
+ setStatus(Inlined);
}
InsetCharStyle::InsetCharStyle(BufferParams const & bp,
CharStyles::iterator cs)
- : InsetCollapsable(bp)
+ : InsetCollapsable(bp), has_label_(true)
{
params_.type = cs->name;
params_.latextype = cs->latextype;
params_.latexname = cs->latexname;
+ params_.latexparam = cs->latexparam;
params_.font = cs->font;
params_.labelfont = cs->labelfont;
init();
InsetCharStyle::InsetCharStyle(InsetCharStyle const & in)
- : InsetCollapsable(in), params_(in.params_)
+ : InsetCollapsable(in), params_(in.params_), has_label_(true)
{
init();
}
void InsetCharStyle::read(Buffer const & buf, LyXLex & lex)
{
InsetCollapsable::read(buf, lex);
- setButtonLabel();
+ setStatus(Inlined);
}
-void InsetCharStyle::setButtonLabel()
+void InsetCharStyle::metrics(MetricsInfo & mi, Dimension & dim) const
{
- LyXFont font(params_.labelfont);
- font.realize(LyXFont(LyXFont::ALL_SANE));
- font.decSize();
- setLabel("Style: " + params_.type);
- setLabelFont(font);
+ LyXFont tmpfont = mi.base.font;
+ getDrawFont(mi.base.font);
+ InsetCollapsable::metrics(mi, dim);
+ mi.base.font = tmpfont;
+ dim_ = dim;
+ if (has_label_)
+ dim_.des += ascent();
}
-void InsetCharStyle::metrics(MetricsInfo & mi, Dimension & dim) const
+void InsetCharStyle::draw(PainterInfo & pi, int x, int y) const
{
- InsetCollapsable::metrics(mi, dim);
- dim_ = dim;
+ setPosCache(pi, x, y);
+
+ // FIXME: setStatus(Inlined); this is not a const operation
+ LyXFont tmpfont = pi.base.font;
+ //setDrawFrame(InsetText::NEVER);
+ getDrawFont(pi.base.font);
+ InsetText::draw(pi, x, y);
+ pi.base.font = tmpfont;
+
+ pi.pain.line(x + 2, y + InsetText::descent() - 4, x + 2,
+ y + InsetText::descent(), params_.labelfont.color());
+ pi.pain.line(x + 2, y + InsetText::descent(), x + dim_.wid - 2,
+ y + InsetText::descent(), params_.labelfont.color());
+ pi.pain.line(x + dim_.wid - 2, y + InsetText::descent(), x + dim_.wid - 2,
+ y + InsetText::descent() - 4, params_.labelfont.color());
+
+ if (has_label_) {
+ LyXFont font(params_.labelfont);
+ font.realize(LyXFont(LyXFont::ALL_SANE));
+ font.decSize();
+ font.decSize();
+ int w = 0;
+ int a = 0;
+ int d = 0;
+ font_metrics::rectText(params_.type, font, w, a, d);
+ pi.pain.rectText(x + (dim_.wid - w) / 2,
+ y + InsetText::descent() + a,
+ params_.type, font, LColor::none, LColor::none);
+ }
}
}
-DispatchResult
-InsetCharStyle::priv_dispatch(FuncRequest const & cmd,
- idx_type & idx, pos_type & pos)
+void InsetCharStyle::priv_dispatch(LCursor & cur, FuncRequest & cmd)
{
- DispatchResult dr = InsetCollapsable::priv_dispatch(cmd, idx, pos);
- setButtonLabel();
- return dr;
+ setStatus(Inlined);
+ switch (cmd.action) {
+ case LFUN_MOUSE_PRESS:
+ if (cmd.button() == mouse_button::button3)
+ has_label_ = !has_label_;
+ else
+ InsetText::dispatch(cur, cmd);
+ break;
+
+ default:
+ InsetCollapsable::priv_dispatch(cur, cmd);
+ break;
+ }
}
namespace {
-int outputVerbatim(std::ostream & os, InsetText inset)
+int outputVerbatim(std::ostream & os, InsetText const & inset)
{
int lines = 0;
- ParagraphList::iterator par = inset.paragraphs.begin();
- ParagraphList::iterator end = inset.paragraphs.end();
+ ParagraphList::const_iterator par = inset.paragraphs().begin();
+ ParagraphList::const_iterator end = inset.paragraphs().end();
while (par != end) {
lyx::pos_type siz = par->size();
for (lyx::pos_type i = 0; i < siz; ++i) {
int InsetCharStyle::latex(Buffer const &, ostream & os,
OutputParams const &) const
{
- os << "%\n\\" << params_.latexname << "{";
- int i = outputVerbatim(os, inset);
+ os << "%\n\\" << params_.latexname;
+ if (!params_.latexparam.empty())
+ os << params_.latexparam;
+ os << "{";
+ int i = outputVerbatim(os, *this);
os << "}%\n";
i += 2;
return i;
int InsetCharStyle::linuxdoc(Buffer const &, std::ostream & os,
OutputParams const &) const
{
- os << "<" << params_.latexname << ">";
- int const i = outputVerbatim(os, inset);
+ os << "<" << params_.latexname;
+ if (!params_.latexparam.empty())
+ os << " " << params_.latexparam;
+ os << ">";
+ int const i = outputVerbatim(os, *this);
os << "</" << params_.latexname << ">";
return i;
}
int InsetCharStyle::docbook(Buffer const &, std::ostream & os,
OutputParams const &) const
{
- os << "<" << params_.latexname << ">";
- int const i = outputVerbatim(os, inset);
+ os << "<" << params_.latexname;
+ if (!params_.latexparam.empty())
+ os << " " << params_.latexparam;
+ os << ">";
+ int const i = outputVerbatim(os, *this);
os << "</" << params_.latexname << ">";
return i;
}
int InsetCharStyle::plaintext(Buffer const &, std::ostream & os,
- OutputParams const & runparams) const
+ OutputParams const & /*runparams*/) const
{
- return outputVerbatim(os, inset);
+ return outputVerbatim(os, *this);
}
void InsetCharStyleParams::write(ostream & os) const
{
- os << type << "\n";
+ os << "CharStyle " << type << "\n";
}