1
/*****************************************************************
3
Copyright 2008 Christian Mollekopf <chrigi_1@hotmail.com>
5
Permission is hereby granted, free of charge, to any person obtaining a copy
6
of this software and associated documentation files (the "Software"), to deal
7
in the Software without restriction, including without limitation the rights
8
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
copies of the Software, and to permit persons to whom the Software is
10
furnished to do so, subject to the following conditions:
12
The above copyright notice and this permission notice shall be included in
13
all copies or substantial portions of the Software.
15
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
19
AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
20
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22
******************************************************************/
24
#ifndef MANUALGROUPINGSTRATEGY_H
25
#define MANUALGROUPINGSTRATEGY_H
27
#include "abstractgroupingstrategy.h"
28
#include "taskgroup.h"
29
//#include "taskmanager.h"
36
class ManualGroupingStrategy;
39
* Allows to manually group tasks
41
class ManualGroupingStrategy: public AbstractGroupingStrategy
45
ManualGroupingStrategy(GroupManager *groupManager);
46
~ManualGroupingStrategy();
48
/** looks up if this item has been grouped before and groups it accordingly.
49
*otherwise the item goes to the rootGroup
51
void handleItem(AbstractGroupableItem *);
52
/** Should be called if the user wants to manually add an item to a group */
53
//bool addItemToGroup(AbstractGroupableItem*, TaskGroup*);
54
/** Should be called if the user wants to group items manually */
55
bool groupItems(ItemList items);
57
/** Returns list of actions that a task can do in this groupingStrategy
58
* fore example: remove this Task from this group
60
QList<QAction*> strategyActions(QObject *parent, AbstractGroupableItem *item);
62
EditableGroupProperties editableGroupProperties();
65
/** Checks if the group is still necessary, removes group if empty*/
69
bool manualGrouping(TaskItem* taskItem, TaskGroup* groupItem);
73
/** Actions which the strategy offers*/
74
/** sender item leaves group*/
76
/** Removes all items from the sender group and adds to the parent Group*/