unify editor url creation and child model creation
This commit is contained in:
parent
f35d548bed
commit
bafe094785
2 changed files with 43 additions and 60 deletions
|
@ -1,12 +1,21 @@
|
|||
from django.apps import apps
|
||||
from django.conf.urls import url
|
||||
|
||||
from c3nav.editor.views import edit, list_objects, main_index, section_detail, space_detail
|
||||
|
||||
|
||||
def add_editor_urls(name, model, parent_name_plural=None, parent_name=None, with_list=True, explicit_edit=False):
|
||||
prefix = ('' if parent_name is None else parent_name_plural+r'/(?P<'+parent_name+'>[0-9]+)/')+name
|
||||
name_prefix = 'editor.'+name+'.'
|
||||
kwargs = {'model': model, 'explicit_edit': explicit_edit}
|
||||
def add_editor_urls(model_name, parent_model_name=None, with_list=True, explicit_edit=False):
|
||||
model = apps.get_model('mapdata', model_name)
|
||||
model_name_plural = model._meta.default_related_name
|
||||
if parent_model_name:
|
||||
parent_model = apps.get_model('mapdata', parent_model_name)
|
||||
parent_model_name_plural = parent_model._meta.default_related_name
|
||||
prefix = (parent_model_name_plural+r'/(?P<'+parent_model_name.lower()+'>[0-9]+)/')+model_name_plural
|
||||
else:
|
||||
prefix = model_name_plural
|
||||
|
||||
name_prefix = 'editor.'+model_name_plural+'.'
|
||||
kwargs = {'model': model_name, 'explicit_edit': explicit_edit}
|
||||
explicit_edit = r'edit' if explicit_edit else ''
|
||||
|
||||
result = []
|
||||
|
@ -24,14 +33,14 @@ urlpatterns = [
|
|||
url(r'^sections/(?P<pk>[0-9]+)/$', section_detail, name='editor.sections.detail'),
|
||||
url(r'^sections/(?P<section>[0-9]+)/spaces/(?P<pk>[0-9]+)/$', space_detail, name='editor.spaces.detail'),
|
||||
]
|
||||
urlpatterns.extend(add_editor_urls('sections', 'Section', with_list=False, explicit_edit=True))
|
||||
urlpatterns.extend(add_editor_urls('locationgroups', 'LocationGroup'))
|
||||
urlpatterns.extend(add_editor_urls('buildings', 'Building', 'sections', 'section'))
|
||||
urlpatterns.extend(add_editor_urls('spaces', 'Space', 'sections', 'section', explicit_edit=True))
|
||||
urlpatterns.extend(add_editor_urls('doors', 'Door', 'sections', 'section'))
|
||||
urlpatterns.extend(add_editor_urls('holes', 'Hole', 'sections', 'section'))
|
||||
urlpatterns.extend(add_editor_urls('areas', 'Area', 'spaces', 'space'))
|
||||
urlpatterns.extend(add_editor_urls('stairs', 'Stair', 'spaces', 'space'))
|
||||
urlpatterns.extend(add_editor_urls('obstacles', 'Obstacle', 'spaces', 'space'))
|
||||
urlpatterns.extend(add_editor_urls('lineobstacles', 'LineObstacle', 'spaces', 'space'))
|
||||
urlpatterns.extend(add_editor_urls('points', 'Point', 'spaces', 'space'))
|
||||
urlpatterns.extend(add_editor_urls('Section', with_list=False, explicit_edit=True))
|
||||
urlpatterns.extend(add_editor_urls('LocationGroup'))
|
||||
urlpatterns.extend(add_editor_urls('Building', 'Section'))
|
||||
urlpatterns.extend(add_editor_urls('Space', 'Section', explicit_edit=True))
|
||||
urlpatterns.extend(add_editor_urls('Door', 'Section'))
|
||||
urlpatterns.extend(add_editor_urls('Hole', 'Section'))
|
||||
urlpatterns.extend(add_editor_urls('Area', 'Space'))
|
||||
urlpatterns.extend(add_editor_urls('Stair', 'Space'))
|
||||
urlpatterns.extend(add_editor_urls('Obstacle', 'Space'))
|
||||
urlpatterns.extend(add_editor_urls('LineObstacle', 'Space'))
|
||||
urlpatterns.extend(add_editor_urls('Point', 'Space'))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue