summaryrefslogtreecommitdiff
path: root/src/frontend/profile/cprofile.h
blob: 8acffd3c478406fb70c524e21da6f82768515c4e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*********
*
* This file is part of BibleTime's source code, http://www.bibletime.info/.
*
* Copyright 1999-2011 by the BibleTime developers.
* The BibleTime source code is licensed under the GNU General Public License version 2.0.
*
**********/

#ifndef CPROFILE_H
#define CPROFILE_H

#include <QByteArray>
#include <QList>
#include "frontend/cmdiarea.h"
#include "frontend/profile/cprofilewindow.h"


namespace Profile {

/** Manages one profile file. Provides functions to save and restore settings of the available display windows.
  * @author The BibleTime team
  */
class CProfile {
    public:
        CProfile(const QString& fileName, const QString& name = QString::null);
        ~CProfile();

        /**
        * Saves the profile to the file given in the constructor.
        * @param windows The list of windows available in the profile.
        */
        bool save( QList<CProfileWindow*> windows );
        /**
        * Saves the profile to the file given in the constructor.
        */
        bool save();
        /**
        * Loads the profile from the file given in the constructor.
        * @return The list of profiled window which exist in the profile.
        */
        QList<CProfileWindow*> load();
        /**
        * Returns the name of this profile.
        */
        const QString& name();
        /**
        * Returns the filename used for this profile.
        */
        const QString& filename();
        /**
        * Initializes the XML for the first time (use to create a new profile)
        */
        void init(const QString);
        /**
        * Chnages the name of this profile.
        */
        void setName( const QString& );
        /**
        * Returns true if the main window was maximized as the profile was saved.
        */
        bool maximized() const;
        /**
        * Set the parameter to true if the main window is maximized.
        */
        void setMaximized( const bool maximized );
        /**
        * Sets the MDI arrangement mode
        */
        void setMDIArrangementMode(const CMDIArea::MDIArrangementMode);
        /**
        * Returns mdi arrangement mode
        */
        CMDIArea::MDIArrangementMode getMDIArrangementMode(void);
        /**
        * set mainwindow saveGeometry - size and position of window
        */
        void setMainwindowGeometry(const QByteArray& geometry);
        /**
         * Return mainwindow saveGeometry - size and position of window
        */
        QByteArray getMainwindowGeometry();
        /**
        * set mainwindow saveState - position of docking windows and toolbar
        */
        void setMainwindowState(const QByteArray& state);
        /**
         * Return mainwindow saveState - position of docking windows and toolbar
        */
        QByteArray getMainwindowState();

    private:
        /**
        * Loads the basic settings requires for proper operation.
        */
        void loadBasics();
        void saveBasics();

        QList<CProfileWindow*> m_profileWindows;
        QString m_name;
        QString m_filename;
        CMDIArea::MDIArrangementMode m_mdiArrangementMode;
        QByteArray m_mainwindowGeometry;
        QByteArray m_mainwindowState;
};

} //end of namespace Profile

#endif