Flask-Admin:如何将数据库视图添加到其他站点

时间:2018-04-23 14:59:56

标签: flask flask-admin

问题:如何将flask-admin视图(仅包含编辑/删除条目的表格)添加到flask-admin和admin路径之外的页面?

我有一页

@app.route("/daten")
@login_required
def ansicht():
     d = current_user.u_daten.order_by('date').all()
     return render_template('ansicht.html',title='Ansicht der Daten', data = d)

呈现此模板。

{% extends "base.html" %}
{% block app_content %}
<h1>Ansicht der Daten</h1>
<table id="table_id" class="table-condensed table-striped table-hover table-responsive table-bordered">
<thead>
  <th> Datum </th>
  <th> Gewicht in Kg</th>
  <th> Körperfett in Prozent</th>
</thead>
<tbody>
  {% for element in data %}
  <tr>
    <td> {{ moment(element.date).format('L') }} </td>
    <td align = "right"> {{ element.bw|float}} </td>
    {% set bf = element.bf|float * 100 %}
    <td align = "right"> {{'%0.1f' % bf }}</td>
  </tr>      
  {% endfor %}
</tbody>
</table>
{% endblock %}

这可以按预期工作但是

  • 我想将此表与烧瓶管理视图交换,以包含编辑和删除功能。
  • 我想使用base.html中的导航栏而不是来自flask-admin的menue / navbar

我已构建此视图以仅过滤当前用户的数据,以便登录用户可以编辑自己的数据。

class UserDaten(ModelView):

    can_create = False

    column_exclude_list = ('user_id')
    column_default_sort = ('date', True)
    column_labels = dict(date=u'Datum', bw=u'Körpergewicht in kg', bf=u'Körperfett in Prozent')
    column_formatters = dict(bf=lambda v,c,m,p: m.bf*100, date=lambda v,c,m,p: m.date.strftime('%d.%m.%Y'))

    form_args = dict(date=dict(label= u'Datum der Messung'  , format='%d.%m.%Y',validators=[DataRequired()]))
    form_excluded_columns = ('user_id')
    form_choices = {'bf': [('0.232','23.2 %'),
                        ('0.218','21.8 %'),
                        ('0.202','20.2 %'),
                        ('0.186','18.6 %'),
                        ('0.168','16.8 %'),
                        ('0.148','14.8 %'),
                        ('0.127','12.7 %'),
                        ('0.105','10.5 %'),
                        ('0.081','8.1 %')]}

    def get_query(self):
        return self.session.query(self.model).filter(self.model.user_id == current_user.id)
    def get_count_query(self):
        return self.session.query(func.count('*')).filter(self.model.user_id == current_user.id)

admin.add_view(UserDaten(Daten, db.session))

使用

admin.add_view(UserDaten(Daten, db.session))

我将此观点添加到

/admin/daten

基于我的__init__.py并带有

admin = Admin(app)
  • 我现在要做的是禁用路由/管理员和
  • 在route / daten
  • 中包含flask-admin视图

我可能需要更改模板以包含相应的jinja标记并将渲染函数添加到类中,但我似乎无法使其工作。

TL; DR 如何使用flask-admin中的“nice”表视图和编辑/删除另一个烧瓶渲染页面内的函数?

1 个答案:

答案 0 :(得分:2)

要将您的HTML样式与Flask-Admin提供的功能结合使用,您可以自定义Flask-Admin的list.htmledit.html和其他模板文件以满足您的要求 风格需求。使用get_query自定义要在表格中显示的数据。

要删除模型视图网址的admin部分,您可以在创建Flask-Admin实例(url)时设置admin = Admin(app, "Admin", url='/')参数。将modelview添加到admin(endpoint)时设置admin.add_view(UserDaten(User, db.session, endpoint='daten'))参数。