messenger-gtk

Gtk+3 graphical user interfaces for GNUnet Messenger
Log | Files | Refs | Submodules | README | LICENSE

new_lobby.h (2025B)


      1 /*
      2    This file is part of GNUnet.
      3    Copyright (C) 2022--2024 GNUnet e.V.
      4 
      5    GNUnet is free software: you can redistribute it and/or modify it
      6    under the terms of the GNU Affero General Public License as published
      7    by the Free Software Foundation, either version 3 of the License,
      8    or (at your option) any later version.
      9 
     10    GNUnet is distributed in the hope that it will be useful, but
     11    WITHOUT ANY WARRANTY; without even the implied warranty of
     12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     13    Affero General Public License for more details.
     14 
     15    You should have received a copy of the GNU Affero General Public License
     16    along with this program.  If not, see <http://www.gnu.org/licenses/>.
     17 
     18    SPDX-License-Identifier: AGPL3.0-or-later
     19  */
     20 /*
     21  * @author Tobias Frisch
     22  * @file ui/new_lobby.h
     23  */
     24 
     25 #ifndef UI_NEW_LOBBY_H_
     26 #define UI_NEW_LOBBY_H_
     27 
     28 #include "messenger.h"
     29 
     30 #include <cairo/cairo.h>
     31 #include <gdk/gdkpixbuf.h>
     32 #include <qrencode.h>
     33 
     34 typedef struct UI_NEW_LOBBY_Handle
     35 {
     36   GtkBuilder *builder;
     37   GtkDialog *dialog;
     38 
     39   GtkInfoBar *warning_info_bar;
     40 
     41   GtkStack *stack;
     42   GtkWidget *generate_box;
     43   GtkWidget *copy_box;
     44 
     45   GtkComboBox *expiration_combo_box;
     46 
     47   GtkStack *preview_stack;
     48   GtkWidget *fail_box;
     49 
     50   GtkSpinner *loading_spinner;
     51 
     52   GtkDrawingArea *id_drawing_area;
     53   GtkEntry *id_entry;
     54 
     55   gulong id_draw_signal;
     56 
     57   GtkButton *cancel_button;
     58   GtkButton *generate_button;
     59   GtkButton *copy_button;
     60 
     61   QRcode *qr;
     62 } UI_NEW_LOBBY_Handle;
     63 
     64 /**
     65  * Initializes a handle for the new lobby dialog
     66  * of a given messenger application.
     67  *
     68  * @param app Messenger application
     69  * @param handle New lobby dialog handle
     70  */
     71 void
     72 ui_new_lobby_dialog_init(MESSENGER_Application *app,
     73                          UI_NEW_LOBBY_Handle *handle);
     74 
     75 /**
     76  * Cleans up the allocated resources and resets the
     77  * state of a given new lobby dialog handle.
     78  *
     79  * @param handle New lobby dialog handle
     80  */
     81 void
     82 ui_new_lobby_dialog_cleanup(UI_NEW_LOBBY_Handle *handle);
     83 
     84 #endif /* UI_NEW_LOBBY_H_ */