Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
flask-admin
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
JIRA
JIRA
Merge Requests
0
Merge Requests
0
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Python-Dev
flask-admin
Commits
834c4d94
Commit
834c4d94
authored
Apr 25, 2016
by
Paul Brown
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add example for filtering options in forms
parent
cbb6acc5
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
112 additions
and
0 deletions
+112
-0
README.rst
examples/sqla-filter-selectable/README.rst
+21
-0
__init__.py
examples/sqla-filter-selectable/__init__.py
+0
-0
app.py
examples/sqla-filter-selectable/app.py
+88
-0
requirement.txt
examples/sqla-filter-selectable/requirement.txt
+3
-0
No files found.
examples/sqla-filter-selectable/README.rst
0 → 100644
View file @
834c4d94
SQLA backend example showing how to filter select dropdown options in forms.
To run this example:
1. Clone the repository::
git clone https://github.com/flask-admin/flask-admin.git
cd flask-admin
2. Create and activate a virtual environment::
virtualenv env
source env/bin/activate
3. Install requirements::
pip install -r 'examples/sqla-filter-selectable/requirements.txt'
4. Run the application::
python examples/sqla-filter-selectable/app.py
examples/sqla-filter-selectable/__init__.py
0 → 100644
View file @
834c4d94
examples/sqla-filter-selectable/app.py
0 → 100644
View file @
834c4d94
from
flask
import
Flask
from
flask_sqlalchemy
import
SQLAlchemy
import
flask_admin
as
admin
from
flask_admin.contrib
import
sqla
# Create application
app
=
Flask
(
__name__
)
# Create dummy secrey key so we can use sessions
app
.
config
[
'SECRET_KEY'
]
=
'123456790'
# Create in-memory database
app
.
config
[
'SQLALCHEMY_DATABASE_URI'
]
=
'sqlite:///sample_db_3.sqlite'
app
.
config
[
'SQLALCHEMY_ECHO'
]
=
True
db
=
SQLAlchemy
(
app
)
# Flask views
@
app
.
route
(
'/'
)
def
index
():
return
'<a href="/admin/">Click me to get to Admin!</a>'
class
Person
(
db
.
Model
):
id
=
db
.
Column
(
db
.
Integer
,
primary_key
=
True
)
name
=
db
.
Column
(
db
.
String
(
50
))
pets
=
db
.
relationship
(
'Pet'
,
backref
=
'person'
)
def
__unicode__
(
self
):
return
self
.
name
class
Pet
(
db
.
Model
):
id
=
db
.
Column
(
db
.
Integer
,
primary_key
=
True
)
name
=
db
.
Column
(
db
.
String
(
50
))
person_id
=
db
.
Column
(
db
.
Integer
,
db
.
ForeignKey
(
'person.id'
))
available
=
db
.
Column
(
db
.
Boolean
)
def
__unicode__
(
self
):
return
self
.
name
class
PersonAdmin
(
sqla
.
ModelView
):
""" Override ModelView to filter options available in forms. """
def
create_form
(
self
):
return
self
.
_use_filtered_parent
(
super
(
PersonAdmin
,
self
)
.
create_form
()
)
def
edit_form
(
self
,
obj
):
return
self
.
_use_filtered_parent
(
super
(
PersonAdmin
,
self
)
.
edit_form
(
obj
)
)
def
_use_filtered_parent
(
self
,
form
):
form
.
pets
.
query_factory
=
self
.
_get_parent_list
return
form
def
_get_parent_list
(
self
):
# only show available pets in the form
return
Pet
.
query
.
filter_by
(
available
=
True
)
.
all
()
def
__unicode__
(
self
):
return
self
.
name
# Create admin
admin
=
admin
.
Admin
(
app
,
name
=
'Example: SQLAlchemy - Filtered Form Selectable'
,
template_mode
=
'bootstrap3'
)
admin
.
add_view
(
PersonAdmin
(
Person
,
db
.
session
))
admin
.
add_view
(
sqla
.
ModelView
(
Pet
,
db
.
session
))
if
__name__
==
'__main__'
:
# Recreate DB
db
.
drop_all
()
db
.
create_all
()
person
=
Person
(
name
=
'Bill'
)
pet1
=
Pet
(
name
=
'Dog'
,
available
=
True
)
pet2
=
Pet
(
name
=
'Fish'
,
available
=
True
)
pet3
=
Pet
(
name
=
'Ocelot'
,
available
=
False
)
db
.
session
.
add_all
([
person
,
pet1
,
pet2
,
pet3
])
db
.
session
.
commit
()
# Start app
app
.
run
(
debug
=
True
)
examples/sqla-filter-selectable/requirement.txt
0 → 100644
View file @
834c4d94
Flask
Flask-Admin
Flask-SQLAlchemy
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment