diff options
Diffstat (limited to 'src/controller.h')
-rw-r--r-- | src/controller.h | 175 |
1 files changed, 175 insertions, 0 deletions
diff --git a/src/controller.h b/src/controller.h new file mode 100644 index 0000000..58c3917 --- /dev/null +++ b/src/controller.h @@ -0,0 +1,175 @@ +/*************************************************************************** + copyright : (C) 2003-2006 by Robby Stephenson + email : [email protected] + ***************************************************************************/ + +/*************************************************************************** + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of version 2 of the GNU General Public License as * + * published by the Free Software Foundation; * + * * + ***************************************************************************/ + +#ifndef TELLICOCONTROLLER_H +#define TELLICOCONTROLLER_H + +class QPopupMenu; + +namespace Tellico { + class MainWindow; + class GroupView; + class GroupIterator; + namespace Data { + class Collection; + } +} + +#include "entry.h" + +#include <qobject.h> + +namespace Tellico { +class Observer; + +/** + * @author Robby Stephenson + */ +class Controller : public QObject { +Q_OBJECT + +public: + static Controller* self() { return s_self; } + /** + * Initializes the singleton. Should just be called once, from Tellico::MainWindow + */ + static void init(MainWindow* parent, const char* name=0) { + if(!s_self) s_self = new Controller(parent, name); + } + + const Data::EntryVec& selectedEntries() const { return m_selectedEntries; } + Data::EntryVec visibleEntries(); + + void editEntry(Data::EntryPtr) const; + void hideTabs() const; + /** + * Plug the default collection actions into a widget + */ + void plugCollectionActions(QPopupMenu* popup); + /** + * Plug the default entry actions into a widget + */ + void plugEntryActions(QPopupMenu* popup); + void updateActions() const; + + GroupIterator groupIterator() const; + /** + * Returns the name of the field being used to group the entries. + * That field name may not be an actual field in the collection, since + * pseudo-groups like _people exist. + */ + QString groupBy() const; + /** + * Returns a list of the fields being used to group the entries. + * For ordinary fields, the list has a single item, the field name. + * For the pseudo-group _people, all the people fields are included. + */ + QStringList expandedGroupBy() const; + /** + * Returns a list of the titles of the fields being used to sort the entries in the detailed column view. + */ + QStringList sortTitles() const; + /** + * Returns the title of the fields currently visible in the detailed column view. + */ + QStringList visibleColumns() const; + + void addObserver(Observer* obs); + void removeObserver(Observer* obs); + + void addedField(Data::CollPtr coll, Data::FieldPtr field); + void modifiedField(Data::CollPtr coll, Data::FieldPtr oldField, Data::FieldPtr newField); + void removedField(Data::CollPtr coll, Data::FieldPtr field); + + void addedEntries(Data::EntryVec entries); + void modifiedEntries(Data::EntryVec entries); + void removedEntries(Data::EntryVec entries); + + void addedBorrower(Data::BorrowerPtr borrower); + void modifiedBorrower(Data::BorrowerPtr borrower); + + void addedFilter(FilterPtr filter); + void removedFilter(FilterPtr filter); + + void reorderedFields(Data::CollPtr coll); + void updatedFetchers(); + +public slots: + /** + * When a collection is added to the document, certain actions need to be taken + * by the parent app. The collection toolbar is updated, the entry count is set, and + * the collection's modified signal is connected to the @ref GroupView widget. + * + * @param coll A pointer to the collection being added + */ + void slotCollectionAdded(Tellico::Data::CollPtr coll); + void slotCollectionModified(Tellico::Data::CollPtr coll); + /** + * Removes a collection from all the widgets + * + * @param coll A pointer to the collection being added + */ + void slotCollectionDeleted(Tellico::Data::CollPtr coll); + void slotRefreshField(Tellico::Data::FieldPtr field); + + void slotClearSelection(); + /** + * Updates the widgets when entries are selected. + * + * param widget A pointer to the widget where the entries were selected + * @param widget The widget doing the selecting, if NULL, then use previous + * @param entries The list of selected entries + */ + void slotUpdateSelection(QWidget* widget, const Tellico::Data::EntryVec& entries); + void slotUpdateCurrent(const Tellico::Data::EntryVec& entries); + void slotCopySelectedEntries(); + void slotUpdateSelectedEntries(const QString& source); + void slotDeleteSelectedEntries(); + void slotMergeSelectedEntries(); + void slotUpdateFilter(Tellico::FilterPtr filter); + void slotCheckOut(); + void slotCheckIn(); + void slotCheckIn(const Data::EntryVec& entries); + void slotGoPrevEntry(); + void slotGoNextEntry(); + +signals: + void collectionAdded(int collType); + +private: + static Controller* s_self; + Controller(MainWindow* parent, const char* name); + + void blockAllSignals(bool block) const; + bool canCheckIn() const; + void plugUpdateMenu(QPopupMenu* popup); + enum EntryDirection { PrevEntry, NextEntry }; + void goEntrySibling(EntryDirection dir); + + MainWindow* m_mainWindow; + + bool m_working; + + typedef PtrVector<Tellico::Observer> ObserverVec; + ObserverVec m_observers; + + /** + * Keep track of the selected entries so that a top-level delete has something for reference + */ + Data::EntryVec m_selectedEntries; + Data::EntryVec m_currentEntries; + QWidget* m_widgetWithSelection; +}; + +} // end namespace +#endif |