繁体   English   中英

使用mongoengine的Flask-Admin - 如何在视图上设置“持久性过滤器”?

[英]Flask-Admin with mongoengine - how to set a “persistent filter” on a view?

我尝试使用带有Mongoengine的Flask-Admin,我完全卡住了。 我找不到实现“持久性过滤器”的解决方案。 我的意思是,用户应该只看到视图(列表)中的项目并与之交互,这些项目是由mongoengine中的自定义查询产生的。

如果我有一个模特

class User(Document):
    name = StringField()
    days = DecimalField()
    book = StringField()

我想在第一个视图中只显示取决于特定用户的书籍,我会查询:

user_peter = User.objects(name=’Peter’)

如果我想为彼得出示过期书籍,我会查询:

overdue_books = User.objects(name=’Peter’, days__gt=28)

如何在自定义flask-admin-view中实现它? 我必须在ModelView中设置什么?

Class LentBooks(ModelView):
    menu_class_name=”Your Books”
    #???

Class OverdueBooks(ModelView):
    menu_class_name=”Overdue Books”
    #???

还是我必须把它放在这里?

Admin.add_view(LentBooks(model=User, #???))

对于SQLAlchemy,有很多食谱,但不适用于mongoengine。 请帮忙!

我发现的是在flask_admin.contrib.mongoengine.filters中

class FilterEqual(BaseMongoEngineFilter):
    def apply(self, query, value):
        flt = {'%s' % self.column.name: value}
        return query.filter(**flt)

    def operation(self):
        return lazy_gettext('equals')

但是如何实现这个?

谢谢pjcunningham !!

以下是来自pjcunningham的小型测试源解决方案:

from flask import Flask
import flask_admin as admin
from flask_mongoengine import MongoEngine
from flask_admin.contrib.mongoengine import ModelView

app = Flask(__name__)

app.config['SECRET_KEY'] = '1234567890'
app.config['MONGODB_SETTINGS'] = {'db': 'library'}

db = MongoEngine()
db.init_app(app)

class User(db.Document):
    name = db.StringField()
    days = db.DecimalField()
    book = db.StringField()

class OverdueBooks(ModelView):
    def get_query(self):
        overdue_books = User.objects(name='Peter', days__gt=28)
        return overdue_books

if __name__ == '__main__':

    admin = admin.Admin(app, 'Example: Library')

    admin.add_view(OverdueBooks(model=User, name='Library'))

    app.run(debug=True)

在MongoDB中:

{ "_id" : ObjectId("5815f403e198515188860e3c"), "name" : "Jane", "days" : 21, "book" : "Testbook1" }
{ "_id" : ObjectId("5815f416e198515188860e3d"), "name" : "Peter", "days" : 30, "book" : "Testbook2" }

非常感谢你! 有用!

在视图中覆盖get_query 例如

class OverdueBooks(ModelView):

    def get_query(self):            
        overdue_books = User.objects(name=’Peter’, days__gt=28)
        return overdue_books

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM