[epiphany/pgriffis/web-extension/windows: 2/8] WebExtensions: Implement windows.getCurrent()
- From: Patrick Griffis <pgriffis src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [epiphany/pgriffis/web-extension/windows: 2/8] WebExtensions: Implement windows.getCurrent()
- Date: Wed, 8 Jun 2022 17:51:04 +0000 (UTC)
commit 314853108a96656bbc724902552765ce687cdc5b
Author: Patrick Griffis <pgriffis igalia com>
Date: Tue Jun 7 14:49:28 2022 -0500
WebExtensions: Implement windows.getCurrent()
src/webextension/api/windows.c | 30 ++++++++++++++++++++++++++++++
1 file changed, 30 insertions(+)
---
diff --git a/src/webextension/api/windows.c b/src/webextension/api/windows.c
index 422de6213..8abbfbbdf 100644
--- a/src/webextension/api/windows.c
+++ b/src/webextension/api/windows.c
@@ -149,8 +149,38 @@ windows_handler_get (EphyWebExtension *self,
return json_to_string (root, FALSE);
}
+static char *
+windows_handler_get_current (EphyWebExtension *self,
+ char *name,
+ JSCValue *args,
+ WebKitWebView *web_view,
+ GError **error)
+{
+ EphyWebExtensionManager *manager = ephy_web_extension_manager_get_default ();
+ g_autoptr (JSCValue) get_info_value = jsc_value_object_get_property_at_index (args, 0);
+ g_autoptr (JsonBuilder) builder = json_builder_new ();
+ g_autoptr (JsonNode) root = NULL;
+ gboolean populate_tabs = FALSE;
+ EphyWindow *window;
+
+ if (web_view == ephy_web_extension_manager_get_background_web_view (manager, self))
+ window = EPHY_WINDOW (gtk_application_get_active_window (GTK_APPLICATION (ephy_shell_get_default ())));
+ else
+ window = EPHY_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (web_view)));
+
+ if (jsc_value_is_object (get_info_value)) {
+ g_autoptr (JSCValue) populate = jsc_value_object_get_property (get_info_value, "populate");
+ populate_tabs = jsc_value_to_boolean (populate);
+ }
+
+ add_window_to_json (self, builder, window, populate_tabs);
+ root = json_builder_get_root (builder);
+ return json_to_string (root, FALSE);
+}
+
static EphyWebExtensionSyncApiHandler windows_handlers[] = {
{"get", windows_handler_get},
+ {"getCurrent", windows_handler_get_current},
};
void
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]