Rename and remove tags.

This commit is contained in:
luxick
2017-04-17 19:22:44 +02:00
parent c2856439c7
commit 4e83d5a8b8
6 changed files with 148 additions and 20 deletions

View File

@@ -173,6 +173,28 @@ class Application:
dialog.run()
dialog.destroy()
def show_tag_rename_dialog(self, tag):
def rename(button, entry):
self.rename_tag(tag, entry.get_text())
window.destroy()
self.current_page.emit('show')
def eval_key_pressed(widget,event):
key, modifier = Gtk.accelerator_parse('Escape')
keyval = event.keyval
if keyval == key:
window.destroy()
builder = Gtk.Builder()
builder.add_from_file(util.get_ui_filename("dialogs.glade"))
window = builder.get_object("renameWindow")
entry = builder.get_object("renameEntry")
entry.set_text(tag)
builder.get_object("renameButton").connect('clicked', rename, entry)
entry.connect('activate', rename, entry)
window.show_all()
window.connect("key-press-event", eval_key_pressed)
def save_library(self):
# Save library file
util.save_file(util.get_root_filename("library"), self.library)
@@ -223,14 +245,22 @@ class Application:
def add_tag(self, tag):
self.tags[tag] = []
util.log("Tag '" + tag + "' added", util.LogLevel.Info)
self.push_status("Added Tag \"" + tag + "\"")
self.unsaved_changes = True
def remove_tag(self, tag):
del self.tags[tag]
util.log("Tag '" + tag + "' removed", util.LogLevel.Info)
self.push_status("Removed Tag \"" + tag + "\"")
self.unsaved_changes = True
def rename_tag(self, old, new):
self.tags[new] = self.tags[old]
del self.tags[old]
util.log("Tag '" + old + "' renamed to '" + new + "'", util.LogLevel.Info)
self.unsaved_changes = True
def add_card_to_lib(self, card, tag=None):
if tag is not None:
self.tag_card(card, tag)

View File

@@ -110,6 +110,8 @@ class CardList(Gtk.ScrolledWindow):
self.list.append_column(col_mana)
self.list.append_column(col_cmc)
self.store.set_sort_column_id(1, Gtk.SortType.ASCENDING)
def get_selected_cards(self):
(model, pathlist) = self.selection.get_selected_rows()
output = {}
@@ -122,32 +124,28 @@ class CardList(Gtk.ScrolledWindow):
def update(self, library, colorize=False):
self.store.clear()
if library is None:
return
self.lib = library
if self.filtered:
self.list.freeze_child_notify()
self.list.set_model(None)
util.log("Updating tree view", util.LogLevel.Info)
start = time.time()
for card_id, card in library.items():
if card.multiverse_id is not None:
if self.app.library.__contains__(card_id) and colorize:
color = util.card_view_colors["owned"]
else:
color = util.card_view_colors["unowned"]
if card.type == "Land":
mana_cost = None
else:
mana_cost = self.app.get_mana_icons(card.mana_cost)
item =[
card.multiverse_id,
item = [card.multiverse_id,
card.name,
" ".join(card.supertypes if card.supertypes else ""),
" ".join(card.types),
@@ -161,7 +159,10 @@ class CardList(Gtk.ScrolledWindow):
color]
self.store.append(item)
end = time.time()
util.log("Time to build Table: " + str(round(end - start, 3)), util.LogLevel.Info)
util.log("Time to build Table: " + str(round(end - start, 3)) + "s", util.LogLevel.Info)
util.log("Total entries: " + str(len(self.lib)), util.LogLevel.Info)
if self.filtered:
self.list.set_model(self.filter_and_sort)
self.list.thaw_child_notify()

View File

@@ -0,0 +1,48 @@
<?xml version="1.0" encoding="UTF-8"?>
<!-- Generated with glade 3.20.0 -->
<interface>
<requires lib="gtk+" version="3.20"/>
<object class="GtkWindow" id="renameWindow">
<property name="can_focus">False</property>
<property name="title" translatable="yes">Rename</property>
<property name="resizable">False</property>
<property name="modal">True</property>
<property name="skip_taskbar_hint">True</property>
<child>
<object class="GtkBox">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="halign">center</property>
<property name="valign">center</property>
<property name="spacing">5</property>
<child>
<object class="GtkEntry" id="renameEntry">
<property name="visible">True</property>
<property name="can_focus">True</property>
</object>
<packing>
<property name="expand">False</property>
<property name="fill">True</property>
<property name="position">0</property>
</packing>
</child>
<child>
<object class="GtkButton" id="renameButton">
<property name="label" translatable="yes">Rename</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
</object>
<packing>
<property name="expand">False</property>
<property name="fill">True</property>
<property name="position">1</property>
</packing>
</child>
</object>
</child>
<child>
<placeholder/>
</child>
</object>
</interface>

View File

@@ -2,6 +2,28 @@
<!-- Generated with glade 3.20.0 -->
<interface>
<requires lib="gtk+" version="3.20"/>
<object class="GtkMenu" id="tagListPopup">
<property name="visible">True</property>
<property name="can_focus">False</property>
<child>
<object class="GtkMenuItem" id="tagRename">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="label" translatable="yes">Rename</property>
<property name="use_underline">True</property>
<signal name="activate" handler="do_tag_list_rename" object="tagTree" swapped="no"/>
</object>
</child>
<child>
<object class="GtkMenuItem" id="tagDelete">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="label" translatable="yes">Delete</property>
<property name="use_underline">True</property>
<signal name="activate" handler="do_tag_list_delete" object="tagTree" swapped="no"/>
</object>
</child>
</object>
<object class="GtkListStore" id="tagStore">
<columns>
<!-- column-name tag -->
@@ -13,6 +35,7 @@
<object class="GtkEntryCompletion" id="tagCompleter">
<property name="model">tagStore</property>
<property name="text_column">0</property>
<property name="inline_selection">True</property>
<child>
<object class="GtkCellRendererText"/>
<attributes>
@@ -45,7 +68,7 @@
<property name="vexpand">True</property>
<property name="model">tagStore</property>
<property name="search_column">1</property>
<property name="activate_on_single_click">True</property>
<signal name="button-press-event" handler="do_tag_tree_press_event" swapped="no"/>
<signal name="drag-data-received" handler="on_drag_data_received" swapped="no"/>
<signal name="row-activated" handler="on_tag_selected" object="tagTreeSelection" swapped="no"/>
<child internal-child="selection">

View File

@@ -153,6 +153,30 @@ class Handlers:
tag = model.get_value(tree_iter, 0)
lib_funct.reload_library(self.app, tag)
def do_tag_tree_press_event(self, treeview, event):
if event.button == 3: # right click
path = treeview.get_path_at_pos(int(event.x), int(event.y))
if path:
tree_iter = treeview.get_model().get_iter(path[0])
tag = treeview.get_model().get_value(tree_iter, 0)
self.app.ui.get_object("tagListPopup").popup(None, None, None, None, 0, event.time)
def do_tag_list_rename(self, tree):
(model, pathlist) = tree.get_selection().get_selected_rows()
for path in pathlist:
tree_iter = model.get_iter(path)
tag = model.get_value(tree_iter, 0)
self.app.show_tag_rename_dialog(tag)
def do_tag_list_delete(self, tree):
(model, pathlist) = tree.get_selection().get_selected_rows()
for path in pathlist:
tree_iter = model.get_iter(path)
tag = model.get_value(tree_iter, 0)
self.app.remove_tag(tag)
self.app.current_page.emit('show')
# Handlers for TreeViews etc. wich have been not added by Glade
# ----------------Search-----------------

View File

@@ -1,5 +1,6 @@
from cardvault import cardlist
import gi
from gi.repository import Gtk
gi.require_version('Gtk', '3.0')
@@ -46,6 +47,7 @@ def reload_tag_list(app, preserve=False):
store.append([tag, tag + " (" + str(len(ids)) + ")"])
if preserve:
tree.set_cursor(path if path else 0)
store.set_sort_column_id(1, Gtk.SortType.ASCENDING)
def tag_cards(card_list, tag, app):