From fe432e13f900d6a6f4630c3538f08bd7c875e694 Mon Sep 17 00:00:00 2001 From: Lukas Giger Date: Tue, 17 Sep 2024 08:04:24 +0200 Subject: [PATCH 1/3] XIVY-12291 edit data class properties --- .../src/mock/dataclass-client-mock.ts | 2 +- ...ataclass-editor-business-dataclass.spec.ts | 2 + .../tests/mock/dataclass-editor.spec.ts | 9 ++++ .../standalone/tests/pageobjects/ClassType.ts | 6 ++- .../standalone/tests/pageobjects/Detail.ts | 7 +++ .../detail/DataClassDetailContent.tsx | 44 +++++++++++++++---- 6 files changed, 59 insertions(+), 11 deletions(-) diff --git a/integrations/standalone/src/mock/dataclass-client-mock.ts b/integrations/standalone/src/mock/dataclass-client-mock.ts index ef1d586c..4d4fb44d 100644 --- a/integrations/standalone/src/mock/dataclass-client-mock.ts +++ b/integrations/standalone/src/mock/dataclass-client-mock.ts @@ -9,7 +9,7 @@ export class DataClassClientMock implements Client { namespace: 'workflow.businesscasedata', comment: 'Information about an interview.', annotations: ['@full.qualified.name.one(argument = "value")', '@full.qualified.name.two'], - isBusinessCaseData: true, + isBusinessCaseData: false, fields: [ { name: 'firstName', diff --git a/integrations/standalone/tests/integration/dataclass-editor-business-dataclass.spec.ts b/integrations/standalone/tests/integration/dataclass-editor-business-dataclass.spec.ts index f7fcbcec..3b583874 100644 --- a/integrations/standalone/tests/integration/dataclass-editor-business-dataclass.spec.ts +++ b/integrations/standalone/tests/integration/dataclass-editor-business-dataclass.spec.ts @@ -41,10 +41,12 @@ test('save data', async ({ page }) => { const editor = await DataClassEditor.openNewDataClass(page); await expect(editor.table.rows).toHaveCount(0); + await editor.detail.fillDataClassValues('Data', 'New Description', 'New Annotations'); await editor.addField('newAttribute', 'String'); await editor.page.reload(); + await editor.detail.expectToHaveDataClassValues('Data', 'New Description', 'New Annotations'); await expect(editor.table.rows).toHaveCount(1); await editor.table.row(0).expectToHaveValues('newAttribute', 'String', ''); diff --git a/integrations/standalone/tests/mock/dataclass-editor.spec.ts b/integrations/standalone/tests/mock/dataclass-editor.spec.ts index bb97c371..77219c72 100644 --- a/integrations/standalone/tests/mock/dataclass-editor.spec.ts +++ b/integrations/standalone/tests/mock/dataclass-editor.spec.ts @@ -13,8 +13,17 @@ test('title', async () => { }); test('headers', async () => { + await expect(editor.title).toHaveText('Data Editor'); + await expect(editor.detail.title).toHaveText('Data - Interview'); + + await editor.detail.classType.button('Business Data').click(); await expect(editor.title).toHaveText('Business Data Editor'); await expect(editor.detail.title).toHaveText('Business Data - Interview'); + + await editor.detail.classType.button('Entity').click(); + await expect(editor.title).toHaveText('Entity Editor'); + await expect(editor.detail.title).toHaveText('Entity - Interview'); + await editor.table.row(0).locator.click(); await expect(editor.detail.title).toHaveText('Attribute - firstName'); }); diff --git a/integrations/standalone/tests/pageobjects/ClassType.ts b/integrations/standalone/tests/pageobjects/ClassType.ts index f915df14..5a7fa151 100644 --- a/integrations/standalone/tests/pageobjects/ClassType.ts +++ b/integrations/standalone/tests/pageobjects/ClassType.ts @@ -7,7 +7,11 @@ export class ClassType { this.locator = locator.getByRole('group'); } + button(classType: string) { + return this.locator.getByRole('radio', { name: classType, exact: true }); + } + async expectToHaveValue(classType: string) { - await expect(this.locator.getByRole('radio', { name: classType, exact: true })).toHaveAttribute('data-state', 'on'); + await expect(this.button(classType)).toHaveAttribute('data-state', 'on'); } } diff --git a/integrations/standalone/tests/pageobjects/Detail.ts b/integrations/standalone/tests/pageobjects/Detail.ts index 29c28391..f39b98d4 100644 --- a/integrations/standalone/tests/pageobjects/Detail.ts +++ b/integrations/standalone/tests/pageobjects/Detail.ts @@ -66,4 +66,11 @@ export class Detail { await expect(this.comment.locator).toHaveValue(comment); await expect(this.annotations.locator).toHaveValue(annotations); } + + async fillDataClassValues(classType: string, description: string, annotations: string) { + await this.expectToBeDataClass(); + await this.classType.button(classType).click(); + await this.description.locator.fill(description); + await this.annotations.locator.fill(annotations); + } } diff --git a/packages/dataclass-editor/src/components/dataclass/detail/DataClassDetailContent.tsx b/packages/dataclass-editor/src/components/dataclass/detail/DataClassDetailContent.tsx index 5a3c0f36..faad96f6 100644 --- a/packages/dataclass-editor/src/components/dataclass/detail/DataClassDetailContent.tsx +++ b/packages/dataclass-editor/src/components/dataclass/detail/DataClassDetailContent.tsx @@ -1,22 +1,45 @@ import { BasicField, Button, Flex, Textarea, ToggleGroup, ToggleGroupItem } from '@axonivy/ui-components'; -import { useState } from 'react'; import { useAppContext } from '../../../context/AppContext'; -import { classType as getClassType } from '../data/dataclass-utils'; +import type { DataClass } from '../data/dataclass'; +import { classType } from '../data/dataclass-utils'; import './DetailContent.css'; export const DataClassDetailContent = () => { - const { dataClass } = useAppContext(); + const { dataClass, setDataClass } = useAppContext(); - const initialClassType = getClassType(dataClass); + const initialClassType = classType(dataClass); - const [classType, setClassType] = useState(initialClassType); + const variant = (value: string) => (value === initialClassType ? 'primary' : undefined); - const variant = (value: string) => (value === classType ? 'primary' : undefined); + const handleClassTypeChange = (classType: string) => { + const newDataClass = structuredClone(dataClass); + switch (classType) { + case 'DATA': + newDataClass.isBusinessCaseData = false; + newDataClass.entity = undefined; + break; + case 'BUSINESS_DATA': + newDataClass.isBusinessCaseData = true; + newDataClass.entity = undefined; + break; + case 'ENTITY': + newDataClass.isBusinessCaseData = false; + newDataClass.entity = { tableName: '' }; + break; + } + setDataClass(newDataClass); + }; + + const handleDataClassPropertyChange = (key: DKey, value: DataClass[DKey]) => { + const newDataClass = structuredClone(dataClass); + newDataClass[key] = value; + setDataClass(newDataClass); + }; return ( - +