2013-10-15 11:21:10 -04:00
|
|
|
/*
|
|
|
|
* Copyright © 2013 Lars Uebernickel
|
|
|
|
*
|
2022-05-18 09:12:45 +01:00
|
|
|
* SPDX-License-Identifier: LGPL-2.1-or-later
|
|
|
|
*
|
2013-10-15 11:21:10 -04:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
2017-05-27 18:21:30 +02:00
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
2013-10-15 11:21:10 -04:00
|
|
|
*
|
|
|
|
* This library 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
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General
|
2014-01-23 12:58:29 +01:00
|
|
|
* Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
2013-10-15 11:21:10 -04:00
|
|
|
*
|
|
|
|
* Authors: Lars Uebernickel <lars@uebernic.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __G_NOTIFICATION_H__
|
|
|
|
#define __G_NOTIFICATION_H__
|
|
|
|
|
|
|
|
#if !defined (__GIO_GIO_H_INSIDE__) && !defined (GIO_COMPILATION)
|
|
|
|
#error "Only <gio/gio.h> can be included directly."
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <gio/giotypes.h>
|
2014-06-15 15:42:31 +02:00
|
|
|
#include <gio/gioenums.h>
|
2013-10-15 11:21:10 -04:00
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
#define G_TYPE_NOTIFICATION (g_notification_get_type ())
|
|
|
|
#define G_NOTIFICATION(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), G_TYPE_NOTIFICATION, GNotification))
|
|
|
|
#define G_IS_NOTIFICATION(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), G_TYPE_NOTIFICATION))
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
GType g_notification_get_type (void) G_GNUC_CONST;
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
GNotification * g_notification_new (const gchar *title);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
void g_notification_set_title (GNotification *notification,
|
|
|
|
const gchar *title);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
void g_notification_set_body (GNotification *notification,
|
|
|
|
const gchar *body);
|
|
|
|
|
2024-04-19 10:32:57 +02:00
|
|
|
GIO_AVAILABLE_IN_2_85
|
|
|
|
void g_notification_set_body_with_markup (GNotification *notification,
|
|
|
|
const gchar *markup_body);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 12:19:09 -04:00
|
|
|
void g_notification_set_icon (GNotification *notification,
|
|
|
|
GIcon *icon);
|
2013-10-15 11:21:10 -04:00
|
|
|
|
2024-11-27 13:12:52 +01:00
|
|
|
GIO_AVAILABLE_IN_2_85
|
|
|
|
void g_notification_set_sound (GNotification *notification,
|
|
|
|
GNotificationSound *sound);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_DEPRECATED_IN_2_42_FOR(g_notification_set_priority)
|
2013-10-15 11:21:10 -04:00
|
|
|
void g_notification_set_urgent (GNotification *notification,
|
|
|
|
gboolean urgent);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_42
|
2014-06-15 15:42:31 +02:00
|
|
|
void g_notification_set_priority (GNotification *notification,
|
|
|
|
GNotificationPriority priority);
|
|
|
|
|
2024-04-18 11:02:10 +02:00
|
|
|
GIO_AVAILABLE_IN_2_85
|
|
|
|
void g_notification_set_display_hint_flags (GNotification *notification,
|
|
|
|
GNotificationDisplayHintFlags flags);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_70
|
2021-07-28 16:45:26 +02:00
|
|
|
void g_notification_set_category (GNotification *notification,
|
|
|
|
const gchar *category);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
void g_notification_add_button (GNotification *notification,
|
|
|
|
const gchar *label,
|
|
|
|
const gchar *detailed_action);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
void g_notification_add_button_with_target (GNotification *notification,
|
|
|
|
const gchar *label,
|
|
|
|
const gchar *action,
|
|
|
|
const gchar *target_format,
|
|
|
|
...);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
void g_notification_add_button_with_target_value (GNotification *notification,
|
|
|
|
const gchar *label,
|
|
|
|
const gchar *action,
|
|
|
|
GVariant *target);
|
|
|
|
|
2024-05-02 10:32:19 +02:00
|
|
|
GIO_AVAILABLE_IN_2_85
|
|
|
|
void g_notification_add_button_with_purpose_and_target_value (GNotification *notification,
|
|
|
|
const gchar *label,
|
|
|
|
const gchar *purpose,
|
|
|
|
const gchar *action,
|
|
|
|
GVariant *target);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
void g_notification_set_default_action (GNotification *notification,
|
|
|
|
const gchar *detailed_action);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
void g_notification_set_default_action_and_target (GNotification *notification,
|
|
|
|
const gchar *action,
|
|
|
|
const gchar *target_format,
|
|
|
|
...);
|
|
|
|
|
2022-10-05 13:39:21 -04:00
|
|
|
GIO_AVAILABLE_IN_2_40
|
2013-10-15 11:21:10 -04:00
|
|
|
void g_notification_set_default_action_and_target_value (GNotification *notification,
|
|
|
|
const gchar *action,
|
|
|
|
GVariant *target);
|
|
|
|
|
2024-05-02 09:42:40 +02:00
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_IM_RECEIVED:
|
|
|
|
*
|
|
|
|
* Intended for instant messaging apps displaying notifications for received messages.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_IM_RECEIVED "im.received"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_ALARM_RINGING:
|
|
|
|
*
|
|
|
|
* Intended for alarm clock apps when an alarm is ringing.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_ALARM_RINGING "alarm.ringing"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_CALL_INCOMING:
|
|
|
|
*
|
|
|
|
* Intended for call apps to notify the user about an incoming call.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_CALL_INCOMING "call.incoming"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_CALL_OUTGOING:
|
|
|
|
*
|
|
|
|
* Intended for call apps to notify the user about an ongoing call.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_CALL_OUTGOING "call.ongoing"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_CALL_MISSED:
|
|
|
|
*
|
|
|
|
* Intended for call apps to notify the user about a missed call.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_CALL_UNANSWERED "call.unanswered"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_WEATHER_WARNING_EXTREME:
|
|
|
|
*
|
|
|
|
* Intended to be used to notify the user about extreme weather conditions.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_WEATHER_WARNING_EXTREME "weather.warning.extreme"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_CELLBROADCAST_DANGER_SEVERE:
|
|
|
|
*
|
|
|
|
* Intended to be used to notify users about severe danger warnings broadcasted by the cell network.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_CELLBROADCAST_DANGER_SEVERE "cellbroadcast.danger.extreme"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_CELLBROADCAST_AMBER_ALERT:
|
|
|
|
*
|
|
|
|
* Intended to be used to notify users about amber alerts broadcasted by the cell network.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_CELLBROADCAST_AMBER_ALERT "cellbroadcast.amber-alert"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_CELLBROADCAST_TEST:
|
|
|
|
*
|
|
|
|
* Intended to be used to notify users about tests broadcasted by the cell network.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_CELLBROADCAST_TEST "cellbroadcast.test"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_OS_BATTERY_LOW:
|
|
|
|
*
|
|
|
|
* Intended to be used to indicate that the system is low on battery.
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_OS_BATTERY_LOW "os.battery.low"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_CATEGORY_BROWSER_WEB_NOTIFICATION:
|
|
|
|
*
|
|
|
|
* Intended to be used by browsers to mark notifications sent by websites via
|
|
|
|
* the [Notifications API](https://developer.mozilla.org/en-US/docs/Web/API/Notifications_API).
|
|
|
|
*
|
2024-05-02 10:32:19 +02:00
|
|
|
* Since: 2.85
|
2024-05-02 09:42:40 +02:00
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_CATEGORY_BROWSER_WEB_NOTIFICATION "browser.web-notification"
|
|
|
|
|
2024-05-02 10:32:19 +02:00
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_BUTTON_PURPOSE_CALL_ACCEPT:
|
|
|
|
*
|
|
|
|
* Purpose for a button that accepts an incoming call.
|
|
|
|
*
|
|
|
|
* Since: 2.85
|
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_BUTTON_PURPOSE_CALL_ACCEPT "call.accept"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_BUTTON_PURPOSE_CALL_DECLINE:
|
|
|
|
*
|
|
|
|
* Purpose for a button that declines an incoming call.
|
|
|
|
*
|
|
|
|
* Since: 2.85
|
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_BUTTON_PURPOSE_CALL_DECLINE "call.decline"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_BUTTON_PURPOSE_CALL_HANG_UP:
|
|
|
|
*
|
|
|
|
* Purpose for a button that hangs up an ongoing call.
|
|
|
|
*
|
|
|
|
* Since: 2.85
|
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_BUTTON_PURPOSE_CALL_HANG_UP "call.hang-up"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_BUTTON_PURPOSE_CALL_ENABLE_SPEAKERPHONE:
|
|
|
|
*
|
|
|
|
* Purpose for a button that enables the speakerphone for an ongoing call.
|
|
|
|
*
|
|
|
|
* Since: 2.85
|
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_BUTTON_PURPOSE_CALL_ENABLE_SPEAKERPHONE "call.enable-speakerphone"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_NOTIFICATION_BUTTON_PURPOSE_CALL_DISABLE_SPEAKERPHONE:
|
|
|
|
*
|
|
|
|
* Purpose for a button that disables the speakerphone for an ongoing call.
|
|
|
|
*
|
|
|
|
* Since: 2.85
|
|
|
|
*/
|
|
|
|
#define G_NOTIFICATION_BUTTON_PURPOSE_CALL_DISABLE_SPEAKERPHONE "call.disable-speakerphone"
|
|
|
|
|
2013-10-15 11:21:10 -04:00
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
#endif
|