2 /* This file is part of
3 * ======================================================
5 * LyX, The Document Processor
7 * Copyright 2000 The LyX Team.
9 * ======================================================
14 #include FORMS_H_LOCATION
17 #pragma implementation
22 #include "FormIndex.h"
25 #include "form_index.h"
28 FormIndex::FormIndex(LyXView * lv, Dialogs * d)
29 : FormCommand(lv, d, _("Index")), minh(0), minw(0), dialog_(0)
31 // let the dialog be shown
32 // These are permanent connections so we won't bother
33 // storing a copy because we won't be disconnecting.
34 d->showIndex.connect(slot(this, &FormIndex::showInset));
35 d->createIndex.connect(slot(this, &FormIndex::createInset));
39 FormIndex::~FormIndex()
45 FL_FORM * FormIndex::form() const
47 if ( dialog_ ) return dialog_->form;
52 void FormIndex::build()
54 dialog_ = build_index();
57 #warning use the buttoncontroller
59 // XFORMS bug workaround
60 // Define the min/max dimensions. Actually applied in update()
61 minw = form()->w; minh = form()->h;
65 void FormIndex::update(bool switched)
72 fl_set_form_minsize(form(), minw, minh);
73 fl_set_form_maxsize(form(), 2*minw, minh);
75 fl_set_input(dialog_->key, params.getContents().c_str());
77 if ( lv_->buffer()->isReadonly() ) {
78 fl_deactivate_object( dialog_->key );
79 fl_deactivate_object( dialog_->ok );
80 fl_set_object_lcol( dialog_->ok, FL_INACTIVE );
82 fl_activate_object( dialog_->key );
83 fl_activate_object( dialog_->ok );
84 fl_set_object_lcol( dialog_->ok, FL_BLACK );
89 void FormIndex::apply()
91 if (lv_->buffer()->isReadonly()) return;
93 params.setContents(fl_get_input(dialog_->key));
96 // Only update if contents have changed
97 if (params != inset_->params()) {
98 inset_->setParams(params);
99 lv_->view()->updateInset(inset_, true);
102 lv_->getLyXFunc()->Dispatch(LFUN_INDEX_INSERT,
103 params.getAsString());