#include "BufferParams.h"
#include "BufferView.h"
#include "BranchList.h"
-#include "Color.h"
+#include "ColorSet.h"
#include "Counters.h"
#include "Cursor.h"
#include "DispatchResult.h"
#include "FuncStatus.h"
#include "Lexer.h"
#include "OutputParams.h"
+#include "output_xhtml.h"
#include "TextClass.h"
#include "TocBackend.h"
#include "support/debug.h"
#include "support/gettext.h"
+#include "support/lstrings.h"
#include "frontends/Application.h"
namespace lyx {
-InsetBranch::InsetBranch(Buffer const & buf, InsetBranchParams const & params)
- : InsetCollapsable(buf), params_(params)
-{
- // override the default for InsetCollapsable, which is to
- // use the plain layout.
- DocumentClass const & dc = buf.params().documentClass();
- paragraphs().back().setDefaultLayout(dc);
-}
-
-
-InsetBranch::~InsetBranch()
-{
- hideDialogs("branch", this);
-}
-
-
-docstring InsetBranch::editMessage() const
-{
- return _("Opened Branch Inset");
-}
+InsetBranch::InsetBranch(Buffer * buf, InsetBranchParams const & params)
+ : InsetCollapsable(buf, InsetText::DefaultLayout), params_(params)
+{}
void InsetBranch::write(ostream & os) const
{
+ os << "Branch ";
params_.write(os);
+ os << '\n';
InsetCollapsable::write(os);
}
}
-docstring InsetBranch::toolTip(BufferView const &, int, int) const
+docstring InsetBranch::toolTip(BufferView const & bv, int x, int y) const
{
- return _("Branch: ") + params_.branch;
+ docstring const status = isBranchSelected() ?
+ _("active") : _("non-active");
+ docstring const heading =
+ support::bformat(_("Branch (%1$s): %2$s"), status, params_.branch);
+ docstring const contents = InsetCollapsable::toolTip(bv, x, y);
+ if (isOpen(bv) || contents.empty())
+ return heading;
+ else
+ return heading + from_ascii("\n") + contents;
}
-void InsetBranch::setButtonLabel()
+docstring const InsetBranch::buttonLabel(BufferView const & bv) const
{
docstring s = _("Branch: ") + params_.branch;
+ Buffer const & realbuffer = *buffer().masterBuffer();
+ BranchList const & branchlist = realbuffer.params().branchlist();
+ if (!branchlist.find(params_.branch)
+ && buffer().params().branchlist().find(params_.branch))
+ s = _("Branch (child only): ") + params_.branch;
+ else if (!branchlist.find(params_.branch))
+ s = _("Branch (undefined): ") + params_.branch;
if (!params_.branch.empty()) {
// FIXME UNICODE
ColorCode c = lcolor.getFromLyXName(to_utf8(params_.branch));
if (c == Color_none)
s = _("Undef: ") + s;
}
+ s = char_type(isBranchSelected() ? 0x2714 : 0x2716) + s;
if (decoration() == InsetLayout::CLASSIC)
- setLabel(isOpen() ? s : getNewLabel(s) );
+ return isOpen(bv) ? s : getNewLabel(s);
else
- setLabel(params_.branch + ": " + getNewLabel(s));
+ return params_.branch + ": " + getNewLabel(s);
}
-ColorCode InsetBranch::backgroundColor() const
+ColorCode InsetBranch::backgroundColor(PainterInfo const & pi) const
{
if (params_.branch.empty())
- return Inset::backgroundColor();
+ return Inset::backgroundColor(pi);
// FIXME UNICODE
ColorCode c = lcolor.getFromLyXName(to_utf8(params_.branch));
if (c == Color_none)
}
-bool InsetBranch::showInsetDialog(BufferView * bv) const
-{
- bv->showDialog("branch", params2string(params()),
- const_cast<InsetBranch *>(this));
- return true;
-}
-
-
void InsetBranch::doDispatch(Cursor & cur, FuncRequest & cmd)
{
- switch (cmd.action) {
+ switch (cmd.action()) {
case LFUN_INSET_MODIFY: {
InsetBranchParams params;
InsetBranch::string2params(to_utf8(cmd.argument()), params);
params_.branch = params.branch;
- setLayout(cur.buffer()->params());
+ // what we really want here is a TOC update, but that means
+ // a full buffer update
+ cur.forceBufferUpdate();
break;
}
-
- case LFUN_MOUSE_PRESS:
- if (cmd.button() != mouse_button::button3)
- InsetCollapsable::doDispatch(cur, cmd);
- else
- cur.undispatched();
- break;
-
- case LFUN_INSET_DIALOG_UPDATE:
- cur.bv().updateDialog("branch", params2string(params()));
+ case LFUN_BRANCH_ACTIVATE:
+ case LFUN_BRANCH_DEACTIVATE: {
+ // FIXME: I do not like this cast, but have no other idea...
+ Buffer const * buf = buffer().masterBuffer();
+ BranchList const & branchlist = buf->params().branchlist();
+ Branch * our_branch = const_cast<Branch *>(branchlist.find(params_.branch));
+ if (!our_branch) {
+ // child only?
+ our_branch = buffer().params().branchlist().find(params_.branch);
+ if (!our_branch)
+ break;
+ }
+ our_branch->setSelected(cmd.action() == LFUN_BRANCH_ACTIVATE);
break;
-
+ }
case LFUN_INSET_TOGGLE:
- if (cmd.argument() == "assign") {
- // The branch inset uses "assign".
- if (isBranchSelected()) {
- if (status() != Open)
- setStatus(cur, Open);
- else
- cur.undispatched();
- } else {
- if (status() != Collapsed)
- setStatus(cur, Collapsed);
- else
- cur.undispatched();
- }
- }
+ if (cmd.argument() == "assign")
+ setStatus(cur, isBranchSelected() ? Open : Collapsed);
else
InsetCollapsable::doDispatch(cur, cmd);
break;
bool InsetBranch::getStatus(Cursor & cur, FuncRequest const & cmd,
FuncStatus & flag) const
{
- switch (cmd.action) {
+ switch (cmd.action()) {
case LFUN_INSET_MODIFY:
- case LFUN_INSET_DIALOG_UPDATE:
flag.setEnabled(true);
break;
+ case LFUN_BRANCH_ACTIVATE:
+ flag.setEnabled(!isBranchSelected());
+ break;
+
+ case LFUN_BRANCH_DEACTIVATE:
+ flag.setEnabled(isBranchSelected());
+ break;
+
case LFUN_INSET_TOGGLE:
- if (cmd.argument() == "open" || cmd.argument() == "close" ||
- cmd.argument() == "toggle")
- flag.setEnabled(true);
- else if (cmd.argument() == "assign" || cmd.argument().empty()) {
- if (isBranchSelected())
- flag.setEnabled(status() != Open);
- else
- flag.setEnabled(status() != Collapsed);
- } else
+ if (cmd.argument() == "assign")
flag.setEnabled(true);
- break;
+ else
+ return InsetCollapsable::getStatus(cur, cmd, flag);
default:
return InsetCollapsable::getStatus(cur, cmd, flag);
Buffer const & realbuffer = *buffer().masterBuffer();
BranchList const & branchlist = realbuffer.params().branchlist();
Branch const * ourBranch = branchlist.find(params_.branch);
- if (!ourBranch)
- return false;
+
+ if (!ourBranch) {
+ // this branch is defined in child only
+ ourBranch = buffer().params().branchlist().find(params_.branch);
+ if (!ourBranch)
+ return false;
+ }
return ourBranch->isSelected();
}
}
+docstring InsetBranch::xhtml(XHTMLStream & xs, OutputParams const & rp) const
+{
+ if (isBranchSelected())
+ return InsetText::xhtml(xs, rp);
+ return docstring();
+}
+
+
void InsetBranch::tocString(odocstream & os) const
{
if (isBranchSelected())
}
+docstring InsetBranch::contextMenu(BufferView const &, int, int) const
+{
+ return from_ascii("context-branch");
+}
+
+
bool InsetBranch::isMacroScope() const
{
// Its own scope if not selected by buffer
string InsetBranch::params2string(InsetBranchParams const & params)
{
ostringstream data;
- data << "branch" << ' ';
params.write(data);
return data.str();
}
Lexer lex;
lex.setStream(data);
lex.setContext("InsetBranch::string2params");
- lex >> "branch" >> "Branch";
params.read(lex);
}
Toc & toc = buffer().tocBackend().toc("branch");
docstring const str = params_.branch + ": " + text().getPar(0).asString();
- toc.push_back(TocItem(pit, 0, str));
+ toc.push_back(TocItem(pit, 0, str, toolTipText()));
// Proceed with the rest of the inset.
InsetCollapsable::addToToc(cpit);
}
void InsetBranchParams::write(ostream & os) const
{
- os << "Branch " << to_utf8(branch) << '\n';
+ os << to_utf8(branch);
}