[bed759] | 1 | /*
|
---|
| 2 | * QtMoleculeItem.hpp
|
---|
| 3 | *
|
---|
| 4 | * Created on: Jan 17, 2015
|
---|
| 5 | * Author: heber
|
---|
| 6 | */
|
---|
| 7 |
|
---|
| 8 | #ifndef QTMOLECULEITEM_HPP_
|
---|
| 9 | #define QTMOLECULEITEM_HPP_
|
---|
| 10 |
|
---|
| 11 | // include config.h
|
---|
| 12 | #ifdef HAVE_CONFIG_H
|
---|
| 13 | #include <config.h>
|
---|
| 14 | #endif
|
---|
| 15 |
|
---|
| 16 | #include <QList>
|
---|
| 17 | #include <QStandardItem>
|
---|
| 18 |
|
---|
| 19 | #include "CodePatterns/Observer/Observer.hpp"
|
---|
| 20 |
|
---|
[6d1e0a] | 21 | #include <boost/function.hpp>
|
---|
| 22 | #include <list>
|
---|
[bed759] | 23 | #include <string>
|
---|
| 24 |
|
---|
[6d1e0a] | 25 | #include "molecule.hpp"
|
---|
[bed759] | 26 |
|
---|
[6d1e0a] | 27 | /** This class describes the general interface for a specific item in a QtAbstractItemModel
|
---|
| 28 | * to contain a specific piece of information about a specific molecule.
|
---|
| 29 | *
|
---|
| 30 | * To this end, we need a ref to the molecule for updating the information when
|
---|
| 31 | * necessary and we need to know the channels we have to listen to know when an
|
---|
| 32 | * update is necessary.
|
---|
| 33 | *
|
---|
| 34 | * This class takes care of of all the rest:
|
---|
| 35 | * -# informing QtMoleculeList about required update ("dirty")
|
---|
| 36 | * -# relaying updateState() call from QtMoleculeList to the specific internal_updateState()
|
---|
| 37 | */
|
---|
[bed759] | 38 | class QtMoleculeItem : public QStandardItem, public Observer
|
---|
| 39 | {
|
---|
| 40 | public:
|
---|
[6d1e0a] | 41 | //!> typedef for a list of notification channels required, to know when to update
|
---|
[3e52834] | 42 | typedef Observable::channels_t channellist_t;
|
---|
[6d1e0a] | 43 |
|
---|
| 44 | //!> enum states whether an item's formula changed or not
|
---|
| 45 | enum MoveTypes {
|
---|
| 46 | NeedsMove,
|
---|
| 47 | DoesNotMove
|
---|
| 48 | };
|
---|
| 49 |
|
---|
[fcdf05] | 50 | //!> enumerates all different item types, coinciding with column in QtMoleculeList
|
---|
| 51 | enum COLUMNTYPES {NAME,VISIBILITY,ATOMCOUNT,FORMULA,OCCURRENCE,COLUMNTYPES_MAX};
|
---|
| 52 |
|
---|
[6d1e0a] | 53 | //!> typedef for callback function to model to inform when we need update
|
---|
[fcdf05] | 54 | typedef const boost::function<void (
|
---|
| 55 | const moleculeId_t _id,
|
---|
| 56 | const QtMoleculeItem::COLUMNTYPES _type,
|
---|
| 57 | const enum MoveTypes)> emitDirtyState_t;
|
---|
[6d1e0a] | 58 |
|
---|
| 59 | QtMoleculeItem(
|
---|
[69b434] | 60 | const moleculeId_t _molid,
|
---|
[6d1e0a] | 61 | const channellist_t &_channellist,
|
---|
| 62 | const enum MoveTypes _movetype,
|
---|
| 63 | const emitDirtyState_t _emitDirtyState);
|
---|
[bed759] | 64 | virtual ~QtMoleculeItem();
|
---|
| 65 |
|
---|
[6d1e0a] | 66 | /** Update the state of this item.
|
---|
| 67 | *
|
---|
| 68 | */
|
---|
| 69 | void updateState();
|
---|
| 70 |
|
---|
[53c1ff] | 71 | /** Const getter to this item's molecule.
|
---|
| 72 | *
|
---|
| 73 | * \return const ref to \a mol
|
---|
| 74 | */
|
---|
[69b434] | 75 | const molecule * const getMolecule() const;
|
---|
[53c1ff] | 76 |
|
---|
[7d0ddb] | 77 | /** Getter for the id of the molecule this item is associated to
|
---|
| 78 | *
|
---|
| 79 | * \return id of molecule
|
---|
| 80 | */
|
---|
| 81 | moleculeId_t getMoleculeId() const
|
---|
| 82 | { return molid; }
|
---|
| 83 |
|
---|
[fcdf05] | 84 | /** Returns the type of this QtMoleculeItem, i.e. the column in QtMoleculeList.
|
---|
| 85 | *
|
---|
| 86 | * @return type of this item
|
---|
| 87 | */
|
---|
| 88 | virtual QtMoleculeItem::COLUMNTYPES getType() const = 0;
|
---|
| 89 |
|
---|
[6d1e0a] | 90 | private:
|
---|
| 91 | void update(Observable *publisher);
|
---|
| 92 | void recieveNotification(Observable *publisher, Notification_ptr notification);
|
---|
| 93 | void subjectKilled(Observable *publisher);
|
---|
| 94 |
|
---|
| 95 | void signOnToMolecule();
|
---|
| 96 | void signOffFromMolecule();
|
---|
[bed759] | 97 |
|
---|
| 98 | protected:
|
---|
[6d1e0a] | 99 | /** This function needs to be implemented to make the specific update.
|
---|
| 100 | *
|
---|
| 101 | */
|
---|
| 102 | virtual void internal_updateState() = 0;
|
---|
[bed759] | 103 |
|
---|
| 104 | //!> molecule we are signed on to
|
---|
[69b434] | 105 | const moleculeId_t molid;
|
---|
[6d1e0a] | 106 |
|
---|
| 107 | private:
|
---|
| 108 | //!> move type for this specific item, set this when implementing
|
---|
| 109 | const enum MoveTypes movetype;
|
---|
| 110 |
|
---|
| 111 | //!> ref to the specific static list of channels we are signed on to
|
---|
| 112 | const channellist_t &channellist;
|
---|
| 113 |
|
---|
[3e52834] | 114 | //!> the Observable we are signed on, also indicates whether we are sign on (not NULL)
|
---|
| 115 | const Observable * owner;
|
---|
[6d1e0a] | 116 |
|
---|
| 117 | //!> states that this item needs to be updated
|
---|
| 118 | bool dirty;
|
---|
| 119 |
|
---|
| 120 | //!> bound callback function to inform model about change
|
---|
| 121 | const emitDirtyState_t emitDirtyState;
|
---|
[bed759] | 122 | };
|
---|
| 123 |
|
---|
| 124 |
|
---|
| 125 | #endif /* QTMOLECULEITEM_HPP_ */
|
---|