Add back colors in the toolbar. Layout/appeareance sucks atm
This commit is contained in:
parent
3fe0d7a580
commit
b129956aba
@ -54,7 +54,7 @@ class Chat(gtk.VBox):
|
|||||||
self._mode = Chat.TEXT_MODE
|
self._mode = Chat.TEXT_MODE
|
||||||
self._editor = ChatEditor(self, ChatEditor.TEXT_MODE)
|
self._editor = ChatEditor(self, ChatEditor.TEXT_MODE)
|
||||||
|
|
||||||
toolbar = ChatToolbar(self._editor.get_buffer())
|
toolbar = ChatToolbar(self._editor)
|
||||||
self.pack_start(toolbar, False)
|
self.pack_start(toolbar, False)
|
||||||
toolbar.show()
|
toolbar.show()
|
||||||
|
|
||||||
|
@ -45,6 +45,9 @@ class ChatEditor(gtk.HBox):
|
|||||||
|
|
||||||
self.set_mode(mode)
|
self.set_mode(mode)
|
||||||
|
|
||||||
|
def set_color(self, color):
|
||||||
|
self._sketchpad.set_color(color)
|
||||||
|
|
||||||
def get_buffer(self):
|
def get_buffer(self):
|
||||||
return self._text_view.get_buffer()
|
return self._text_view.get_buffer()
|
||||||
|
|
||||||
|
@ -3,19 +3,22 @@ pygtk.require('2.0')
|
|||||||
import gtk
|
import gtk
|
||||||
|
|
||||||
from sugar.chat.Emoticons import Emoticons
|
from sugar.chat.Emoticons import Emoticons
|
||||||
|
from sugar.chat.sketchpad.Toolbox import Toolbox
|
||||||
import richtext
|
import richtext
|
||||||
|
|
||||||
class ChatToolbar(gtk.HBox):
|
class ChatToolbar(gtk.HBox):
|
||||||
def __init__(self, rich_buf):
|
def __init__(self, editor):
|
||||||
gtk.HBox.__init__(self)
|
gtk.HBox.__init__(self)
|
||||||
|
|
||||||
|
self._editor = editor
|
||||||
self._emt_popup = None
|
self._emt_popup = None
|
||||||
|
|
||||||
spring = gtk.Label('')
|
# spring = gtk.Label('')
|
||||||
self.pack_start(spring, True)
|
# self.pack_start(spring, True)
|
||||||
spring.show()
|
# spring.show()
|
||||||
|
|
||||||
toolbar = richtext.RichTextToolbar(rich_buf)
|
toolbar = richtext.RichTextToolbar(editor.get_buffer())
|
||||||
|
toolbar.set_show_arrow(False)
|
||||||
|
|
||||||
item = gtk.ToolButton()
|
item = gtk.ToolButton()
|
||||||
|
|
||||||
@ -36,22 +39,30 @@ class ChatToolbar(gtk.HBox):
|
|||||||
toolbar.insert(item, -1)
|
toolbar.insert(item, -1)
|
||||||
item.show()
|
item.show()
|
||||||
|
|
||||||
separator = gtk.SeparatorToolItem()
|
# separator = gtk.SeparatorToolItem()
|
||||||
toolbar.insert(separator, -1)
|
# toolbar.insert(separator, -1)
|
||||||
separator.show()
|
# separator.show()
|
||||||
|
|
||||||
item = gtk.MenuToolButton(None, "Links")
|
# item = gtk.MenuToolButton(None, "Links")
|
||||||
item.set_menu(gtk.Menu())
|
# item.set_menu(gtk.Menu())
|
||||||
item.connect("show-menu", self.__show_link_menu_cb)
|
# item.connect("show-menu", self.__show_link_menu_cb)
|
||||||
toolbar.insert(item, -1)
|
# toolbar.insert(item, -1)
|
||||||
item.show()
|
# item.show()
|
||||||
|
|
||||||
self.pack_start(toolbar)
|
self.pack_start(toolbar)
|
||||||
toolbar.show()
|
toolbar.show()
|
||||||
|
|
||||||
spring = gtk.Label('')
|
toolbox = Toolbox()
|
||||||
self.pack_start(spring, True)
|
toolbox.connect('color-selected', self._color_selected)
|
||||||
spring.show()
|
self.pack_start(toolbox, False)
|
||||||
|
toolbox.show()
|
||||||
|
|
||||||
|
# spring = gtk.Label('')
|
||||||
|
# self.pack_start(spring, True)
|
||||||
|
# spring.show()
|
||||||
|
|
||||||
|
def _color_selected(self, toolbox, color):
|
||||||
|
self._editor.set_color(color)
|
||||||
|
|
||||||
def __link_activate_cb(self, item, link):
|
def __link_activate_cb(self, item, link):
|
||||||
buf = self._editor.get_buffer()
|
buf = self._editor.get_buffer()
|
||||||
@ -68,8 +79,7 @@ class ChatToolbar(gtk.HBox):
|
|||||||
menu.append(item)
|
menu.append(item)
|
||||||
item.show()
|
item.show()
|
||||||
|
|
||||||
button.set_menu(menu)
|
button.set_menu(menu)
|
||||||
|
|
||||||
|
|
||||||
def _create_emoticons_popup(self):
|
def _create_emoticons_popup(self):
|
||||||
model = gtk.ListStore(gtk.gdk.Pixbuf, str)
|
model = gtk.ListStore(gtk.gdk.Pixbuf, str)
|
||||||
|
@ -31,75 +31,31 @@ class ColorButton(gtk.RadioButton):
|
|||||||
|
|
||||||
return False
|
return False
|
||||||
|
|
||||||
class Toolbox(gtk.VBox):
|
class Toolbox(gtk.HBox):
|
||||||
__gsignals__ = {
|
__gsignals__ = {
|
||||||
'tool-selected': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
|
|
||||||
([gobject.TYPE_STRING])),
|
|
||||||
'color-selected': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
|
'color-selected': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
|
||||||
([gobject.TYPE_PYOBJECT]))
|
([gobject.TYPE_PYOBJECT]))
|
||||||
}
|
}
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
gtk.VBox.__init__(self, False, 12)
|
gtk.HBox.__init__(self, False, 6)
|
||||||
|
|
||||||
self._tools_group = None
|
|
||||||
self._colors_group = None
|
self._colors_group = None
|
||||||
|
|
||||||
self._tool_hbox = gtk.HBox(False, 2)
|
|
||||||
|
|
||||||
spring = gtk.Label()
|
|
||||||
self._tool_hbox.pack_start(spring, True)
|
|
||||||
spring.show()
|
|
||||||
|
|
||||||
self._add_tool('stock_draw-text', 'text')
|
|
||||||
self._add_tool('stock_draw-freeform-line', 'freehand')
|
|
||||||
|
|
||||||
spring = gtk.Label()
|
|
||||||
self._tool_hbox.pack_start(spring, True)
|
|
||||||
spring.show()
|
|
||||||
|
|
||||||
self.pack_start(self._tool_hbox)
|
|
||||||
self._tool_hbox.show()
|
|
||||||
|
|
||||||
self._color_hbox = gtk.HBox(False, 2)
|
|
||||||
|
|
||||||
self._add_color([0, 0, 0])
|
self._add_color([0, 0, 0])
|
||||||
self._add_color([1, 0, 0])
|
self._add_color([1, 0, 0])
|
||||||
self._add_color([0, 1, 0])
|
self._add_color([0, 1, 0])
|
||||||
self._add_color([0, 0, 1])
|
self._add_color([0, 0, 1])
|
||||||
|
|
||||||
self.pack_start(self._color_hbox)
|
|
||||||
self._color_hbox.show()
|
|
||||||
|
|
||||||
def _add_tool(self, icon, tool_id):
|
|
||||||
image = gtk.Image()
|
|
||||||
image.set_from_icon_name(icon, gtk.ICON_SIZE_LARGE_TOOLBAR)
|
|
||||||
|
|
||||||
tool = gtk.RadioButton(self._tools_group)
|
|
||||||
tool.set_mode(False)
|
|
||||||
tool.set_relief(gtk.RELIEF_NONE)
|
|
||||||
tool.set_image(image)
|
|
||||||
tool.connect('clicked', self.__tool_clicked_cb, tool_id)
|
|
||||||
self._tool_hbox.pack_start(tool, False)
|
|
||||||
|
|
||||||
if self._tools_group == None:
|
|
||||||
self._tools_group = tool
|
|
||||||
|
|
||||||
tool.show()
|
|
||||||
|
|
||||||
def _add_color(self, rgb):
|
def _add_color(self, rgb):
|
||||||
color = ColorButton(self._colors_group, rgb)
|
color = ColorButton(self._colors_group, rgb)
|
||||||
color.connect('clicked', self.__color_clicked_cb, rgb)
|
color.connect('clicked', self.__color_clicked_cb, rgb)
|
||||||
self._color_hbox.pack_start(color, False)
|
self.pack_start(color, False)
|
||||||
|
|
||||||
if self._colors_group == None:
|
if self._colors_group == None:
|
||||||
self._colors_group = color
|
self._colors_group = color
|
||||||
|
|
||||||
color.show()
|
color.show()
|
||||||
|
|
||||||
def __tool_clicked_cb(self, button, tool_id):
|
|
||||||
self.emit("tool-selected", tool_id)
|
|
||||||
|
|
||||||
def __color_clicked_cb(self, button, rgb):
|
def __color_clicked_cb(self, button, rgb):
|
||||||
self.emit("color-selected", button.color())
|
self.emit("color-selected", button.color())
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user