Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

4900 multi select field front implement expanded cells #5151

Merged
merged 52 commits into from
May 3, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
52 commits
Select commit Hold shift + click to select a range
c9566d8
WIP: Use isHovered in fieldDisplay
martmull Apr 23, 2024
ebd95b2
Update design
martmull Apr 23, 2024
8fe7363
Add shrink
martmull Apr 24, 2024
cd3b1cd
Use width to compute hover
martmull Apr 24, 2024
accabe9
Simplify
martmull Apr 24, 2024
466bba9
Merge branch 'main' into 4900-multi-select-field-front-implement-expa…
martmull Apr 24, 2024
63f4e33
Use dropdown for expanded cell
martmull Apr 25, 2024
0b02ba9
Update dropdown component
martmull Apr 25, 2024
07bec4a
Factorize
martmull Apr 26, 2024
5be6608
Fix dropdown for inline cell
martmull Apr 26, 2024
eadb24a
WIP: add default state
martmull Apr 26, 2024
1d48763
Fix soft focus
martmull Apr 26, 2024
cebc4b2
Inject children properties in parent
martmull Apr 26, 2024
4be93e9
Rename state
martmull Apr 26, 2024
9cb05af
Rename component
martmull Apr 26, 2024
fa10ac6
Factorize type
martmull Apr 26, 2024
fc610d4
Factorize Var
martmull Apr 26, 2024
cbdc290
Fix dropdown size
martmull Apr 26, 2024
8a8433c
Display when navigating with keyboard
martmull Apr 26, 2024
55b7519
Fix +number chip width
martmull Apr 26, 2024
784826e
Use expanded list in activities
martmull Apr 26, 2024
2f50fa8
Fix: Use expanded list in activities
martmull Apr 29, 2024
74e8298
Use expanded list in calendar
martmull Apr 29, 2024
0405af5
Fix multiworkspace
martmull Apr 29, 2024
d453ee9
WIP: fix force display hidden count
martmull Apr 29, 2024
60bda4e
Merge branch 'main' into 4900-multi-select-field-front-implement-expa…
martmull Apr 29, 2024
1548766
Simplify
martmull Apr 30, 2024
fd3c37a
Make expandable list component function pure
martmull Apr 30, 2024
62d7733
Merge branch 'main' into 4900-multi-select-field-front-implement-expa…
martmull Apr 30, 2024
2c69203
Move expandable list to proper place
martmull Apr 30, 2024
d09bbb3
Split components in two
martmull Apr 30, 2024
ee17e78
Move to proper place and fix imports
martmull Apr 30, 2024
4f5f3b2
Remove width for chip
martmull Apr 30, 2024
82bf06e
Create dedicated function to compute children properties
martmull May 1, 2024
1b3ae40
Remove useless parameter
martmull May 1, 2024
a00216b
Add tests
martmull May 1, 2024
e1db801
Merge branch 'main' into 4900-multi-select-field-front-implement-expa…
martmull May 2, 2024
38014bf
Code review returns
martmull May 2, 2024
5cceba8
Disallow allowImportingTsExtensions
martmull May 2, 2024
0bdb6a3
Remove useless component
martmull May 2, 2024
50dd265
Remove ANIMATION DIV PROPS constant
martmull May 3, 2024
a84177a
Add story for expandableList
martmull May 3, 2024
409bcc7
Rename variable
martmull May 3, 2024
6046af9
Fix ci
martmull May 3, 2024
a3be163
Fix ci
martmull May 3, 2024
eb27698
Fix console error
martmull May 3, 2024
82732b0
Fix console error
martmull May 3, 2024
cb9a9ff
Fix test
martmull May 3, 2024
0a18062
Remove fix
martmull May 3, 2024
40cf4bf
Update test
martmull May 3, 2024
8bdec12
Merge branch 'main' into 4900-multi-select-field-front-implement-expa…
martmull May 3, 2024
25a117e
Merge branch 'main' into 4900-multi-select-field-front-implement-expa…
martmull May 3, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fix +number chip width
  • Loading branch information
martmull committed Apr 26, 2024
commit 55b751903695f601faafc72da4e5b36570145899
Original file line number Diff line number Diff line change
Expand Up @@ -7,18 +7,21 @@ import { Chip, ChipVariant } from 'twenty-ui';
import { AnimationDivProps } from '@/object-record/record-table/record-table-cell/components/RecordTableCellButton.tsx';
import { DropdownMenu } from '@/ui/layout/dropdown/components/DropdownMenu.tsx';

const SPACING = 1;
const GAP_WIDTH = 4 * SPACING;

const StyledContainer = styled.div`
align-items: center;
display: flex;
gap: ${({ theme }) => theme.spacing(1)};
gap: ${({ theme }) => theme.spacing(SPACING)};
justify-content: space-between;
width: 100%;
`;

const StyledChildrenContainer = styled.div`
align-items: center;
display: flex;
gap: ${({ theme }) => theme.spacing(1)};
gap: ${({ theme }) => theme.spacing(SPACING)};
overflow: hidden;
`;

Expand Down Expand Up @@ -52,8 +55,6 @@ export type ExpandableListProps = {
reference?: HTMLDivElement;
};

const CHIP_CONTAINER_WIDTH = 42;

export const ExpandableList = ({
children,
isHovered,
Expand All @@ -67,11 +68,31 @@ export const ExpandableList = ({
{},
);

// Because Chip width depends on the number of hidden children which depends on the Chip width, we have a circular dependency
// To avoid it, we fix the Chip width and make sure it can display its content (a number greater than 1)
const getChipContentWidth = () => {
if (children.length <= 1) {
return 0;
}
if (children.length <= 10) {
return 17;
}
if (children.length <= 100) {
return 17 + 8;
}
if (children.length <= 1000) {
return 17 + 8 * 2;
}
return 17 + 8 * (Math.trunc(Math.log10(children.length)) - 1);
};

const chipContainerWidth = getChipContentWidth() + 2 * 4; // Because Chip component has a 4px padding
const availableWidth = containerWidth - (chipContainerWidth + GAP_WIDTH); // Because there is a 4px gap between children and chipContainer

const computeChildProperties = (index: number) => {
const availableWidth = containerWidth - CHIP_CONTAINER_WIDTH;
const childWidth = childrenWidths[index];
const cumulatedChildrenWidth = Array.from(Array(index).keys()).reduce(
(acc, currentIndex) => acc + childrenWidths[currentIndex],
(acc, currentIndex) => acc + childrenWidths[currentIndex] + GAP_WIDTH, // Because there is a 4px gap between children
0,
);
if (!isHovered) {
Expand All @@ -80,7 +101,8 @@ export const ExpandableList = ({
if (cumulatedChildrenWidth > availableWidth) {
return { shrink: 1, isVisible: false };
}
if (cumulatedChildrenWidth + childWidth <= availableWidth) {
if (cumulatedChildrenWidth + childWidth + GAP_WIDTH <= availableWidth) {
// Because there is a 4px gap between children
return { shrink: 0, isVisible: true };
}
return { shrink: 1, isVisible: true };
Expand All @@ -91,8 +113,8 @@ export const ExpandableList = ({
let result = 0;
let cumulatedWidth = 0;
childrenContainerWidthValues.forEach((childrenContainerWidthValue) => {
cumulatedWidth += childrenContainerWidthValue;
if (cumulatedWidth > containerWidth - CHIP_CONTAINER_WIDTH) {
cumulatedWidth += childrenContainerWidthValue + GAP_WIDTH; // Because there is a 4px gap between children
if (cumulatedWidth > availableWidth) {
result += 1;
}
});
Expand Down Expand Up @@ -157,6 +179,7 @@ export const ExpandableList = ({
label={`+${hiddenChildrenCount}`}
variant={ChipVariant.Highlighted}
onClick={openDropdownMenu}
width={getChipContentWidth()}
/>
</StyledAnimatedChipContainer>
)}
Expand Down
13 changes: 12 additions & 1 deletion packages/twenty-ui/src/display/chip/components/Chip.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ type ChipProps = {
clickable?: boolean;
label: string;
maxWidth?: number;
width?: number;
variant?: ChipVariant;
accent?: ChipAccent;
leftComponent?: ReactNode;
Expand All @@ -38,7 +39,13 @@ type ChipProps = {
const StyledContainer = styled.div<
Pick<
ChipProps,
'accent' | 'clickable' | 'disabled' | 'maxWidth' | 'size' | 'variant'
| 'accent'
| 'clickable'
| 'disabled'
| 'width'
| 'maxWidth'
| 'size'
| 'variant'
>
>`
--chip-horizontal-padding: ${({ theme }) => theme.spacing(1)};
Expand All @@ -51,8 +58,10 @@ const StyledContainer = styled.div<
cursor: ${({ clickable, disabled }) =>
clickable ? 'pointer' : disabled ? 'not-allowed' : 'inherit'};
display: inline-flex;
flex-direction: row-reverse;
gap: ${({ theme }) => theme.spacing(1)};
height: ${({ theme }) => theme.spacing(3)};
width: ${({ width }) => `${width}px` || 'auto'};
max-width: ${({ maxWidth }) =>
maxWidth
? `calc(${maxWidth}px - 2 * var(--chip-horizontal-padding))`
Expand Down Expand Up @@ -154,6 +163,7 @@ export const Chip = ({
leftComponent,
rightComponent,
accent = ChipAccent.TextPrimary,
width,
maxWidth,
className,
onClick,
Expand All @@ -166,6 +176,7 @@ export const Chip = ({
size={size}
disabled={disabled}
className={className}
width={width}
maxWidth={maxWidth}
onClick={onClick}
>
Expand Down
Loading