messenger-gtk

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

file_load_entry.h (1804B)


      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/file_load_entry.h
     23  */
     24 
     25 #ifndef UI_FILE_LOAD_ENTRY_H_
     26 #define UI_FILE_LOAD_ENTRY_H_
     27 
     28 #include <gnunet/gnunet_chat_lib.h>
     29 
     30 #include "messenger.h"
     31 
     32 typedef struct UI_CHAT_TITLE_Handle UI_CHAT_TITLE_Handle;
     33 
     34 typedef struct UI_FILE_LOAD_ENTRY_Handle
     35 {
     36   UI_CHAT_TITLE_Handle *chat_title;
     37 
     38   GtkBuilder *builder;
     39 
     40   GtkWidget *entry_box;
     41 
     42   GtkImage *file_image;
     43   GtkLabel *file_label;
     44 
     45   GtkProgressBar *load_progress_bar;
     46 
     47   GtkButton *cancel_button;
     48 } UI_FILE_LOAD_ENTRY_Handle;
     49 
     50 /**
     51  * Allocates and creates a new file load entry
     52  * handle to manage loading files for a given
     53  * messenger application.
     54  *
     55  * @param app Messenger application
     56  * @return New file load entry handle
     57  */
     58 UI_FILE_LOAD_ENTRY_Handle*
     59 ui_file_load_entry_new(MESSENGER_Application *app);
     60 
     61 /**
     62  * Frees its resources and destroys a given file
     63  * load entry handle.
     64  *
     65  * @param handle File load entry handle
     66  */
     67 void
     68 ui_file_load_entry_delete(UI_FILE_LOAD_ENTRY_Handle *handle);
     69 
     70 #endif /* UI_FILE_LOAD_ENTRY_H_ */