aboutsummaryrefslogtreecommitdiffstats
path: root/widgets/table/e-cell-popup.h
blob: 2ccfd730ae493006e07f1558c1a551df3fad607a (plain) (blame)
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
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */

/*
 * Author :
 *  Damon Chaplin <damon@ximian.com>
 *
 * Copyright 2001, Ximian, Inc.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation; either version 2 of the
 * License, or (at your option) any later version.
 *
 * 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 General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
 * USA
 */

/*
 * ECellPopup - an ECell used to support popup selections like a GtkCombo
 * widget. It contains a child ECell, e.g. an ECellText, but when selected it
 * displays an arrow on the right edge which the user can click to show a
 * popup. It will support subclassing or signals so that different types of
 * popup can be provided.
 */

#ifndef _E_CELL_POPUP_H_
#define _E_CELL_POPUP_H_

#include <libgnomeui/gnome-canvas.h>
#include <gal/e-table/e-cell.h>

#define E_CELL_POPUP_TYPE        (e_cell_popup_get_type ())
#define E_CELL_POPUP(o)          (GTK_CHECK_CAST ((o), E_CELL_POPUP_TYPE, ECellPopup))
#define E_CELL_POPUP_CLASS(k)    (GTK_CHECK_CLASS_CAST((k), E_CELL_POPUP_TYPE, ECellPopupClass))
#define E_IS_CELL_POPUP(o)       (GTK_CHECK_TYPE ((o), E_CELL_POPUP_TYPE))
#define E_IS_CELL_POPUP_CLASS(k) (GTK_CHECK_CLASS_TYPE ((k), E_CELL_POPUP_TYPE))

typedef struct _ECellPopupView ECellPopupView;

typedef struct {
    ECell parent;

    ECell *child;

    /* This is TRUE if the popup window is shown for the cell being
       edited. While shown we display the arrow indented. */
    gboolean     popup_shown;

    /* This is TRUE if the popup arrow is shown for the cell being edited.
       This is needed to stop the first click on the cell from popping up
       the popup window. We only popup the window after we have drawn the
       arrow. */
    gboolean     popup_arrow_shown;

    /* The view in which the popup is shown. */
    ECellPopupView  *popup_cell_view;

    gint         popup_view_col;
    gint         popup_row;
} ECellPopup;


typedef struct {
    ECellClass parent_class;

    /* Virtual function for subclasses to override. */
    gint       (*popup)        (ECellPopup *ecp, GdkEvent *event);
} ECellPopupClass;


struct _ECellPopupView {
    ECellView    cell_view;

    ECellView   *child_view;
};


GtkType    e_cell_popup_get_type        (void);
ECell     *e_cell_popup_new         (void);

/* Get and set the child ECell. */
ECell     *e_cell_popup_get_child       (ECellPopup *ecp);
void       e_cell_popup_set_child       (ECellPopup *ecp,
                         ECell      *child);

#endif /* _E_CELL_POPUP_H_ */