remove MetaDataTable and MetaDataColumn to cleanup schema
This commit is contained in:
@@ -1,26 +0,0 @@
|
||||
from typing import List
|
||||
|
||||
from fastapi import APIRouter
|
||||
|
||||
from src.apis.utils import SessionDep
|
||||
from src.db.models.metadata import MetaDataTable, MetaDataColumn
|
||||
from src.db.repository.metadata import get_tables, get_columns
|
||||
from src.schema.admin import MetaDataTableResponse, MetaDataColumnResponse
|
||||
|
||||
router = APIRouter()
|
||||
|
||||
|
||||
|
||||
@router.get("/tables")
|
||||
def get_meta_data_tables(db: SessionDep) -> List[MetaDataTableResponse]:
|
||||
tables = db.query(MetaDataTable).all()
|
||||
response: List[MetaDataTableResponse] = get_tables(tables)
|
||||
return response
|
||||
|
||||
|
||||
|
||||
@router.get("/columns")
|
||||
def get_meta_data_columns(db: SessionDep) -> List[MetaDataColumnResponse]:
|
||||
columns = db.query(MetaDataColumn).all()
|
||||
response: List[MetaDataColumnResponse] = get_columns(columns)
|
||||
return response
|
||||
@@ -1,39 +0,0 @@
|
||||
from sqlalchemy import Column, String, ForeignKey, Integer, Boolean
|
||||
from sqlalchemy.orm import relationship
|
||||
|
||||
from src.db.models.base import Base, BaseMixin
|
||||
|
||||
|
||||
class MetaDataTable(Base, BaseMixin):
|
||||
__tablename__ = 'meta_data_table'
|
||||
table_name = Column(String, unique=True)
|
||||
table_columns = relationship("MetaDataColumn")
|
||||
|
||||
def __repr__(self):
|
||||
return f'MetaDataTable({self.id} {self.table_name})'
|
||||
|
||||
def __str__(self):
|
||||
return f'{self.table_name}({self.id})'
|
||||
|
||||
|
||||
class MetaDataColumn(Base, BaseMixin):
|
||||
__tablename__ = 'meta_data_column'
|
||||
column_name = Column(String, nullable=False)
|
||||
column_type = Column(String)
|
||||
column_order = Column(Integer)
|
||||
is_shown = Column(Boolean)
|
||||
column_label = Column(String)
|
||||
show_filter = Column(Boolean)
|
||||
filter_label = Column(String)
|
||||
ref_column = Column(String, nullable=True)
|
||||
table_id = Column(String, ForeignKey('meta_data_table.id'))
|
||||
table = relationship("MetaDataTable", back_populates="table_columns")
|
||||
|
||||
def __repr__(self):
|
||||
if self.column_name is None:
|
||||
return f'MetaDataColumn({self.id} {self.table.table_name}.__)'
|
||||
else:
|
||||
return f'MetaDataColumn({self.id} {self.table.table_name}.{self.column_name})'
|
||||
|
||||
def __str__(self):
|
||||
return f'{self.column_name}({self.id})'
|
||||
@@ -1,30 +0,0 @@
|
||||
from typing import List
|
||||
|
||||
from src.db.models.metadata import MetaDataTable, MetaDataColumn
|
||||
from src.schema.admin import MetaDataTableResponse, MetaDataColumnResponse
|
||||
|
||||
|
||||
def get_tables(tables: List[MetaDataTable]) -> List[MetaDataTableResponse]:
|
||||
results: List[MetaDataTableResponse] = []
|
||||
for table in tables:
|
||||
result = MetaDataTableResponse(id=table.id, name=table.table_name)
|
||||
results.append(result)
|
||||
return results
|
||||
|
||||
def get_columns(columns: List[MetaDataColumn]) -> List[MetaDataColumnResponse]:
|
||||
results: List[MetaDataColumnResponse] = []
|
||||
for column in columns:
|
||||
result = MetaDataColumnResponse(
|
||||
id=column.id,
|
||||
table_name=column.table.table_name,
|
||||
column_name=column.column_name,
|
||||
column_type=column.column_type,
|
||||
column_order=column.column_order,
|
||||
is_shown=column.is_shown,
|
||||
column_label=column.column_label,
|
||||
show_filter=column.show_filter,
|
||||
filter_label=column.filter_label,
|
||||
ref_column=column.ref_column
|
||||
)
|
||||
results.append(result)
|
||||
return results
|
||||
@@ -6,21 +6,3 @@ from pydantic import BaseModel
|
||||
class Token(BaseModel):
|
||||
access_token: str
|
||||
token_type: str
|
||||
|
||||
class MetaDataTableResponse(BaseModel):
|
||||
id: str
|
||||
name: str
|
||||
|
||||
class MetaDataColumnResponse(BaseModel):
|
||||
id: str
|
||||
table_name: str
|
||||
column_name: str
|
||||
column_sync_name: str
|
||||
column_type: str
|
||||
column_modifier: Optional[str]
|
||||
column_order: int
|
||||
is_shown: bool
|
||||
column_label: Optional[str]
|
||||
show_filter: bool
|
||||
filter_label: Optional[str]
|
||||
ref_column: Optional[str]
|
||||
|
||||
@@ -1,21 +0,0 @@
|
||||
{% extends "shared/base.html" %}
|
||||
|
||||
{% block title %}
|
||||
<title>MetaData</title>
|
||||
{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
{% with msg=msg %}
|
||||
{% include "components/alerts.html" %}
|
||||
{% endwith %}
|
||||
<div class="container">
|
||||
{% for table in data %}
|
||||
<div class="row">
|
||||
{% with obj=table %}
|
||||
{% include "components/metadatatable_cards.html" %}
|
||||
{% endwith %}
|
||||
<br>
|
||||
</div>
|
||||
{% endfor %}
|
||||
</div>
|
||||
{% endblock %}
|
||||
@@ -1,31 +0,0 @@
|
||||
<div class="card shadow p-3 mb-2 bg-body rounded">
|
||||
<div class="card-body">
|
||||
<h5 class="card-title">{{obj.table_name}}</h5>
|
||||
<table class="table table-hover">
|
||||
<thead><tr>
|
||||
<th scope="col">Column Name</th>
|
||||
<th scope="col">Column Type</th>
|
||||
<th scope="col">Column Order</th>
|
||||
<th scope="col">Is Shown</th>
|
||||
<th scope="col">Column Label</th>
|
||||
<th scope="col">Show Filter</th>
|
||||
<th scope="col">Filter Label</th>
|
||||
<th scope="col">Ref Column</th>
|
||||
</tr></thead>
|
||||
<tbody>
|
||||
{% for column in obj.table_columns %}
|
||||
<tr>
|
||||
<th scope="row"><a href="/admin/metadata/{{column.id}}">{{column.column_name}}</a></th>
|
||||
<td>{{column.column_type}}</td>
|
||||
<td>{{column.column_order}}</td>
|
||||
<td>{% with check=column.is_shown %}{% include "components/check.html" %}{% endwith %}</td>
|
||||
<td>{{column.column_label}}</td>
|
||||
<td>{% with check=column.show_filter %}{% include "components/check.html" %}{% endwith %}</td>
|
||||
<td>{{column.filter_label}}</td>
|
||||
<td>{{column.ref_column}}</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
@@ -1,6 +1,5 @@
|
||||
from fastapi import APIRouter, Form, Request, status
|
||||
from fastapi.templating import Jinja2Templates
|
||||
from fastapi.responses import RedirectResponse
|
||||
|
||||
from src.apis.utils import SessionDep
|
||||
from src.db.models.comic import Comic, Publisher, Issue
|
||||
@@ -10,11 +9,6 @@ from src.db.repository.comics.comic import update_comic
|
||||
from src.schema.comics.comic import ComicSchema
|
||||
from src.webapps.comic.forms.comic import ValidateComicForm
|
||||
|
||||
from src.db.repository.comic import create_new_worktype, update_worktype
|
||||
from src.main import logger
|
||||
from src.schema.comics.worktype import AddWorkType
|
||||
from src.webapps.comic.forms import AddWorktypeForm
|
||||
|
||||
templates = Jinja2Templates(directory="src/templates")
|
||||
router = APIRouter(include_in_schema=True, prefix="/comic")
|
||||
|
||||
|
||||
Reference in New Issue
Block a user