2 Copyright 2004-2005 Chris Tallon
4 This file is part of VOMP.
6 VOMP is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 VOMP is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with VOMP; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 #include "vrecordinglist.h"
23 VRecordingList::VRecordingList()
25 viewman = ViewMan::getInstance();
30 if (Video::getInstance()->getFormat() == Video::PAL)
39 setBackgroundColour(Colour::VIEWBACKGROUND);
41 setTitleBarColour(Colour::TITLEBARBACKGROUND);
43 sl.setSurface(surface);
44 sl.setSurfaceOffset(10, 30 + 5);
45 sl.setDimensions(area.w - 20, area.h - 30 - 15 - 30);
48 VRecordingList::~VRecordingList()
53 void VRecordingList::drawData(bool doIndexPop)
55 int saveIndex = sl.getCurrentOption();
56 int saveTop = sl.getTopOption();
64 char tempA[300]; // FIXME this is guesswork!
65 char tempB[300]; // FIXME
68 Directory* currentSubDir;
69 DirectoryList::iterator i;
70 DirectoryList* dirList = recman->getDirectories();
71 for (i = dirList->begin(); i != dirList->end(); i++)
74 SNPRINTF(tempA, 299, tr("<dir> %lu\t%s"), currentSubDir->getNumRecordings(), currentSubDir->name);
75 currentSubDir->index = sl.addOption(tempA, 0, first);
79 // FIXME convert the whole program to time_t's
81 Recording* currentRec;
82 RecordingList::iterator j;
83 RecordingList* recList = recman->getRecordings();
84 for (j = recList->begin(); j != recList->end(); j++)
87 time_t recStartTime = (time_t)currentRec->getStartTime();
88 btime = localtime(&recStartTime);
90 strftime(tempA, 299, "%0d/%0m %0H:%0M ", btime);
92 strftime(tempA, 299, "%d/%m %H:%M ", btime);
94 sprintf(tempB, "%s\t%s", tempA, currentRec->getProgName());
95 currentRec->index = sl.addOption(tempB, 0, first);
101 sl.hintSetCurrent(slIndexStack.top());
106 sl.hintSetCurrent(saveIndex);
107 sl.hintSetTop(saveTop);
113 void VRecordingList::draw(bool doIndexPop)
117 if (recman->isSubDir())
120 SNPRINTF(title, 299, tr("Recordings - %s"), recman->getCurDirName());
125 setTitleText(tr("Recordings"));
133 drawText(tr("Loading..."), 240, 180, Colour::LIGHTTEXT);
138 int gigFree = recman->getFreeSpace() / 1024;
139 SNPRINTF(freeSpace, 49, tr("%lu%% used, %iGB free"), recman->getUsedPercent(), gigFree);
140 drawTextRJ(freeSpace, 560, 5, Colour::LIGHTTEXT);
145 w.setSurface(surface);
147 w.nextSymbol = WSymbol::UP;
148 w.setSurfaceOffset(20, 385);
151 w.nextSymbol = WSymbol::DOWN;
152 w.setSurfaceOffset(50, 385);
155 w.nextSymbol = WSymbol::SKIPBACK;
156 w.setSurfaceOffset(85, 385);
159 w.nextSymbol = WSymbol::SKIPFORWARD;
160 w.setSurfaceOffset(115, 385);
163 w.nextSymbol = WSymbol::PLAY;
164 w.setSurfaceOffset(150, 385);
167 drawTextRJ(tr("[ok] = menu"), 560, 385, Colour::LIGHTTEXT);
169 // All static stuff done
171 drawData(doIndexPop);
175 void VRecordingList::doShowingBar()
177 int topOption = sl.getTopOption() + 1;
178 if (sl.getNumOptions() == 0) topOption = 0;
180 rectangle(220, 385, 180, 25, Colour::VIEWBACKGROUND);
182 sprintf(showing, tr("%i to %i of %i"), topOption, sl.getBottomOption(), sl.getNumOptions());
183 drawText(showing, 220, 385, Colour::LIGHTTEXT);
186 void VRecordingList::processMessage(Message* m)
188 Log::getInstance()->log("VRecordingList", Log::DEBUG, "Got message value %lu", m->message);
189 if (m->message == Message::DELETE_SELECTED_RECORDING)
191 Log::getInstance()->log("VRecordingList", Log::DEBUG, "Doing delete selected");
196 if (m->message == Message::MOVE_RECORDING)
198 Log::getInstance()->log("VRecordingList", Log::DEBUG, "Doing move recording");
199 doMoveRecording((Directory*)m->parameter);
203 if (m->message == Message::PLAY_SELECTED_RECORDING)
209 if (m->message == Message::RESUME_SELECTED_RECORDING)
216 void VRecordingList::doDeleteSelected()
218 Recording* toDelete = getCurrentOptionRecording();
220 if (!toDelete) return;
222 Log::getInstance()->log("VRecordingList", Log::DEBUG, "FOUND: %i %s %s", toDelete->index, toDelete->getProgName(), toDelete->getFileName());
224 int success = recman->deleteRecording(toDelete);
225 if (!VDR::getInstance()->isConnected())
227 Command::getInstance()->connectionLost();
233 VInfo* vi = new VInfo();
234 vi->create(360, 200);
235 if (Video::getInstance()->getFormat() == Video::PAL)
236 vi->setScreenPos(190, 170);
238 vi->setScreenPos(180, 120);
239 vi->setOneLiner(tr("Failed to delete recording"));
242 vi->setTitleBarColour(Colour::DANGER);
246 viewman->updateView(vi);
251 viewman->updateView(this);
256 void VRecordingList::doMoveRecording(Directory* toDir)
258 Recording* toMove = getCurrentOptionRecording();
259 if (!toMove || !toDir) return;
261 Log::getInstance()->log("VRecordingList", Log::DEBUG, "MOVE: %s %s", toMove->getProgName(), toDir->name);
263 int success = recman->moveRecording(toMove, toDir);
264 if (!VDR::getInstance()->isConnected())
266 Command::getInstance()->connectionLost();
272 VInfo* vi = new VInfo();
273 vi->create(360, 200);
274 if (Video::getInstance()->getFormat() == Video::PAL)
275 vi->setScreenPos(190, 170);
277 vi->setScreenPos(180, 120);
278 vi->setOneLiner(tr("Failed to move recording"));
281 vi->setTitleBarColour(Colour::DANGER);
285 viewman->updateView(vi);
290 viewman->updateView(this);
294 int VRecordingList::doPlay(bool resume)
296 Recording* toPlay = getCurrentOptionRecording();
299 toPlay->loadRecInfo();
300 if (toPlay->recInfo->hasVideo())
302 VVideoRec* vidrec = new VVideoRec(toPlay);
304 viewman->add(vidrec);
305 viewman->updateView(vidrec);
310 VRadioRec* radrec = new VRadioRec(toPlay);
312 viewman->add(radrec);
313 viewman->updateView(radrec);
318 // should not get to here
322 Recording* VRecordingList::getCurrentOptionRecording()
324 Recording* currentRec;
325 RecordingList::iterator j;
326 RecordingList* recList = recman->getRecordings();
327 for (j = recList->begin(); j != recList->end(); j++)
330 if (currentRec->index == sl.getCurrentOption()) return currentRec;
336 int VRecordingList::handleCommand(int command)
347 viewman->updateView(this);
350 case Remote::DF_DOWN:
353 Log::getInstance()->log("P", Log::DEBUG, "1");
355 Log::getInstance()->log("P", Log::DEBUG, "1.5");
357 Log::getInstance()->log("P", Log::DEBUG, "2");
360 Log::getInstance()->log("P", Log::DEBUG, "3");
361 viewman->updateView(this);
362 Log::getInstance()->log("P", Log::DEBUG, "4");
365 case Remote::SKIPBACK:
371 viewman->updateView(this);
374 case Remote::SKIPFORWARD:
380 viewman->updateView(this);
385 if (sl.getNumOptions() == 0) return 2;
387 // Check to see if it is a sub directory
388 Directory* currentSubDir;
389 DirectoryList::iterator i;
390 DirectoryList* dirList = recman->getDirectories();
391 for (i = dirList->begin(); i != dirList->end(); i++)
394 if (currentSubDir->index == sl.getCurrentOption())
396 if (recman->down(currentSubDir))
398 slIndexStack.push(sl.getCurrentOption());
401 viewman->updateView(this);
407 // check to see if it's a recording
408 Recording* current = getCurrentOptionRecording();
411 Log::getInstance()->log("VRecordingList", Log::DEBUG, "Found the option you pointed at. %s %s", current->getProgName(), current->getFileName());
413 VRecordingMenu* v = new VRecordingMenu(recman);
415 v->setRecording(current);
418 viewman->updateView(v);
421 // should not get to here
426 if (recman->isSubDir())
431 viewman->updateView(this);
441 if (doPlay(true)) return 2;
446 // stop command getting to any more views
450 bool VRecordingList::load()
452 recman = new RecMan();
453 bool success = VDR::getInstance()->getRecordingsList(recman);
458 viewman->updateView(this);