Fix HtmlView that crashes after recent changes

svn: r11667
This commit is contained in:
Benny Malengier 2009-01-19 20:58:02 +00:00
parent 0df7429978
commit c0c9f08a54

View File

@ -280,6 +280,9 @@ class HtmlView(PageView.PageView):
PageView.PageView.__init__(self, _('HtmlView'), dbstate, uistate) PageView.PageView.__init__(self, _('HtmlView'), dbstate, uistate)
self.dbstate = dbstate self.dbstate = dbstate
self.external_url = False
self.need_to_resize = False
def build_widget(self): def build_widget(self):
""" """
@ -339,9 +342,39 @@ class HtmlView(PageView.PageView):
self.back_action.set_sensitive(self.renderer.can_go_back()) self.back_action.set_sensitive(self.renderer.can_go_back())
def open(self, url): def open(self, url):
""" open an url
"""
self.renderer.open(url) self.renderer.open(url)
self.set_button_sensitivity() self.set_button_sensitivity()
def go_back(self, button):
self.renderer.go_back();
self.set_button_sensitivity()
self.external_uri()
def go_forward(self, button):
self.renderer.go_forward();
self.set_button_sensitivity()
self.external_uri()
def refresh(self,button):
self.renderer.refresh();
def external_uri(self):
uri = self.renderer.get_uri()
if self.external_url:
self.external_url = False
self.need_to_resize = True
else:
try:
if uri.find(self.htmlfile) == -1:
# external web page or start_page
self.need_to_resize = True
else:
self.need_to_resize = False
except:
pass
def _on_activate(self, object): def _on_activate(self, object):
url = self.urlfield.get_text() url = self.urlfield.get_text()
if url.find('://') == -1: if url.find('://') == -1:
@ -363,8 +396,54 @@ class HtmlView(PageView.PageView):
""" """
return 'gramps-geo' return 'gramps-geo'
def ui_definition(self):
"""
Specifies the UIManager XML code that defines the menus and buttons
associated with the interface.
"""
return '''<ui>
<toolbar name="ToolBar">
<placeholder name="CommonNavigation">
<toolitem action="Back"/>
<toolitem action="Forward"/>
<toolitem action="Refresh"/>
</placeholder>
</toolbar>
</ui>'''
def define_actions(self): def define_actions(self):
pass """
Required define_actions function for PageView. Builds the action
group information required.
"""
HtmlView._define_actions_fw_bw(self)
def _define_actions_fw_bw(self):
# add the Backward action to handle the Backward button
# accel doesn't work in webkit and gtkmozembed !
# we must do that ...
self.back_action = gtk.ActionGroup(self.title + '/Back')
self.back_action.add_actions([
('Back', gtk.STOCK_GO_BACK, _("_Back"),
"<ALT>Left", _("Go to the previous page in the history"),
self.go_back)
])
self._add_action_group(self.back_action)
# add the Forward action to handle the Forward button
self.forward_action = gtk.ActionGroup(self.title + '/Forward')
self.forward_action.add_actions([
('Forward', gtk.STOCK_GO_FORWARD, _("_Forward"),
"<ALT>Right", _("Go to the next page in the history"),
self.go_forward)
])
self._add_action_group(self.forward_action)
# add the Refresh action to handle the Refresh button
self._add_action('Refresh', gtk.STOCK_REFRESH, _("_Refresh"),
callback=self.refresh,
accel="<Ctl>R",
tip=_("Stop and reload the page."))
def init_parent_signals_for_map(self, widget, event): def init_parent_signals_for_map(self, widget, event):
# required to properly bootstrap the signal handlers. # required to properly bootstrap the signal handlers.
@ -416,8 +495,6 @@ class GeoView(HtmlView):
self.usedmap = "openstreetmap" self.usedmap = "openstreetmap"
self.displaytype = "person" self.displaytype = "person"
self.external_url = False
self.need_to_resize = False
self.nbmarkers = 0 self.nbmarkers = 0
self.nbpages = 0 self.nbpages = 0
@ -468,34 +545,6 @@ class GeoView(HtmlView):
def change_map(self,usedmap): def change_map(self,usedmap):
self.renderer.execute_script("javascript:mapstraction.swap(map,'"+usedmap+"')"); self.renderer.execute_script("javascript:mapstraction.swap(map,'"+usedmap+"')");
def refresh(self,button):
self.renderer.refresh();
def external_uri(self):
uri = self.renderer.get_uri()
if self.external_url:
self.external_url = False
self.need_to_resize = True
else:
try:
if uri.find(self.htmlfile) == -1:
# external web page or start_page
self.need_to_resize = True
else:
self.need_to_resize = False
except:
pass
def go_back(self,button):
self.renderer.go_back();
self.set_button_sensitivity()
self.external_uri()
def go_forward(self,button):
self.renderer.go_forward();
self.set_button_sensitivity()
self.external_uri()
def ui_definition(self): def ui_definition(self):
""" """
Specifies the UIManager XML code that defines the menus and buttons Specifies the UIManager XML code that defines the menus and buttons
@ -532,42 +581,10 @@ class GeoView(HtmlView):
def define_actions(self): def define_actions(self):
""" """
Required define_actions function for PageView. Builds the action Required define_actions function for PageView. Builds the action
group information required. We extend beyond the normal here, group information required.
since we want to have more than one action group for the PersonView.
Most PageViews really won't care about this.
Special action groups for Forward and Back are created to allow the
handling of navigation buttons. Forward and Back allow the user to
advance or retreat throughout the history, and we want to have these
be able to toggle these when you are at the end of the history or
at the beginning of the history.
""" """
# add the Backward action to handle the Backward button HtmlView._define_actions_fw_bw(self)
# accel doesn't work in webkit and gtkmozembed !
# we must do that ...
self.back_action = gtk.ActionGroup(self.title + '/Back')
self.back_action.add_actions([
('Back', gtk.STOCK_GO_BACK, _("_Back"),
"<ALT>Left", _("Go to the previous page in the history"),
self.go_back)
])
self._add_action_group(self.back_action)
# add the Forward action to handle the Forward button
self.forward_action = gtk.ActionGroup(self.title + '/Forward')
self.forward_action.add_actions([
('Forward', gtk.STOCK_GO_FORWARD, _("_Forward"),
"<ALT>Right", _("Go to the next page in the history"),
self.go_forward)
])
self._add_action_group(self.forward_action)
# add the Refresh action to handle the Refresh button
self._add_action('Refresh', gtk.STOCK_REFRESH, _("_Refresh"),
callback=self.refresh,
accel="<Ctl>R",
tip=_("Stop and reload the page."))
self._add_action('OpenStreetMap', 'gramps-openstreetmap', _('_OpenStreetMap'), self._add_action('OpenStreetMap', 'gramps-openstreetmap', _('_OpenStreetMap'),
callback=self.select_OpenStreetMap_map, callback=self.select_OpenStreetMap_map,
@ -610,7 +627,6 @@ class GeoView(HtmlView):
callback=self.event_places, callback=self.event_places,
tip=_("Attempt to view places on the Map for all events.")) tip=_("Attempt to view places on the Map for all events."))
HtmlView.define_actions(self)
def goto_active_person(self,handle=None): def goto_active_person(self,handle=None):
self.geo_places(self.displaytype) self.geo_places(self.displaytype)