X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsetlabel.C;h=66963db35005b0d03398cbd7e78de312fdfb6f78;hb=6ce86e2bfe0a403e0e811b66fdddb2d56cfe0f83;hp=bfc43de3a1109f58c1a6e7e1ea7dbdf10503d730;hpb=0507b8600d40ac155d6576dafe1218db643a8970;p=lyx.git diff --git a/src/insets/insetlabel.C b/src/insets/insetlabel.C index bfc43de3a1..66963db350 100644 --- a/src/insets/insetlabel.C +++ b/src/insets/insetlabel.C @@ -10,32 +10,35 @@ #include -#ifdef __GNUG__ -#pragma implementation -#endif #include "insetlabel.h" -#include "support/LOstream.h" -#include "frontends/Alert.h" -#include "support/lstrings.h" //frontStrip, strip -#include "lyxtext.h" #include "buffer.h" -#include "gettext.h" #include "BufferView.h" +#include "funcrequest.h" +#include "gettext.h" +#include "lyxtext.h" + #include "support/lstrings.h" +#include "support/LOstream.h" +#include "support/lstrings.h" //frontStrip, strip using std::ostream; using std::vector; using std::pair; -/* Label. Used to insert a label automatically */ - InsetLabel::InsetLabel(InsetCommandParams const & p, bool) : InsetCommand(p) {} +InsetLabel::~InsetLabel() +{ + InsetCommandMailer mailer("label", *this); + mailer.hideDialog(); +} + + vector const InsetLabel::getLabelList() const { return vector(1, getContents()); @@ -44,27 +47,39 @@ vector const InsetLabel::getLabelList() const void InsetLabel::edit(BufferView * bv, int, int, mouse_button::state) { - pair result = Alert::askForText(_("Enter label:"), getContents()); - if (result.first) { - string new_contents = trim(result.second); - if (!new_contents.empty() && - getContents() != new_contents) { - bv->buffer()->markDirty(); - bool flag = bv->ChangeRefsIfUnique(getContents(), - new_contents); - setContents(new_contents); -#if 0 - bv->text->redoParagraph(bv); - if (flag) { - bv->redraw(); - bv->fitCursor(); - } else - bv->update(bv->text, BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE); -#else - bv->updateInset(this, !flag); -#endif + InsetCommandMailer mailer("label", *this); + mailer.showDialog(bv); +} + + +dispatch_result InsetLabel::localDispatch(FuncRequest const & cmd) +{ + Inset::RESULT result = UNDISPATCHED; + + switch (cmd.action) { + case LFUN_INSET_MODIFY: { + InsetCommandParams p; + InsetCommandMailer::string2params(cmd.argument, p); + if (p.getCmdName().empty()) + return UNDISPATCHED; + + bool clean = true; + if (view() && p.getContents() != params().getContents()) { + clean = view()->ChangeRefsIfUnique(params().getContents(), + p.getContents()); } + + setParams(p); + cmd.view()->updateInset(this); + result = DISPATCHED; + } + break; + + default: + result = InsetCommand::localDispatch(cmd); } + + return result; } @@ -81,9 +96,10 @@ int InsetLabel::latex(Buffer const *, ostream & os, return 0; } + int InsetLabel::ascii(Buffer const *, ostream & os, int) const { - os << "<" << getContents() << ">"; + os << '<' << getContents() << '>'; return 0; }