Use new style API for global user stylesheets
This commit is contained in:
parent
968c967592
commit
4854e2e2d7
1 changed files with 56 additions and 1 deletions
|
@ -1076,6 +1076,7 @@ css_metadata_from_file (const gchar* filename,
|
||||||
static gboolean
|
static gboolean
|
||||||
addons_get_element_content (gchar* file_path,
|
addons_get_element_content (gchar* file_path,
|
||||||
AddonsKind kind,
|
AddonsKind kind,
|
||||||
|
gboolean has_metadata,
|
||||||
gchar** content)
|
gchar** content)
|
||||||
{
|
{
|
||||||
gchar* file_content;
|
gchar* file_content;
|
||||||
|
@ -1156,6 +1157,8 @@ addons_get_element_content (gchar* file_path,
|
||||||
g_string_append_c (content_chunks, file_content[i]);
|
g_string_append_c (content_chunks, file_content[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (has_metadata)
|
||||||
|
{
|
||||||
*content = g_strdup_printf (
|
*content = g_strdup_printf (
|
||||||
"window.addEventListener ('DOMContentLoaded',"
|
"window.addEventListener ('DOMContentLoaded',"
|
||||||
"function () {"
|
"function () {"
|
||||||
|
@ -1169,6 +1172,12 @@ addons_get_element_content (gchar* file_path,
|
||||||
"}, true);",
|
"}, true);",
|
||||||
content_chunks->str);
|
content_chunks->str);
|
||||||
g_string_free (content_chunks, TRUE);
|
g_string_free (content_chunks, TRUE);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
*content = content_chunks->str;
|
||||||
|
g_string_free (content_chunks, FALSE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
g_free (file_content);
|
g_free (file_content);
|
||||||
if (*content)
|
if (*content)
|
||||||
|
@ -1252,7 +1261,7 @@ addons_update_elements (MidoriExtension* extension,
|
||||||
katze_assign (element->displayname, name);
|
katze_assign (element->displayname, name);
|
||||||
|
|
||||||
if (!element->broken)
|
if (!element->broken)
|
||||||
if (!addons_get_element_content (fullpath, kind,
|
if (!addons_get_element_content (fullpath, kind, FALSE,
|
||||||
&(element->script_content)))
|
&(element->script_content)))
|
||||||
element->broken = TRUE;
|
element->broken = TRUE;
|
||||||
|
|
||||||
|
@ -1268,6 +1277,7 @@ addons_update_elements (MidoriExtension* extension,
|
||||||
|
|
||||||
if (!element->broken)
|
if (!element->broken)
|
||||||
if (!addons_get_element_content (fullpath, kind,
|
if (!addons_get_element_content (fullpath, kind,
|
||||||
|
element->includes || element->excludes,
|
||||||
&(element->script_content)))
|
&(element->script_content)))
|
||||||
element->broken = TRUE;
|
element->broken = TRUE;
|
||||||
|
|
||||||
|
@ -1550,6 +1560,41 @@ addons_browser_destroy (MidoriBrowser* browser,
|
||||||
gtk_widget_destroy (styles);
|
gtk_widget_destroy (styles);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static char*
|
||||||
|
addons_generate_global_stylesheet (MidoriExtension* extension)
|
||||||
|
{
|
||||||
|
GSList* styles;
|
||||||
|
struct AddonElement* style;
|
||||||
|
struct AddonsList* styles_list;
|
||||||
|
GString* style_string = g_string_new ("");
|
||||||
|
|
||||||
|
styles_list = g_object_get_data (G_OBJECT (extension), "styles-list");
|
||||||
|
styles = styles_list->elements;
|
||||||
|
while (styles != NULL)
|
||||||
|
{
|
||||||
|
style = styles->data;
|
||||||
|
if (style->enabled &&
|
||||||
|
!(style->includes || style->excludes || style->broken))
|
||||||
|
{
|
||||||
|
style_string = g_string_append (style_string, style->script_content);
|
||||||
|
}
|
||||||
|
styles = g_slist_next (styles);
|
||||||
|
}
|
||||||
|
|
||||||
|
return g_string_free (style_string, FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
addons_apply_global_stylesheet (MidoriExtension* extension)
|
||||||
|
{
|
||||||
|
MidoriApp* app = midori_extension_get_app (extension);
|
||||||
|
MidoriWebSettings* settings = katze_object_get_object (app, "settings");
|
||||||
|
gchar* data = addons_generate_global_stylesheet (extension);
|
||||||
|
midori_web_settings_add_style (settings, "addons", data);
|
||||||
|
g_free (data);
|
||||||
|
g_object_unref (settings);
|
||||||
|
}
|
||||||
|
|
||||||
GtkWidget*
|
GtkWidget*
|
||||||
addons_new (AddonsKind kind, MidoriExtension* extension)
|
addons_new (AddonsKind kind, MidoriExtension* extension)
|
||||||
{
|
{
|
||||||
|
@ -1572,6 +1617,10 @@ addons_new (AddonsKind kind, MidoriExtension* extension)
|
||||||
GTK_TREE_MODEL (liststore));
|
GTK_TREE_MODEL (liststore));
|
||||||
gtk_widget_queue_draw (GTK_WIDGET (ADDONS(addons)->treeview));
|
gtk_widget_queue_draw (GTK_WIDGET (ADDONS(addons)->treeview));
|
||||||
|
|
||||||
|
if (kind == ADDONS_USER_STYLES)
|
||||||
|
g_signal_connect_swapped (liststore, "row-changed",
|
||||||
|
G_CALLBACK (addons_apply_global_stylesheet), extension);
|
||||||
|
|
||||||
return addons;
|
return addons;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1672,12 +1721,14 @@ static void
|
||||||
addons_deactivate_cb (MidoriExtension* extension,
|
addons_deactivate_cb (MidoriExtension* extension,
|
||||||
MidoriApp* app)
|
MidoriApp* app)
|
||||||
{
|
{
|
||||||
|
MidoriWebSettings* settings = katze_object_get_object (app, "settings");
|
||||||
KatzeArray* browsers;
|
KatzeArray* browsers;
|
||||||
MidoriBrowser* browser;
|
MidoriBrowser* browser;
|
||||||
GSource* source;
|
GSource* source;
|
||||||
|
|
||||||
addons_disable_monitors (extension);
|
addons_disable_monitors (extension);
|
||||||
addons_save_settings (NULL, extension);
|
addons_save_settings (NULL, extension);
|
||||||
|
midori_web_settings_remove_style (settings, "addons");
|
||||||
|
|
||||||
browsers = katze_object_get_object (app, "browsers");
|
browsers = katze_object_get_object (app, "browsers");
|
||||||
KATZE_ARRAY_FOREACH_ITEM (browser, browsers)
|
KATZE_ARRAY_FOREACH_ITEM (browser, browsers)
|
||||||
|
@ -1695,6 +1746,7 @@ addons_deactivate_cb (MidoriExtension* extension,
|
||||||
extension, addons_deactivate_cb, app);
|
extension, addons_deactivate_cb, app);
|
||||||
|
|
||||||
g_object_unref (browsers);
|
g_object_unref (browsers);
|
||||||
|
g_object_unref (settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
@ -1781,6 +1833,7 @@ static void
|
||||||
addons_activate_cb (MidoriExtension* extension,
|
addons_activate_cb (MidoriExtension* extension,
|
||||||
MidoriApp* app)
|
MidoriApp* app)
|
||||||
{
|
{
|
||||||
|
MidoriWebSettings* settings = katze_object_get_object (app, "settings");
|
||||||
KatzeArray* browsers;
|
KatzeArray* browsers;
|
||||||
MidoriBrowser* browser;
|
MidoriBrowser* browser;
|
||||||
|
|
||||||
|
@ -1789,10 +1842,12 @@ addons_activate_cb (MidoriExtension* extension,
|
||||||
addons_monitor_directories (extension, ADDONS_USER_STYLES);
|
addons_monitor_directories (extension, ADDONS_USER_STYLES);
|
||||||
addons_update_elements (extension, ADDONS_USER_SCRIPTS);
|
addons_update_elements (extension, ADDONS_USER_SCRIPTS);
|
||||||
addons_monitor_directories (extension, ADDONS_USER_SCRIPTS);
|
addons_monitor_directories (extension, ADDONS_USER_SCRIPTS);
|
||||||
|
midori_web_settings_remove_style (settings, "addons");
|
||||||
|
|
||||||
KATZE_ARRAY_FOREACH_ITEM (browser, browsers)
|
KATZE_ARRAY_FOREACH_ITEM (browser, browsers)
|
||||||
addons_app_add_browser_cb (app, browser, extension);
|
addons_app_add_browser_cb (app, browser, extension);
|
||||||
g_object_unref (browsers);
|
g_object_unref (browsers);
|
||||||
|
g_object_unref (settings);
|
||||||
|
|
||||||
g_signal_connect (app, "add-browser",
|
g_signal_connect (app, "add-browser",
|
||||||
G_CALLBACK (addons_app_add_browser_cb), extension);
|
G_CALLBACK (addons_app_add_browser_cb), extension);
|
||||||
|
|
Loading…
Reference in a new issue