diff --git a/packages/app-builder/public/locales/en/decisions.json b/packages/app-builder/public/locales/en/decisions.json index dd7b660be..21d925992 100644 --- a/packages/app-builder/public/locales/en/decisions.json +++ b/packages/app-builder/public/locales/en/decisions.json @@ -5,6 +5,7 @@ "detail.scenario_name_runs_on": "{{scenarioName}} (runs on {{triggerObjectType}})", "detail.error": "An error as occured. Make sure the provided decision id is valid.", "trigger_object.type": "Trigger object", + "pivot_value": "Pivot value", "filters.has_case": "Presence of a case", "filters.pivot_value": "Pivot value", "filters.date_range.title": "creation date is:", diff --git a/packages/app-builder/src/components/Decisions/DecisionsList.tsx b/packages/app-builder/src/components/Decisions/DecisionsList.tsx index b4920c6cc..7099ffaec 100644 --- a/packages/app-builder/src/components/Decisions/DecisionsList.tsx +++ b/packages/app-builder/src/components/Decisions/DecisionsList.tsx @@ -17,7 +17,7 @@ import { useState, } from 'react'; import { useTranslation } from 'react-i18next'; -import { Checkbox, Table, useVirtualTable } from 'ui-design-system'; +import { Checkbox, Table, Tooltip, useVirtualTable } from 'ui-design-system'; import { Score } from './Score'; @@ -26,6 +26,7 @@ type Column = | 'scenario_name' | 'trigger_object_type' | 'case' + | 'pivot_value' | 'score' | 'outcome'; @@ -44,6 +45,10 @@ export interface DecisionViewModel { name: string; status: TCaseStatus; }; + pivotValues: { + id?: string; + value?: string; + }[]; score: number; outcome: TOutcome; } @@ -161,7 +166,7 @@ export function DecisionsList({ columnHelper.accessor((row) => row.scenario.version, { id: 'scenario_version', header: 'Vi', - size: 20, + size: 50, cell: ({ getValue, row }) => ( row.triggerObjectType, { id: 'trigger_object_type', header: t('decisions:trigger_object.type'), - size: 200, + size: 150, }), columnHelper.accessor((row) => row.case?.name ?? '-', { id: 'case', header: t('decisions:case'), - size: 200, + size: 150, cell: ({ getValue, row }) => row.original.case ? (
@@ -204,6 +209,26 @@ export function DecisionsList({ ), }), + columnHelper.accessor((row) => row.pivotValues, { + id: 'pivot_value', + header: t('decisions:pivot_value'), + size: 100, + cell: ({ getValue }) => { + const pivotValues = getValue() ?? []; + if (pivotValues.length === 0) return null; + return ( +
+ {pivotValues.map((pivotValue) => ( + + + {pivotValue.value} + + + ))} +
+ ); + }, + }), columnHelper.accessor((row) => row.score, { id: 'score', header: t('decisions:score'), diff --git a/packages/app-builder/src/models/cases.ts b/packages/app-builder/src/models/cases.ts index e31ce8ac0..e2b135064 100644 --- a/packages/app-builder/src/models/cases.ts +++ b/packages/app-builder/src/models/cases.ts @@ -66,6 +66,10 @@ export interface CaseDetail triggerObject: Record; triggerObjectType: string; outcome: Outcome; + pivotValues: { + id?: string; + value?: string; + }[]; scenario: { id: string; name: string; @@ -92,6 +96,12 @@ export function adaptCaseDetailDto({ triggerObject: decisionDto.trigger_object, triggerObjectType: decisionDto.trigger_object_type, outcome: decisionDto.outcome, + pivotValues: decisionDto.pivot_values.map( + ({ pivot_id, pivot_value }) => ({ + id: pivot_id ?? undefined, + value: pivot_value ?? undefined, + }), + ), scenario: { id: decisionDto.scenario.id, name: decisionDto.scenario.name, diff --git a/packages/app-builder/src/routes/_builder+/decisions+/_index.tsx b/packages/app-builder/src/routes/_builder+/decisions+/_index.tsx index 541f4533f..b481b0e68 100644 --- a/packages/app-builder/src/routes/_builder+/decisions+/_index.tsx +++ b/packages/app-builder/src/routes/_builder+/decisions+/_index.tsx @@ -165,6 +165,9 @@ export default function Decisions() { decisions={decisions} selectable selectionProps={selectionProps} + columnVisibility={{ + pivot_value: false, + }} />