-// -*- C++ -*-
/* This file is part of
* ======================================================
*
* LyX, The Document Processor
*
- * Copyright 2000 The LyX Team.
+ * Copyright 2000-2001 The LyX Team.
*
* ======================================================
+ *
+ * \file FormRef.C
+ * \author Angus Leeming, a.leeming@ic.ac.uk
*/
#include <config.h>
-
#include <algorithm>
-#include FORMS_H_LOCATION
#ifdef __GNUG__
#pragma implementation
#endif
-#include "Dialogs.h"
+#include "xformsBC.h"
+#include "ControlRef.h"
#include "FormRef.h"
-#include "LyXView.h"
-#include "buffer.h"
#include "form_ref.h"
-#include "lyxfunc.h"
-#include "insets/insetref.h"
#include "xforms_helpers.h"
+#include "insets/insetref.h"
+#include "helper_funcs.h" // getStringFromVector
+#include "support/lstrings.h" // frontStrip, strip
using std::find;
using std::max;
using std::sort;
using std::vector;
-using SigC::slot;
-
-bool saved_position;
-
-FormRef::FormRef(LyXView * lv, Dialogs * d)
- : FormCommand(lv, d, _("Reference")),
- at_ref(false)
-{
- // let the dialog be shown
- // These are permanent connections so we won't bother
- // storing a copy because we won't be disconnecting.
- d->showRef.connect(slot(this, &FormRef::showInset));
- d->createRef.connect(slot(this, &FormRef::createInset));
-}
-
-FL_FORM * FormRef::form() const
-{
- if (dialog_.get())
- return dialog_->form;
- return 0;
-}
+typedef FormCB<ControlRef, FormDB<FD_form_ref> > base_class;
-
-void FormRef::disconnect()
-{
- refs.clear();
- FormCommand::disconnect();
-}
+FormRef::FormRef(ControlRef & c)
+ : base_class(c, _("Reference")),
+ at_ref_(false)
+{}
void FormRef::build()
{
dialog_.reset(build_ref());
- for (int i = 0; !InsetRef::types[i].latex_name.empty(); ++i)
- fl_addto_choice(dialog_->type,
+ for (int i = 0; !InsetRef::types[i].latex_name.empty(); ++i)
+ fl_addto_choice(dialog_->choice_type,
_(InsetRef::types[i].gui_name.c_str()));
- // Workaround dumb xforms sizing bug
- minw_ = form()->w;
- minh_ = form()->h;
-
// Force the user to use the browser to change refs.
- fl_deactivate_object(dialog_->ref);
+ fl_deactivate_object(dialog_->input_ref);
- // Manage the ok and cancel/close buttons
+ // Manage the ok and cancel/close buttons
bc().setOK(dialog_->button_ok);
bc().setApply(dialog_->button_apply);
bc().setCancel(dialog_->button_cancel);
- bc().setUndoAll(dialog_->button_restore);
- bc().refresh();
+ bc().setRestore(dialog_->button_restore);
-#warning I had to uncomment this so the buttons could be disabled in update() (dekel)
- //bc().addReadOnly(dialog_->type);
- //bc().addReadOnly(dialog_->name);
+ bc().addReadOnly(dialog_->button_update);
+ bc().addReadOnly(dialog_->input_name);
+ bc().addReadOnly(dialog_->input_ref);
}
void FormRef::update()
{
- if (inset_) {
- fl_set_input(dialog_->ref, params.getContents().c_str());
- fl_set_input(dialog_->name, params.getOptions().c_str());
- fl_set_choice(dialog_->type,
- InsetRef::getType(params.getCmdName()) + 1);
+ fl_set_input(dialog_->input_ref,
+ controller().params().getContents().c_str());
+ fl_set_input(dialog_->input_name,
+ controller().params().getOptions().c_str());
+ fl_set_choice(dialog_->choice_type,
+ InsetRef::getType(controller().params().getCmdName()) + 1);
+
+ at_ref_ = false;
+ fl_set_object_label(dialog_->button_go, _("Go to reference"));
+
+ // Name is irrelevant to LaTeX/Literate documents
+ if (controller().docType() == ControlRef::LATEX ||
+ controller().docType() == ControlRef::LITERATE) {
+ setEnabled(dialog_->input_name, false);
+ } else {
+ setEnabled(dialog_->input_name, true);
}
- at_ref = false;
- fl_set_object_label(dialog_->button_go, _("Goto reference"));
-
- // Name is irrelevant to LaTeX/Literate documents, while
// type is irrelevant to LinuxDoc/DocBook.
- if (lv_->buffer()->isLatex() || lv_->buffer()->isLatex()) {
- setEnabled(dialog_->name, false);
- setEnabled(dialog_->type, true);
+ if (controller().docType() == ControlRef::LINUXDOC ||
+ controller().docType() == ControlRef::DOCBOOK) {
+ fl_set_choice(dialog_->choice_type, 1);
+ setEnabled(dialog_->choice_type, false);
} else {
- fl_set_choice(dialog_->type, 1);
-
- setEnabled(dialog_->name, true);
- setEnabled(dialog_->type, false);
+ setEnabled(dialog_->choice_type, true);
}
- refs = lv_->buffer()->getLabelList();
- updateBrowser(refs);
+ // Get the available buffers
+ vector<string> const buffers = controller().getBufferList();
+ vector<string> const choice_buffers =
+ getVectorFromChoice(dialog_->choice_buffer);
+
+ // If different from the current contents of the choice, then update it
+ if (buffers != choice_buffers) {
+ // create a string of entries " entry1 | entry2 | entry3 "
+ // with which to initialise the xforms choice object.
+ string const choice =
+ " " + getStringFromVector(buffers, " | ") + " ";
+
+ fl_clear_choice(dialog_->choice_buffer);
+ fl_addto_choice(dialog_->choice_buffer, choice.c_str());
+
+ fl_set_choice(dialog_->choice_buffer,
+ controller().getBufferNum() + 1);
+ }
- bc().readOnly(lv_->buffer()->isReadonly());
+ refs_ = controller().getLabelList(string());
+ updateBrowser(refs_);
}
void FormRef::updateBrowser(vector<string> const & akeys) const
{
vector<string> keys(akeys);
- if (fl_get_button(dialog_->sort))
+ if (fl_get_button(dialog_->check_sort))
sort(keys.begin(), keys.end());
- fl_clear_browser(dialog_->browser);
+ vector<string> browser_keys =
+ getVectorFromBrowser(dialog_->browser_refs);
+
+ if (browser_keys == keys)
+ return;
+
+ fl_clear_browser(dialog_->browser_refs);
for (vector<string>::const_iterator it = keys.begin();
it != keys.end(); ++it)
- fl_add_browser_line(dialog_->browser, (*it).c_str());
+ fl_add_browser_line(dialog_->browser_refs, it->c_str());
if (keys.empty()) {
- fl_add_browser_line(dialog_->browser,
+ fl_add_browser_line(dialog_->browser_refs,
_("*** No labels found in document ***"));
- setEnabled(dialog_->browser, false);
- setEnabled(dialog_->sort, false);
+ setEnabled(dialog_->browser_refs, false);
+ setEnabled(dialog_->check_sort, false);
- fl_set_input(dialog_->ref, "");
+ fl_set_input(dialog_->input_ref, "");
} else {
- setEnabled(dialog_->browser, true);
- setEnabled(dialog_->sort, true);
+ setEnabled(dialog_->browser_refs, true);
+ setEnabled(dialog_->check_sort, true);
- string ref = fl_get_input(dialog_->ref);
- vector<string>::const_iterator cit =
- find(keys.begin(), keys.end(), ref);
+ string ref = fl_get_input(dialog_->input_ref);
+ vector<string>::const_iterator cit = (ref.empty())
+ ? keys.begin()
+ : find(keys.begin(), keys.end(), ref);
if (cit == keys.end()) {
- cit = keys.begin();
- fl_set_input(dialog_->ref, (*cit).c_str());
- } else if (ref.empty())
- fl_set_input(dialog_->ref, (*cit).c_str());
-
- int const i = static_cast<int>(cit - keys.begin());
- fl_set_browser_topline(dialog_->browser, max(i-5, 1));
- fl_select_browser_line(dialog_->browser, i+1);
+ fl_deselect_browser(dialog_->browser_refs);
+ } else {
+ if (ref.empty())
+ fl_set_input(dialog_->input_ref, cit->c_str());
+
+ int const i = static_cast<int>(cit - keys.begin());
+ fl_set_browser_topline(dialog_->browser_refs, max(i-5, 1));
+ fl_select_browser_line(dialog_->browser_refs, i+1);
+ }
}
}
void FormRef::apply()
{
- if (!lv_->view()->available())
- return;
+ int const type = fl_get_choice(dialog_->choice_type) - 1;
+ controller().params().setCmdName(InsetRef::getName(type));
- int const type = fl_get_choice(dialog_->type) - 1;
- params.setCmdName(InsetRef::getName(type));
-
- params.setOptions(fl_get_input(dialog_->name));
- params.setContents(fl_get_input(dialog_->ref));
-
- if (inset_ != 0) {
- // Only update if contents have changed
- if (params != inset_->params()) {
- inset_->setParams(params);
- lv_->view()->updateInset(inset_, true);
- }
- } else {
- lv_->getLyXFunc()->Dispatch(LFUN_REF_INSERT,
- params.getAsString());
- }
+ controller().params().setOptions(fl_get_input(dialog_->input_name));
+ controller().params().setContents(fl_get_input(dialog_->input_ref));
}
-bool FormRef::input(FL_OBJECT *, long data)
+ButtonPolicy::SMInput FormRef::input(FL_OBJECT * ob, long)
{
- bool activate(true);
- switch (data) {
- // goto reference / go back
- case 1:
- {
+ ButtonPolicy::SMInput activate(ButtonPolicy::SMI_VALID);
+
+ if (ob == dialog_->button_go) {
+ // goto reference / go back
+
// No change to data
- activate = false;
-
- at_ref = !at_ref;
- if (at_ref) {
- lv_->getLyXFunc()->Dispatch(LFUN_BOOKMARK_SAVE, "0");
- lv_->getLyXFunc()->
- Dispatch(LFUN_REF_GOTO,
- fl_get_input(dialog_->ref));
+ activate = ButtonPolicy::SMI_NOOP;
+
+ at_ref_ = !at_ref_;
+ if (at_ref_) {
+ controller().gotoRef(fl_get_input(dialog_->input_ref));
fl_set_object_label(dialog_->button_go, _("Go back"));
} else {
- lv_->getLyXFunc()->Dispatch(LFUN_BOOKMARK_GOTO, "0");
+ controller().gotoBookmark();
fl_set_object_label(dialog_->button_go,
- _("Goto reference"));
+ _("Go to reference"));
}
- }
- break;
- // choose browser key
- case 2:
- {
- unsigned int sel = fl_get_browser(dialog_->browser);
- if (sel < 1 || sel > refs.size()) break;
+ } else if (ob == dialog_->browser_refs) {
+
+ unsigned int sel = fl_get_browser(dialog_->browser_refs);
+ if (sel < 1 || sel > refs_.size())
+ return ButtonPolicy::SMI_NOOP;
- if (!lv_->buffer()->isReadonly()) {
- string s = fl_get_browser_line(dialog_->browser, sel);
- fl_set_input(dialog_->ref, s.c_str());
+ if (!controller().isReadonly()) {
+ string s = fl_get_browser_line(dialog_->browser_refs, sel);
+ fl_set_input(dialog_->input_ref, s.c_str());
}
- if (at_ref)
- lv_->getLyXFunc()->Dispatch(LFUN_BOOKMARK_GOTO, "0");
- at_ref = false;
- fl_set_object_label(dialog_->button_go, _("Goto reference"));
+ if (at_ref_)
+ controller().gotoBookmark();
+ at_ref_ = false;
+ fl_set_object_label(dialog_->button_go, _("Go to reference"));
- setEnabled(dialog_->type, true);
+ setEnabled(dialog_->choice_type, true);
setEnabled(dialog_->button_go, true);
- fl_set_object_lcol(dialog_->ref, FL_BLACK);
- }
- break;
+ fl_set_object_lcol(dialog_->input_ref, FL_BLACK);
- // update or sort
- case 3:
- refs = lv_->buffer()->getLabelList();
+ } else if (ob == dialog_->button_update ||
+ ob == dialog_->check_sort ||
+ ob == dialog_->choice_buffer) {
+
+ if (ob == dialog_->button_update ||
+ ob == dialog_->choice_buffer) {
+ string const name =
+ frontStrip(strip(fl_get_choice_text(dialog_->choice_buffer)));
+ refs_ = controller().getLabelList(name);
+ }
- // fall through to...
- case 4:
fl_freeze_form(form());
- updateBrowser(refs);
+ updateBrowser(refs_);
fl_unfreeze_form(form());
- break;
-
- // changed reference type
- case 5:
- {
- int const type = fl_get_choice(dialog_->type) - 1;
- if (params.getCmdName() == InsetRef::getName(type) && inset_) {
- activate = false;
- }
- }
- break;
- default:
- break;
+ } else if (ob == dialog_->choice_type) {
+
+ int const type = fl_get_choice(dialog_->choice_type) - 1;
+ if (controller().params().getCmdName() ==
+ InsetRef::getName(type)) {
+ activate = ButtonPolicy::SMI_NOOP;
+ }
}
return activate;
}
-
-