Example #1
0
    def __init__(self, table):
        super(TableFields, self).__init__()

        self.table = table

        self.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
        self.tv_fields = gtk.TreeView()
        self.tv_fields.set_rules_hint(True)
        self.tv_fields_model = gtk.ListStore(
            gobject.TYPE_BOOLEAN,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
        )
        self.tv_fields.set_model(self.tv_fields_model)
        self.tv_fields.connect("button-release-event", self.on_button_release)
        self.pop_up = TableFieldsPopUp()
        self.pop_up.add.connect('activate', self.on_add_activate)
        self.pop_up.edit.connect('activate', self.on_edit_activate)
        self.pop_up.drop.connect('activate', self.on_drop_activate)
        self.add(self.tv_fields)
Example #2
0
    def __init__(self, table):
        super(TableFields, self).__init__()

        self.table = table

        self.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
        self.tv_fields = gtk.TreeView()
        self.tv_fields.set_rules_hint(True)
        self.tv_fields_model = gtk.ListStore(
            gobject.TYPE_BOOLEAN,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
        )
        self.tv_fields.set_model(self.tv_fields_model)
        self.tv_fields.connect("button-release-event", self.on_button_release)
        self.pop_up = TableFieldsPopUp()
        self.pop_up.add.connect("activate", self.on_add_activate)
        self.pop_up.edit.connect("activate", self.on_edit_activate)
        self.pop_up.drop.connect("activate", self.on_drop_activate)
        self.add(self.tv_fields)
Example #3
0
class TableFields(gtk.ScrolledWindow):
    def __init__(self, table):
        super(TableFields, self).__init__()

        self.table = table

        self.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
        self.tv_fields = gtk.TreeView()
        self.tv_fields.set_rules_hint(True)
        self.tv_fields_model = gtk.ListStore(
            gobject.TYPE_BOOLEAN,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
        )
        self.tv_fields.set_model(self.tv_fields_model)
        self.tv_fields.connect("button-release-event", self.on_button_release)
        self.pop_up = TableFieldsPopUp()
        self.pop_up.add.connect('activate', self.on_add_activate)
        self.pop_up.edit.connect('activate', self.on_edit_activate)
        self.pop_up.drop.connect('activate', self.on_drop_activate)
        self.add(self.tv_fields)

    def on_drop_activate(self, *args):
        path, column = self.tv_fields.get_cursor()
        _iter = self.tv_fields_model.get_iter(path)
        _field_name = self.tv_fields_model.get_value(_iter, 2)
        if not dialogs.confirm(
                "Drop field",
                "Do you really want to DROP field <b>%s</b> from table <b>%s</b>"
                " in database <b>%s</b> on <b>%s</b>?" %
            (_field_name, self.table.name, self.table.db.name,
             self.table.db.host.name), None):
            return
        self.table.drop_field(_field_name)
        self.refresh()

    def on_add_activate(self, *args):
        dialog = TableFieldDialog(MySqlField({}))
        answer = dialog.run()
        if answer == gtk.RESPONSE_OK:
            q = dialog.get_sql(self.table.name)
            self.table.db.query(q)
            self.table.refresh()
            self.refresh()
        dialog.destroy()

    def on_edit_activate(self, *args):
        path, column = self.tv_fields.get_cursor()
        _iter = self.tv_fields_model.get_iter(path)
        _field_name = self.tv_fields_model.get_value(_iter, 2)
        for f in self.table.fields:
            if f.name == _field_name:
                dialog = TableFieldDialog(f)
                answer = dialog.run()
                if answer == gtk.RESPONSE_OK:
                    q = dialog.get_sql(self.table.name)
                    self.table.db.query(q)
                    self.table.refresh()
                    self.refresh()
                dialog.destroy()

    def refresh(self):
        for col in self.tv_fields.get_columns():
            self.tv_fields.remove_column(col)
        if self.tv_fields_model:
            self.tv_fields_model.clear()

        crt = gtk.CellRendererToggle()
        crt.connect('toggled', self.row_toggled, self.tv_fields_model)
        crt.set_activatable(True)
        tvc = gtk.TreeViewColumn("", crt)
        tvc.add_attribute(crt, "active", 0)
        self.tv_fields.append_column(tvc)
        self.tv_fields.append_column(
            gtk.TreeViewColumn("#", gtk.CellRendererText(), text=1))
        self.tv_fields.append_column(
            gtk.TreeViewColumn("Name", gtk.CellRendererText(), text=2))
        self.tv_fields.append_column(
            gtk.TreeViewColumn("Type", gtk.CellRendererText(), text=3))
        self.tv_fields.append_column(
            gtk.TreeViewColumn("Collation", gtk.CellRendererText(), text=4))
        self.tv_fields.append_column(
            gtk.TreeViewColumn("Null", gtk.CellRendererText(), text=5))
        self.tv_fields.append_column(
            gtk.TreeViewColumn("Default", gtk.CellRendererText(), text=6))
        self.tv_fields.append_column(
            gtk.TreeViewColumn("Extra", gtk.CellRendererText(), text=7))
        self.tv_fields.append_column(
            gtk.TreeViewColumn("Comment", gtk.CellRendererText(), text=8))
        fn = 1
        for f in self.table.fields:
            self.tv_fields_model.append(
                (False, fn, f.name, f.type_string, f.row['Collation'],
                 "YES" if f.is_null else "NO", f.default, f.row['Extra'],
                 f.comment))
            fn += 1

    def row_toggled(self, cell, path, model):
        if not cell or not path or not model:
            return
        model[path][0] = not model[path][0]

    def on_button_release(self, tv, event):
        if not tv or not event or not event.button == 3:
            return False
        self.pop_up.popup(None, None, None, event.button, event.time, tv)
Example #4
0
class TableFields(gtk.ScrolledWindow):
    def __init__(self, table):
        super(TableFields, self).__init__()

        self.table = table

        self.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
        self.tv_fields = gtk.TreeView()
        self.tv_fields.set_rules_hint(True)
        self.tv_fields_model = gtk.ListStore(
            gobject.TYPE_BOOLEAN,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
            gobject.TYPE_STRING,
        )
        self.tv_fields.set_model(self.tv_fields_model)
        self.tv_fields.connect("button-release-event", self.on_button_release)
        self.pop_up = TableFieldsPopUp()
        self.pop_up.add.connect("activate", self.on_add_activate)
        self.pop_up.edit.connect("activate", self.on_edit_activate)
        self.pop_up.drop.connect("activate", self.on_drop_activate)
        self.add(self.tv_fields)

    def on_drop_activate(self, *args):
        path, column = self.tv_fields.get_cursor()
        _iter = self.tv_fields_model.get_iter(path)
        _field_name = self.tv_fields_model.get_value(_iter, 2)
        if not confirm(
            "Drop field",
            "Do you really want to DROP field <b>%s</b> from table <b>%s</b>"
            " in database <b>%s</b> on <b>%s</b>?"
            % (_field_name, self.table.name, self.table.db.name, self.table.db.host.name),
            None,
        ):
            return
        self.table.drop_field(_field_name)
        self.refresh()

    def on_add_activate(self, *args):
        dialog = TableFieldDialog(MySqlField({}))
        answer = dialog.run()
        if answer == gtk.RESPONSE_OK:
            q = dialog.get_sql(self.table.name)
            self.table.db.query(q)
            self.table.refresh()
            self.refresh()
        dialog.destroy()

    def on_edit_activate(self, *args):
        path, column = self.tv_fields.get_cursor()
        _iter = self.tv_fields_model.get_iter(path)
        _field_name = self.tv_fields_model.get_value(_iter, 2)
        for f in self.table.fields:
            if f.name == _field_name:
                dialog = TableFieldDialog(f)
                answer = dialog.run()
                if answer == gtk.RESPONSE_OK:
                    q = dialog.get_sql(self.table.name)
                    self.table.db.query(q)
                    self.table.refresh()
                    self.refresh()
                dialog.destroy()

    def refresh(self):
        for col in self.tv_fields.get_columns():
            self.tv_fields.remove_column(col)
        if self.tv_fields_model:
            self.tv_fields_model.clear()

        crt = gtk.CellRendererToggle()
        crt.connect("toggled", self.row_toggled, self.tv_fields_model)
        crt.set_activatable(True)
        tvc = gtk.TreeViewColumn("", crt)
        tvc.add_attribute(crt, "active", 0)
        self.tv_fields.append_column(tvc)
        self.tv_fields.append_column(gtk.TreeViewColumn("#", gtk.CellRendererText(), text=1))
        self.tv_fields.append_column(gtk.TreeViewColumn("Name", gtk.CellRendererText(), text=2))
        self.tv_fields.append_column(gtk.TreeViewColumn("Type", gtk.CellRendererText(), text=3))
        self.tv_fields.append_column(gtk.TreeViewColumn("Collation", gtk.CellRendererText(), text=4))
        self.tv_fields.append_column(gtk.TreeViewColumn("Null", gtk.CellRendererText(), text=5))
        self.tv_fields.append_column(gtk.TreeViewColumn("Default", gtk.CellRendererText(), text=6))
        self.tv_fields.append_column(gtk.TreeViewColumn("Extra", gtk.CellRendererText(), text=7))
        self.tv_fields.append_column(gtk.TreeViewColumn("Comment", gtk.CellRendererText(), text=8))
        fn = 1
        for f in self.table.fields:
            self.tv_fields_model.append(
                (
                    False,
                    fn,
                    f.name,
                    f.type_string,
                    f.row["Collation"],
                    "YES" if f.is_null else "NO",
                    f.default,
                    f.row["Extra"],
                    f.comment,
                )
            )
            fn += 1

    def row_toggled(self, cell, path, model):
        if not cell or not path or not model:
            return
        model[path][0] = not model[path][0]

    def on_button_release(self, tv, event):
        if not tv or not event or not event.button == 3:
            return False
        self.pop_up.popup(None, None, None, event.button, event.time, tv)