mirror of
https://github.com/fastapi-admin/fastapi-admin.git
synced 2025-08-26 02:39:01 +08:00
add row_attributes and cell_attributes
This commit is contained in:
@ -68,7 +68,8 @@ class FastAPIAdmin(FastAPI):
|
||||
self.resources.append(resource)
|
||||
|
||||
def get_model_resource(self, model: Type[Model]):
|
||||
return self.model_resources[model]()
|
||||
r = self.model_resources.get(model)
|
||||
return r() if r else None
|
||||
|
||||
|
||||
app = FastAPIAdmin(
|
||||
|
@ -21,6 +21,8 @@ def get_model(resource: Optional[str] = Path(...)):
|
||||
|
||||
def get_model_resource(request: Request, model=Depends(get_model)):
|
||||
model_resource = request.app.get_model_resource(model) # type:Model
|
||||
if not model_resource:
|
||||
raise HTTPException(status_code=HTTP_404_NOT_FOUND)
|
||||
actions = model_resource.get_actions()
|
||||
bulk_actions = model_resource.get_bulk_actions()
|
||||
model_resource.actions = actions
|
||||
|
@ -70,6 +70,12 @@ class Model(Resource):
|
||||
can_create: bool = True
|
||||
enctype = "application/x-www-form-urlencoded"
|
||||
|
||||
def row_attributes(self, obj: dict) -> dict:
|
||||
return {}
|
||||
|
||||
def cell_attributes(self, obj: dict, field: Field) -> dict:
|
||||
return {}
|
||||
|
||||
def get_actions(self) -> List[Action]:
|
||||
return [
|
||||
Action(label=_("update"), icon="ti ti-edit", name="update", ajax=False),
|
||||
@ -78,7 +84,12 @@ class Model(Resource):
|
||||
|
||||
def get_bulk_actions(self) -> List[Action]:
|
||||
return [
|
||||
Action(label=_("delete_selected"), icon="ti ti-trash", name="delete", method="DELETE"),
|
||||
Action(
|
||||
label=_("delete_selected"),
|
||||
icon="ti ti-trash",
|
||||
name="delete",
|
||||
method="DELETE",
|
||||
),
|
||||
]
|
||||
|
||||
@classmethod
|
||||
|
@ -37,14 +37,15 @@ async def list_view(
|
||||
else:
|
||||
page_size = model_resource.page_size
|
||||
qs = qs.offset((page_num - 1) * page_size)
|
||||
values = await qs.values_list(*fields_name)
|
||||
values = await render_values(fields, values)
|
||||
values = await qs.values(*fields_name)
|
||||
rendered_values = await render_values(fields, values)
|
||||
context = {
|
||||
"request": request,
|
||||
"resources": resources,
|
||||
"fields_label": fields_label,
|
||||
"fields": fields,
|
||||
"values": values,
|
||||
"rendered_values": rendered_values,
|
||||
"filters": filters,
|
||||
"resource": resource,
|
||||
"model_resource": model_resource,
|
||||
|
@ -58,10 +58,10 @@ async def render_values(
|
||||
ret = []
|
||||
for value in values:
|
||||
item = []
|
||||
for i, v in enumerate(value):
|
||||
for i, k in enumerate(value):
|
||||
if display:
|
||||
item.append(await fields[i].display.render(v))
|
||||
item.append(await fields[i].display.render(value[k]))
|
||||
else:
|
||||
item.append(await fields[i].input.render(v))
|
||||
item.append(await fields[i].input.render(value[k]))
|
||||
ret.append(item)
|
||||
return ret
|
||||
|
@ -107,20 +107,24 @@
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
{% for value in values %}
|
||||
<tr>
|
||||
{% if model_resource.bulk_actions %}
|
||||
<td>
|
||||
<input
|
||||
data-id="{{ value[0]|int }}"
|
||||
class="form-check-input m-0 align-middle checkbox-select-item"
|
||||
type="checkbox"
|
||||
/>
|
||||
</td>
|
||||
{% endif %}
|
||||
{% for v in value %}
|
||||
<td>{{ v|safe }}</td>
|
||||
{% for value in rendered_values %}
|
||||
<tr {% for k,v in model_resource.row_attributes(values[loop.index0]).items() %}{{ k }}="{{ v }}"{% endfor %}>
|
||||
{% if model_resource.bulk_actions %}
|
||||
<td>
|
||||
<input
|
||||
data-id="{{ value[0]|int }}"
|
||||
class="form-check-input m-0 align-middle checkbox-select-item"
|
||||
type="checkbox"
|
||||
/>
|
||||
</td>
|
||||
{% endif %}
|
||||
{% with outer_index = loop.index0 %}
|
||||
{% for x in value %}
|
||||
<td
|
||||
{% for k,v in model_resource.cell_attributes(values[outer_index],fields[loop.index0]).items() %}
|
||||
{{ k }}="{{ v }}"{% endfor %}>{{ x|safe }}</td>
|
||||
{% endfor %}
|
||||
{% endwith %}
|
||||
{% if model_resource.actions %}
|
||||
<td class="text-end">
|
||||
<span class="dropdown">
|
||||
|
Reference in New Issue
Block a user