Provides a dashboard for Horae
The horae.dashboard package provides user and group dashboards for the Horae resource planning system. Every user and groups has its own dashboard which may contain multiple widgets which may be individually positioned and resized.
There are several dashboard widgets already implemented:
- Time tracking
- A widget to track time on tickets
- User tickets
- A widget listing the tickets the current user is responsible for
- A widget listing the latest changed objects of the current user
- A widget listing the latest notifications for the current user. Only available if the optional horae.notification package is installed.
- Work time tracking
- A widget to track the work time of human resources. Only available if the optional horae.resources package is installed.
- A widget displaying the results of a previously created report. Only available if the optional horae.reports package is installed.
Creating custom dashboard widgets is possible through the pluggable architecture of the package. A widget consists of at least four parts:
- The interface defining the schema of the widget and extends the base schema provided by horae.dashboard.interfaces.IWidget
- Widget factory
- A named global utility implementing horae.dashboard.interfaces.IWidgetFactory
- A persistent widget extending horae.dashboard.dashboard.Widget and implementing the Interface mentioned above
- The view named index rendering the widget in the dashboard
A sample widget having one custom field which is later rendered on the widgets view would be implemented as followed:
import grok from zope import schema from zope.schema.fieldproperty import FieldProperty from horae.dashboard import dashboard, interfaces class ISampleWidget(interfaces.IWidget): content = schema.TextLine( title = u'Content', required = True ) class SampleWidgetFactory(grok.GlobalUtility): grok.name('sample') grok.implements(interfaces.IWidgetFactory) name = u'Sample' schema = ISampleWidget def __call__(self): return SampleWidget() class SampleWidget(dashboard.Widget): grok.implements(ISampleWidget) title = u'Sample' content = FieldProperty(ISampleWidget['content']) class SampleWidgetIndex(grok.View): grok.name('index') grok.require('horae.View') grok.context(ISampleWidget) def render(self): return self.context.content
- Initial release