From 6a84f7ffcc153f3135d1f3276e8c689d214e525c Mon Sep 17 00:00:00 2001 From: Birk Johansson Date: Tue, 24 Oct 2023 15:24:50 +0300 Subject: [PATCH] fix(form): fix editing style object --- .../edit/createJsonPatchOperations.ts | 40 +++++++++++++------ 1 file changed, 27 insertions(+), 13 deletions(-) diff --git a/src/pages/dataElements/edit/createJsonPatchOperations.ts b/src/pages/dataElements/edit/createJsonPatchOperations.ts index 11feec85..93f3a452 100644 --- a/src/pages/dataElements/edit/createJsonPatchOperations.ts +++ b/src/pages/dataElements/edit/createJsonPatchOperations.ts @@ -3,27 +3,42 @@ import { JsonPatchOperation } from '../../../types' import { DataElement } from '../../../types/generated' import { FormValues } from '../form/types' -type DataElementKey = keyof DataElement - interface FormatFormValuesArgs { dataElement: DataElement dirtyFields: { [name: string]: boolean } values: FormValues } -const sanitizeDirtyValueKeys = (keys: DataElementKey[]) => { - const attributeValuesDirty = keys.find((key) => - key.startsWith('attributeValues') +const sanitizeDirtyValueKeys = (keys: string[]) => { + // these are removed from the dirtyKeys + // attributeValues is an array in the form, thus fields will be attributeValues[0] etc + // style.code should post to style, not style.code, because it's a complex object + const keyStartsWithToRemove = ['attributeValues', 'style'] as const + const shouldInclude = Object.fromEntries( + keys.map((key) => [key, false]) + ) as Record<(typeof keyStartsWithToRemove)[number], boolean> + + const keysWithout = keys.filter( + (key) => + !keyStartsWithToRemove.some((keyToRemove) => { + const shouldRemove = key.startsWith(keyToRemove) + if (shouldRemove) { + shouldInclude[keyToRemove] = true + } + return shouldRemove + }) ) - if (!attributeValuesDirty) { + // no difference + if (keysWithout.length === keys.length) { return keys } - return [ - ...keys.filter((key) => !key.startsWith('attributeValues')), - 'attributeValues' as DataElementKey, - ] + const keysToInclude = Object.entries(shouldInclude) + .filter(([, val]) => val) + .map(([key]) => key) + + return keysWithout.concat(keysToInclude) } export function createJsonPatchOperations({ @@ -39,9 +54,8 @@ export function createJsonPatchOperations({ ), } - const dirtyFieldsKeys = Object.keys(dirtyFields) as DataElementKey[] - const adjustedDirtyFieldsKeys: DataElementKey[] = - sanitizeDirtyValueKeys(dirtyFieldsKeys) + const dirtyFieldsKeys = Object.keys(dirtyFields) + const adjustedDirtyFieldsKeys = sanitizeDirtyValueKeys(dirtyFieldsKeys) return adjustedDirtyFieldsKeys.map((name) => ({ op: get(name, dataElement) ? 'replace' : 'add',