Extended (add, delete) and improved profile handling

This commit is contained in:
coderkun 2013-02-28 17:44:40 +01:00
parent c45c10a49d
commit 9171871af0
2 changed files with 80 additions and 16 deletions

16
mcg.py
View file

@ -612,6 +612,12 @@ class MCGProfileConfig(MCGConfig):
self._profiles.append(profile) self._profiles.append(profile)
def delete_profile(self, profile):
if profile in self._profiles:
self._profiles.remove(profile)
self._force_default_profile()
def get_profiles(self): def get_profiles(self):
return self._profiles return self._profiles
@ -630,6 +636,7 @@ class MCGProfileConfig(MCGConfig):
if self.has_option(section, attribute): if self.has_option(section, attribute):
profile.set(attribute, self.get(section, attribute)) profile.set(attribute, self.get(section, attribute))
self._profiles.append(profile) self._profiles.append(profile)
self._force_default_profile()
def save(self): def save(self):
@ -647,6 +654,11 @@ class MCGProfileConfig(MCGConfig):
super().save() super().save()
def _force_default_profile(self):
if len(self._profiles) == 0:
self._profiles.append(MCGProfile())
class MCGConfigurable: class MCGConfigurable:
@ -681,6 +693,10 @@ class MCGProfile(MCGConfigurable):
self.set('tags', "") self.set('tags', "")
def __str__(self):
return self.get("host")
def get_tags(self): def get_tags(self):
return self.get('tags').split(',') return self.get('tags').split(',')

View file

@ -468,13 +468,29 @@ class ConnectionPanel(mcg.MCGBase, Gtk.Box):
self._table = Gtk.Table(6, 2, False) self._table = Gtk.Table(6, 2, False)
vbox.pack_start(self._table, True, False, 0) vbox.pack_start(self._table, True, False, 0)
# Profile # Profile
profile_box = Gtk.HBox()
self._table.attach(profile_box, 0, 2, 0, 1)
# Profile Selection
self._profile_combo = Gtk.ComboBox.new_with_model(self._profiles) self._profile_combo = Gtk.ComboBox.new_with_model(self._profiles)
self._profile_combo.set_entry_text_column(0) self._profile_combo.set_entry_text_column(0)
self._profile_combo.connect("changed", self.on_profile_combo_changed) self._profile_combo.connect("changed", self.on_profile_combo_changed)
renderer = Gtk.CellRendererText() renderer = Gtk.CellRendererText()
self._profile_combo.pack_start(renderer, True) self._profile_combo.pack_start(renderer, True)
self._profile_combo.add_attribute(renderer, "text", 0) self._profile_combo.add_attribute(renderer, "text", 0)
self._table.attach(self._profile_combo, 0, 2, 0, 1) profile_box.pack_start(self._profile_combo, True, True, 0)
# Profile Management
profile_button_box = Gtk.HBox()
profile_box.pack_end(profile_button_box, False, True, 0)
# New Profile
self._profile_new_button = Gtk.Button()
self._profile_new_button.set_image(Gtk.Image.new_from_stock(Gtk.STOCK_ADD, Gtk.IconSize.BUTTON))
self._profile_new_button.connect('clicked', self.on_profile_new_clicked)
profile_button_box.add(self._profile_new_button)
# Delete Profile
self._profile_delete_button = Gtk.Button()
self._profile_delete_button.set_image(Gtk.Image.new_from_stock(Gtk.STOCK_DELETE, Gtk.IconSize.BUTTON))
self._profile_delete_button.connect('clicked', self.on_profile_delete_clicked)
profile_button_box.add(self._profile_delete_button)
# Host # Host
host_label = Gtk.Label("Host:") host_label = Gtk.Label("Host:")
host_label.set_alignment(0, 0.5) host_label.set_alignment(0, 0.5)
@ -515,23 +531,34 @@ class ConnectionPanel(mcg.MCGBase, Gtk.Box):
# Actions # Actions
self._load_config() self._load_config()
GObject.idle_add(self._profile_combo.set_active, config.last_profile) GObject.idle_add(self._select_last_profile, config.last_profile)
def on_profile_combo_changed(self, combo): def on_profile_combo_changed(self, combo):
index = combo.get_active() (index, profile) = self._get_selected_profile()
if index < 0: if profile is not None:
return self._profile = profile
profiles = self._config.get_profiles() self.set_host(self._profile.get('host'))
if index >= len(profiles): self.set_port(int(self._profile.get('port')))
return self.set_password(self._profile.get('password'))
self._profile = profiles[index] self.set_image_dir(self._profile.get('image_dir'))
self.set_host(self._profile.get('host')) self._autoconnect_button.set_active(ConnectionPanel.TAG_AUTOCONNECT in self._profile.get_tags())
self.set_port(int(self._profile.get('port'))) self._callback(ConnectionPanel.SIGNAL_PROFILE_CHANGED, index, self._profile)
self.set_password(self._profile.get('password'))
self.set_image_dir(self._profile.get('image_dir'))
self._autoconnect_button.set_active(ConnectionPanel.TAG_AUTOCONNECT in self._profile.get_tags()) def on_profile_new_clicked(self, widget):
self._callback(ConnectionPanel.SIGNAL_PROFILE_CHANGED, index, self._profile) profile = mcg.MCGProfile()
self._config.add_profile(profile)
self._reload_config()
self._profile_combo.set_active(len(self._profiles)-1)
def on_profile_delete_clicked(self, widget):
(index, profile) = self._get_selected_profile()
if profile is not None:
self._config.delete_profile(profile)
self._reload_config()
self._profile_combo.set_active(0)
def on_host_entry_outfocused(self, widget, event): def on_host_entry_outfocused(self, widget, event):
@ -606,13 +633,34 @@ class ConnectionPanel(mcg.MCGBase, Gtk.Box):
def _load_config(self): def _load_config(self):
self._config.load() self._config.load()
for profile in self._config.get_profiles(): for profile in self._config.get_profiles():
self._profiles.append([profile.get('host')]) self._profiles.append([profile.__str__()])
def _reload_config(self):
self._profiles.clear()
for profile in self._config.get_profiles():
self._profiles.append([profile.__str__()])
def set_sensitive(self, sensitive): def set_sensitive(self, sensitive):
self._table.set_sensitive(sensitive) self._table.set_sensitive(sensitive)
def _get_selected_profile(self):
index = self._profile_combo.get_active()
if index >= 0:
profiles = self._config.get_profiles()
if index < len(profiles):
return (index, profiles[index])
return (-1, None)
def _select_last_profile(self, index):
if len(self._profiles) <= index:
index = 0
self._profile_combo.set_active(index)
class CoverPanel(mcg.MCGBase, Gtk.HPaned): class CoverPanel(mcg.MCGBase, Gtk.HPaned):