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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
/*
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) version 3.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with the program; if not, see <http://www.gnu.org/licenses/>
*
*
* Authors:
* Michel Zucchi <notzed@ximian.com>
*
* Copyright (C) 1999-2008 Novell, Inc. (www.novell.com)
*
*/
#ifndef __E_CAL_MENU_H__
#define __E_CAL_MENU_H__
#include <glib-object.h>
#include "e-util/e-menu.h"
#ifdef __cplusplus
extern "C" {
#pragma }
#endif /* __cplusplus */
typedef struct _ECalMenu ECalMenu;
typedef struct _ECalMenuClass ECalMenuClass;
/* Current target description */
/* Types of popup tagets */
enum _e_cal_menu_target_t {
E_CAL_MENU_TARGET_SELECT
};
/**
* enum _e_cal_menu_target_select_t - ECalPopupTargetSelect qualifiers.
*
* @E_CAL_MENU_SELECT_ONE: Only one item is selected.
* @E_CAL_MENU_SELECT_MANY: More than one item selected.
* @E_CAL_MENU_SELECT_ANY: One or more items selected.
* @E_CAL_MENU_SELECT_EDITABLE: The selection is editable.
* @E_CAL_MENU_SELECT_RECURRING: Is a recurring event.
* @E_CAL_MENU_SELECT_NONRECURRING: Is not a recurring event.
* @E_CAL_MENU_SELECT_INSTANCE: This is an instance event.
* @E_CAL_MENU_SELECT_ORGANIZER: The user is the organiser of the event.
* @E_CAL_MENU_SELECT_NOTEDITING: The event is not being edited already. Not implemented.
* @E_CAL_MENU_SELECT_NOTMEETING: The event is not a meeting.
* @E_CAL_MENU_SELECT_ASSIGNABLE: An assignable task.
* @E_CAL_MENU_SELECT_HASURL: A task that contains a URL.
**/
enum _e_cal_menu_target_select_t {
E_CAL_MENU_SELECT_ONE = 1<<0,
E_CAL_MENU_SELECT_MANY = 1<<1,
E_CAL_MENU_SELECT_ANY = 1<<2,
E_CAL_MENU_SELECT_EDITABLE = 1<<3,
E_CAL_MENU_SELECT_RECURRING = 1<<4,
E_CAL_MENU_SELECT_NONRECURRING = 1<<5,
E_CAL_MENU_SELECT_INSTANCE = 1<<6,
E_CAL_MENU_SELECT_ORGANIZER = 1<<7,
E_CAL_MENU_SELECT_NOTEDITING = 1<<8,
E_CAL_MENU_SELECT_NOTMEETING = 1<<9,
E_CAL_MENU_SELECT_ASSIGNABLE = 1<<10,
E_CAL_MENU_SELECT_HASURL = 1<<11,
E_CAL_MENU_SELECT_NOTCOMPLETE = 1<<12
};
typedef struct _ECalMenuTargetSelect ECalMenuTargetSelect;
struct _ECalMenuTargetSelect {
EMenuTarget target;
struct _ECalModel *model;
GPtrArray *events;
};
typedef struct _EMenuItem ECalMenuItem;
/* The object */
struct _ECalMenu {
EMenu menu;
struct _ECalMenuPrivate *priv;
};
struct _ECalMenuClass {
EMenuClass menu_class;
};
GType e_cal_menu_get_type(void);
ECalMenu *e_cal_menu_new(const gchar *menuid);
ECalMenuTargetSelect *e_cal_menu_target_new_select(ECalMenu *emp, struct _ECalModel *model, GPtrArray *events);
/* ********************************************************************** */
typedef struct _ECalMenuHook ECalMenuHook;
typedef struct _ECalMenuHookClass ECalMenuHookClass;
struct _ECalMenuHook {
EMenuHook hook;
};
struct _ECalMenuHookClass {
EMenuHookClass hook_class;
};
GType e_cal_menu_hook_get_type(void);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* __E_CAL_MENU_H__ */
|