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_ */