feat: show related Quantity records when viewing a Measure
This commit is contained in:
parent
a547188a90
commit
609a900f39
1 changed files with 51 additions and 0 deletions
|
|
@ -52,6 +52,26 @@ class MeasureView(WuttaFarmMasterView):
|
||||||
"drupal_id",
|
"drupal_id",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
has_rows = True
|
||||||
|
row_model_class = Quantity
|
||||||
|
rows_viewable = True
|
||||||
|
|
||||||
|
row_labels = {
|
||||||
|
"quantity_type_id": "Quantity Type ID",
|
||||||
|
"measure_id": "Measure ID",
|
||||||
|
}
|
||||||
|
|
||||||
|
row_grid_columns = [
|
||||||
|
"drupal_id",
|
||||||
|
"as_text",
|
||||||
|
"quantity_type",
|
||||||
|
"value",
|
||||||
|
"units",
|
||||||
|
"label",
|
||||||
|
]
|
||||||
|
|
||||||
|
rows_sort_defaults = ("drupal_id", "desc")
|
||||||
|
|
||||||
def configure_grid(self, grid):
|
def configure_grid(self, grid):
|
||||||
g = grid
|
g = grid
|
||||||
super().configure_grid(g)
|
super().configure_grid(g)
|
||||||
|
|
@ -59,6 +79,37 @@ class MeasureView(WuttaFarmMasterView):
|
||||||
# name
|
# name
|
||||||
g.set_link("name")
|
g.set_link("name")
|
||||||
|
|
||||||
|
def get_row_grid_data(self, measure):
|
||||||
|
model = self.app.model
|
||||||
|
session = self.Session()
|
||||||
|
return session.query(model.Quantity).filter(model.Quantity.measure == measure)
|
||||||
|
|
||||||
|
def configure_row_grid(self, grid):
|
||||||
|
g = grid
|
||||||
|
super().configure_row_grid(g)
|
||||||
|
|
||||||
|
# drupal_id
|
||||||
|
g.set_label("drupal_id", "ID", column_only=True)
|
||||||
|
|
||||||
|
# as_text
|
||||||
|
g.set_renderer("as_text", self.render_as_text_for_grid)
|
||||||
|
g.set_link("as_text")
|
||||||
|
|
||||||
|
# value
|
||||||
|
g.set_renderer("value", self.render_value_for_grid)
|
||||||
|
|
||||||
|
def render_as_text_for_grid(self, quantity, field, value):
|
||||||
|
return quantity.render_as_text(self.config)
|
||||||
|
|
||||||
|
def render_value_for_grid(self, quantity, field, value):
|
||||||
|
value = quantity.value_numerator / quantity.value_denominator
|
||||||
|
return self.app.render_quantity(value)
|
||||||
|
|
||||||
|
def get_row_action_url_view(self, quantity, i):
|
||||||
|
return self.request.route_url(
|
||||||
|
f"quantities_{quantity.quantity_type_id}.view", uuid=quantity.uuid
|
||||||
|
)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def defaults(cls, config):
|
def defaults(cls, config):
|
||||||
""" """
|
""" """
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue