44 lines
1.2 KiB
Python
44 lines
1.2 KiB
Python
from .operation import *
|
|
|
|
|
|
def get_title_schema(name: str) -> dict[str, dict[str, Any]]:
|
|
return {'value': {'type': 'float', 'optional': False, 'readonly': False}}
|
|
|
|
|
|
def get_title(name: str) -> dict[str, Any]:
|
|
title = read(name, 'select * from title')
|
|
return { 'value': title['value'] }
|
|
|
|
|
|
def set_title_cache(name: str, cs: ChangeSet) -> SqlChangeSet:
|
|
new = cs.operations[0]['value']
|
|
old = get_title(name)['value']
|
|
|
|
redo_sql = f"update title set value = '{new}';"
|
|
undo_sql = f"update title set value = '{old}';"
|
|
|
|
redo_cs = g_update_prefix | { 'type': 'title', 'value': new }
|
|
undo_cs = g_update_prefix | { 'type': 'title', 'value': old }
|
|
|
|
return SqlChangeSet(redo_sql, undo_sql, redo_cs, undo_cs)
|
|
|
|
|
|
def set_title(name: str, cs: ChangeSet) -> ChangeSet:
|
|
return execute_command(name, set_title_cache(name ,cs))
|
|
|
|
|
|
class InpTitle:
|
|
def __init__(self, section) -> None:
|
|
self.value = '\n'.join(section)
|
|
|
|
|
|
def inp_in_title(section: list[str]) -> ChangeSet:
|
|
obj = InpTitle(section)
|
|
cs = ChangeSet({'operation' : API_ADD, 'type': 'title', 'value' : obj.value})
|
|
return cs
|
|
|
|
|
|
def inp_out_title(name: str) -> list[str]:
|
|
obj = str(get_title(name)['value'])
|
|
return obj.split('\n')
|