[gnome-clocks/zbrown/ditch-selection-mode] general: ditch the remains of selection mode



commit d79b93d9b95348f79a1090dcbeb92be510dfb535
Author: Zander Brown <zbrown gnome org>
Date:   Sun Feb 23 18:43:54 2020 +0000

    general: ditch the remains of selection mode

 data/gnome-clocks.gresource.xml |   1 -
 data/gtk/menus.ui               |  16 ---
 data/ui/headerbar.ui            |  64 ---------
 src/alarm.vala                  |   6 -
 src/application.vala            |   1 -
 src/clock.vala                  |  14 --
 src/headerbar.vala              |  39 -----
 src/stopwatch.vala              |   2 -
 src/timer.vala                  |   5 -
 src/widgets.vala                | 307 ----------------------------------------
 src/window.vala                 |  40 ------
 src/world.vala                  |   5 -
 12 files changed, 500 deletions(-)
---
diff --git a/data/gnome-clocks.gresource.xml b/data/gnome-clocks.gresource.xml
index 83fab71..3f03601 100644
--- a/data/gnome-clocks.gresource.xml
+++ b/data/gnome-clocks.gresource.xml
@@ -3,7 +3,6 @@
   <gresource prefix="/org/gnome/clocks">
     <file>css/gnome-clocks.css</file>
     <file>css/gnome-clocks.highcontrast.css</file>
-    <file preprocess="xml-stripblanks">gtk/menus.ui</file>
     <file preprocess="xml-stripblanks">gtk/help-overlay.ui</file>
     <file preprocess="xml-stripblanks">ui/window.ui</file>
     <file preprocess="xml-stripblanks">ui/headerbar.ui</file>
diff --git a/data/ui/headerbar.ui b/data/ui/headerbar.ui
index 8e07ef9..9302e62 100644
--- a/data/ui/headerbar.ui
+++ b/data/ui/headerbar.ui
@@ -78,15 +78,6 @@
             <property name="name">switcher</property>
           </packing>
         </child>
-        <child>
-          <object class="ClocksSelectionMenuButton">
-            <property name="visible">True</property>
-            <property name="n-items" bind-source="ClocksHeaderBar" bind-property="n-selected" 
bind-flags="sync-create" />
-          </object>
-          <packing>
-            <property name="name">selection</property>
-          </packing>
-        </child>
         <child>
           <object class="GtkBox">
             <property name="visible">True</property>
@@ -206,19 +197,6 @@
             <property name="name">menu</property>
           </packing>
         </child>
-        <child>
-          <object class="GtkButton">
-            <property name="label" translatable="yes">_Cancel</property>
-            <property name="visible">True</property>
-            <property name="can_focus">True</property>
-            <property name="receives_default">True</property>
-            <property name="action_name">win.select-cancel</property>
-            <property name="use_underline">True</property>
-          </object>
-          <packing>
-            <property name="name">cancel</property>
-          </packing>
-        </child>
         <child>
           <object class="GtkBox">
             <property name="visible">True</property>
@@ -234,48 +212,6 @@
         <property name="pack_type">end</property>
       </packing>
     </child>
-    <child>
-      <object class="GtkStack" id="select_stack">
-        <property name="visible">True</property>
-        <property name="can_focus">False</property>
-        <property name="transition_type">crossfade</property>
-        <child>
-          <object class="GtkButton">
-            <property name="visible">True</property>
-            <property name="can_focus">True</property>
-            <property name="receives_default">True</property>
-            <property name="action_name">win.select</property>
-            <property name="tooltip-text" translatable="yes">Select</property>
-            <child>
-              <object class="GtkImage">
-                <property name="visible">True</property>
-                <property name="can_focus">False</property>
-                <property name="icon_name">object-select-symbolic</property>
-              </object>
-            </child>
-          </object>
-          <packing>
-            <property name="name">select</property>
-          </packing>
-        </child>
-        <child>
-          <object class="GtkBox">
-            <property name="visible">True</property>
-            <property name="can_focus">False</property>
-            <property name="orientation">vertical</property>
-            <child>
-              <placeholder/>
-            </child>
-          </object>
-          <packing>
-            <property name="name">empty</property>
-          </packing>
-        </child>
-      </object>
-      <packing>
-        <property name="pack_type">end</property>
-      </packing>
-    </child>
   </template>
   <object class="GtkStack" id="ignore-me"></object>
 </interface>
diff --git a/src/alarm.vala b/src/alarm.vala
index c23283e..5e5cfcc 100644
--- a/src/alarm.vala
+++ b/src/alarm.vala
@@ -39,10 +39,6 @@ private class Item : Object, ContentItem {
 
     public string title_icon { get; set; default = null; }
 
-    public bool selectable { get; set; default = true; }
-
-    public bool selected { get; set; default = false; }
-
     public bool editing { get; set; default = false; }
 
     public string id { get; construct set; }
@@ -789,8 +785,6 @@ public class Face : Gtk.Stack, Clocks.Clock {
     public ViewMode view_mode { get; set; default = NORMAL; }
     public PanelId panel_id { get; construct set; }
     public ButtonMode button_mode { get; set; default = NEW; }
-    public bool can_select { get; set; default = false; }
-    public bool n_selected { get; set; }
     public string title { get; set; default = _("Clocks"); }
     public string subtitle { get; set; }
     // Translators: Tooltip for the + button
diff --git a/src/application.vala b/src/application.vala
index 509ce54..24ac931 100644
--- a/src/application.vala
+++ b/src/application.vala
@@ -131,7 +131,6 @@ public class Application : Gtk.Application {
         update_theme (settings);
 
         set_accels_for_action ("win.new", { "<Primary>n" });
-        set_accels_for_action ("win.select-all", { "<Primary>a" });
         set_accels_for_action ("win.show-primary-menu", { "F10" });
         set_accels_for_action ("win.show-help-overlay", { "<Primary>question" });
         set_accels_for_action ("win.help", { "F1" });
diff --git a/src/clock.vala b/src/clock.vala
index 404ad89..739edae 100644
--- a/src/clock.vala
+++ b/src/clock.vala
@@ -28,8 +28,6 @@ public interface Clocks.Clock : GLib.Object {
     public abstract PanelId panel_id { get; protected construct set; }
     public abstract ButtonMode button_mode { get; set; }
     public abstract ViewMode view_mode { get; set; }
-    public abstract bool can_select { get; set; }
-    public abstract bool n_selected { get; set; }
     public abstract string title { get; protected set; }
     public abstract string subtitle { get; protected set; }
     public abstract string new_label { get; }
@@ -40,18 +38,6 @@ public interface Clocks.Clock : GLib.Object {
     public virtual void activate_back () {
     }
 
-    public virtual void activate_select () {
-    }
-
-    public virtual void activate_select_cancel () {
-    }
-
-    public virtual void activate_select_all () {
-    }
-
-    public virtual void activate_select_none () {
-    }
-
     public virtual bool escape_pressed () {
         return false;
     }
diff --git a/src/headerbar.vala b/src/headerbar.vala
index 367e662..90d3eaf 100644
--- a/src/headerbar.vala
+++ b/src/headerbar.vala
@@ -28,7 +28,6 @@ public enum Clocks.ButtonMode {
 
 public enum Clocks.ViewMode {
     NORMAL,
-    SELECTION,
     STANDALONE
 }
 
@@ -46,22 +45,10 @@ public class Clocks.HeaderBar : Hdy.HeaderBar {
             var width = get_allocated_width ();
 
             switch (_mode) {
-                case SELECTION:
-                    title_stack.visible_child_name = "selection";
-                    get_style_context ().add_class ("selection-mode");
-                    start_button_stack.hide ();
-                    end_button_stack.show ();
-                    select_stack.hide ();
-                    end_button_stack.visible_child_name = "cancel";
-                    centering_policy = LOOSE;
-                    switcher_bar.reveal = width <= 500;
-                    break;
                 case NORMAL:
                     title_stack.visible_child_name = "switcher";
-                    get_style_context ().remove_class ("selection-mode");
                     start_button_stack.show ();
                     end_button_stack.show ();
-                    select_stack.show ();
                     end_button_stack.visible_child_name = "menu";
                     centering_policy = STRICT;
                     switcher_bar.reveal = width <= 500;
@@ -70,13 +57,10 @@ public class Clocks.HeaderBar : Hdy.HeaderBar {
                     title_stack.visible_child_name = "title";
                     start_button_stack.show ();
                     end_button_stack.hide ();
-                    select_stack.hide ();
                     centering_policy = STRICT;
                     switcher_bar.reveal = false;
                     break;
             }
-
-            show_close_button = _mode != SELECTION;
         }
     }
 
@@ -101,35 +85,16 @@ public class Clocks.HeaderBar : Hdy.HeaderBar {
         }
     }
 
-    public bool can_select {
-        get {
-            return _can_select;
-        }
-
-        set {
-            _can_select = value;
-            if (_can_select) {
-                select_stack.visible_child_name = "select";
-            } else {
-                select_stack.visible_child_name = "empty";
-            }
-        }
-    }
-
     public Gtk.Stack stack { get; set; }
     public Hdy.ViewSwitcherBar switcher_bar { get; set; }
-    public uint n_selected { get; set; }
     public string new_label { get; set; }
 
-    private bool _can_select;
     private ViewMode _mode;
     private ButtonMode _button_mode;
 
     [GtkChild]
     private Gtk.Stack start_button_stack;
     [GtkChild]
-    private Gtk.Stack select_stack;
-    [GtkChild]
     private Gtk.Stack end_button_stack;
     [GtkChild]
     private Hdy.Squeezer squeezer;
@@ -144,10 +109,6 @@ public class Clocks.HeaderBar : Hdy.HeaderBar {
     [GtkChild]
     private Gtk.Revealer reveal_subtitle;
 
-    class construct {
-        typeof (SelectionMenuButton).ensure ();
-    }
-
     public override void size_allocate (Gtk.Allocation allocation) {
         base.size_allocate (allocation);
         squeezer.set_child_enabled (title_wide_switcher, allocation.width > 800);
diff --git a/src/stopwatch.vala b/src/stopwatch.vala
index 7a2077c..88c6039 100644
--- a/src/stopwatch.vala
+++ b/src/stopwatch.vala
@@ -119,8 +119,6 @@ public class Face : Gtk.Box, Clocks.Clock {
     public PanelId panel_id { get; construct set; }
     public ButtonMode button_mode { get; set; default = NONE; }
     public ViewMode view_mode { get; set; default = NORMAL; }
-    public bool can_select { get; set; default = false; }
-    public bool n_selected { get; set; }
     public string title { get; set; default = _("Clocks"); }
     public string subtitle { get; set; }
     public string new_label { get; default = null; }
diff --git a/src/timer.vala b/src/timer.vala
index 523029b..2ea8342 100644
--- a/src/timer.vala
+++ b/src/timer.vala
@@ -29,9 +29,6 @@ public class Item : Object, ContentItem {
 
     public State state { get; private set; default = State.STOPPED; }
 
-    public bool selectable { get; set; default = false; }
-    public bool selected { get; set; default = false; }
-
     public string name { get ; set; }
     public int hours { get; set; default = 0; }
     public int minutes { get; set; default = 0; }
@@ -407,8 +404,6 @@ public class Face : Gtk.Stack, Clocks.Clock {
     public ButtonMode button_mode { get; set; default = NONE; }
     public ViewMode view_mode { get; set; default = NORMAL; }
     public bool is_running { get; set; default = false; }
-    public bool can_select { get; set; default = false; }
-    public bool n_selected { get; set; }
     public string title { get; set; default = _("Clocks"); }
     public string subtitle { get; set; }
     // Translators: Tooltip for the + button
diff --git a/src/widgets.vala b/src/widgets.vala
index 3d1f3b0..8542917 100644
--- a/src/widgets.vala
+++ b/src/widgets.vala
@@ -20,8 +20,6 @@ namespace Clocks {
 
 public interface ContentItem : GLib.Object {
     public abstract string name { get; set; }
-    public abstract bool selectable { get; set; default = true; }
-    public abstract bool selected { get; set; default = false; }
     public abstract void serialize (GLib.VariantBuilder builder);
 }
 
@@ -29,7 +27,6 @@ public class ContentStore : GLib.Object, GLib.ListModel {
     private ListStore store;
     private CompareDataFunc sort_func;
 
-    public signal void selection_changed ();
 
     public ContentStore () {
         store = new ListStore (typeof (ContentItem));
@@ -58,18 +55,12 @@ public class ContentStore : GLib.Object, GLib.ListModel {
         assert (store.get_n_items () == 0);
     }
 
-    private void on_item_selection_toggle (Object o, ParamSpec p) {
-        selection_changed ();
-    }
-
     public void add (ContentItem item) {
         if (sort_func == null) {
             store.append (item);
         } else {
             store.insert_sorted (item, sort_func);
         }
-
-        item.notify["selected"].connect (on_item_selection_toggle);
     }
 
     public int get_index (ContentItem item) {
@@ -114,18 +105,6 @@ public class ContentStore : GLib.Object, GLib.ListModel {
         return null;
     }
 
-    public uint get_n_selected () {
-        uint n_selected = 0;
-        var n = store.get_n_items ();
-        for (int i = 0; i < n; i++) {
-            var item = store.get_object (i) as ContentItem;
-            if (item.selected) {
-                n_selected++;
-            }
-        }
-        return n_selected;
-    }
-
     public void delete_item (ContentItem item) {
         var n = store.get_n_items ();
         for (int i = 0; i < n; i++) {
@@ -137,66 +116,11 @@ public class ContentStore : GLib.Object, GLib.ListModel {
                     store.sort (sort_func);
                 }
 
-                selection_changed ();
-
                 return;
             }
         }
     }
 
-    public void delete_selected () {
-        // remove everything and readd the ones not selected
-        uint n_deleted = 0;
-        Object[] not_selected = {};
-        var n = store.get_n_items ();
-        for (int i = 0; i < n; i++) {
-            var o = store.get_object (i);
-            if (!((ContentItem)o).selected) {
-                not_selected += o;
-            } else {
-                n_deleted++;
-                SignalHandler.disconnect_by_func (o, (void *)on_item_selection_toggle, (void *)this);
-            }
-        }
-
-        if (n_deleted > 0) {
-            store.splice (0, n, not_selected);
-            if (sort_func != null) {
-                store.sort (sort_func);
-            }
-
-            selection_changed ();
-        }
-    }
-
-    private void select_unselect_all (bool select) {
-        uint n_toggled = 0;
-
-        var n = store.get_n_items ();
-        for (int i = 0; i < n; i++) {
-            var item = store.get_object (i) as ContentItem;
-            var selected = item.selectable && select;
-            if (selected != item.selected) {
-                SignalHandler.block_by_func (item, (void *)on_item_selection_toggle, (void *)this);
-                item.selected = selected;
-                SignalHandler.unblock_by_func (item, (void *)on_item_selection_toggle, (void *)this);
-                n_toggled++;
-            }
-        }
-
-        if (n_toggled > 0) {
-            selection_changed ();
-        }
-    }
-
-    public void select_all () {
-        select_unselect_all (true);
-    }
-
-    public void unselect_all () {
-        select_unselect_all (false);
-    }
-
     public Variant serialize () {
         var builder = new GLib.VariantBuilder (new VariantType ("aa{sv}"));
         var n = store.get_n_items ();
@@ -219,237 +143,6 @@ public class ContentStore : GLib.Object, GLib.ListModel {
     }
 }
 
-private class SelectionMenuButton : Gtk.MenuButton {
-    public uint n_items {
-        get {
-            return _n_items;
-        }
-        set {
-            if (_n_items != value) {
-                _n_items = value;
-                string label;
-                if (n_items == 0) {
-                    label = _("Click on items to select them");
-                } else {
-                    label = ngettext ("%u selected", "%u selected", n_items).printf (n_items);
-                }
-                menubutton_label.label = label;
-            }
-        }
-    }
-
-    private uint _n_items;
-    private Gtk.Label menubutton_label;
-
-    construct {
-        var app = (Gtk.Application) GLib.Application.get_default ();
-        menu_model = app.get_menu_by_id ("selection-menu");
-        menubutton_label = new Gtk.Label (_("Click on items to select them"));
-        var arrow = new Gtk.Image.from_icon_name ("pan-down-symbolic", Gtk.IconSize.BUTTON);
-        var grid = new Gtk.Grid ();
-        grid.set_column_spacing (6);
-        grid.attach (menubutton_label, 0, 0, 1, 1);
-        grid.attach (arrow, 1, 0, 1, 1);
-        add (grid);
-        valign = Gtk.Align.CENTER;
-        get_style_context ().add_class ("selection-menu");
-        show_all ();
-    }
-}
-
-public class ContentView : Gtk.Bin {
-    public ViewMode mode {
-        get {
-            return _mode;
-        }
-
-        set {
-            if (_mode != value) {
-                _mode = value;
-
-                switch (_mode) {
-                    case SELECTION:
-                        action_bar.show ();
-                        break;
-                    case NORMAL:
-                    case STANDALONE:
-                        action_bar.hide ();
-                        // clear current selection
-                        model.unselect_all ();
-                        break;
-                }
-            }
-        }
-    }
-    public uint n_selected { get; private set; }
-
-    private ViewMode _mode;
-    private ContentStore model;
-    private Gtk.FlowBox flow_box;
-    private Gtk.Grid grid;
-    private Gtk.ActionBar action_bar;
-    private Gtk.Button delete_button;
-
-    construct {
-        get_style_context ().add_class ("content-view");
-
-        flow_box = new Gtk.FlowBox ();
-        flow_box.selection_mode = Gtk.SelectionMode.NONE;
-        flow_box.min_children_per_line = 3;
-
-        flow_box.child_activated.connect ((child) => {
-            var item = model.get_item (child.get_index ()) as ContentItem;
-            if (item != null) {
-                item_activated (item);
-            }
-        });
-
-        var scrolled_window = new Gtk.ScrolledWindow (null, null);
-        scrolled_window.add (flow_box);
-        scrolled_window.hexpand = true;
-        scrolled_window.vexpand = true;
-        scrolled_window.halign = Gtk.Align.FILL;
-        scrolled_window.valign = Gtk.Align.FILL;
-
-        grid = new Gtk.Grid ();
-        grid.attach (scrolled_window, 0, 0, 1, 1);
-
-        action_bar = new Gtk.ActionBar ();
-        action_bar.no_show_all = true;
-        grid.attach (action_bar, 0, 1, 1, 1);
-
-        delete_button = new Gtk.Button ();
-        delete_button.label = _("Delete");
-        delete_button.visible = true;
-        delete_button.sensitive = false;
-        delete_button.halign = Gtk.Align.END;
-        delete_button.hexpand = true;
-        delete_button.clicked.connect (() => {
-            model.delete_selected ();
-            mode = NORMAL;
-        });
-
-        action_bar.pack_end (delete_button);
-
-        add (grid);
-        grid.show_all ();
-    }
-
-    public signal void item_activated (ContentItem item);
-
-    public delegate Gtk.Widget ContentViewCreateWidgetFunc (ContentItem item);
-
-    public void bind_model (ContentStore store, owned ContentViewCreateWidgetFunc create_func) {
-        model = store;
-
-        model.selection_changed.connect (() => {
-            var n_items = model.get_n_selected ();
-            n_selected = n_items;
-
-            if (n_items != 0) {
-                delete_button.sensitive = true;
-            } else {
-                delete_button.sensitive = false;
-            }
-        });
-
-        flow_box.bind_model (model, (object) => {
-            var item = (ContentItem) object;
-            var inner = create_func (item);
-
-            // wrap the widget in an event box to handle righ-click
-            var event_box = new Gtk.EventBox ();
-            event_box.add (inner);
-            event_box.button_press_event.connect ((event) => {
-                // On right click, switch to selection mode automatically
-                if (item.selectable && event.button == Gdk.BUTTON_SECONDARY) {
-                    mode = SELECTION;
-                }
-
-                if (item.selectable && mode == SELECTION) {
-                    item.selected = !item.selected;
-                    return true;
-                } else if (event.button == Gdk.BUTTON_PRIMARY) {
-                    item_activated (item);
-                    return true;
-                }
-
-                return false;
-            });
-
-            // wrap the widget in overlay for the selection check box
-            var overlay = new Gtk.Overlay ();
-            overlay.halign = Gtk.Align.START;
-            overlay.valign = Gtk.Align.START;
-            overlay.add (event_box);
-
-            var check = new Gtk.CheckButton ();
-            check.no_show_all = true;
-            check.halign = Gtk.Align.END;
-            check.valign = Gtk.Align.END;
-            check.margin_bottom = 8;
-            check.margin_end = 8;
-
-            item.bind_property ("selected", check, "active", BindingFlags.DEFAULT | BindingFlags.SYNC_CREATE 
| BindingFlags.BIDIRECTIONAL);
-            item.bind_property ("selectable", check, "visible", BindingFlags.DEFAULT | 
BindingFlags.SYNC_CREATE,
-                                 (binding, selectable, ref visible) => {
-                visible = this.mode == SELECTION && (item).selectable;
-                return true;
-            });
-
-            bind_property ("mode", check, "visible", BindingFlags.DEFAULT | BindingFlags.SYNC_CREATE,
-                           (binding, mode, ref visible) => {
-                visible = mode == ViewMode.SELECTION && (item).selectable;
-                return true;
-            });
-
-            overlay.add_overlay (check);
-
-            // manually wrap in flowboxchild ourselves since we want to set alignment
-            var flow_box_child = new Gtk.FlowBoxChild ();
-            flow_box_child.halign = Gtk.Align.START;
-            flow_box_child.valign = Gtk.Align.START;
-            flow_box_child.add (overlay);
-            flow_box_child.get_style_context ().add_class ("tile");
-
-            // flowbox does not handle :hover and setting the PRELIGHT state does not
-            // seem to get propagated to the children despite what the documentation
-            // says... emulate it ourselves with css classes :(
-            event_box.enter_notify_event.connect ((event) => {
-                flow_box_child.get_style_context ().add_class ("prelight");
-                return false;
-            });
-
-            event_box.leave_notify_event.connect ((event) => {
-                if (event.detail != Gdk.NotifyType.INFERIOR) {
-                    flow_box_child.get_style_context ().remove_class ("prelight");
-                }
-                return false;
-            });
-
-            flow_box_child.show_all ();
-
-            return flow_box_child;
-        });
-    }
-
-    public void select_all () {
-        mode = SELECTION;
-        model.select_all ();
-    }
-
-    public void unselect_all () {
-        model.unselect_all ();
-    }
-
-    public bool escape_pressed () {
-        if (mode == SELECTION) {
-            mode = NORMAL;
-            return true;
-        }
-        return false;
-    }
-}
 
 public class AmPmToggleButton : Gtk.Button {
     public enum AmPm {
diff --git a/src/window.vala b/src/window.vala
index 820e73f..ab4e3fb 100644
--- a/src/window.vala
+++ b/src/window.vala
@@ -27,12 +27,6 @@ public class Window : Gtk.ApplicationWindow {
         { "back", on_back_activate },
         { "help", on_help_activate },
         { "about", on_about_activate },
-        { "select", on_select_activate },
-        { "select-cancel", on_select_cancel_activate },
-
-        // selection menu
-        { "select-all", on_select_all_activate },
-        { "select-none", on_select_none_activate }
     };
 
     [GtkChild]
@@ -53,8 +47,6 @@ public class Window : Gtk.ApplicationWindow {
     // DIY DzlBindingGroup
     private Binding bind_button_mode = null;
     private Binding bind_view_mode = null;
-    private Binding bind_can_select = null;
-    private Binding bind_selected = null;
     private Binding bind_title = null;
     private Binding bind_subtitle = null;
     private Binding bind_new_label = null;
@@ -193,22 +185,6 @@ public class Window : Gtk.ApplicationWindow {
         ((Clock) stack.visible_child).activate_back ();
     }
 
-    private void on_select_activate () {
-        ((Clock) stack.visible_child).activate_select ();
-    }
-
-    private void on_select_cancel_activate () {
-        ((Clock) stack.visible_child).activate_select_cancel ();
-    }
-
-    private void on_select_all_activate () {
-        ((Clock) stack.visible_child).activate_select_all ();
-    }
-
-    private void on_select_none_activate () {
-        ((Clock) stack.visible_child).activate_select_none ();
-    }
-
     public void show_world () {
         world.reset_view ();
         stack.visible_child = world;
@@ -339,22 +315,6 @@ public class Window : Gtk.ApplicationWindow {
                                               "view-mode",
                                               SYNC_CREATE);
 
-        if (bind_can_select != null) {
-            bind_can_select.unbind ();
-        }
-        bind_can_select = panel.bind_property ("can-select",
-                                               header_bar,
-                                               "can-select",
-                                               SYNC_CREATE);
-
-        if (bind_selected != null) {
-            bind_selected.unbind ();
-        }
-        bind_selected = panel.bind_property ("n-selected",
-                                             header_bar,
-                                             "n-selected",
-                                             SYNC_CREATE);
-
         if (bind_title != null) {
             bind_title.unbind ();
         }
diff --git a/src/world.vala b/src/world.vala
index 0f488a5..75e3d88 100644
--- a/src/world.vala
+++ b/src/world.vala
@@ -72,9 +72,6 @@ public class Item : Object, ContentItem {
 
     public bool automatic { get; set; default = false; }
 
-    public bool selectable { get; set; default = false; }
-    public bool selected { get; set; default = false; }
-
     public string name {
         get {
             // We store it in a _name member even if we overwrite it every time
@@ -495,8 +492,6 @@ public class Face : Gtk.Stack, Clocks.Clock {
     public PanelId panel_id { get; construct set; }
     public ButtonMode button_mode { get; set; default = NEW; }
     public ViewMode view_mode { get; set; default = NORMAL; }
-    public bool can_select { get; set; default = false; }
-    public bool n_selected { get; set; }
     public string title { get; set; default = _("Clocks"); }
     public string subtitle { get; set; }
     // Translators: Tooltip for the + button


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]