class AdminPluginPage(Page):
def __init__(self, obj, site, parent):
- super(AdminPluginPage, self).__init__(site)
+ super(AdminPluginPage, self).__init__(site, form=True)
self._obj = obj
self.title = '%s plugin' % obj.name
self.url = '%s/%s' % (parent.url, obj.name)
self.facility = parent.facility
self.menu = [parent]
+ self.back = parent.url
# Get the defaults
self.plugin_config = obj.get_config_desc()
if not self.plugin_config:
- self.plugin_config = []
+ self.plugin_config = dict()
# Now overlay the actual config
for option in self.plugin_config:
self.plugin_config[option][2] = obj.get_config_value(option)
+ self.options_order = []
+ if hasattr(obj, 'conf_opt_order'):
+ self.options_order = obj.conf_opt_order
+
+ # append any undefined options
+ add = []
+ for k in self.plugin_config.keys():
+ if k not in self.options_order:
+ add.append(k)
+ if len(add):
+ add.sort()
+ for k in add:
+ self.options_order.append(k)
+
@admin_protect
def GET(self, *args, **kwargs):
return self._template('admin/plugin_config.html', title=self.title,
name='admin_%s_%s_form' % (self.facility,
self._obj.name),
- menu=self.menu, action=self.url,
+ menu=self.menu, action=self.url, back=self.back,
+ options_order=self.options_order,
options=self.plugin_config)
@admin_protect
menu=self.menu, action=self.url,
options=self.plugin_config)
- def root(self, *args, **kwargs):
- cherrypy.log.error("method: %s" % cherrypy.request.method)
- op = getattr(self, cherrypy.request.method, self.GET)
- if callable(op):
- return op(*args, **kwargs)
-
class Admin(Page):