Skip to content

Commit

Permalink
add page for the listing of schemas
Browse files Browse the repository at this point in the history
  • Loading branch information
kimakan committed Feb 19, 2024
1 parent 6eeec21 commit 401573d
Show file tree
Hide file tree
Showing 3 changed files with 53 additions and 1 deletion.
36 changes: 36 additions & 0 deletions daiquiri/metadata/templates/metadata/schemas.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
{% extends 'core/page.html' %}
{% load i18n %}
{% load static %}
{% load core_tags %}
{% load metadata_tags %}

{% block page %}

<h1 class="hide-overflow">
Database Schemas
</h1>

<ul class="list-unstyled">
{% for schema in schemas %}
<li>
<h4>
<a href="{% url 'metadata:schema' schema.name %}">
{% if schema.title %}
{{ schema.title }} ({{ schema }})
{% else %}
{{ schema }}
{% endif %}
</a>
</h4>
{% if schema.description %}
{{ schema.description | markdown }}
{% endif %}
</li>
{% endfor %}
</ul>

{% endblock %}

{% block sidebar %}

{% endblock %}
3 changes: 2 additions & 1 deletion daiquiri/metadata/urls.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
from django.urls import include, path, re_path
from rest_framework import routers

from .views import ManagementView, SchemaView, TableView
from .views import ManagementView, SchemaView, SchemasView, TableView
from .viewsets import (AccessLevelViewSet, ColumnViewSet, FunctionViewSet,
LicenseViewSet, SchemaViewSet, TableTypeViewSet,
TableViewSet)
Expand All @@ -24,4 +24,5 @@

re_path(r'^(?P<schema_name>\w+)/$', SchemaView.as_view(), name='schema'),
re_path(r'^(?P<schema_name>\w+)/(?P<table_name>\w+)/$', TableView.as_view(), name='table'),
path(r'', SchemasView.as_view(), name='schemas'),
]
15 changes: 15 additions & 0 deletions daiquiri/metadata/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,21 @@ def get_context_data(self, **kwargs):
return context


class SchemasView(TemplateView):
template_name = 'metadata/schemas.html'

def get_context_data(self, **kwargs):
context = super(SchemasView, self).get_context_data(**kwargs)

try:
schemas = Schema.objects.filter_by_metadata_access_level(self.request.user).all()
except Schema.DoesNotExist:
raise Http404()

context['schemas'] = schemas
return context


class SchemaView(TemplateView):
template_name = 'metadata/schema.html'

Expand Down

0 comments on commit 401573d

Please sign in to comment.