2 Copyright (C) 2004 Kern Sibbald and John Walker
4 This program is free software; you can redistribute it and/or
5 modify it under the terms of the GNU General Public License
6 as published by the Free Software Foundation; either version 2
7 of the License, or (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19 #ifndef WXBRESTOREPANEL_H
20 #define WXBRESTOREPANEL_H
22 #include "wx/wxprec.h"
28 #include "wxbtableparser.h"
30 #include <wx/thread.h>
31 #include <wx/listctrl.h>
32 #include <wx/treectrl.h>
37 #include "wxbtreectrl.h"
38 #include "wxblistctrl.h"
41 * wxbPanel for restoring files
43 class wxbRestorePanel : public wxbPanel
46 wxbRestorePanel(wxWindow* parent);
49 /* wxbPanel overloadings */
50 virtual wxString GetTitle();
51 virtual void Print(wxString str, int status);
52 virtual void EnablePanel(bool enable = true);
55 /* Commands called by events handler */
57 /* The main button has been clicked */
60 /* List jobs for a specified client */
63 /* List files and directories for a specified tree item */
64 void CmdList(wxTreeItemId item);
66 /* Mark a treeitem (directory) or a listitem (file or directory) */
67 void CmdMark(wxTreeItemId treeitem, long listitem);
69 /* General functions and variables */
70 bool ended; /* The last command send has finished */
72 long filemessages; /* When restoring, number of files restored */
73 long totfilemessages; /* When restoring, number of files to be restored */
75 /* When listing a directory, sets if file list must be updated
76 * (otherwise only the tree structure is updated)
80 wxbTableParser* tableParser; /* Used to parse tables */
82 /* Parse a table in tableParser */
83 void CreateAndWaitForParser(wxString cmd);
85 /* Run a command, and waits until result is fully received. */
86 void WaitForEnd(wxString cmd);
88 /* Run a dir command, and waits until result is fully received. */
89 void WaitForList(wxTreeItemId item, bool updatelist);
91 /* Parse dir command results. */
92 wxString* ParseList(wxString line);
94 /* Sets a list item state, and update its parents and children if it is a directory */
95 void SetListItemState(long listitem, int newstate);
97 /* Sets a tree item state, and update its children, parents and list (if necessary) */
98 void SetTreeItemState(wxTreeItemId item, int newstate);
100 /* Update a tree item parents' state */
101 void UpdateTreeItemState(wxTreeItemId item);
103 /* Refresh a tree item, and all its children. */
104 void RefreshTree(wxTreeItemId item);
109 disabled, // The panel is not activatable
110 activable, // The panel is activable, but not activated
111 entered, // The panel is activated
112 choosing, // The user is choosing files to restore
113 listing, // Dir listing is in progress
114 restoring, // Bacula is restoring files
115 finished // Retore done (state will change in activable)
120 /* Set current status by enabling/disabling components */
121 void SetStatus(status_enum newstatus);
124 bool working; // A command is running, discard GUI events
125 wxTreeItemId currentTreeItem; // Currently selected tree item
128 void OnStart(wxEvent& WXUNUSED(event));
129 void OnTreeChanging(wxTreeEvent& event);
130 void OnTreeExpanding(wxTreeEvent& event);
131 void OnTreeChanged(wxTreeEvent& event);
132 void OnTreeMarked(wxbTreeMarkedEvent& event);
133 void OnListMarked(wxbListMarkedEvent& event);
134 void OnListActivated(wxListEvent& event);
135 void OnClientChoiceChanged(wxCommandEvent& event);
138 wxImageList* imagelist; //image list for tree and list
141 wxChoice* clientChoice;
147 DECLARE_EVENT_TABLE();
150 #endif // WXBRESTOREPANEL_H