mirror of
https://github.com/gristlabs/grist-core.git
synced 2024-10-27 20:44:07 +00:00
b537539b73
Summary: - Implement UI with "Apply to new records" and "Apply on record changes" checkboxes, and options for selecting which changes to recalculate on. - For consistency, always represent empty RefList as None - Fix up generated SchemaTypes to remember that values are encoded. Included test cases for the main planned use cases: - Auto-filled UUID column - Data cleaning - NOW() formula for record's last-updated timestamp. - Updates that depend on other columns. Test Plan: Added a browser test. Reviewers: jarek Reviewed By: jarek Subscribers: paulfitz Differential Revision: https://phab.getgrist.com/D2885
54 lines
1.4 KiB
Python
54 lines
1.4 KiB
Python
#!/usr/bin/env python -B
|
|
"""
|
|
Generates a JS schema file from sandbox/grist/schema.py.
|
|
"""
|
|
|
|
import os
|
|
import sys
|
|
sys.path.append(os.path.join(os.path.dirname(__file__), 'grist'))
|
|
|
|
import schema # pylint: disable=import-error,wrong-import-position
|
|
|
|
# These are the types that appear in Grist metadata columns.
|
|
_ts_types = {
|
|
"Bool": "boolean",
|
|
"DateTime": "number",
|
|
"Int": "number",
|
|
"PositionNumber": "number",
|
|
"Ref": "number",
|
|
"RefList": "['L', ...number[]]|null", # Non-primitive values are encoded
|
|
"Text": "string",
|
|
}
|
|
|
|
def get_ts_type(col_type):
|
|
col_type = col_type.split(':', 1)[0] # Strip suffix for Ref:, DateTime:, etc.
|
|
return _ts_types.get(col_type, "CellValue")
|
|
|
|
def main():
|
|
print("""\
|
|
/*** THIS FILE IS AUTO-GENERATED BY %s ***/
|
|
// tslint:disable:object-literal-key-quotes
|
|
|
|
export const schema = {
|
|
""" % __file__)
|
|
|
|
for table in schema.schema_create_actions():
|
|
print(' "%s": {' % table.table_id)
|
|
for column in table.columns:
|
|
print(' %-20s: "%s",' % (column['id'], column['type']))
|
|
print(' },\n')
|
|
|
|
print("""};
|
|
|
|
export interface SchemaTypes {
|
|
""")
|
|
for table in schema.schema_create_actions():
|
|
print(' "%s": {' % table.table_id)
|
|
for column in table.columns:
|
|
print(' %s: %s;' % (column['id'], get_ts_type(column['type'])))
|
|
print(' };\n')
|
|
print("}")
|
|
|
|
if __name__ == '__main__':
|
|
main()
|