summaryrefslogtreecommitdiffstats
path: root/src/window.c
blob: be034f8321e2a28078953b16c645011ebba5149e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/*
 * Main window
 *
 * Copyright (C) 2017  Patrick McDermott
 *
 * This file is part of Marquee.
 *
 * Marquee 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 3 of the License, or
 * (at your option) any later version.
 *
 * Marquee 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 Marquee.  If not, see <http://www.gnu.org/licenses/>.
 */

#include <stdlib.h>

#include <gtk/gtk.h>

#include "window.h"
#include "application.h"
#include "tab.h"

static void
switch_page_cb(GtkNotebook __attribute__((unused)) *notebook,
	GtkWidget __attribute__((unused)) *page, guint page_num,
	MqWindow *window)
{
	window->current_tab = page_num;
}

static void
update_positions(GtkNotebook __attribute__((unused)) *notebook,
	GtkWidget __attribute__((unused)) *child,
	guint __attribute__((unused)) page_num, MqWindow *window)
{
	/* TODO: Once MqWindow has a data structure for tabs, loop through them
	 * all and call mq_tab_update_position(). */
	/* TODO: Should this also update the tabs data structure?  Probably. */

	/* Temporarily "use" window. */
	window = window;
}

MqWindow *
mq_window_new(MqApplication *application, const gchar **uris)
{
	MqWindow *window;
	guint i;

	window = malloc(sizeof(*window));
	window->application = application;

	window->window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
	gtk_window_set_default_size(GTK_WINDOW(window->window), 1024, 768);
	g_signal_connect(window->window, "destroy",
		G_CALLBACK(mq_application_delete_window), application);

	window->notebook = gtk_notebook_new();
	gtk_notebook_set_scrollable(GTK_NOTEBOOK(window->notebook), TRUE);
	gtk_notebook_set_group_name(GTK_NOTEBOOK(window->notebook), "mq-tabs");
	gtk_widget_set_can_focus(window->notebook, FALSE);
	gtk_container_add(GTK_CONTAINER(window->window),
		window->notebook);
	g_signal_connect(window->notebook, "switch-page",
		G_CALLBACK(switch_page_cb), window);
	g_signal_connect(window->notebook, "page-reordered",
		G_CALLBACK(update_positions), window);

	window->root_tab = mq_tab_new_root(window);

	if (uris && uris[0]) {
		for (i = 0; uris && uris[i]; ++i) {
			mq_tab_new_relative(uris[i], window->root_tab);
		}
	} else {
		mq_tab_new_relative(NULL, window->root_tab);
	}

	gtk_widget_show_all(window->window);

	return window;
}

MqApplication *
mq_window_get_application(MqWindow *window)
{
	return window->application;
}

void
mq_window_insert_tab(MqWindow *window, GtkWidget *tab_page,
	GtkWidget *tab_label, gint position)
{
	gtk_notebook_insert_page(GTK_NOTEBOOK(window->notebook),
		tab_page, tab_label, position - 1);
	gtk_notebook_set_tab_reorderable(GTK_NOTEBOOK(window->notebook),
		tab_page, TRUE);
	gtk_notebook_set_tab_detachable(GTK_NOTEBOOK(window->notebook),
		tab_page, TRUE);
	gtk_widget_show_all(tab_page);
	gtk_widget_show_all(tab_label);
}

guint
mq_window_get_current_tab(MqWindow *window)
{
	return window->current_tab;
}