from __future__ import annotations
from attr import attrs
from itertools import groupby
from typing import Literal, TYPE_CHECKING
if TYPE_CHECKING:
from collections.abc import Iterator
from onegov.org.request import OrgRequest
[docs]
class Dashboard:
def __init__(self, request: OrgRequest) -> None:
@property
[docs]
def is_available(self) -> bool:
""" Returns true if there are boardlets to show. """
return self.request.app.config.boardlets_registry and True or False
[docs]
def boardlets(self) -> list[tuple[Boardlet, ...]]:
""" Returns the boardlets, grouped/ordered by their order tuple. """
instances = []
for name, data in self.request.app.config.boardlets_registry.items():
instances.append(data['cls'](
name=name,
order=data['order'],
request=self.request
))
instances.sort(key=lambda i: i.order)
boardlets = []
for group, items in groupby(instances, key=lambda i: i.order[0]):
boardlets.append(tuple(items))
return boardlets
[docs]
class Boardlet:
""" Base class used by all boardlets.
Use as follows::
from onegov.app import App
@App.boardlet(name='foo', order=(1, 1))
class MyBoardlet(Boardlet):
pass
"""
def __init__(
self,
name: str,
order: tuple[int, int],
request: OrgRequest
) -> None:
@property
[docs]
def title(self) -> str:
""" Returns the title of the boardlet, which is meant to be something
meaningful, like the most important metric used in the boardlet.
"""
raise NotImplementedError()
@property
[docs]
def facts(self) -> Iterator[BoardletFact]:
""" Yields facts. (:class:`BoardletFact` instances)"""
raise NotImplementedError()
@property
[docs]
def state(self) -> Literal['success', 'warning', 'failure']:
""" Yields one of three states:
* 'success'
* 'warning'
* 'failure'
"""
return 'success'
@attrs(auto_attribs=True)
[docs]
class BoardletFact:
""" A single boardlet fact. """
# the text of the fact (includes the metric)
# the font awesome (fa-*) icon to use, if any
[docs]
icon: str | None = None
[docs]
css_class: str | None = None