fix: add ordinal for sorting Measures
This commit is contained in:
parent
a43f98c304
commit
a355e9e1b7
5 changed files with 53 additions and 2 deletions
|
|
@ -167,7 +167,7 @@ class WuttaFarmAppHandler(base.AppHandler):
|
||||||
"""
|
"""
|
||||||
model = self.model
|
model = self.model
|
||||||
with self.short_session(session=session) as sess:
|
with self.short_session(session=session) as sess:
|
||||||
return sess.query(model.Measure).order_by(model.Measure.name).all()
|
return sess.query(model.Measure).order_by(model.Measure.ordinal).all()
|
||||||
|
|
||||||
def get_units(self, session=None):
|
def get_units(self, session=None):
|
||||||
"""
|
"""
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,37 @@
|
||||||
|
"""add Measure.ordinal
|
||||||
|
|
||||||
|
Revision ID: 82a497e30a97
|
||||||
|
Revises: c5183b781d34
|
||||||
|
Create Date: 2026-03-08 13:15:36.917747
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
from typing import Sequence, Union
|
||||||
|
|
||||||
|
from alembic import op
|
||||||
|
import sqlalchemy as sa
|
||||||
|
import wuttjamaican.db.util
|
||||||
|
|
||||||
|
|
||||||
|
# revision identifiers, used by Alembic.
|
||||||
|
revision: str = "82a497e30a97"
|
||||||
|
down_revision: Union[str, None] = "c5183b781d34"
|
||||||
|
branch_labels: Union[str, Sequence[str], None] = None
|
||||||
|
depends_on: Union[str, Sequence[str], None] = None
|
||||||
|
|
||||||
|
|
||||||
|
def upgrade() -> None:
|
||||||
|
|
||||||
|
# measure
|
||||||
|
op.add_column("measure", sa.Column("ordinal", sa.Integer(), nullable=True))
|
||||||
|
op.add_column(
|
||||||
|
"measure_version",
|
||||||
|
sa.Column("ordinal", sa.Integer(), autoincrement=False, nullable=True),
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def downgrade() -> None:
|
||||||
|
|
||||||
|
# measure
|
||||||
|
op.drop_column("measure_version", "ordinal")
|
||||||
|
op.drop_column("measure", "ordinal")
|
||||||
|
|
@ -42,6 +42,14 @@ class Measure(model.Base):
|
||||||
|
|
||||||
uuid = model.uuid_column()
|
uuid = model.uuid_column()
|
||||||
|
|
||||||
|
ordinal = sa.Column(
|
||||||
|
sa.Integer(),
|
||||||
|
nullable=True,
|
||||||
|
doc="""
|
||||||
|
Ordinal (sequence number) for the measure.
|
||||||
|
""",
|
||||||
|
)
|
||||||
|
|
||||||
name = sa.Column(
|
name = sa.Column(
|
||||||
sa.String(length=100),
|
sa.String(length=100),
|
||||||
nullable=False,
|
nullable=False,
|
||||||
|
|
|
||||||
|
|
@ -873,6 +873,7 @@ class MeasureImporter(FromFarmOS, ToWutta):
|
||||||
|
|
||||||
supported_fields = [
|
supported_fields = [
|
||||||
"drupal_id",
|
"drupal_id",
|
||||||
|
"ordinal",
|
||||||
"name",
|
"name",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
@ -883,12 +884,15 @@ class MeasureImporter(FromFarmOS, ToWutta):
|
||||||
)
|
)
|
||||||
response.raise_for_status()
|
response.raise_for_status()
|
||||||
data = response.json()
|
data = response.json()
|
||||||
|
self.ordinal = 0
|
||||||
return data["definitions"]["attributes"]["properties"]["measure"]["oneOf"]
|
return data["definitions"]["attributes"]["properties"]["measure"]["oneOf"]
|
||||||
|
|
||||||
def normalize_source_object(self, measure):
|
def normalize_source_object(self, measure):
|
||||||
""" """
|
""" """
|
||||||
|
self.ordinal += 1
|
||||||
return {
|
return {
|
||||||
"drupal_id": measure["const"],
|
"drupal_id": measure["const"],
|
||||||
|
"ordinal": self.ordinal,
|
||||||
"name": measure["title"],
|
"name": measure["title"],
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -37,17 +37,19 @@ class MeasureView(WuttaFarmMasterView):
|
||||||
url_prefix = "/measures"
|
url_prefix = "/measures"
|
||||||
|
|
||||||
grid_columns = [
|
grid_columns = [
|
||||||
|
"ordinal",
|
||||||
"name",
|
"name",
|
||||||
"drupal_id",
|
"drupal_id",
|
||||||
]
|
]
|
||||||
|
|
||||||
sort_defaults = "name"
|
sort_defaults = "ordinal"
|
||||||
|
|
||||||
filter_defaults = {
|
filter_defaults = {
|
||||||
"name": {"active": True, "verb": "contains"},
|
"name": {"active": True, "verb": "contains"},
|
||||||
}
|
}
|
||||||
|
|
||||||
form_fields = [
|
form_fields = [
|
||||||
|
"ordinal",
|
||||||
"name",
|
"name",
|
||||||
"drupal_id",
|
"drupal_id",
|
||||||
]
|
]
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue