Roll src/third_party/WebKit d9c6159:8139f33 (svn 201974:201975)
[chromium-blink-merge.git] / chrome / common / extensions / api / notifications.idl
blob7b416053fad2a2ca82ea8186f847b971c0297304
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 // Use the <code>chrome.notifications</code> API to create rich notifications
6 // using templates and show these notifications to users in the system tray.
7 namespace notifications {
8 [noinline_doc] enum TemplateType {
9 // icon, title, message, expandedMessage, up to two buttons
10 basic,
12 // icon, title, message, expandedMessage, image, up to two buttons
13 image,
15 // icon, title, message, items, up to two buttons
16 list,
18 // icon, title, message, progress, up to two buttons
19 progress
22 enum PermissionLevel {
23 // User has elected to show notifications from the app or extension.
24 // This is the default at install time.
25 granted,
27 // User has elected not to show notifications from the app or extension.
28 denied
31 dictionary NotificationItem {
32 // Title of one item of a list notification.
33 DOMString title;
35 // Additional details about this item.
36 DOMString message;
39 [nodoc] dictionary NotificationBitmap {
40 long width;
41 long height;
42 ArrayBuffer? data;
45 dictionary NotificationButton {
46 DOMString title;
47 DOMString? iconUrl;
48 [nodoc] NotificationBitmap? iconBitmap;
51 dictionary NotificationOptions {
52 // Which type of notification to display.
53 // <em>Required for $(ref:notifications.create)</em> method.
54 TemplateType? type;
56 // A URL to the sender's avatar, app icon, or a thumbnail for image
57 // notifications.
59 // URLs can be a data URL, a blob URL, or a URL relative to a resource
60 // within this extension's .crx file
61 // <em>Required for $(ref:notifications.create)</em> method.
62 DOMString? iconUrl;
63 [nodoc] NotificationBitmap? iconBitmap;
65 // A URL to the app icon mask. URLs have the same restrictions as
66 // $(ref:notifications.NotificationOptions.iconUrl iconUrl).
67 //
68 // The app icon mask should be in alpha channel, as only the alpha channel
69 // of the image will be considered.
70 DOMString? appIconMaskUrl;
71 [nodoc] NotificationBitmap? appIconMaskBitmap;
73 // Title of the notification (e.g. sender name for email).
74 // <em>Required for $(ref:notifications.create)</em> method.
75 DOMString? title;
77 // Main notification content.
78 // <em>Required for $(ref:notifications.create)</em> method.
79 DOMString? message;
81 // Alternate notification content with a lower-weight font.
82 DOMString? contextMessage;
84 // Priority ranges from -2 to 2. -2 is lowest priority. 2 is highest. Zero
85 // is default.
86 long? priority;
88 // A timestamp associated with the notification, in milliseconds past the
89 // epoch (e.g. <code>Date.now() + n</code>).
90 double? eventTime;
92 // Text and icons for up to two notification action buttons.
93 NotificationButton[]? buttons;
95 // Secondary notification content.
96 [nodoc] DOMString? expandedMessage;
98 // A URL to the image thumbnail for image-type notifications.
99 // URLs have the same restrictions as
100 // $(ref:notifications.NotificationOptions.iconUrl iconUrl).
101 DOMString? imageUrl;
102 [nodoc] NotificationBitmap? imageBitmap;
104 // Items for multi-item notifications.
105 NotificationItem[]? items;
107 // Current progress ranges from 0 to 100.
108 long? progress;
110 // Whether to show UI indicating that the app will visibly respond to
111 // clicks on the body of a notification.
112 boolean? isClickable;
115 callback CreateCallback = void (DOMString notificationId);
117 callback UpdateCallback = void (boolean wasUpdated);
119 callback ClearCallback = void (boolean wasCleared);
121 callback GetAllCallback = void (object notifications);
123 callback PermissionLevelCallback = void (PermissionLevel level);
125 interface Functions {
126 // Creates and displays a notification.
127 // |notificationId|: Identifier of the notification. If not set or empty, an
128 // ID will automatically be generated. If it matches an existing
129 // notification, this method first clears that notification before
130 // proceeding with the create operation.
132 // The <code>notificationId</code> parameter is required before Chrome 42.
133 // |options|: Contents of the notification.
134 // |callback|: Returns the notification id (either supplied or generated)
135 // that represents the created notification.
137 // The callback is required before Chrome 42.
138 static void create(optional DOMString notificationId,
139 NotificationOptions options,
140 optional CreateCallback callback);
142 // Updates an existing notification.
143 // |notificationId|: The id of the notification to be updated. This is
144 // returned by $(ref:notifications.create) method.
145 // |options|: Contents of the notification to update to.
146 // |callback|: Called to indicate whether a matching notification existed.
148 // The callback is required before Chrome 42.
149 static void update(DOMString notificationId,
150 NotificationOptions options,
151 optional UpdateCallback callback);
153 // Clears the specified notification.
154 // |notificationId|: The id of the notification to be cleared. This is
155 // returned by $(ref:notifications.create) method.
156 // |callback|: Called to indicate whether a matching notification existed.
158 // The callback is required before Chrome 42.
159 static void clear(DOMString notificationId,
160 optional ClearCallback callback);
162 // Retrieves all the notifications.
163 // |callback|: Returns the set of notification_ids currently in the system.
164 static void getAll(GetAllCallback callback);
166 // Retrieves whether the user has enabled notifications from this app
167 // or extension.
168 // |callback|: Returns the current permission level.
169 static void getPermissionLevel(PermissionLevelCallback callback);
172 interface Events {
173 // The notification closed, either by the system or by user action.
174 static void onClosed(DOMString notificationId, boolean byUser);
176 // The user clicked in a non-button area of the notification.
177 static void onClicked(DOMString notificationId);
179 // The user pressed a button in the notification.
180 static void onButtonClicked(DOMString notificationId, long buttonIndex);
182 // The user changes the permission level.
183 static void onPermissionLevelChanged(PermissionLevel level);
185 // The user clicked on a link for the app's notification settings.
186 static void onShowSettings();