/*
 * Copyright © 2005, 2006 Christian Persch
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2, or (at your option)
 *  any later version.
 *
 *  This program 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 General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 *
 */

#include <glib.h>
#include <gtk/gtk.h>

#define COMPILING_TESTSPINNER
#define LOG(msg, args...) g_print(msg, ## args); g_print ("\n")
#define START_PROFILER(name)
#define STOP_PROFILER(name)

#include "ephy-spinner.c"
#include "ephy-spinner-tool-item.c"

#define MOVE_TIMEOUT	211 /* ms */

static void start_or_stop (GtkToggleButton *button, EphySpinner *spinner)
{
	if (gtk_toggle_button_get_active (button))
	{
		ephy_spinner_start (spinner);
	}
	else
	{
		ephy_spinner_stop (spinner);
	}
}

static void add_spinner (GtkTable *table,
			 int row,
			 GtkIconSize size,
			 const char *sizename,
			 guint interval,
			 gboolean start)
{
	GtkWidget *label, *frame, *button, *spinner;
	char *text;

	text = g_strdup_printf ("%s size:", sizename);
	label = gtk_label_new (text);
	gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
	gtk_table_attach_defaults (table, label, 0, 1, row, row + 1);
	g_free (text);

	frame = gtk_frame_new (NULL);
	gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
	gtk_table_attach (table, frame, 1, 2, row, row + 1, GTK_SHRINK, GTK_SHRINK, 0, 0);

	spinner = ephy_spinner_new ();
	ephy_spinner_set_size (EPHY_SPINNER (spinner), size);
	gtk_container_add (GTK_CONTAINER (frame), spinner);

	button = gtk_check_button_new_with_label ("Spin");
	gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), start);
	start_or_stop (GTK_TOGGLE_BUTTON (button), EPHY_SPINNER (spinner));
	g_signal_connect (button, "toggled", G_CALLBACK (start_or_stop), spinner);
	gtk_table_attach_defaults (table, button, 2, 3, row, row + 1);
}

static void move_window (GtkWindow *window)
{
	GdkScreen *screen = gtk_widget_get_screen (GTK_WIDGET (window));
	GdkDisplay *display = gdk_screen_get_display (screen);
	gint number_of_screens = gdk_display_get_n_screens (display);
	gint screen_num = gdk_screen_get_number (screen);
	
	if ((screen_num + 1) < number_of_screens)
	{
		gtk_window_set_screen (window, gdk_display_get_screen (display, screen_num + 1));
	}
	else
	{
		gtk_window_set_screen (window, gdk_display_get_screen (display, 0));
	}
}

static gboolean
move_true (GtkWindow *window)
{
	move_window (window);
	return TRUE;
}

static void
start_or_stop_repeated_moves (GtkWindow *window)
{
	static guint timeout = 0;

	if (timeout == 0)
	{
		timeout = g_timeout_add (MOVE_TIMEOUT, (GSourceFunc) move_true, window);
	}
	else
	{
		g_source_remove (timeout);
		timeout = 0;
	}
}

static void
change_toolbar_style_cb (GtkComboBox *combo,
			 GtkToolbar *toolbar)
{
	int value = gtk_combo_box_get_active (combo);

	gtk_toolbar_set_style (toolbar, value);
}

static void
change_toolbar_icon_size_cb (GtkComboBox *combo,
			     GtkToolbar *toolbar)
{
	int value = gtk_combo_box_get_active (combo);

	if (value == GTK_ICON_SIZE_INVALID)
	{
		gtk_toolbar_unset_icon_size (toolbar);
	}
	else
	{
		gtk_toolbar_set_icon_size (toolbar, value);
	}
}

static void
spin_toolbar_spinner_cb (GtkToggleButton *button,
			 EphySpinnerToolItem *item)
{
	ephy_spinner_tool_item_set_spinning (item, gtk_toggle_button_get_active (button));
}

int main(int argc, char **argv)
{
	GtkWidget *window, *vbox, *vbox2, *widget, *toolbar, *combo;
	GtkToolItem *item;
	GtkTable *table;
	int row = 0, i;
	const char *toolbar_styles[] = {
		"icons",
		"text",
		"both (vertical)",
		"both (horizontal)"
	};
	const char *icon_sizes[] = {
		"default",
		"menu",
		"small toolbar",
		"large toolbar",
		"button",
		"dnd",
		"dialog"
	};
	
	gtk_init (&argc, &argv);

	window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
	gtk_container_set_border_width (GTK_CONTAINER (window), 12);

	vbox = gtk_vbox_new (FALSE, 6);
	gtk_container_add (GTK_CONTAINER (window), vbox);

	widget = gtk_table_new (5, 3, FALSE);
	gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);

	table = GTK_TABLE (widget);
	gtk_table_set_row_spacings (table, 6);
	gtk_table_set_col_spacings (table,12);

	add_spinner (table, row++, GTK_ICON_SIZE_INVALID, "Native", 0, FALSE);
	add_spinner (table, row++, GTK_ICON_SIZE_MENU, "Menu", 0, FALSE);
	add_spinner (table, row++, GTK_ICON_SIZE_SMALL_TOOLBAR, "Small toolbar", 0, FALSE);
	add_spinner (table, row++, GTK_ICON_SIZE_LARGE_TOOLBAR, "Large toolbar", 0, FALSE);
	add_spinner (table, row++, GTK_ICON_SIZE_BUTTON, "Button", 0, FALSE);
	add_spinner (table, row++, GTK_ICON_SIZE_DND, "Drag-and-drop", 0, FALSE);
	add_spinner (table, row++, GTK_ICON_SIZE_DIALOG, "Dialog", 0, FALSE);

	/* Test toolbar */
	vbox2 = gtk_vbox_new (FALSE, 6);
	gtk_box_pack_start (GTK_BOX (vbox), vbox2, FALSE, FALSE, 0);

	toolbar = gtk_toolbar_new ();
	gtk_toolbar_set_style (GTK_TOOLBAR (toolbar), GTK_TOOLBAR_BOTH);
	gtk_box_pack_end (GTK_BOX (vbox2), toolbar, FALSE, FALSE, 0);

	item = gtk_tool_button_new_from_stock (GTK_STOCK_NEW);
	gtk_tool_item_set_homogeneous (item, FALSE);
	gtk_tool_item_set_is_important (item, TRUE);
	gtk_widget_show (GTK_WIDGET (item));
	gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, 0);

	item = gtk_tool_button_new_from_stock (GTK_STOCK_OPEN);
	gtk_tool_item_set_homogeneous (item, FALSE);
	gtk_widget_show (GTK_WIDGET (item));
	gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, 0);

	item = gtk_tool_item_new ();
	gtk_tool_item_set_homogeneous (item, FALSE);
	gtk_widget_show (GTK_WIDGET (item));
	gtk_tool_item_set_expand (item, TRUE);
	gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1);

	item = ephy_spinner_tool_item_new ();
	gtk_widget_show (GTK_WIDGET (item));
	gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1);

	widget = gtk_check_button_new_with_label ("Spin");
	g_signal_connect (widget, "toggled", G_CALLBACK (spin_toolbar_spinner_cb), item);
	gtk_box_pack_start (GTK_BOX (vbox2), widget, FALSE, FALSE, 0);

	combo = gtk_combo_box_new_text ();
	g_signal_connect (combo, "changed", G_CALLBACK (change_toolbar_style_cb), toolbar);
	for (i = 0; i < G_N_ELEMENTS (toolbar_styles); ++i)
	{
		gtk_combo_box_append_text (GTK_COMBO_BOX (combo), toolbar_styles[i]);
	}
	gtk_combo_box_set_active (GTK_COMBO_BOX (combo), GTK_TOOLBAR_BOTH);
	gtk_box_pack_start (GTK_BOX (vbox2), combo, FALSE, FALSE, 0);

	combo = gtk_combo_box_new_text ();
	g_signal_connect (combo, "changed", G_CALLBACK (change_toolbar_icon_size_cb), toolbar);
	for (i = 0; i < G_N_ELEMENTS (icon_sizes); ++i)
	{
		gtk_combo_box_append_text (GTK_COMBO_BOX (combo), icon_sizes[i]);
	}
	gtk_combo_box_set_active (GTK_COMBO_BOX (combo), GTK_ICON_SIZE_INVALID);
	gtk_box_pack_start (GTK_BOX (vbox2), combo, FALSE, FALSE, 0);

	/* Controls */
	widget = gtk_button_new_with_label ("Move to next screen");
	g_signal_connect_swapped (widget, "clicked", G_CALLBACK (move_window), window);
	gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);

	widget = gtk_toggle_button_new_with_label ("Move repeatedly to next screen");
	g_signal_connect_swapped (widget, "toggled", G_CALLBACK (start_or_stop_repeated_moves), window);
	gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);

	widget = gtk_button_new_with_label ("Quit");
	g_signal_connect_swapped (widget, "clicked", G_CALLBACK (gtk_widget_destroy), window);
	gtk_box_pack_start (GTK_BOX (vbox), widget, FALSE, FALSE, 0);

	gtk_widget_show_all (window);

	g_signal_connect (window, "destroy", G_CALLBACK (gtk_main_quit), NULL);

	gtk_main ();

	return 0;
}