mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* Add separators and scroll button Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Add tabs controlls Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Update values on resize Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Fix right button Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Add change tab on keydown Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Fix flickering and arrows position Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Fix pr comments. Cleanup function. Simplify reaction Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Add disposer cleanup Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Add separators and scroll button Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Add tabs controlls Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Update values on resize Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Fix right button Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Add change tab on keydown Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Fix flickering and arrows position Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Fix pr comments. Cleanup function. Simplify reaction Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Add disposer cleanup Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * PR fixes and improvements Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Add reaction cleanup Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Cleanup. Remove reaction. Signed-off-by: DmitriyNoa <dmytro.zharkov@gmail.com> * Active tab soft background Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Show close btn on hover Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Removing custom left/right arrow buttons Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Remove dock-tabs styles from dock.scss Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Add dock-tabs.module.scss Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Add useResizeObserver hook Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Set tabs scrollable on small window sizes Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Add custom scrollbar on hover Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Update scrollbar overflow on tabs change Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Adding shadow corners to scrollable area Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Update material icons font Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Change terminal and chart install icons Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Add hover tooltip Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Controls scrollable within Tabs Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Move tooltips to top Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Set dock tabs theme colors Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Mock ResizeObserver Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Increase tooltip show delay Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Scroll active tab into view Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Scroll horizontally with mouse wheel Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Add tiny shadow to cropped tab Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Remove dock-tab.scss Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Adding tab role attributes Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Handle dock open/closed state Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Increase shadow corner size Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Selecting next or previous tab after closing selected one Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Add tiny test Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Use scrollIntoViewIfNeeded in tabs Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Small cleaning Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Small fix for useResizeObserver deps array Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Fix plus button padding on empty dock Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Fix close button position in active tab Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Remove min-width for tab title Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> * Clean up Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> Co-authored-by: Alex Andreev <alex.andreev.email@gmail.com>
98 lines
2.7 KiB
TypeScript
98 lines
2.7 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
import styles from "./dock-tabs.module.scss";
|
|
|
|
import React, { Fragment, useEffect, useRef, useState } from "react";
|
|
import { Tabs } from "../tabs/tabs";
|
|
import { DockTab } from "./dock-tab";
|
|
import type { DockTab as DockTabModel } from "./dock/store";
|
|
import { TabKind } from "./dock/store";
|
|
import { TerminalTab } from "./terminal/dock-tab";
|
|
import { useResizeObserver } from "../../hooks";
|
|
import { cssVar } from "../../utils";
|
|
|
|
export interface DockTabsProps {
|
|
tabs: DockTabModel[];
|
|
autoFocus: boolean;
|
|
selectedTab: DockTabModel;
|
|
onChangeTab: (tab: DockTabModel) => void;
|
|
}
|
|
|
|
export const DockTabs = ({ tabs, autoFocus, selectedTab, onChangeTab }: DockTabsProps) => {
|
|
const elem = useRef<HTMLDivElement>();
|
|
const minTabSize = useRef<number>(0);
|
|
const [showScrollbar, setShowScrollbar] = useState(false);
|
|
|
|
const getTabElements = (): HTMLDivElement[] => {
|
|
return Array.from(elem.current?.querySelectorAll(".Tabs .Tab"));
|
|
};
|
|
|
|
const renderTab = (tab?: DockTabModel) => {
|
|
if (!tab) {
|
|
return null;
|
|
}
|
|
|
|
switch (tab.kind) {
|
|
case TabKind.CREATE_RESOURCE:
|
|
case TabKind.EDIT_RESOURCE:
|
|
return <DockTab value={tab} icon="edit" />;
|
|
case TabKind.INSTALL_CHART:
|
|
case TabKind.UPGRADE_CHART:
|
|
return <DockTab value={tab} icon="install_desktop" />;
|
|
case TabKind.POD_LOGS:
|
|
return <DockTab value={tab} icon="subject" />;
|
|
case TabKind.TERMINAL:
|
|
return <TerminalTab value={tab} />;
|
|
}
|
|
};
|
|
|
|
const scrollActiveTabIntoView = () => {
|
|
const tab = elem.current?.querySelector(".Tab.active");
|
|
|
|
tab?.scrollIntoView();
|
|
};
|
|
|
|
const updateScrollbarVisibility = () => {
|
|
const allTabsShrunk = getTabElements().every(tab => tab.offsetWidth == minTabSize.current);
|
|
|
|
setShowScrollbar(allTabsShrunk);
|
|
};
|
|
|
|
const scrollTabsWithMouseWheel = (left: number) => {
|
|
elem.current?.children[0]?.scrollBy({ left });
|
|
};
|
|
|
|
const onMouseWheel = (event: React.WheelEvent) => {
|
|
scrollTabsWithMouseWheel(event.deltaY);
|
|
};
|
|
|
|
useEffect(() => {
|
|
const cssVars = cssVar(elem.current);
|
|
|
|
minTabSize.current = cssVars.get("--min-tab-width").valueOf();
|
|
});
|
|
|
|
useResizeObserver(elem.current, () => {
|
|
scrollActiveTabIntoView();
|
|
updateScrollbarVisibility();
|
|
});
|
|
|
|
return (
|
|
<div className={styles.dockTabs} ref={elem} role="tablist">
|
|
<Tabs
|
|
autoFocus={autoFocus}
|
|
value={selectedTab}
|
|
onChange={onChangeTab}
|
|
onWheel={onMouseWheel}
|
|
scrollable={showScrollbar}
|
|
className={styles.tabs}
|
|
>
|
|
{tabs.map(tab => <Fragment key={tab.id}>{renderTab(tab)}</Fragment>)}
|
|
</Tabs>
|
|
</div>
|
|
);
|
|
};
|