Skip to content

Commit

Permalink
Merge pull request #3004 from the-deep/feature/add-column-remove
Browse files Browse the repository at this point in the history
Add column remove in compact entry edit's matrix 2d
  • Loading branch information
subinasr authored Dec 5, 2024
2 parents 861d8c3 + b0a01fa commit 7bdd90f
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,15 @@ import {
Modal,
QuickActionButton,
} from '@the-deep/deep-ui';
import { IoChevronForward, IoOpenOutline } from 'react-icons/io5';
import {
IoChevronForward,
IoOpenOutline,
IoClose,
} from 'react-icons/io5';
import { PartialForm, Error, getErrorObject } from '@togglecorp/toggle-form';
import { useModalState } from '#hooks/stateManagement';
import { sortByOrder } from '#utils/common';
import { removeUndefinedKeys, removeEmptyObject } from '#utils/unsafeCommon';

import NonFieldError from '#components/NonFieldError';
import { Matrix2dWidget } from '#types/newAnalyticalFramework';
Expand Down Expand Up @@ -121,6 +126,19 @@ function Column(props: ColumnProps) {
value,
]);

const handleColumnRemove = useCallback((columnKey: string) => {
onSubColumnsChange(
rowId,
subRowId,
columnKey,
undefined,
);
}, [
onSubColumnsChange,
rowId,
subRowId,
]);

return (
<div className={styles.column}>
<div
Expand Down Expand Up @@ -173,15 +191,26 @@ function Column(props: ColumnProps) {
</div>
)}
{!readOnly && !suggestionMode && (
<MultiSelectInput
name={column.key}
value={value?.[column.key]}
disabled={disabled}
labelSelector={subColumnLabelSelector}
onChange={handleSubColumnValueChange}
options={orderedSubColumns}
keySelector={subColumnKeySelector}
/>
<div className={styles.subColumnSelectWrapper}>
<MultiSelectInput
className={styles.input}
name={column.key}
value={value?.[column.key]}
disabled={disabled}
labelSelector={subColumnLabelSelector}
onChange={handleSubColumnValueChange}
options={orderedSubColumns}
keySelector={subColumnKeySelector}
/>
<QuickActionButton
className={styles.button}
name={column.key}
onClick={handleColumnRemove}
variant="secondary"
>
<IoClose />
</QuickActionButton>
</div>
)}
{readOnly && (
<div className={styles.selectedValues}>
Expand Down Expand Up @@ -432,7 +461,7 @@ function Matrix2dWidgetInput<N extends string>(props: Props<N>) {
columnId: string,
newSubColValue: string[] | undefined,
) => {
const newValue = {
const newValue = removeEmptyObject(removeUndefinedKeys({
...value?.value,
[rowId]: {
...value?.value?.[rowId],
Expand All @@ -441,7 +470,7 @@ function Matrix2dWidgetInput<N extends string>(props: Props<N>) {
[columnId]: newSubColValue,
},
},
};
}));
onChange(newValue, name);
},
[value, name, onChange],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,20 @@
}
}

.sub-column-select-wrapper {
display: flex;
align-items: center;
gap: var(--dui-spacing-extra-small);

.input {
flex-grow: 1;
}

.button {
flex-shrink: 0;
}
}

.selected-values {
color: var(--dui-color-accent);
}
Expand Down

0 comments on commit 7bdd90f

Please sign in to comment.