creole macro changed and improved. Help added
This commit is contained in:
parent
4116e36e7c
commit
f8cbb6ee4d
@ -25,8 +25,9 @@ CREOLE += mycreole.render_simple("""
|
|||||||
| {{{<<subpages>>}}} | will result in a list of all subpages below the current page. |
|
| {{{<<subpages>>}}} | will result in a list of all subpages below the current page. |
|
||||||
| {{{<<subpages=N,startswith>>}}} | will result in a list of subpages below the current page.\
|
| {{{<<subpages=N,startswith>>}}} | will result in a list of subpages below the current page.\
|
||||||
N will reduce the depth of the subpages to N. \
|
N will reduce the depth of the subpages to N. \
|
||||||
startswith will reduce the hits to all pages starting with the given string.
|
startswith will reduce the hits to all pages starting with the given string. \
|
||||||
You can give one or both Parameters. |
|
You can give one or both Parameters. |
|
||||||
|
| {{{<<allpages>>}}} | will result in a last of all pages. You can use [N,startswith] as with subpages. |
|
||||||
""")
|
""")
|
||||||
|
|
||||||
ACCESS = mycreole.render_simple(_("""
|
ACCESS = mycreole.render_simple(_("""
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
|
||||||
# TODO: PRIO: BugFix if subpages filter is used without parameters
|
|
||||||
# TODO: PRIO: Add wildcards for subpages filter
|
# TODO: PRIO: Add wildcards for subpages filter
|
||||||
# TODO: Add whoosh and search
|
# TODO: Add whoosh and search
|
||||||
|
|
||||||
@ -105,10 +104,13 @@ class creol_page(object):
|
|||||||
depth = 9999
|
depth = 9999
|
||||||
#
|
#
|
||||||
rv = ""
|
rv = ""
|
||||||
pathlist = fstools.dirlist(settings.PAGES_ROOT, rekursive=False)
|
# create a rel_path list
|
||||||
pathlist.sort()
|
pathlist = [self.__folder_content_filter__(os.path.basename(path)) for path in fstools.dirlist(settings.PAGES_ROOT, rekursive=False)]
|
||||||
for path in pathlist:
|
# sort basename
|
||||||
contentname = self.__folder_content_filter__(os.path.basename(path))
|
pathlist.sort(key=os.path.basename)
|
||||||
|
|
||||||
|
last_char = None
|
||||||
|
for contentname in pathlist:
|
||||||
#
|
#
|
||||||
if (contentname.startswith(self._rel_path) or allpages) and contentname != self._rel_path:
|
if (contentname.startswith(self._rel_path) or allpages) and contentname != self._rel_path:
|
||||||
if allpages:
|
if allpages:
|
||||||
@ -116,7 +118,12 @@ class creol_page(object):
|
|||||||
else:
|
else:
|
||||||
name = contentname[len(self._rel_path)+1:]
|
name = contentname[len(self._rel_path)+1:]
|
||||||
if name.count('/') < depth and name.startswith(startname):
|
if name.count('/') < depth and name.startswith(startname):
|
||||||
|
if last_char != os.path.basename(name)[0].upper():
|
||||||
|
last_char = os.path.basename(name)[0].upper()
|
||||||
|
if last_char is not None:
|
||||||
|
rv += "</ul>\n"
|
||||||
|
rv += f'<h3>{last_char}</h3>\n<ul>\n'
|
||||||
rv += f' <li><a href="{url_page(self._request, contentname)}">{name}</a></li>\n'
|
rv += f' <li><a href="{url_page(self._request, contentname)}">{name}</a></li>\n'
|
||||||
if len(rv) > 0:
|
if len(rv) > 0:
|
||||||
rv = "<ul>\n" + rv + "</ul>\n"
|
rv += "</ul>\n"
|
||||||
return rv
|
return rv
|
||||||
|
Loading…
x
Reference in New Issue
Block a user