import Noco from '../Noco'; import { CacheGetType, CacheScope, MetaTable } from '../utils/globals'; import { deserializeJSON, serializeJSON } from '../utils/serialize'; import NocoCache from '../cache/NocoCache'; import { extractProps } from '../helpers/extractProps'; import View from './View'; import type { BoolType, FormColumnType, MetaType, StringOrNullType, } from 'nocodb-sdk'; export default class FormViewColumn implements FormColumnType { id?: string; fk_view_id?: string; fk_column_id?: string; project_id?: string; base_id?: string; label?: StringOrNullType; help?: StringOrNullType; description?: StringOrNullType; required?: BoolType; enable_scanner?: BoolType; uuid?: StringOrNullType; show?: BoolType; order?: number; meta?: MetaType; constructor(data: FormViewColumn) { Object.assign(this, data); } public static async get(formViewColumnId: string, ncMeta = Noco.ncMeta) { let viewColumn = formViewColumnId && (await NocoCache.get( `${CacheScope.FORM_VIEW_COLUMN}:${formViewColumnId}`, CacheGetType.TYPE_OBJECT, )); if (!viewColumn) { viewColumn = await ncMeta.metaGet2( null, null, MetaTable.FORM_VIEW_COLUMNS, formViewColumnId, ); viewColumn.meta = viewColumn.meta && typeof viewColumn.meta === 'string' ? JSON.parse(viewColumn.meta) : viewColumn.meta; } await NocoCache.set( `${CacheScope.FORM_VIEW_COLUMN}:${formViewColumnId}`, viewColumn, ); return viewColumn && new FormViewColumn(viewColumn); } static async insert(column: Partial, ncMeta = Noco.ncMeta) { const insertObj = extractProps(column, [ 'fk_view_id', 'fk_column_id', 'show', 'project_id', 'base_id', 'label', 'help', 'description', 'required', 'enable_scanner', 'meta', ]); insertObj.order = await ncMeta.metaGetNextOrder( MetaTable.FORM_VIEW_COLUMNS, { fk_view_id: insertObj.fk_view_id, }, ); if (insertObj.meta) { insertObj.meta = serializeJSON(insertObj.meta); } if (!(insertObj.project_id && insertObj.base_id)) { const viewRef = await View.get(insertObj.fk_view_id, ncMeta); insertObj.project_id = viewRef.project_id; insertObj.base_id = viewRef.base_id; } const { id, fk_column_id } = await ncMeta.metaInsert2( null, null, MetaTable.FORM_VIEW_COLUMNS, insertObj, ); await NocoCache.set(`${CacheScope.FORM_VIEW_COLUMN}:${fk_column_id}`, id); // if cache is not present skip pushing it into the list to avoid unexpected behaviour if ( ( await NocoCache.getList(CacheScope.FORM_VIEW_COLUMN, [ column.fk_view_id, ]) )?.length ) await NocoCache.appendToList( CacheScope.FORM_VIEW_COLUMN, [column.fk_view_id], `${CacheScope.FORM_VIEW_COLUMN}:${id}`, ); return this.get(id, ncMeta); } public static async list( viewId: string, ncMeta = Noco.ncMeta, ): Promise { let viewColumns = await NocoCache.getList(CacheScope.FORM_VIEW_COLUMN, [ viewId, ]); if (!viewColumns.length) { viewColumns = await ncMeta.metaList2( null, null, MetaTable.FORM_VIEW_COLUMNS, { condition: { fk_view_id: viewId, }, orderBy: { order: 'asc', }, }, ); for (const viewColumn of viewColumns) { viewColumn.meta = deserializeJSON(viewColumn.meta); } await NocoCache.setList( CacheScope.FORM_VIEW_COLUMN, [viewId], viewColumns, ); } viewColumns.sort( (a, b) => (a.order != null ? a.order : Infinity) - (b.order != null ? b.order : Infinity), ); return viewColumns?.map((v) => new FormViewColumn(v)); } static async update( columnId: string, body: Partial, ncMeta = Noco.ncMeta, ) { const updateObj = extractProps(body, [ 'label', 'help', 'description', 'required', 'show', 'order', 'meta', 'enable_scanner', ]); // get existing cache const key = `${CacheScope.FORM_VIEW_COLUMN}:${columnId}`; const o = await NocoCache.get(key, CacheGetType.TYPE_OBJECT); if (o) { Object.assign(o, updateObj); // set cache await NocoCache.set(key, o); } if (updateObj.meta) { updateObj.meta = serializeJSON(updateObj.meta); } // update meta return await ncMeta.metaUpdate( null, null, MetaTable.FORM_VIEW_COLUMNS, updateObj, columnId, ); } }