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
8a9f3c6b
Commit
8a9f3c6b
authored
Dec 14, 2013
by
bryhoyt
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1 from bryhoyt/named-url-filters
Named url filters
parents
b49d5cc2
e61f2580
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
59 additions
and
34 deletions
+59
-34
base.py
flask_admin/model/base.py
+51
-34
filters.py
flask_admin/model/filters.py
+8
-0
No files found.
flask_admin/model/base.py
View file @
8a9f3c6b
...
@@ -948,45 +948,61 @@ class BaseModelView(BaseView, ActionsMixin):
...
@@ -948,45 +948,61 @@ class BaseModelView(BaseView, ActionsMixin):
def
get_empty_list_message
(
self
):
def
get_empty_list_message
(
self
):
return
gettext
(
'There are no items in the table.'
)
return
gettext
(
'There are no items in the table.'
)
# URL generation helper
def
get_filter_args
(
self
):
def
_get_extra_args
(
self
):
"""
"""
Return arguments from query string.
Retrieve and parse filter parameters from the request URL.
Returns a list of 2-tuples in the format [(idx, value), ...],
where idx is the index into the list returned by get_filters().
Override this method to provide your own URL filter format.
"""
if
not
self
.
_filters
:
return
None
filter_idx_by_label
=
dict
((
flt
.
query_label
(),
i
)
for
i
,
flt
in
enumerate
(
self
.
_filters
))
sfilters
=
[]
for
n
in
request
.
args
:
if
not
n
.
startswith
(
'flt'
):
continue
if
'_'
not
in
n
:
continue
pos
,
filter_label
=
n
[
3
:]
.
split
(
'_'
,
1
)
# If pos not specified, just add incrementally to the list.
pos
=
int
(
pos
)
if
pos
else
len
(
sfilters
)
try
:
# See if filter is numeric
idx
=
int
(
filter_label
)
except
ValueError
:
# If non-numeric, look filter up by name
try
:
idx
=
filter_idx_by_label
[
filter_label
]
except
KeyError
:
# No matching filter name
continue
if
0
<=
idx
<
len
(
self
.
_filters
):
flt
=
self
.
_filters
[
idx
]
value
=
request
.
args
[
n
]
if
flt
.
validate
(
value
):
sfilters
.
append
((
pos
,
(
idx
,
flt
.
clean
(
value
))))
return
[
v
[
1
]
for
v
in
sorted
(
sfilters
,
key
=
lambda
n
:
n
[
0
])]
def
_get_listing_args
(
self
):
"""
Return generic list view arguments from query string.
"""
"""
page
=
request
.
args
.
get
(
'page'
,
0
,
type
=
int
)
page
=
request
.
args
.
get
(
'page'
,
0
,
type
=
int
)
sort
=
request
.
args
.
get
(
'sort'
,
None
,
type
=
int
)
sort
=
request
.
args
.
get
(
'sort'
,
None
,
type
=
int
)
sort_desc
=
request
.
args
.
get
(
'desc'
,
None
,
type
=
int
)
sort_desc
=
request
.
args
.
get
(
'desc'
,
None
,
type
=
int
)
search
=
request
.
args
.
get
(
'search'
,
None
)
search
=
request
.
args
.
get
(
'search'
,
None
)
return
page
,
sort
,
sort_desc
,
search
# Gather filters
if
self
.
_filters
:
sfilters
=
[]
for
n
in
request
.
args
:
if
n
.
startswith
(
'flt'
):
ofs
=
n
.
find
(
'_'
)
if
ofs
==
-
1
:
continue
try
:
pos
=
int
(
n
[
3
:
ofs
])
idx
=
int
(
n
[
ofs
+
1
:])
except
ValueError
:
continue
if
idx
>=
0
and
idx
<
len
(
self
.
_filters
):
flt
=
self
.
_filters
[
idx
]
value
=
request
.
args
[
n
]
if
flt
.
validate
(
value
):
sfilters
.
append
((
pos
,
(
idx
,
flt
.
clean
(
value
))))
filters
=
[
v
[
1
]
for
v
in
sorted
(
sfilters
,
key
=
lambda
n
:
n
[
0
])]
else
:
filters
=
None
return
page
,
sort
,
sort_desc
,
search
,
filters
def
_get_url
(
self
,
view
=
None
,
page
=
None
,
sort
=
None
,
sort_desc
=
None
,
def
_get_url
(
self
,
view
=
None
,
page
=
None
,
sort
=
None
,
sort_desc
=
None
,
search
=
None
,
filters
=
None
):
search
=
None
,
filters
=
None
):
...
@@ -1104,7 +1120,8 @@ class BaseModelView(BaseView, ActionsMixin):
...
@@ -1104,7 +1120,8 @@ class BaseModelView(BaseView, ActionsMixin):
List view
List view
"""
"""
# Grab parameters from URL
# Grab parameters from URL
page
,
sort_idx
,
sort_desc
,
search
,
filters
=
self
.
_get_extra_args
()
page
,
sort_idx
,
sort_desc
,
search
=
self
.
_get_listing_args
()
filters
=
self
.
get_filter_args
()
# Map column index to column name
# Map column index to column name
sort_column
=
self
.
_get_column_by_idx
(
sort_idx
)
sort_column
=
self
.
_get_column_by_idx
(
sort_idx
)
...
...
flask_admin/model/filters.py
View file @
8a9f3c6b
...
@@ -72,6 +72,14 @@ class BaseFilter(object):
...
@@ -72,6 +72,14 @@ class BaseFilter(object):
"""
"""
raise
NotImplemented
()
raise
NotImplemented
()
def
query_label
(
self
):
"""
Return a string that can be used in a url to identify this filter.
For example u'username_equals'
"""
return
'{name}_{operation}'
.
format
(
name
=
self
.
name
,
operation
=
self
.
operation
())
.
lower
()
.
replace
(
' '
,
'_'
)
def
__unicode__
(
self
):
def
__unicode__
(
self
):
return
self
.
name
return
self
.
name
...
...
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