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

feat(shell-panel): deprecate float displayMode and add float-content and float-all #9795

Merged
merged 32 commits into from
Jul 30, 2024
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
725a45e
fix(shell-panel): implement float display mode
josercarcamo Jul 16, 2024
8cef11f
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 16, 2024
d881904
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 16, 2024
a5cb68c
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 17, 2024
b9c0b6c
Removed code that reduced action bar size per code review
josercarcamo Jul 19, 2024
57c8731
REmoved undefined --calcite-shell-panel-max-width-internal
josercarcamo Jul 19, 2024
e58b0d5
Removed unused line; renamed display-mode values; other
josercarcamo Jul 22, 2024
f778931
Made further changes to code
josercarcamo Jul 22, 2024
b2698eb
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 23, 2024
38069e2
Reverted name change
josercarcamo Jul 23, 2024
46011d0
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 23, 2024
6adf1f7
Merge branch 'josercarcamo/7513-shell-panel-add-float-display-v2' of …
josercarcamo Jul 23, 2024
6c4d128
Reverted name change
josercarcamo Jul 23, 2024
951d1f7
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 23, 2024
e3b608d
Separated rules for float-detach and float
josercarcamo Jul 24, 2024
cbc1c53
Merge branch 'josercarcamo/7513-shell-panel-add-float-display-v2' of …
josercarcamo Jul 24, 2024
4329cc9
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 24, 2024
7722db7
Fixing failed test
josercarcamo Jul 24, 2024
3b6755a
Merge branch 'josercarcamo/7513-shell-panel-add-float-display-v2' of …
josercarcamo Jul 24, 2024
84b1026
Fixing failed test
josercarcamo Jul 24, 2024
957b678
Fixing failed test
josercarcamo Jul 24, 2024
50f283f
Fixing failed test
josercarcamo Jul 24, 2024
abf80a5
Moved the '-internal' ending right after 'calcite' for each rule
josercarcamo Jul 24, 2024
5f39407
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 24, 2024
3540fba
Changed display-mode from float to float-detach
josercarcamo Jul 24, 2024
ea1b001
Merge branch 'josercarcamo/7513-shell-panel-add-float-display-v2' of …
josercarcamo Jul 24, 2024
46b45f8
Added stories for vertical and horizontal float
josercarcamo Jul 25, 2024
271b1a5
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 25, 2024
c312514
Deprecated display mode float and added float-content and float-all
josercarcamo Jul 29, 2024
c132c44
Merge branch 'dev' into josercarcamo/7513-shell-panel-add-float-displ…
josercarcamo Jul 29, 2024
dd6c2f6
Made tests for float and float-content
josercarcamo Jul 30, 2024
141c097
Merge branch 'josercarcamo/7513-shell-panel-add-float-display-v2' of …
josercarcamo Jul 30, 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
28 changes: 14 additions & 14 deletions packages/calcite-components/src/components.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4311,6 +4311,10 @@ export namespace Components {
"position": Extract<"start" | "end", Position>;
}
interface CalciteShellPanel {
/**
* Specifies the action bar's position. Will be flipped when the element direction is right-to-left (`"rtl"`).
*/
"actionBarPosition": Extract<"start" | "end", Position>;
/**
* When `true`, hides the component's content area.
*/
Expand All @@ -4321,12 +4325,12 @@ export namespace Components {
*/
"detached": boolean;
/**
* When `displayMode` is `float`, specifies the maximum height of the component.
* When `displayMode` is `content-detached`, specifies the maximum height of the component.
* @deprecated Use `heightScale` instead.
*/
"detachedHeightScale": Scale;
/**
* Specifies the display mode of the component, where: `"dock"` displays at full height adjacent to center content, `"overlay"` displays at full height on top of center content, and `"float"` does not display at full height with content separately detached from `calcite-action-bar` on top of center content.
* Specifies the display mode of the component, where: `"dock"` displays at full height adjacent to center content, `"overlay"` displays at full height on top of center content, and `"content-detached"` does not display at full height with content separately detached from `calcite-action-bar` on top of center content.
*/
"displayMode": DisplayMode1;
/**
Expand All @@ -4346,11 +4350,7 @@ export namespace Components {
*/
"messages": ShellPanelMessages;
/**
* Specifies the component's position. Will be flipped when the element direction is right-to-left (`"rtl"`).
*/
"position": Extract<"start" | "end", Position>;
/**
* When `true` and `displayMode` is not `float`, the component's content area is resizable.
* When `true` and `displayMode` is not `content-detached`, the component's content area is resizable.
*/
"resizable": boolean;
/**
Expand Down Expand Up @@ -12326,6 +12326,10 @@ declare namespace LocalJSX {
"position"?: Extract<"start" | "end", Position>;
}
interface CalciteShellPanel {
/**
* Specifies the action bar's position. Will be flipped when the element direction is right-to-left (`"rtl"`).
*/
"actionBarPosition"?: Extract<"start" | "end", Position>;
/**
* When `true`, hides the component's content area.
*/
Expand All @@ -12336,12 +12340,12 @@ declare namespace LocalJSX {
*/
"detached"?: boolean;
/**
* When `displayMode` is `float`, specifies the maximum height of the component.
* When `displayMode` is `content-detached`, specifies the maximum height of the component.
* @deprecated Use `heightScale` instead.
*/
"detachedHeightScale"?: Scale;
/**
* Specifies the display mode of the component, where: `"dock"` displays at full height adjacent to center content, `"overlay"` displays at full height on top of center content, and `"float"` does not display at full height with content separately detached from `calcite-action-bar` on top of center content.
* Specifies the display mode of the component, where: `"dock"` displays at full height adjacent to center content, `"overlay"` displays at full height on top of center content, and `"content-detached"` does not display at full height with content separately detached from `calcite-action-bar` on top of center content.
*/
"displayMode"?: DisplayMode1;
/**
Expand All @@ -12363,11 +12367,7 @@ declare namespace LocalJSX {
"onCalciteInternalShellPanelResizeEnd"?: (event: CalciteShellPanelCustomEvent<void>) => void;
"onCalciteInternalShellPanelResizeStart"?: (event: CalciteShellPanelCustomEvent<void>) => void;
/**
* Specifies the component's position. Will be flipped when the element direction is right-to-left (`"rtl"`).
*/
"position"?: Extract<"start" | "end", Position>;
/**
* When `true` and `displayMode` is not `float`, the component's content area is resizable.
* When `true` and `displayMode` is not `content-detached`, the component's content area is resizable.
*/
"resizable"?: boolean;
/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -342,8 +342,32 @@ export class ActionBar
expanded,
overflowCount,
});

this.removeOverflowGroups(height, actionGroups, layout);
}, overflowActionsDebounceInMs);

private removeOverflowGroups(
driskull marked this conversation as resolved.
Show resolved Hide resolved
height: number,
actionGroups: HTMLCalciteActionGroupElement[],
layout: "horizontal" | "vertical",
) {
let groupHeight = 0;
if (layout === "vertical") {
actionGroups.forEach((group) => {
groupHeight += group.clientHeight;
});
while (height > groupHeight || Math.abs(height - groupHeight) <= 20) {
const group = actionGroups.shift();
group.style.display = "none";
driskull marked this conversation as resolved.
Show resolved Hide resolved
actionGroups.forEach((group) => {
groupHeight += group.clientHeight;
});
}
} else {
actionGroups.forEach((a) => (a.style.display = "inline-block"));
driskull marked this conversation as resolved.
Show resolved Hide resolved
}
}

toggleExpand = (): void => {
this.expanded = !this.expanded;
this.calciteActionBarToggle.emit();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ const ICONS = {
} as const;

function getCalcitePosition(position: Position, el: HTMLElement): Position {
return position || el.closest("calcite-shell-panel")?.position || "start";
return position || el.closest("calcite-shell-panel")?.actionBarPosition || "start";
}

export function toggleChildActionText({
Expand Down
Original file line number Diff line number Diff line change
@@ -1 +1 @@
export type DisplayMode = "dock" | "float" | "overlay";
export type DisplayMode = "dock" | "float" | "overlay" | "content-detached";
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,10 @@ export const CSS = {
content: "content",
contentHeader: "content__header",
contentBody: "content__body",
contentFloat: "content--float",
contentDetached: "content--detached",
contentOverlay: "content--overlay",
separator: "separator",
float: "float",
};

export const SLOTS = {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ describe("calcite-shell-panel", () => {

await page.setContent("<calcite-shell-panel><div>content</div></calcite-shell-panel>");

let detachedElement = await page.find(`calcite-shell-panel >>> .${CSS.contentFloat}`);
let detachedElement = await page.find(`calcite-shell-panel >>> .${CSS.contentDetached}`);

expect(detachedElement).toBeNull();

Expand All @@ -161,7 +161,7 @@ describe("calcite-shell-panel", () => {

expect(await panel.getProperty("detached")).toBe(true);

detachedElement = await page.find(`calcite-shell-panel >>> .${CSS.contentFloat}`);
detachedElement = await page.find(`calcite-shell-panel >>> .${CSS.contentDetached}`);

expect(detachedElement).not.toBeNull();
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,21 +48,23 @@
z-index: var(--calcite-shell-panel-z-index, calc(theme("zIndex.header") + 1));
}

:host([layout="vertical"][display-mode="float"]) .content,
:host([layout="vertical"][display-mode="content-detached"]) .content {
flex: 2;
}

:host([layout="vertical"][width-scale="s"]) .content {
--calcite-shell-panel-width-internal: var(--calcite-shell-panel-width, 12vw);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the naming schema for these should be --calcite-internal-shell-panel-

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I didn't add these tokens. They're pre-existing.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can you update them while you're there? They're already internal so there won't be any breaking changes to worry about.

--calcite-shell-panel-max-width-internal: var(--calcite-shell-panel-max-width, 300px);
driskull marked this conversation as resolved.
Show resolved Hide resolved
--calcite-shell-panel-min-width-internal: var(--calcite-shell-panel-min-width, 150px);
}

:host([layout="vertical"][width-scale="m"]) .content {
--calcite-shell-panel-width-internal: var(--calcite-shell-panel-width, 20vw);
--calcite-shell-panel-max-width-internal: var(--calcite-shell-panel-max-width, 420px);
--calcite-shell-panel-min-width-internal: var(--calcite-shell-panel-min-width, 240px);
}

:host([layout="vertical"][width-scale="l"]) .content {
--calcite-shell-panel-width-internal: var(--calcite-shell-panel-width, 45vw);
--calcite-shell-panel-max-width-internal: var(--calcite-shell-panel-max-width, 680px);
--calcite-shell-panel-min-width-internal: var(--calcite-shell-panel-min-width, 340px);
}

Expand Down Expand Up @@ -101,6 +103,11 @@
* {
@apply box-border;
}

&.float {
margin-block: 0.5rem;
driskull marked this conversation as resolved.
Show resolved Hide resolved
margin-inline: 0.5rem;
}
}

:host([layout="horizontal"]) .container {
Expand Down Expand Up @@ -253,7 +260,7 @@
box-shadow: var(--calcite-shell-panel-shadow-block-end-internal);
}

.content--float {
.content--detached {
@apply shadow-0
mx-2
mt-2
Expand All @@ -268,12 +275,12 @@
}
}

:host([layout="horizontal"]) .content--float {
:host([layout="horizontal"]) .content--detached {
@apply my-2;
}

:host([position="start"]) .content--float,
:host([position="end"]) .content--float {
:host([position="start"]) .content--detached,
:host([position="end"]) .content--detached {
::slotted(calcite-panel),
::slotted(calcite-flow) {
@apply border-none;
Expand All @@ -290,7 +297,7 @@ slot[name="action-bar"]::slotted(calcite-action-bar),
@apply border-color-3 border border-solid;
}

:host([position="start"]:not([slot="panel-end"])),
:host([position="start"]:not([slot="panel-end"]):not([display-mode="float"])),
:host([position="end"][slot="panel-start"]) {
slot[name="action-bar"]::slotted(calcite-action-bar),
.content ::slotted(calcite-flow),
Expand All @@ -308,12 +315,12 @@ slot[name="action-bar"]::slotted(calcite-action-bar),
}
}

:host([layout="horizontal"]) slot[name="action-bar"]::slotted(calcite-action-bar) {
:host([layout="horizontal"]:not([display-mode="float"])) slot[name="action-bar"]::slotted(calcite-action-bar) {
border-inline: 0;
}

:host([layout="horizontal"][position="start"]) .content ::slotted(calcite-flow),
:host([layout="horizontal"][position="start"]) .content ::slotted(calcite-panel) {
:host([layout="horizontal"][position="start"]:not([display-mode="float"])) .content ::slotted(calcite-flow),
:host([layout="horizontal"][position="start"]:not([display-mode="float"])) .content ::slotted(calcite-panel) {
border-inline: 0;
border-block-start: 0;
}
Expand Down
Loading
Loading