From 0f946616b6d1e1c881bda446d7280c6eb0d99410 Mon Sep 17 00:00:00 2001 From: Alex Hall Date: Wed, 3 Nov 2021 14:35:41 +0200 Subject: [PATCH] (core) Parsing pasting in reflist columns Summary: Handle reflist columns in ViewFieldRec.parseValue Test Plan: Reused section of test of reference columns Reviewers: dsagal Reviewed By: dsagal Differential Revision: https://phab.getgrist.com/D3105 --- app/client/models/entities/ViewFieldRec.ts | 29 +++++++++++++++++----- 1 file changed, 23 insertions(+), 6 deletions(-) diff --git a/app/client/models/entities/ViewFieldRec.ts b/app/client/models/entities/ViewFieldRec.ts index 93594410..cf116cbf 100644 --- a/app/client/models/entities/ViewFieldRec.ts +++ b/app/client/models/entities/ViewFieldRec.ts @@ -1,9 +1,9 @@ +import { ReferenceUtils } from 'app/client/lib/ReferenceUtils'; import { ColumnRec, DocModel, IRowModel, refRecord, ViewSectionRec } from 'app/client/models/DocModel'; import * as modelUtil from 'app/client/models/modelUtil'; -import { ReferenceUtils } from 'app/client/lib/ReferenceUtils'; import * as UserType from 'app/client/widgets/UserType'; import { DocumentSettings } from 'app/common/DocumentSettings'; -import { extractTypeFromColType } from 'app/common/gristTypes'; +import { isFullReferencingType, isRefListType } from 'app/common/gristTypes'; import { BaseFormatter, createFormatter } from 'app/common/ValueFormatter'; import { createParser } from 'app/common/ValueParser'; import { Computed, fromKo } from 'grainjs'; @@ -186,13 +186,30 @@ export function createViewFieldRec(this: ViewFieldRec, docModel: DocModel): void const docSettings = this.documentSettings(); const type = this.column().type(); - if (extractTypeFromColType(type) === "Ref") { // TODO reflists + if (!isFullReferencingType(type)) { + return createParser(type, this.widgetOptionsJson(), docSettings); + } else { const vcol = this.visibleColModel(); const vcolParser = createParser(vcol.type(), vcol.widgetOptionsJson(), docSettings); const refUtils = new ReferenceUtils(this, docModel.docData); // uses several more observables immediately - return (s: string) => refUtils.parseValue(vcolParser(s)); - } else { - return createParser(type, this.widgetOptionsJson(), docSettings); + return (s: string) => { + const result = refUtils.parseValue(vcolParser(s)); + // If `result` is a number that means it successfully parsed a reference (row ID). + // For a reflist we need to wrap that row ID in a list. + // Otherwise `result` is a string meaning it couldn't be parsed + // and it will be saved as AltText (i.e. invalid for the column type). + // We don't try to parse multiple references from a single string. + if (isRefListType(type) && typeof result === "number") { + if (result > 0) { + return ['L', result]; + } else { + // parseValue returns 0 sometimes because that's the default for reference columns. + // The default for a reflist column is null. + return null; + } + } + return result; + }; } });