/gpump/trunk

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/gpump/trunk

« back to all changes in this revision

Viewing changes to src/app.js

  • Committer: Gustav Hartvigsson
  • Date: 2014-06-09 17:42:01 UTC
  • Revision ID: gustav.hartvigsson@gmail.com-20140609174201-9j752hye8k69m9ze
* UI for preferences done, it is still not functional.
  * TODO: bind some functions to the different buttons and switches.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* This file is part of GPump, a Pump.io client.
 
2
 *
 
3
 * GPump (THE SOFTWARE) is made available under the terms and conditions of the
 
4
 * GNU Lesser General Public Licence 3.0. A copy of the licence can be read
 
5
 * in the file lgpl-3.0.txt in the root of this project.
 
6
 */
 
7
 
 
8
const Gio = imports.gi.Gio;
 
9
const GLib = imports.gi.GLib;
 
10
const Gtk = imports.gi.Gtk;
 
11
const Lang = imports.lang;
 
12
const _ = imports.gettext.gettext;
 
13
 
 
14
 
 
15
const SettingsData = imports.settings_data;
 
16
const PreferencesUI = imports.preferences_ui;
 
17
 
 
18
const Application = new Lang.Class ({
 
19
  Name: "Application",
 
20
  Extends: Gtk.Application,
 
21
  
 
22
  _init: function () {
 
23
    this.parent ({
 
24
      application_id: "org.gego.gpump",
 
25
      flags: Gio.ApplicationFlags.FLAGS_NONE,
 
26
      register_session: true
 
27
    });
 
28
   GLib.set_application_name (_("GPump"));
 
29
    
 
30
    this.settings = SettingsData.get_settings ();
 
31
  },
 
32
  
 
33
  vfunc_activate: function () {
 
34
    /* Guarantee that only one window is present at any time. */
 
35
    let w_list = this.get_windows ();
 
36
    if (w_list.length) {
 
37
      w_list[0].present ();
 
38
      return;
 
39
    }
 
40
    
 
41
    this._prepare_window ();
 
42
    this._prepare_app_menu ();
 
43
    this._prepare_header_bar ();
 
44
    
 
45
    this.window.show_all ();
 
46
  },
 
47
  
 
48
  /**
 
49
   * This function is used to prepare the window, it also initializes and adds
 
50
   * the headerbar to it.
 
51
   */
 
52
  _prepare_window: function () {
 
53
    this.window = new Gtk.ApplicationWindow ({
 
54
      application: this,
 
55
      type: Gtk.WindowType.TOPLEVEL,
 
56
      title: GLib.get_application_name (),
 
57
      default_height: 500,
 
58
      default_width: 500,
 
59
      height_request: 500,
 
60
      width_request: 500,
 
61
      window_position: Gtk.WindowPosition.CENTER
 
62
    });
 
63
    
 
64
    this.window.set_titlebar ((this.headerbar = new Gtk.HeaderBar({
 
65
      title: GLib.get_application_name (),
 
66
      subtitle: _('A Pump.io client'),
 
67
      show_close_button: true
 
68
    })));
 
69
    
 
70
    print ("derp!\n");
 
71
    
 
72
    this.window.add (( this.scroll_view = new Gtk.ScrolledWindow () ));
 
73
    this.scroll_view.add ((this.list_box = new Gtk.ListBox ()));
 
74
    
 
75
    this.window.connect ('delete_event',
 
76
                         Lang.bind (this.window,
 
77
                                    this.window.hide_on_delete));
 
78
    
 
79
    this.add_window (this.window);
 
80
  },
 
81
  
 
82
  /**
 
83
   * This function is used to create the application menu.
 
84
   */
 
85
  _prepare_app_menu: function () {
 
86
    let menu = new Gio.Menu ();
 
87
    let section = new Gio.Menu ();
 
88
    
 
89
    section.append ("Preferences", "app.preferences");
 
90
    menu.append_section (null, section);
 
91
    
 
92
    section = new Gio.Menu ();
 
93
    section.append (_("About"), "app.about");
 
94
    section.append (_("Quit"), "app.quit");
 
95
    menu.append_section (null, section);
 
96
    
 
97
    this.set_app_menu (menu);
 
98
    
 
99
    let quit_action = new Gio.SimpleAction ({name: "quit"});
 
100
    quit_action.connect ('activate', Lang.bind (this, function () {
 
101
      this.quit ();
 
102
    }));
 
103
    this.add_action (quit_action);
 
104
    
 
105
    let preferences_action = new Gio.SimpleAction ({name: "preferences"});
 
106
    preferences_action.connect ('activate', Lang.bind (this, function (){
 
107
      let pref_dialog = new PreferencesUI.PreferencesUI ();
 
108
      pref_dialog.run ();
 
109
    }));
 
110
    this.add_action (preferences_action)
 
111
  },
 
112
  
 
113
  /**
 
114
   * This function is used to prepare the hearderbar by adding buttons and
 
115
   * assigning callback functions to them.
 
116
   */
 
117
  _prepare_header_bar: function () {
 
118
    this.headerbar.pack_start ((this.new_post_btn = new Gtk.Button ({
 
119
      image: (new Gtk.Image ({icon_name: 'text-editor-symbolic'})),
 
120
      tooltip_text: _('Create new post')
 
121
    })));
 
122
    
 
123
    this.headerbar.pack_start ((this.refresh_btn = new Gtk.Button({
 
124
      image: (new Gtk.Image ({icon_name: 'emblem-synchronizing-symbolic'})),
 
125
      tooltip_text: _('Refresh the stream')
 
126
    })));
 
127
    
 
128
    this.headerbar.pack_end ((this.user_menu_btn = new Gtk.Button ({
 
129
      image: (new Gtk.Image ({icon_name: 'emblem-system-symbolic'})),
 
130
      tooltip_text: _('Switch and manage users')
 
131
    })));
 
132
  }
 
133
  
 
134
});