messenger-gtk

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

new_account.h (2110B)


      1 /*
      2    This file is part of GNUnet.
      3    Copyright (C) 2021--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_account.h
     23  */
     24 
     25 #ifndef UI_NEW_ACCOUNT_H_
     26 #define UI_NEW_ACCOUNT_H_
     27 
     28 #include "messenger.h"
     29 
     30 typedef struct UI_NEW_ACCOUNT_Handle
     31 {
     32   gchar *filename;
     33 
     34   GtkBuilder *builder;
     35   GtkDialog *dialog;
     36 
     37   HdyAvatar *account_avatar;
     38   GtkFileChooserButton *account_avatar_file;
     39 
     40   GtkEntry *account_entry;
     41 
     42   GtkButton *cancel_button;
     43   GtkButton *confirm_button;
     44 } UI_NEW_ACCOUNT_Handle;
     45 
     46 /**
     47  * Initializes a handle for the new account dialog
     48  * of a given messenger application.
     49  *
     50  * @param app Messenger application
     51  * @param handle New account dialog handle
     52  */
     53 void
     54 ui_new_account_dialog_init(MESSENGER_Application *app,
     55                            UI_NEW_ACCOUNT_Handle *handle);
     56 
     57 /**
     58  * Triggers an update of a new account dialog handle
     59  * to process selected changes regarding the new 
     60  * account and finish account creation.
     61  *
     62  * @param app Messenger application
     63  * @param handle New account dialog handle
     64  */
     65 void
     66 ui_new_account_dialog_update(MESSENGER_Application *app,
     67                              UI_NEW_ACCOUNT_Handle *handle);
     68 
     69 /**
     70  * Cleans up the allocated resources and resets the
     71  * state of a given new account dialog handle.
     72  *
     73  * @param handle New account dialog handle
     74  */
     75 void
     76 ui_new_account_dialog_cleanup(UI_NEW_ACCOUNT_Handle *handle);
     77 
     78 #endif /* UI_NEW_ACCOUNT_H_ */