@hitachivantara/uikit-react-pentaho 0.1.3 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/dist/cjs/Canvas/BottomPanel/BottomPanel.cjs +4 -4
  2. package/dist/cjs/Canvas/PanelTab/PanelTab.cjs +18 -0
  3. package/dist/cjs/Canvas/{Tab/Tab.styles.cjs → PanelTab/PanelTab.styles.cjs} +1 -1
  4. package/dist/cjs/Canvas/PanelTabs/PanelTabs.cjs +30 -0
  5. package/dist/cjs/Canvas/{Tabs/Tabs.styles.cjs → PanelTabs/PanelTabs.styles.cjs} +10 -7
  6. package/dist/cjs/Canvas/SidePanel/SidePanel.cjs +4 -4
  7. package/dist/cjs/index.cjs +16 -16
  8. package/dist/esm/Canvas/BottomPanel/BottomPanel.js +4 -4
  9. package/dist/esm/Canvas/BottomPanel/BottomPanel.js.map +1 -1
  10. package/dist/esm/Canvas/PanelTab/PanelTab.js +19 -0
  11. package/dist/esm/Canvas/PanelTab/PanelTab.js.map +1 -0
  12. package/dist/esm/Canvas/{Tab/Tab.styles.js → PanelTab/PanelTab.styles.js} +1 -1
  13. package/dist/esm/Canvas/PanelTab/PanelTab.styles.js.map +1 -0
  14. package/dist/esm/Canvas/PanelTabs/PanelTabs.js +31 -0
  15. package/dist/esm/Canvas/PanelTabs/PanelTabs.js.map +1 -0
  16. package/dist/esm/Canvas/PanelTabs/PanelTabs.styles.js +16 -0
  17. package/dist/esm/Canvas/PanelTabs/PanelTabs.styles.js.map +1 -0
  18. package/dist/esm/Canvas/SidePanel/SidePanel.js +4 -4
  19. package/dist/esm/Canvas/SidePanel/SidePanel.js.map +1 -1
  20. package/dist/esm/index.js +16 -16
  21. package/dist/types/index.d.ts +66 -66
  22. package/package.json +4 -4
  23. package/dist/cjs/Canvas/Tab/Tab.cjs +0 -20
  24. package/dist/cjs/Canvas/Tabs/Tabs.cjs +0 -32
  25. package/dist/esm/Canvas/Tab/Tab.js +0 -21
  26. package/dist/esm/Canvas/Tab/Tab.js.map +0 -1
  27. package/dist/esm/Canvas/Tab/Tab.styles.js.map +0 -1
  28. package/dist/esm/Canvas/Tabs/Tabs.js +0 -33
  29. package/dist/esm/Canvas/Tabs/Tabs.js.map +0 -1
  30. package/dist/esm/Canvas/Tabs/Tabs.styles.js +0 -13
  31. package/dist/esm/Canvas/Tabs/Tabs.styles.js.map +0 -1
@@ -5,8 +5,8 @@ const react = require("react");
5
5
  const reactResizeDetector = require("react-resize-detector");
6
6
  const uikitReactCore = require("@hitachivantara/uikit-react-core");
7
7
  const BottomPanel_styles = require("./BottomPanel.styles.cjs");
8
- const Tabs = require("../Tabs/Tabs.cjs");
9
- const Tab = require("../Tab/Tab.cjs");
8
+ const PanelTabs = require("../PanelTabs/PanelTabs.cjs");
9
+ const PanelTab = require("../PanelTab/PanelTab.cjs");
10
10
  const HvCanvasBottomPanel = react.forwardRef((props, ref) => {
11
11
  const {
12
12
  id: idProp,
@@ -78,7 +78,7 @@ const HvCanvasBottomPanel = react.forwardRef((props, ref) => {
78
78
  children: [
79
79
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: classes.tabsRoot, children: [
80
80
  /* @__PURE__ */ jsxRuntime.jsx(
81
- Tabs.HvCanvasTabs,
81
+ PanelTabs.HvCanvasPanelTabs,
82
82
  {
83
83
  style: {
84
84
  // @ts-ignore
@@ -88,7 +88,7 @@ const HvCanvasBottomPanel = react.forwardRef((props, ref) => {
88
88
  onChange: handleTabChange,
89
89
  value: selectedTab,
90
90
  children: tabs.map((tab, index) => /* @__PURE__ */ jsxRuntime.jsx(
91
- Tab.HvCanvasTab,
91
+ PanelTab.HvCanvasPanelTab,
92
92
  {
93
93
  ref: index === 0 ? tabRef : void 0,
94
94
  id: `${id}-${tab.id}`,
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("react/jsx-runtime");
4
+ const react = require("react");
5
+ const Tab = require("@mui/base/Tab");
6
+ const uikitReactCore = require("@hitachivantara/uikit-react-core");
7
+ const PanelTab_styles = require("./PanelTab.styles.cjs");
8
+ const HvCanvasPanelTab = react.forwardRef((props, ref) => {
9
+ const {
10
+ classes: classesProp,
11
+ className,
12
+ ...others
13
+ } = uikitReactCore.useDefaultProps("HvCanvasPanelTab", props);
14
+ const { classes, cx } = PanelTab_styles.useClasses(classesProp);
15
+ return /* @__PURE__ */ jsxRuntime.jsx(Tab.Tab, { ref, className: cx(classes.root, className), ...others });
16
+ });
17
+ exports.canvasPanelTabClasses = PanelTab_styles.staticClasses;
18
+ exports.HvCanvasPanelTab = HvCanvasPanelTab;
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const Tab = require("@mui/base/Tab");
4
4
  const uikitReactCore = require("@hitachivantara/uikit-react-core");
5
- const { staticClasses, useClasses } = uikitReactCore.createClasses("HvCanvasTab", {
5
+ const { staticClasses, useClasses } = uikitReactCore.createClasses("HvCanvasPanelTab", {
6
6
  root: {
7
7
  height: "100%",
8
8
  display: "flex",
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("react/jsx-runtime");
4
+ const react = require("react");
5
+ const Tabs = require("@mui/base/Tabs");
6
+ const TabsList = require("@mui/base/TabsList");
7
+ const uikitReactCore = require("@hitachivantara/uikit-react-core");
8
+ const PanelTabs_styles = require("./PanelTabs.styles.cjs");
9
+ const HvCanvasPanelTabs = react.forwardRef((props, ref) => {
10
+ const {
11
+ selectionFollowsFocus = true,
12
+ children,
13
+ className,
14
+ classes: classesProp,
15
+ ...others
16
+ } = uikitReactCore.useDefaultProps("HvCanvasPanelTabs", props);
17
+ const { classes, cx } = PanelTabs_styles.useClasses(classesProp);
18
+ return /* @__PURE__ */ jsxRuntime.jsx(
19
+ Tabs.Tabs,
20
+ {
21
+ ref,
22
+ className: cx(classes.root, className),
23
+ selectionFollowsFocus,
24
+ ...others,
25
+ children: /* @__PURE__ */ jsxRuntime.jsx(TabsList.TabsList, { className: classes.list, children })
26
+ }
27
+ );
28
+ });
29
+ exports.canvasPanelTabsClasses = PanelTabs_styles.staticClasses;
30
+ exports.HvCanvasPanelTabs = HvCanvasPanelTabs;
@@ -1,13 +1,16 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const uikitReactCore = require("@hitachivantara/uikit-react-core");
4
- const { staticClasses, useClasses } = uikitReactCore.createClasses("HvCanvasTabs", {
5
- root: {},
6
- list: {
7
- display: "flex",
8
- width: "100%",
9
- height: 48
4
+ const { staticClasses, useClasses } = uikitReactCore.createClasses(
5
+ "HvCanvasPanelTabs",
6
+ {
7
+ root: {},
8
+ list: {
9
+ display: "flex",
10
+ width: "100%",
11
+ height: 48
12
+ }
10
13
  }
11
- });
14
+ );
12
15
  exports.staticClasses = staticClasses;
13
16
  exports.useClasses = useClasses;
@@ -5,8 +5,8 @@ const react = require("react");
5
5
  const uikitReactCore = require("@hitachivantara/uikit-react-core");
6
6
  const uikitReactIcons = require("@hitachivantara/uikit-react-icons");
7
7
  const SidePanel_styles = require("./SidePanel.styles.cjs");
8
- const Tabs = require("../Tabs/Tabs.cjs");
9
- const Tab = require("../Tab/Tab.cjs");
8
+ const PanelTabs = require("../PanelTabs/PanelTabs.cjs");
9
+ const PanelTab = require("../PanelTab/PanelTab.cjs");
10
10
  const DEFAULT_LABELS = {
11
11
  open: "Open",
12
12
  close: "Close"
@@ -55,13 +55,13 @@ const HvCanvasSidePanel = react.forwardRef((props, ref) => {
55
55
  ...others,
56
56
  children: [
57
57
  tabs && /* @__PURE__ */ jsxRuntime.jsx(
58
- Tabs.HvCanvasTabs,
58
+ PanelTabs.HvCanvasPanelTabs,
59
59
  {
60
60
  className: classes.tabs,
61
61
  value: selectedTab,
62
62
  onChange: handleTabChange,
63
63
  children: tabs.map((tab) => /* @__PURE__ */ jsxRuntime.jsx(
64
- Tab.HvCanvasTab,
64
+ PanelTab.HvCanvasPanelTab,
65
65
  {
66
66
  id: `${id}-${tab.id}`,
67
67
  value: tab.id,
@@ -1,22 +1,22 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const Toolbar_styles = require("./Canvas/Toolbar/Toolbar.styles.cjs");
4
- const Toolbar = require("./Canvas/Toolbar/Toolbar.cjs");
5
- const SidePanel_styles = require("./Canvas/SidePanel/SidePanel.styles.cjs");
6
- const SidePanel = require("./Canvas/SidePanel/SidePanel.cjs");
7
- const Tabs_styles = require("./Canvas/Tabs/Tabs.styles.cjs");
8
- const Tabs = require("./Canvas/Tabs/Tabs.cjs");
9
3
  const BottomPanel_styles = require("./Canvas/BottomPanel/BottomPanel.styles.cjs");
10
4
  const BottomPanel = require("./Canvas/BottomPanel/BottomPanel.cjs");
11
- const Tab_styles = require("./Canvas/Tab/Tab.styles.cjs");
12
- const Tab = require("./Canvas/Tab/Tab.cjs");
13
- exports.canvasToolbarClasses = Toolbar_styles.staticClasses;
14
- exports.HvCanvasToolbar = Toolbar.HvCanvasToolbar;
15
- exports.canvasSidePanelClasses = SidePanel_styles.staticClasses;
16
- exports.HvCanvasSidePanel = SidePanel.HvCanvasSidePanel;
17
- exports.canvasTabsClasses = Tabs_styles.staticClasses;
18
- exports.HvCanvasTabs = Tabs.HvCanvasTabs;
5
+ const PanelTab_styles = require("./Canvas/PanelTab/PanelTab.styles.cjs");
6
+ const PanelTab = require("./Canvas/PanelTab/PanelTab.cjs");
7
+ const PanelTabs_styles = require("./Canvas/PanelTabs/PanelTabs.styles.cjs");
8
+ const PanelTabs = require("./Canvas/PanelTabs/PanelTabs.cjs");
9
+ const SidePanel_styles = require("./Canvas/SidePanel/SidePanel.styles.cjs");
10
+ const SidePanel = require("./Canvas/SidePanel/SidePanel.cjs");
11
+ const Toolbar_styles = require("./Canvas/Toolbar/Toolbar.styles.cjs");
12
+ const Toolbar = require("./Canvas/Toolbar/Toolbar.cjs");
19
13
  exports.canvasBottomPanelClasses = BottomPanel_styles.staticClasses;
20
14
  exports.HvCanvasBottomPanel = BottomPanel.HvCanvasBottomPanel;
21
- exports.canvasTabClasses = Tab_styles.staticClasses;
22
- exports.HvCanvasTab = Tab.HvCanvasTab;
15
+ exports.canvasPanelTabClasses = PanelTab_styles.staticClasses;
16
+ exports.HvCanvasPanelTab = PanelTab.HvCanvasPanelTab;
17
+ exports.canvasPanelTabsClasses = PanelTabs_styles.staticClasses;
18
+ exports.HvCanvasPanelTabs = PanelTabs.HvCanvasPanelTabs;
19
+ exports.canvasSidePanelClasses = SidePanel_styles.staticClasses;
20
+ exports.HvCanvasSidePanel = SidePanel.HvCanvasSidePanel;
21
+ exports.canvasToolbarClasses = Toolbar_styles.staticClasses;
22
+ exports.HvCanvasToolbar = Toolbar.HvCanvasToolbar;
@@ -4,8 +4,8 @@ import { useResizeDetector } from "react-resize-detector";
4
4
  import { useDefaultProps, useUniqueId, useControlled, HvActionsGeneric, HvPanel } from "@hitachivantara/uikit-react-core";
5
5
  import { useClasses } from "./BottomPanel.styles.js";
6
6
  import { staticClasses } from "./BottomPanel.styles.js";
7
- import { HvCanvasTabs } from "../Tabs/Tabs.js";
8
- import { HvCanvasTab } from "../Tab/Tab.js";
7
+ import { HvCanvasPanelTabs } from "../PanelTabs/PanelTabs.js";
8
+ import { HvCanvasPanelTab } from "../PanelTab/PanelTab.js";
9
9
  const HvCanvasBottomPanel = forwardRef((props, ref) => {
10
10
  const {
11
11
  id: idProp,
@@ -77,7 +77,7 @@ const HvCanvasBottomPanel = forwardRef((props, ref) => {
77
77
  children: [
78
78
  /* @__PURE__ */ jsxs("div", { className: classes.tabsRoot, children: [
79
79
  /* @__PURE__ */ jsx(
80
- HvCanvasTabs,
80
+ HvCanvasPanelTabs,
81
81
  {
82
82
  style: {
83
83
  // @ts-ignore
@@ -87,7 +87,7 @@ const HvCanvasBottomPanel = forwardRef((props, ref) => {
87
87
  onChange: handleTabChange,
88
88
  value: selectedTab,
89
89
  children: tabs.map((tab, index) => /* @__PURE__ */ jsx(
90
- HvCanvasTab,
90
+ HvCanvasPanelTab,
91
91
  {
92
92
  ref: index === 0 ? tabRef : void 0,
93
93
  id: `${id}-${tab.id}`,
@@ -1 +1 @@
1
- {"version":3,"file":"BottomPanel.js","sources":["../../../../src/Canvas/BottomPanel/BottomPanel.tsx"],"sourcesContent":["import { forwardRef, useMemo } from \"react\";\nimport { useResizeDetector } from \"react-resize-detector\";\nimport {\n ExtractNames,\n HvActionGeneric,\n HvActionsGeneric,\n HvActionsGenericProps,\n HvBaseProps,\n HvPanel,\n useControlled,\n useDefaultProps,\n useUniqueId,\n} from \"@hitachivantara/uikit-react-core\";\n\nimport { HvCanvasTab } from \"../Tab\";\nimport { HvCanvasTabs, HvCanvasTabsProps } from \"../Tabs\";\nimport { staticClasses, useClasses } from \"./BottomPanel.styles\";\n\nexport { staticClasses as canvasBottomPanelClasses };\n\nexport type HvCanvasBottomPanelClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvCanvasBottomPanelProps extends HvBaseProps {\n /** Open state of the bottom panel. */\n open?: boolean;\n /** Minimize state of the bottom panel tabs'. */\n minimize?: boolean;\n /** List of tabs visible on the panel. */\n tabs: {\n id: string | number;\n title: React.ReactNode;\n }[];\n /** Id of the selected tab if it needs to be controlled. */\n tab?: string | number;\n /** Callback triggered when a tab changes/is clicked. */\n onTabChange?: (\n event: React.SyntheticEvent | null,\n tabId: string | number | null,\n ) => void;\n /** Actions to be rendered in the left side of a tab. If more than one action is provided, a dropdown menu will be used. */\n leftActions?: HvActionsGenericProps[\"actions\"];\n /** Actions to be rendered in the right side of a tab.If more than two actions are provided, a dropdown menu will be used to add the remaining actions. */\n rightActions?: HvActionsGenericProps[\"actions\"];\n /** Callback triggered when a right or left action is clicked. */\n onAction?: (\n event: React.SyntheticEvent,\n action: HvActionGeneric,\n tabId: string | number,\n ) => void;\n /** A Jss Object used to override or extend the styles applied. */\n classes?: HvCanvasBottomPanelClasses;\n}\n\n/**\n * A bottom panel component to use in a canvas context.\n */\nexport const HvCanvasBottomPanel = forwardRef<\n HTMLDivElement,\n HvCanvasBottomPanelProps\n>((props, ref) => {\n const {\n id: idProp,\n className,\n children,\n open,\n tabs,\n minimize,\n leftActions,\n rightActions,\n tab: tabProp,\n classes: classesProp,\n onTabChange,\n onAction,\n ...others\n } = useDefaultProps(\"HvCanvasBottomPanel\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n const id = useUniqueId(idProp);\n\n // Tab resize detector: to position tab actions and set the panel top right border radius\n const { width: tabWidth = 0, ref: tabRef } = useResizeDetector({\n handleHeight: false,\n });\n // Tab panel resize detector: to set the panel top right border radius\n const { width: panelWidth = 0, ref: panelRef } = useResizeDetector({\n handleHeight: false,\n });\n\n // Left actions resize detector: to position tab title according with actions\n const { width: leftActionWidth = 32, ref: leftActionRef } = useResizeDetector(\n {\n handleHeight: false,\n refreshMode: \"debounce\",\n refreshOptions: {\n trailing: true,\n },\n },\n );\n // Right actions resize detector: to position tab title according with actions\n const { width: rightActionWidth = 32, ref: rightActionRef } =\n useResizeDetector({\n handleHeight: false,\n refreshMode: \"debounce\",\n refreshOptions: {\n trailing: true,\n },\n });\n\n const overflowing = useMemo(() => {\n const scrollWidth = tabRef.current?.scrollWidth ?? 0;\n return scrollWidth - tabWidth >= 1;\n }, [tabRef, tabWidth]);\n\n const [selectedTab, setSelectedTab] = useControlled<string | number | null>(\n tabProp,\n tabs[0].id,\n );\n\n const handleTabChange: HvCanvasTabsProps[\"onChange\"] = (event, tabId) => {\n setSelectedTab(tabId);\n onTabChange?.(event, tabId);\n };\n\n return (\n <div\n id={id}\n ref={ref}\n className={cx(\n classes.root,\n {\n [classes.closed]: !open,\n [classes.minimized]: minimize,\n [classes.multipleTabs]: tabs.length > 1,\n [classes.overflowing]: overflowing,\n },\n className,\n )}\n {...others}\n >\n <div className={classes.tabsRoot}>\n <HvCanvasTabs\n style={{\n // @ts-ignore\n \"--left-actions-width\": `${leftActionWidth}px`,\n \"--right-actions-width\": `${rightActionWidth}px`,\n }}\n onChange={handleTabChange}\n value={selectedTab}\n >\n {tabs.map((tab, index) => (\n <HvCanvasTab\n ref={index === 0 ? tabRef : undefined}\n key={tab.id}\n id={`${id}-${tab.id}`}\n value={tab.id}\n className={classes.tab}\n >\n <div className={classes.tabTitle}>{tab.title}</div>\n </HvCanvasTab>\n ))}\n </HvCanvasTabs>\n {/* For accessibility purposes, these buttons cannot be children of a tablist so they are rendered as HvCanvasTabs sibling. */}\n {(leftActions || rightActions) && !overflowing\n ? tabs.map((tab, index) => {\n const btnsDisabled = selectedTab !== tab.id && !minimize;\n return (\n <div\n key={tab.id}\n style={{\n // @ts-ignore\n \"--tab-width\": `${tabWidth}px`,\n \"--right\": `calc((${index} + 1) * var(--tab-width))`,\n \"--left\": `calc(${index} * var(--tab-width))`,\n }}\n >\n {leftActions && (\n <div ref={leftActionRef} className={classes.leftActions}>\n <HvActionsGeneric\n maxVisibleActions={1}\n actions={leftActions}\n disabled={btnsDisabled}\n onAction={(event, action) =>\n onAction?.(event, action, tab.id)\n }\n variant=\"secondaryGhost\"\n iconOnly\n />\n </div>\n )}\n {rightActions && (\n <div ref={rightActionRef} className={classes.rightActions}>\n <HvActionsGeneric\n maxVisibleActions={2}\n actions={rightActions}\n disabled={btnsDisabled}\n onAction={(event, action) =>\n onAction?.(event, action, tab.id)\n }\n variant=\"secondaryGhost\"\n iconOnly\n />\n </div>\n )}\n </div>\n );\n })\n : null}\n </div>\n <HvPanel\n ref={panelRef}\n role=\"tabpanel\"\n aria-labelledby={`${id}-${selectedTab}`}\n className={classes.content}\n style={{\n // @ts-ignore\n \"--right-border-radius\":\n tabWidth * tabs.length >= panelWidth ? \"0px\" : \"16px\",\n }}\n >\n {children}\n </HvPanel>\n </div>\n );\n});\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"BottomPanel.js","sources":["../../../../src/Canvas/BottomPanel/BottomPanel.tsx"],"sourcesContent":["import { forwardRef, useMemo } from \"react\";\nimport { useResizeDetector } from \"react-resize-detector\";\nimport {\n ExtractNames,\n HvActionGeneric,\n HvActionsGeneric,\n HvActionsGenericProps,\n HvBaseProps,\n HvPanel,\n useControlled,\n useDefaultProps,\n useUniqueId,\n} from \"@hitachivantara/uikit-react-core\";\n\nimport { HvCanvasPanelTab } from \"../PanelTab\";\nimport { HvCanvasPanelTabs, HvCanvasPanelTabsProps } from \"../PanelTabs\";\nimport { staticClasses, useClasses } from \"./BottomPanel.styles\";\n\nexport { staticClasses as canvasBottomPanelClasses };\n\nexport type HvCanvasBottomPanelClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvCanvasBottomPanelProps extends HvBaseProps {\n /** Open state of the bottom panel. */\n open?: boolean;\n /** Minimize state of the bottom panel tabs'. */\n minimize?: boolean;\n /** List of tabs visible on the panel. */\n tabs: {\n id: string | number;\n title: React.ReactNode;\n }[];\n /** Id of the selected tab if it needs to be controlled. */\n tab?: string | number;\n /** Callback triggered when a tab changes/is clicked. */\n onTabChange?: (\n event: React.SyntheticEvent | null,\n tabId: string | number | null,\n ) => void;\n /** Actions to be rendered in the left side of a tab. If more than one action is provided, a dropdown menu will be used. */\n leftActions?: HvActionsGenericProps[\"actions\"];\n /** Actions to be rendered in the right side of a tab.If more than two actions are provided, a dropdown menu will be used to add the remaining actions. */\n rightActions?: HvActionsGenericProps[\"actions\"];\n /** Callback triggered when a right or left action is clicked. */\n onAction?: (\n event: React.SyntheticEvent,\n action: HvActionGeneric,\n tabId: string | number,\n ) => void;\n /** A Jss Object used to override or extend the styles applied. */\n classes?: HvCanvasBottomPanelClasses;\n}\n\n/**\n * A bottom panel component to use in a canvas context.\n */\nexport const HvCanvasBottomPanel = forwardRef<\n HTMLDivElement,\n HvCanvasBottomPanelProps\n>((props, ref) => {\n const {\n id: idProp,\n className,\n children,\n open,\n tabs,\n minimize,\n leftActions,\n rightActions,\n tab: tabProp,\n classes: classesProp,\n onTabChange,\n onAction,\n ...others\n } = useDefaultProps(\"HvCanvasBottomPanel\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n const id = useUniqueId(idProp);\n\n // Tab resize detector: to position tab actions and set the panel top right border radius\n const { width: tabWidth = 0, ref: tabRef } = useResizeDetector({\n handleHeight: false,\n });\n // Tab panel resize detector: to set the panel top right border radius\n const { width: panelWidth = 0, ref: panelRef } = useResizeDetector({\n handleHeight: false,\n });\n\n // Left actions resize detector: to position tab title according with actions\n const { width: leftActionWidth = 32, ref: leftActionRef } = useResizeDetector(\n {\n handleHeight: false,\n refreshMode: \"debounce\",\n refreshOptions: {\n trailing: true,\n },\n },\n );\n // Right actions resize detector: to position tab title according with actions\n const { width: rightActionWidth = 32, ref: rightActionRef } =\n useResizeDetector({\n handleHeight: false,\n refreshMode: \"debounce\",\n refreshOptions: {\n trailing: true,\n },\n });\n\n const overflowing = useMemo(() => {\n const scrollWidth = tabRef.current?.scrollWidth ?? 0;\n return scrollWidth - tabWidth >= 1;\n }, [tabRef, tabWidth]);\n\n const [selectedTab, setSelectedTab] = useControlled<string | number | null>(\n tabProp,\n tabs[0].id,\n );\n\n const handleTabChange: HvCanvasPanelTabsProps[\"onChange\"] = (\n event,\n tabId,\n ) => {\n setSelectedTab(tabId);\n onTabChange?.(event, tabId);\n };\n\n return (\n <div\n id={id}\n ref={ref}\n className={cx(\n classes.root,\n {\n [classes.closed]: !open,\n [classes.minimized]: minimize,\n [classes.multipleTabs]: tabs.length > 1,\n [classes.overflowing]: overflowing,\n },\n className,\n )}\n {...others}\n >\n <div className={classes.tabsRoot}>\n <HvCanvasPanelTabs\n style={{\n // @ts-ignore\n \"--left-actions-width\": `${leftActionWidth}px`,\n \"--right-actions-width\": `${rightActionWidth}px`,\n }}\n onChange={handleTabChange}\n value={selectedTab}\n >\n {tabs.map((tab, index) => (\n <HvCanvasPanelTab\n ref={index === 0 ? tabRef : undefined}\n key={tab.id}\n id={`${id}-${tab.id}`}\n value={tab.id}\n className={classes.tab}\n >\n <div className={classes.tabTitle}>{tab.title}</div>\n </HvCanvasPanelTab>\n ))}\n </HvCanvasPanelTabs>\n {/* For accessibility purposes, these buttons cannot be children of a tablist so they are rendered as HvCanvasPanelTabs sibling. */}\n {(leftActions || rightActions) && !overflowing\n ? tabs.map((tab, index) => {\n const btnsDisabled = selectedTab !== tab.id && !minimize;\n return (\n <div\n key={tab.id}\n style={{\n // @ts-ignore\n \"--tab-width\": `${tabWidth}px`,\n \"--right\": `calc((${index} + 1) * var(--tab-width))`,\n \"--left\": `calc(${index} * var(--tab-width))`,\n }}\n >\n {leftActions && (\n <div ref={leftActionRef} className={classes.leftActions}>\n <HvActionsGeneric\n maxVisibleActions={1}\n actions={leftActions}\n disabled={btnsDisabled}\n onAction={(event, action) =>\n onAction?.(event, action, tab.id)\n }\n variant=\"secondaryGhost\"\n iconOnly\n />\n </div>\n )}\n {rightActions && (\n <div ref={rightActionRef} className={classes.rightActions}>\n <HvActionsGeneric\n maxVisibleActions={2}\n actions={rightActions}\n disabled={btnsDisabled}\n onAction={(event, action) =>\n onAction?.(event, action, tab.id)\n }\n variant=\"secondaryGhost\"\n iconOnly\n />\n </div>\n )}\n </div>\n );\n })\n : null}\n </div>\n <HvPanel\n ref={panelRef}\n role=\"tabpanel\"\n aria-labelledby={`${id}-${selectedTab}`}\n className={classes.content}\n style={{\n // @ts-ignore\n \"--right-border-radius\":\n tabWidth * tabs.length >= panelWidth ? \"0px\" : \"16px\",\n }}\n >\n {children}\n </HvPanel>\n </div>\n );\n});\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import { jsx } from "react/jsx-runtime";
2
+ import { forwardRef } from "react";
3
+ import { Tab } from "@mui/base/Tab";
4
+ import { useDefaultProps } from "@hitachivantara/uikit-react-core";
5
+ import { useClasses } from "./PanelTab.styles.js";
6
+ import { staticClasses } from "./PanelTab.styles.js";
7
+ const HvCanvasPanelTab = forwardRef((props, ref) => {
8
+ const {
9
+ classes: classesProp,
10
+ className,
11
+ ...others
12
+ } = useDefaultProps("HvCanvasPanelTab", props);
13
+ const { classes, cx } = useClasses(classesProp);
14
+ return /* @__PURE__ */ jsx(Tab, { ref, className: cx(classes.root, className), ...others });
15
+ });
16
+ export {
17
+ HvCanvasPanelTab,
18
+ staticClasses as canvasPanelTabClasses
19
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PanelTab.js","sources":["../../../../src/Canvas/PanelTab/PanelTab.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport { Tab, TabProps } from \"@mui/base/Tab\";\nimport {\n ExtractNames,\n useDefaultProps,\n} from \"@hitachivantara/uikit-react-core\";\n\nimport { staticClasses, useClasses } from \"./PanelTab.styles\";\n\nexport { staticClasses as canvasPanelTabClasses };\n\nexport type HvCanvasPanelTabClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvCanvasPanelTabProps extends TabProps {\n /** A Jss Object used to override or extend the styles applied. */\n classes?: HvCanvasPanelTabClasses;\n}\n\n/**\n * The tab component to use inside `HvCanvasPanelTabs`.\n */\nexport const HvCanvasPanelTab = forwardRef<\n HTMLButtonElement,\n HvCanvasPanelTabProps\n>((props, ref) => {\n const {\n classes: classesProp,\n className,\n ...others\n } = useDefaultProps(\"HvCanvasPanelTab\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n return <Tab ref={ref} className={cx(classes.root, className)} {...others} />;\n});\n"],"names":[],"mappings":";;;;;;AAqBO,MAAM,mBAAmB,WAG9B,CAAC,OAAO,QAAQ;AACV,QAAA;AAAA,IACJ,SAAS;AAAA,IACT;AAAA,IACA,GAAG;AAAA,EAAA,IACD,gBAAgB,oBAAoB,KAAK;AAE7C,QAAM,EAAE,SAAS,GAAG,IAAI,WAAW,WAAW;AAEvC,SAAA,oBAAC,KAAI,EAAA,KAAU,WAAW,GAAG,QAAQ,MAAM,SAAS,GAAI,GAAG,OAAQ,CAAA;AAC5E,CAAC;"}
@@ -1,6 +1,6 @@
1
1
  import { tabClasses } from "@mui/base/Tab";
2
2
  import { createClasses, theme, outlineStyles } from "@hitachivantara/uikit-react-core";
3
- const { staticClasses, useClasses } = createClasses("HvCanvasTab", {
3
+ const { staticClasses, useClasses } = createClasses("HvCanvasPanelTab", {
4
4
  root: {
5
5
  height: "100%",
6
6
  display: "flex",
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PanelTab.styles.js","sources":["../../../../src/Canvas/PanelTab/PanelTab.styles.tsx"],"sourcesContent":["import { tabClasses } from \"@mui/base/Tab\";\nimport {\n createClasses,\n outlineStyles,\n theme,\n} from \"@hitachivantara/uikit-react-core\";\n\nexport const { staticClasses, useClasses } = createClasses(\"HvCanvasPanelTab\", {\n root: {\n height: \"100%\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n flex: 1,\n borderRadius: \"16px 16px 0 0\",\n backgroundColor: theme.colors.atmo2,\n color: theme.colors.secondary_60,\n overflow: \"hidden\",\n width: \"100%\",\n boxShadow: \"0px -2px 8px 0px #4141410F\",\n paddingInlineEnd: 0,\n paddingInlineStart: 0,\n \"& svg .color0\": {\n fill: \"currentcolor\",\n },\n \"&:hover\": {\n cursor: \"pointer\",\n },\n \"&:focus\": {\n backgroundColor: theme.colors.atmo1,\n },\n [`&.${tabClasses.selected}`]: {\n backgroundColor: theme.colors.atmo1,\n ...theme.typography.label,\n },\n \"&:focus-visible\": {\n ...outlineStyles,\n },\n },\n});\n"],"names":[],"mappings":";;AAOO,MAAM,EAAE,eAAe,eAAe,cAAc,oBAAoB;AAAA,EAC7E,MAAM;AAAA,IACJ,QAAQ;AAAA,IACR,SAAS;AAAA,IACT,YAAY;AAAA,IACZ,gBAAgB;AAAA,IAChB,MAAM;AAAA,IACN,cAAc;AAAA,IACd,iBAAiB,MAAM,OAAO;AAAA,IAC9B,OAAO,MAAM,OAAO;AAAA,IACpB,UAAU;AAAA,IACV,OAAO;AAAA,IACP,WAAW;AAAA,IACX,kBAAkB;AAAA,IAClB,oBAAoB;AAAA,IACpB,iBAAiB;AAAA,MACf,MAAM;AAAA,IACR;AAAA,IACA,WAAW;AAAA,MACT,QAAQ;AAAA,IACV;AAAA,IACA,WAAW;AAAA,MACT,iBAAiB,MAAM,OAAO;AAAA,IAChC;AAAA,IACA,CAAC,KAAK,WAAW,QAAQ,EAAE,GAAG;AAAA,MAC5B,iBAAiB,MAAM,OAAO;AAAA,MAC9B,GAAG,MAAM,WAAW;AAAA,IACtB;AAAA,IACA,mBAAmB;AAAA,MACjB,GAAG;AAAA,IACL;AAAA,EACF;AACF,CAAC;"}
@@ -0,0 +1,31 @@
1
+ import { jsx } from "react/jsx-runtime";
2
+ import { forwardRef } from "react";
3
+ import { Tabs } from "@mui/base/Tabs";
4
+ import { TabsList } from "@mui/base/TabsList";
5
+ import { useDefaultProps } from "@hitachivantara/uikit-react-core";
6
+ import { useClasses } from "./PanelTabs.styles.js";
7
+ import { staticClasses } from "./PanelTabs.styles.js";
8
+ const HvCanvasPanelTabs = forwardRef((props, ref) => {
9
+ const {
10
+ selectionFollowsFocus = true,
11
+ children,
12
+ className,
13
+ classes: classesProp,
14
+ ...others
15
+ } = useDefaultProps("HvCanvasPanelTabs", props);
16
+ const { classes, cx } = useClasses(classesProp);
17
+ return /* @__PURE__ */ jsx(
18
+ Tabs,
19
+ {
20
+ ref,
21
+ className: cx(classes.root, className),
22
+ selectionFollowsFocus,
23
+ ...others,
24
+ children: /* @__PURE__ */ jsx(TabsList, { className: classes.list, children })
25
+ }
26
+ );
27
+ });
28
+ export {
29
+ HvCanvasPanelTabs,
30
+ staticClasses as canvasPanelTabsClasses
31
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PanelTabs.js","sources":["../../../../src/Canvas/PanelTabs/PanelTabs.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport { Tabs, TabsProps } from \"@mui/base/Tabs\";\nimport { TabsList } from \"@mui/base/TabsList\";\nimport {\n ExtractNames,\n useDefaultProps,\n} from \"@hitachivantara/uikit-react-core\";\n\nimport { staticClasses, useClasses } from \"./PanelTabs.styles\";\n\nexport { staticClasses as canvasPanelTabsClasses };\n\nexport type HvCanvasPanelTabsClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvCanvasPanelTabsProps extends TabsProps {\n /** A Jss Object used to override or extend the styles applied. */\n classes?: HvCanvasPanelTabsClasses;\n}\n\n/**\n * A tabs component to use in a canvas context.\n */\nexport const HvCanvasPanelTabs = forwardRef<\n HTMLDivElement,\n HvCanvasPanelTabsProps\n>((props, ref) => {\n const {\n selectionFollowsFocus = true,\n children,\n className,\n classes: classesProp,\n ...others\n } = useDefaultProps(\"HvCanvasPanelTabs\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n return (\n <Tabs\n ref={ref}\n className={cx(classes.root, className)}\n selectionFollowsFocus={selectionFollowsFocus}\n {...others}\n >\n <TabsList className={classes.list}>{children}</TabsList>\n </Tabs>\n );\n});\n"],"names":[],"mappings":";;;;;;;AAsBO,MAAM,oBAAoB,WAG/B,CAAC,OAAO,QAAQ;AACV,QAAA;AAAA,IACJ,wBAAwB;AAAA,IACxB;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,GAAG;AAAA,EAAA,IACD,gBAAgB,qBAAqB,KAAK;AAE9C,QAAM,EAAE,SAAS,GAAG,IAAI,WAAW,WAAW;AAG5C,SAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC;AAAA,MACA,WAAW,GAAG,QAAQ,MAAM,SAAS;AAAA,MACrC;AAAA,MACC,GAAG;AAAA,MAEJ,UAAC,oBAAA,UAAA,EAAS,WAAW,QAAQ,MAAO,UAAS;AAAA,IAAA;AAAA,EAAA;AAGnD,CAAC;"}
@@ -0,0 +1,16 @@
1
+ import { createClasses } from "@hitachivantara/uikit-react-core";
2
+ const { staticClasses, useClasses } = createClasses(
3
+ "HvCanvasPanelTabs",
4
+ {
5
+ root: {},
6
+ list: {
7
+ display: "flex",
8
+ width: "100%",
9
+ height: 48
10
+ }
11
+ }
12
+ );
13
+ export {
14
+ staticClasses,
15
+ useClasses
16
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PanelTabs.styles.js","sources":["../../../../src/Canvas/PanelTabs/PanelTabs.styles.tsx"],"sourcesContent":["import { createClasses } from \"@hitachivantara/uikit-react-core\";\n\nexport const { staticClasses, useClasses } = createClasses(\n \"HvCanvasPanelTabs\",\n {\n root: {},\n list: {\n display: \"flex\",\n width: \"100%\",\n height: 48,\n },\n },\n);\n"],"names":[],"mappings":";AAEa,MAAA,EAAE,eAAe,WAAA,IAAe;AAAA,EAC3C;AAAA,EACA;AAAA,IACE,MAAM,CAAC;AAAA,IACP,MAAM;AAAA,MACJ,SAAS;AAAA,MACT,OAAO;AAAA,MACP,QAAQ;AAAA,IACV;AAAA,EACF;AACF;"}
@@ -4,8 +4,8 @@ import { useDefaultProps, useUniqueId, useLabels, useControlled, HvPanel } from
4
4
  import { Start, End } from "@hitachivantara/uikit-react-icons";
5
5
  import { useClasses } from "./SidePanel.styles.js";
6
6
  import { staticClasses } from "./SidePanel.styles.js";
7
- import { HvCanvasTabs } from "../Tabs/Tabs.js";
8
- import { HvCanvasTab } from "../Tab/Tab.js";
7
+ import { HvCanvasPanelTabs } from "../PanelTabs/PanelTabs.js";
8
+ import { HvCanvasPanelTab } from "../PanelTab/PanelTab.js";
9
9
  const DEFAULT_LABELS = {
10
10
  open: "Open",
11
11
  close: "Close"
@@ -54,13 +54,13 @@ const HvCanvasSidePanel = forwardRef((props, ref) => {
54
54
  ...others,
55
55
  children: [
56
56
  tabs && /* @__PURE__ */ jsx(
57
- HvCanvasTabs,
57
+ HvCanvasPanelTabs,
58
58
  {
59
59
  className: classes.tabs,
60
60
  value: selectedTab,
61
61
  onChange: handleTabChange,
62
62
  children: tabs.map((tab) => /* @__PURE__ */ jsx(
63
- HvCanvasTab,
63
+ HvCanvasPanelTab,
64
64
  {
65
65
  id: `${id}-${tab.id}`,
66
66
  value: tab.id,
@@ -1 +1 @@
1
- {"version":3,"file":"SidePanel.js","sources":["../../../../src/Canvas/SidePanel/SidePanel.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport {\n ExtractNames,\n HvBaseProps,\n HvPanel,\n useControlled,\n useDefaultProps,\n useLabels,\n useUniqueId,\n} from \"@hitachivantara/uikit-react-core\";\nimport { End, Start } from \"@hitachivantara/uikit-react-icons\";\n\nimport { HvCanvasTab } from \"../Tab\";\nimport { HvCanvasTabs, HvCanvasTabsProps } from \"../Tabs\";\nimport { staticClasses, useClasses } from \"./SidePanel.styles\";\n\nexport { staticClasses as canvasSidePanelClasses };\n\nexport type HvCanvasSidePanelClasses = ExtractNames<typeof useClasses>;\n\nconst DEFAULT_LABELS = {\n open: \"Open\",\n close: \"Close\",\n};\n\nexport interface HvCanvasSidePanelProps extends HvBaseProps<HTMLDivElement> {\n /** When controlled, defines id the panel is open or not. */\n open?: boolean;\n /** When uncontrolled, defines the initial state of the panel. */\n defaultOpen?: boolean;\n /** List of tabs visible on the panel. */\n tabs?: {\n id: string | number;\n content: React.ReactNode;\n }[];\n /** Id of the selected tab if it needs to be controlled. */\n tab?: string | number;\n /** Callback triggered whenever the panel toggles. */\n onToggle?: (\n event: React.MouseEvent | React.KeyboardEvent,\n open: boolean,\n ) => void;\n /** Callback triggered when a tab changes/is clicked. */\n onTabChange?: (\n event: React.SyntheticEvent | null,\n tabId: string | number | null,\n ) => void;\n /** An object containing all the labels. */\n labels?: Partial<typeof DEFAULT_LABELS>;\n /** The content that will be rendered within the canvas panel. */\n children?: React.ReactNode;\n /** A Jss Object used to override or extend the styles applied. */\n classes?: HvCanvasSidePanelClasses;\n}\n\n/**\n * A side panel component to use in a canvas context.\n */\nexport const HvCanvasSidePanel = forwardRef<\n HTMLDivElement,\n HvCanvasSidePanelProps\n>((props, ref) => {\n const {\n id: idProp,\n tab: tabProp,\n open: openProp,\n defaultOpen = false,\n tabs,\n onToggle,\n onTabChange,\n labels: labelsProp,\n className,\n children,\n classes: classesProp,\n ...others\n } = useDefaultProps(\"HvCanvasSidePanel\", props);\n\n const id = useUniqueId(idProp);\n\n const { classes, cx } = useClasses(classesProp);\n\n const labels = useLabels(DEFAULT_LABELS, labelsProp);\n\n const [open, setOpen] = useControlled(openProp, Boolean(defaultOpen));\n const [selectedTab, setSelectedTab] = useControlled<string | number | null>(\n tabProp,\n tabs?.[0]?.id ?? \"none\",\n );\n\n const handleTogglePanel = (event: React.MouseEvent | React.KeyboardEvent) => {\n setOpen((prev) => !prev);\n onToggle?.(event, !open);\n };\n\n const handleTabChange: HvCanvasTabsProps[\"onChange\"] = (event, tabId) => {\n setSelectedTab(tabId);\n onTabChange?.(event, tabId);\n };\n\n return (\n <>\n <div\n ref={ref}\n id={id}\n className={cx(classes.root, className, {\n [classes.open]: open,\n [classes.close]: !open,\n })}\n {...others}\n >\n {tabs && (\n <HvCanvasTabs\n className={classes.tabs}\n value={selectedTab}\n onChange={handleTabChange}\n >\n {tabs.map((tab) => (\n <HvCanvasTab\n key={tab.id}\n id={`${id}-${tab.id}`}\n value={tab.id}\n tabIndex={0}\n >\n {tab.content}\n </HvCanvasTab>\n ))}\n </HvCanvasTabs>\n )}\n <HvPanel\n role={tabs ? \"tabpanel\" : undefined}\n aria-labelledby={tabs ? `${id}-${selectedTab}` : undefined}\n className={classes.content}\n >\n {children}\n </HvPanel>\n </div>\n <div\n className={cx(classes.handle, {\n [classes.handleOpen]: open,\n [classes.handleClose]: !open,\n })}\n onClick={handleTogglePanel}\n role=\"button\"\n tabIndex={0}\n onKeyDown={(e) => {\n if (e.key === \"Enter\" || e.key === \" \") {\n handleTogglePanel(e);\n }\n }}\n aria-label={open ? labels.close : labels.open}\n >\n <div className={classes.handleButton}>\n {open ? <Start color={[\"primary\"]} /> : <End color={[\"primary\"]} />}\n </div>\n </div>\n </>\n );\n});\n"],"names":[],"mappings":";;;;;;;;AAoBA,MAAM,iBAAiB;AAAA,EACrB,MAAM;AAAA,EACN,OAAO;AACT;AAmCO,MAAM,oBAAoB,WAG/B,CAAC,OAAO,QAAQ;AACV,QAAA;AAAA,IACJ,IAAI;AAAA,IACJ,KAAK;AAAA,IACL,MAAM;AAAA,IACN,cAAc;AAAA,IACd;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQ;AAAA,IACR;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,GAAG;AAAA,EAAA,IACD,gBAAgB,qBAAqB,KAAK;AAExC,QAAA,KAAK,YAAY,MAAM;AAE7B,QAAM,EAAE,SAAS,GAAG,IAAI,WAAW,WAAW;AAExC,QAAA,SAAS,UAAU,gBAAgB,UAAU;AAE7C,QAAA,CAAC,MAAM,OAAO,IAAI,cAAc,UAAU,QAAQ,WAAW,CAAC;AAC9D,QAAA,CAAC,aAAa,cAAc,IAAI;AAAA,IACpC;AAAA,IACA,OAAO,CAAC,GAAG,MAAM;AAAA,EAAA;AAGb,QAAA,oBAAoB,CAAC,UAAkD;AACnE,YAAA,CAAC,SAAS,CAAC,IAAI;AACZ,eAAA,OAAO,CAAC,IAAI;AAAA,EAAA;AAGnB,QAAA,kBAAiD,CAAC,OAAO,UAAU;AACvE,mBAAe,KAAK;AACpB,kBAAc,OAAO,KAAK;AAAA,EAAA;AAG5B,SAEI,qBAAA,UAAA,EAAA,UAAA;AAAA,IAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA;AAAA,QACA,WAAW,GAAG,QAAQ,MAAM,WAAW;AAAA,UACrC,CAAC,QAAQ,IAAI,GAAG;AAAA,UAChB,CAAC,QAAQ,KAAK,GAAG,CAAC;AAAA,QAAA,CACnB;AAAA,QACA,GAAG;AAAA,QAEH,UAAA;AAAA,UACC,QAAA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAW,QAAQ;AAAA,cACnB,OAAO;AAAA,cACP,UAAU;AAAA,cAET,UAAA,KAAK,IAAI,CAAC,QACT;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBAEC,IAAI,GAAG,EAAE,IAAI,IAAI,EAAE;AAAA,kBACnB,OAAO,IAAI;AAAA,kBACX,UAAU;AAAA,kBAET,UAAI,IAAA;AAAA,gBAAA;AAAA,gBALA,IAAI;AAAA,cAAA,CAOZ;AAAA,YAAA;AAAA,UACH;AAAA,UAEF;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,MAAM,OAAO,aAAa;AAAA,cAC1B,mBAAiB,OAAO,GAAG,EAAE,IAAI,WAAW,KAAK;AAAA,cACjD,WAAW,QAAQ;AAAA,cAElB;AAAA,YAAA;AAAA,UACH;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,IACA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,WAAW,GAAG,QAAQ,QAAQ;AAAA,UAC5B,CAAC,QAAQ,UAAU,GAAG;AAAA,UACtB,CAAC,QAAQ,WAAW,GAAG,CAAC;AAAA,QAAA,CACzB;AAAA,QACD,SAAS;AAAA,QACT,MAAK;AAAA,QACL,UAAU;AAAA,QACV,WAAW,CAAC,MAAM;AAChB,cAAI,EAAE,QAAQ,WAAW,EAAE,QAAQ,KAAK;AACtC,8BAAkB,CAAC;AAAA,UACrB;AAAA,QACF;AAAA,QACA,cAAY,OAAO,OAAO,QAAQ,OAAO;AAAA,QAEzC,8BAAC,OAAI,EAAA,WAAW,QAAQ,cACrB,UAAA,2BAAQ,OAAM,EAAA,OAAO,CAAC,SAAS,GAAG,IAAM,oBAAA,KAAA,EAAI,OAAO,CAAC,SAAS,EAAG,CAAA,GACnE;AAAA,MAAA;AAAA,IACF;AAAA,EACF,EAAA,CAAA;AAEJ,CAAC;"}
1
+ {"version":3,"file":"SidePanel.js","sources":["../../../../src/Canvas/SidePanel/SidePanel.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport {\n ExtractNames,\n HvBaseProps,\n HvPanel,\n useControlled,\n useDefaultProps,\n useLabels,\n useUniqueId,\n} from \"@hitachivantara/uikit-react-core\";\nimport { End, Start } from \"@hitachivantara/uikit-react-icons\";\n\nimport { HvCanvasPanelTab } from \"../PanelTab\";\nimport { HvCanvasPanelTabs, HvCanvasPanelTabsProps } from \"../PanelTabs\";\nimport { staticClasses, useClasses } from \"./SidePanel.styles\";\n\nexport { staticClasses as canvasSidePanelClasses };\n\nexport type HvCanvasSidePanelClasses = ExtractNames<typeof useClasses>;\n\nconst DEFAULT_LABELS = {\n open: \"Open\",\n close: \"Close\",\n};\n\nexport interface HvCanvasSidePanelProps\n extends HvBaseProps<HTMLDivElement, \"onToggle\"> {\n /** When controlled, defines id the panel is open or not. */\n open?: boolean;\n /** When uncontrolled, defines the initial state of the panel. */\n defaultOpen?: boolean;\n /** List of tabs visible on the panel. */\n tabs?: {\n id: string | number;\n content: React.ReactNode;\n }[];\n /** Id of the selected tab if it needs to be controlled. */\n tab?: string | number;\n /** Callback triggered whenever the panel toggles. */\n onToggle?: (\n event: React.MouseEvent | React.KeyboardEvent,\n open: boolean,\n ) => void;\n /** Callback triggered when a tab changes/is clicked. */\n onTabChange?: (\n event: React.SyntheticEvent | null,\n tabId: string | number | null,\n ) => void;\n /** An object containing all the labels. */\n labels?: Partial<typeof DEFAULT_LABELS>;\n /** The content that will be rendered within the canvas panel. */\n children?: React.ReactNode;\n /** A Jss Object used to override or extend the styles applied. */\n classes?: HvCanvasSidePanelClasses;\n}\n\n/**\n * A side panel component to use in a canvas context.\n */\nexport const HvCanvasSidePanel = forwardRef<\n HTMLDivElement,\n HvCanvasSidePanelProps\n>((props, ref) => {\n const {\n id: idProp,\n tab: tabProp,\n open: openProp,\n defaultOpen = false,\n tabs,\n onToggle,\n onTabChange,\n labels: labelsProp,\n className,\n children,\n classes: classesProp,\n ...others\n } = useDefaultProps(\"HvCanvasSidePanel\", props);\n\n const id = useUniqueId(idProp);\n\n const { classes, cx } = useClasses(classesProp);\n\n const labels = useLabels(DEFAULT_LABELS, labelsProp);\n\n const [open, setOpen] = useControlled(openProp, Boolean(defaultOpen));\n const [selectedTab, setSelectedTab] = useControlled<string | number | null>(\n tabProp,\n tabs?.[0]?.id ?? \"none\",\n );\n\n const handleTogglePanel = (event: React.MouseEvent | React.KeyboardEvent) => {\n setOpen((prev) => !prev);\n onToggle?.(event, !open);\n };\n\n const handleTabChange: HvCanvasPanelTabsProps[\"onChange\"] = (\n event,\n tabId,\n ) => {\n setSelectedTab(tabId);\n onTabChange?.(event, tabId);\n };\n\n return (\n <>\n <div\n ref={ref}\n id={id}\n className={cx(classes.root, className, {\n [classes.open]: open,\n [classes.close]: !open,\n })}\n {...others}\n >\n {tabs && (\n <HvCanvasPanelTabs\n className={classes.tabs}\n value={selectedTab}\n onChange={handleTabChange}\n >\n {tabs.map((tab) => (\n <HvCanvasPanelTab\n key={tab.id}\n id={`${id}-${tab.id}`}\n value={tab.id}\n tabIndex={0}\n >\n {tab.content}\n </HvCanvasPanelTab>\n ))}\n </HvCanvasPanelTabs>\n )}\n <HvPanel\n role={tabs ? \"tabpanel\" : undefined}\n aria-labelledby={tabs ? `${id}-${selectedTab}` : undefined}\n className={classes.content}\n >\n {children}\n </HvPanel>\n </div>\n <div\n className={cx(classes.handle, {\n [classes.handleOpen]: open,\n [classes.handleClose]: !open,\n })}\n onClick={handleTogglePanel}\n role=\"button\"\n tabIndex={0}\n onKeyDown={(e) => {\n if (e.key === \"Enter\" || e.key === \" \") {\n handleTogglePanel(e);\n }\n }}\n aria-label={open ? labels.close : labels.open}\n >\n <div className={classes.handleButton}>\n {open ? <Start color={[\"primary\"]} /> : <End color={[\"primary\"]} />}\n </div>\n </div>\n </>\n );\n});\n"],"names":[],"mappings":";;;;;;;;AAoBA,MAAM,iBAAiB;AAAA,EACrB,MAAM;AAAA,EACN,OAAO;AACT;AAoCO,MAAM,oBAAoB,WAG/B,CAAC,OAAO,QAAQ;AACV,QAAA;AAAA,IACJ,IAAI;AAAA,IACJ,KAAK;AAAA,IACL,MAAM;AAAA,IACN,cAAc;AAAA,IACd;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQ;AAAA,IACR;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,GAAG;AAAA,EAAA,IACD,gBAAgB,qBAAqB,KAAK;AAExC,QAAA,KAAK,YAAY,MAAM;AAE7B,QAAM,EAAE,SAAS,GAAG,IAAI,WAAW,WAAW;AAExC,QAAA,SAAS,UAAU,gBAAgB,UAAU;AAE7C,QAAA,CAAC,MAAM,OAAO,IAAI,cAAc,UAAU,QAAQ,WAAW,CAAC;AAC9D,QAAA,CAAC,aAAa,cAAc,IAAI;AAAA,IACpC;AAAA,IACA,OAAO,CAAC,GAAG,MAAM;AAAA,EAAA;AAGb,QAAA,oBAAoB,CAAC,UAAkD;AACnE,YAAA,CAAC,SAAS,CAAC,IAAI;AACZ,eAAA,OAAO,CAAC,IAAI;AAAA,EAAA;AAGnB,QAAA,kBAAsD,CAC1D,OACA,UACG;AACH,mBAAe,KAAK;AACpB,kBAAc,OAAO,KAAK;AAAA,EAAA;AAG5B,SAEI,qBAAA,UAAA,EAAA,UAAA;AAAA,IAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA;AAAA,QACA,WAAW,GAAG,QAAQ,MAAM,WAAW;AAAA,UACrC,CAAC,QAAQ,IAAI,GAAG;AAAA,UAChB,CAAC,QAAQ,KAAK,GAAG,CAAC;AAAA,QAAA,CACnB;AAAA,QACA,GAAG;AAAA,QAEH,UAAA;AAAA,UACC,QAAA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAW,QAAQ;AAAA,cACnB,OAAO;AAAA,cACP,UAAU;AAAA,cAET,UAAA,KAAK,IAAI,CAAC,QACT;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBAEC,IAAI,GAAG,EAAE,IAAI,IAAI,EAAE;AAAA,kBACnB,OAAO,IAAI;AAAA,kBACX,UAAU;AAAA,kBAET,UAAI,IAAA;AAAA,gBAAA;AAAA,gBALA,IAAI;AAAA,cAAA,CAOZ;AAAA,YAAA;AAAA,UACH;AAAA,UAEF;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,MAAM,OAAO,aAAa;AAAA,cAC1B,mBAAiB,OAAO,GAAG,EAAE,IAAI,WAAW,KAAK;AAAA,cACjD,WAAW,QAAQ;AAAA,cAElB;AAAA,YAAA;AAAA,UACH;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,IACA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,WAAW,GAAG,QAAQ,QAAQ;AAAA,UAC5B,CAAC,QAAQ,UAAU,GAAG;AAAA,UACtB,CAAC,QAAQ,WAAW,GAAG,CAAC;AAAA,QAAA,CACzB;AAAA,QACD,SAAS;AAAA,QACT,MAAK;AAAA,QACL,UAAU;AAAA,QACV,WAAW,CAAC,MAAM;AAChB,cAAI,EAAE,QAAQ,WAAW,EAAE,QAAQ,KAAK;AACtC,8BAAkB,CAAC;AAAA,UACrB;AAAA,QACF;AAAA,QACA,cAAY,OAAO,OAAO,QAAQ,OAAO;AAAA,QAEzC,8BAAC,OAAI,EAAA,WAAW,QAAQ,cACrB,UAAA,2BAAQ,OAAM,EAAA,OAAO,CAAC,SAAS,GAAG,IAAM,oBAAA,KAAA,EAAI,OAAO,CAAC,SAAS,EAAG,CAAA,GACnE;AAAA,MAAA;AAAA,IACF;AAAA,EACF,EAAA,CAAA;AAEJ,CAAC;"}
package/dist/esm/index.js CHANGED
@@ -1,22 +1,22 @@
1
- import { staticClasses } from "./Canvas/Toolbar/Toolbar.styles.js";
2
- import { HvCanvasToolbar } from "./Canvas/Toolbar/Toolbar.js";
3
- import { staticClasses as staticClasses2 } from "./Canvas/SidePanel/SidePanel.styles.js";
4
- import { HvCanvasSidePanel } from "./Canvas/SidePanel/SidePanel.js";
5
- import { staticClasses as staticClasses3 } from "./Canvas/Tabs/Tabs.styles.js";
6
- import { HvCanvasTabs } from "./Canvas/Tabs/Tabs.js";
7
- import { staticClasses as staticClasses4 } from "./Canvas/BottomPanel/BottomPanel.styles.js";
1
+ import { staticClasses } from "./Canvas/BottomPanel/BottomPanel.styles.js";
8
2
  import { HvCanvasBottomPanel } from "./Canvas/BottomPanel/BottomPanel.js";
9
- import { staticClasses as staticClasses5 } from "./Canvas/Tab/Tab.styles.js";
10
- import { HvCanvasTab } from "./Canvas/Tab/Tab.js";
3
+ import { staticClasses as staticClasses2 } from "./Canvas/PanelTab/PanelTab.styles.js";
4
+ import { HvCanvasPanelTab } from "./Canvas/PanelTab/PanelTab.js";
5
+ import { staticClasses as staticClasses3 } from "./Canvas/PanelTabs/PanelTabs.styles.js";
6
+ import { HvCanvasPanelTabs } from "./Canvas/PanelTabs/PanelTabs.js";
7
+ import { staticClasses as staticClasses4 } from "./Canvas/SidePanel/SidePanel.styles.js";
8
+ import { HvCanvasSidePanel } from "./Canvas/SidePanel/SidePanel.js";
9
+ import { staticClasses as staticClasses5 } from "./Canvas/Toolbar/Toolbar.styles.js";
10
+ import { HvCanvasToolbar } from "./Canvas/Toolbar/Toolbar.js";
11
11
  export {
12
12
  HvCanvasBottomPanel,
13
+ HvCanvasPanelTab,
14
+ HvCanvasPanelTabs,
13
15
  HvCanvasSidePanel,
14
- HvCanvasTab,
15
- HvCanvasTabs,
16
16
  HvCanvasToolbar,
17
- staticClasses4 as canvasBottomPanelClasses,
18
- staticClasses2 as canvasSidePanelClasses,
19
- staticClasses5 as canvasTabClasses,
20
- staticClasses3 as canvasTabsClasses,
21
- staticClasses as canvasToolbarClasses
17
+ staticClasses as canvasBottomPanelClasses,
18
+ staticClasses2 as canvasPanelTabClasses,
19
+ staticClasses3 as canvasPanelTabsClasses,
20
+ staticClasses4 as canvasSidePanelClasses,
21
+ staticClasses5 as canvasToolbarClasses
22
22
  };
@@ -23,6 +23,15 @@ export declare const canvasBottomPanelClasses: {
23
23
  rightActions: "HvCanvasBottomPanel-rightActions";
24
24
  };
25
25
 
26
+ export declare const canvasPanelTabClasses: {
27
+ root: "HvCanvasPanelTab-root";
28
+ };
29
+
30
+ export declare const canvasPanelTabsClasses: {
31
+ root: "HvCanvasPanelTabs-root";
32
+ list: "HvCanvasPanelTabs-list";
33
+ };
34
+
26
35
  export declare const canvasSidePanelClasses: {
27
36
  content: "HvCanvasSidePanel-content";
28
37
  root: "HvCanvasSidePanel-root";
@@ -35,15 +44,6 @@ export declare const canvasSidePanelClasses: {
35
44
  handleClose: "HvCanvasSidePanel-handleClose";
36
45
  };
37
46
 
38
- export declare const canvasTabClasses: {
39
- root: "HvCanvasTab-root";
40
- };
41
-
42
- export declare const canvasTabsClasses: {
43
- root: "HvCanvasTabs-root";
44
- list: "HvCanvasTabs-list";
45
- };
46
-
47
47
  export declare const canvasToolbarClasses: {
48
48
  root: "HvCanvasToolbar-root";
49
49
  title: "HvCanvasToolbar-title";
@@ -52,12 +52,12 @@ export declare const canvasToolbarClasses: {
52
52
  };
53
53
 
54
54
  declare const DEFAULT_LABELS: {
55
- back: string;
55
+ open: string;
56
+ close: string;
56
57
  };
57
58
 
58
59
  declare const DEFAULT_LABELS_2: {
59
- open: string;
60
- close: string;
60
+ back: string;
61
61
  };
62
62
 
63
63
  /**
@@ -65,7 +65,7 @@ declare const DEFAULT_LABELS_2: {
65
65
  */
66
66
  export declare const HvCanvasBottomPanel: ForwardRefExoticComponent<HvCanvasBottomPanelProps & RefAttributes<HTMLDivElement>>;
67
67
 
68
- export declare type HvCanvasBottomPanelClasses = ExtractNames<typeof useClasses_4>;
68
+ export declare type HvCanvasBottomPanelClasses = ExtractNames<typeof useClasses>;
69
69
 
70
70
  export declare interface HvCanvasBottomPanelProps extends HvBaseProps {
71
71
  /** Open state of the bottom panel. */
@@ -91,14 +91,38 @@ export declare interface HvCanvasBottomPanelProps extends HvBaseProps {
91
91
  classes?: HvCanvasBottomPanelClasses;
92
92
  }
93
93
 
94
+ /**
95
+ * The tab component to use inside `HvCanvasPanelTabs`.
96
+ */
97
+ export declare const HvCanvasPanelTab: ForwardRefExoticComponent<Omit<HvCanvasPanelTabProps, "ref"> & RefAttributes<HTMLButtonElement>>;
98
+
99
+ export declare type HvCanvasPanelTabClasses = ExtractNames<typeof useClasses_2>;
100
+
101
+ export declare interface HvCanvasPanelTabProps extends TabProps {
102
+ /** A Jss Object used to override or extend the styles applied. */
103
+ classes?: HvCanvasPanelTabClasses;
104
+ }
105
+
106
+ /**
107
+ * A tabs component to use in a canvas context.
108
+ */
109
+ export declare const HvCanvasPanelTabs: ForwardRefExoticComponent<Omit<HvCanvasPanelTabsProps, "ref"> & RefAttributes<HTMLDivElement>>;
110
+
111
+ export declare type HvCanvasPanelTabsClasses = ExtractNames<typeof useClasses_3>;
112
+
113
+ export declare interface HvCanvasPanelTabsProps extends TabsProps {
114
+ /** A Jss Object used to override or extend the styles applied. */
115
+ classes?: HvCanvasPanelTabsClasses;
116
+ }
117
+
94
118
  /**
95
119
  * A side panel component to use in a canvas context.
96
120
  */
97
121
  export declare const HvCanvasSidePanel: ForwardRefExoticComponent<HvCanvasSidePanelProps & RefAttributes<HTMLDivElement>>;
98
122
 
99
- export declare type HvCanvasSidePanelClasses = ExtractNames<typeof useClasses_2>;
123
+ export declare type HvCanvasSidePanelClasses = ExtractNames<typeof useClasses_4>;
100
124
 
101
- export declare interface HvCanvasSidePanelProps extends HvBaseProps<HTMLDivElement> {
125
+ export declare interface HvCanvasSidePanelProps extends HvBaseProps<HTMLDivElement, "onToggle"> {
102
126
  /** When controlled, defines id the panel is open or not. */
103
127
  open?: boolean;
104
128
  /** When uncontrolled, defines the initial state of the panel. */
@@ -115,43 +139,19 @@ export declare interface HvCanvasSidePanelProps extends HvBaseProps<HTMLDivEleme
115
139
  /** Callback triggered when a tab changes/is clicked. */
116
140
  onTabChange?: (event: React.SyntheticEvent | null, tabId: string | number | null) => void;
117
141
  /** An object containing all the labels. */
118
- labels?: Partial<typeof DEFAULT_LABELS_2>;
142
+ labels?: Partial<typeof DEFAULT_LABELS>;
119
143
  /** The content that will be rendered within the canvas panel. */
120
144
  children?: React.ReactNode;
121
145
  /** A Jss Object used to override or extend the styles applied. */
122
146
  classes?: HvCanvasSidePanelClasses;
123
147
  }
124
148
 
125
- /**
126
- * The tab component to use inside `HvCanvasTabs`.
127
- */
128
- export declare const HvCanvasTab: ForwardRefExoticComponent<Omit<HvCanvasTabProps, "ref"> & RefAttributes<HTMLButtonElement>>;
129
-
130
- export declare type HvCanvasTabClasses = ExtractNames<typeof useClasses_5>;
131
-
132
- export declare interface HvCanvasTabProps extends TabProps {
133
- /** A Jss Object used to override or extend the styles applied. */
134
- classes?: HvCanvasTabClasses;
135
- }
136
-
137
- /**
138
- * A tabs component to use in a canvas context.
139
- */
140
- export declare const HvCanvasTabs: ForwardRefExoticComponent<Omit<HvCanvasTabsProps, "ref"> & RefAttributes<HTMLDivElement>>;
141
-
142
- export declare type HvCanvasTabsClasses = ExtractNames<typeof useClasses_3>;
143
-
144
- export declare interface HvCanvasTabsProps extends TabsProps {
145
- /** A Jss Object used to override or extend the styles applied. */
146
- classes?: HvCanvasTabsClasses;
147
- }
148
-
149
149
  /**
150
150
  * A toolbar component to use in a canvas context.
151
151
  */
152
152
  export declare const HvCanvasToolbar: ForwardRefExoticComponent<HvCanvasToolbarProps & RefAttributes<HTMLDivElement>>;
153
153
 
154
- export declare type HvCanvasToolbarClasses = ExtractNames<typeof useClasses>;
154
+ export declare type HvCanvasToolbarClasses = ExtractNames<typeof useClasses_5>;
155
155
 
156
156
  export declare interface HvCanvasToolbarProps extends HvBaseProps<HTMLDivElement, "title"> {
157
157
  /** Text to display in the component. */
@@ -159,7 +159,7 @@ export declare interface HvCanvasToolbarProps extends HvBaseProps<HTMLDivElement
159
159
  /** Fully customized button or false for when the back button should not be rendered. */
160
160
  backButton?: React.ReactNode;
161
161
  /** An object containing all the labels. */
162
- labels?: Partial<typeof DEFAULT_LABELS>;
162
+ labels?: Partial<typeof DEFAULT_LABELS_2>;
163
163
  children?: React.ReactNode;
164
164
  /** Props for the default back button. */
165
165
  backButtonProps?: Partial<HvIconButtonProps>;
@@ -167,12 +167,19 @@ export declare interface HvCanvasToolbarProps extends HvBaseProps<HTMLDivElement
167
167
  classes?: HvCanvasToolbarClasses;
168
168
  }
169
169
 
170
- declare const useClasses: (classesProp?: Partial<Record<"root" | "title" | "actions" | "back", string>>, addStatic?: boolean) => {
170
+ declare const useClasses: (classesProp?: Partial<Record<"content" | "root" | "tab" | "closed" | "minimized" | "multipleTabs" | "overflowing" | "tabTitle" | "tabsRoot" | "leftActions" | "rightActions", string>>, addStatic?: boolean) => {
171
171
  classes: {
172
+ content: string;
172
173
  root: string;
173
- title: string;
174
- actions: string;
175
- back: string;
174
+ tab: string;
175
+ closed: string;
176
+ minimized: string;
177
+ multipleTabs: string;
178
+ overflowing: string;
179
+ tabTitle: string;
180
+ tabsRoot: string;
181
+ leftActions: string;
182
+ rightActions: string;
176
183
  };
177
184
  css: {
178
185
  (template: TemplateStringsArray, ...args: CSSInterpolation[]): string;
@@ -181,17 +188,9 @@ declare const useClasses: (classesProp?: Partial<Record<"root" | "title" | "acti
181
188
  cx: (...args: any) => string;
182
189
  };
183
190
 
184
- declare const useClasses_2: (classesProp?: Partial<Record<"content" | "root" | "open" | "close" | "handle" | "tabs" | "handleButton" | "handleOpen" | "handleClose", string>>, addStatic?: boolean) => {
191
+ declare const useClasses_2: (classesProp?: Partial<Record<"root", string>>, addStatic?: boolean) => {
185
192
  classes: {
186
- content: string;
187
193
  root: string;
188
- open: string;
189
- close: string;
190
- handle: string;
191
- tabs: string;
192
- handleButton: string;
193
- handleOpen: string;
194
- handleClose: string;
195
194
  };
196
195
  css: {
197
196
  (template: TemplateStringsArray, ...args: CSSInterpolation[]): string;
@@ -212,19 +211,17 @@ declare const useClasses_3: (classesProp?: Partial<Record<"root" | "list", strin
212
211
  cx: (...args: any) => string;
213
212
  };
214
213
 
215
- declare const useClasses_4: (classesProp?: Partial<Record<"content" | "root" | "tab" | "closed" | "minimized" | "multipleTabs" | "overflowing" | "tabTitle" | "tabsRoot" | "leftActions" | "rightActions", string>>, addStatic?: boolean) => {
214
+ declare const useClasses_4: (classesProp?: Partial<Record<"content" | "root" | "open" | "close" | "handle" | "tabs" | "handleButton" | "handleOpen" | "handleClose", string>>, addStatic?: boolean) => {
216
215
  classes: {
217
216
  content: string;
218
217
  root: string;
219
- tab: string;
220
- closed: string;
221
- minimized: string;
222
- multipleTabs: string;
223
- overflowing: string;
224
- tabTitle: string;
225
- tabsRoot: string;
226
- leftActions: string;
227
- rightActions: string;
218
+ open: string;
219
+ close: string;
220
+ handle: string;
221
+ tabs: string;
222
+ handleButton: string;
223
+ handleOpen: string;
224
+ handleClose: string;
228
225
  };
229
226
  css: {
230
227
  (template: TemplateStringsArray, ...args: CSSInterpolation[]): string;
@@ -233,9 +230,12 @@ declare const useClasses_4: (classesProp?: Partial<Record<"content" | "root" | "
233
230
  cx: (...args: any) => string;
234
231
  };
235
232
 
236
- declare const useClasses_5: (classesProp?: Partial<Record<"root", string>>, addStatic?: boolean) => {
233
+ declare const useClasses_5: (classesProp?: Partial<Record<"root" | "title" | "actions" | "back", string>>, addStatic?: boolean) => {
237
234
  classes: {
238
235
  root: string;
236
+ title: string;
237
+ actions: string;
238
+ back: string;
239
239
  };
240
240
  css: {
241
241
  (template: TemplateStringsArray, ...args: CSSInterpolation[]): string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hitachivantara/uikit-react-pentaho",
3
- "version": "0.1.3",
3
+ "version": "0.2.0",
4
4
  "private": false,
5
5
  "author": "Hitachi Vantara UI Kit Team",
6
6
  "description": "UI Kit Pentaho+ React components.",
@@ -30,8 +30,8 @@
30
30
  },
31
31
  "dependencies": {
32
32
  "@emotion/css": "^11.11.0",
33
- "@hitachivantara/uikit-react-core": "^5.66.12",
34
- "@hitachivantara/uikit-react-icons": "^5.10.3",
33
+ "@hitachivantara/uikit-react-core": "^5.66.14",
34
+ "@hitachivantara/uikit-react-icons": "^5.10.5",
35
35
  "@mui/base": "^5.0.0-beta.40",
36
36
  "react-resize-detector": "^8.1.0"
37
37
  },
@@ -42,7 +42,7 @@
42
42
  "access": "public",
43
43
  "directory": "package"
44
44
  },
45
- "gitHead": "0e182f8f81ce3e93aa8c822124ec1b8a4624a48f",
45
+ "gitHead": "143286b6fdeed50a3265683bebb09dba16ab0395",
46
46
  "exports": {
47
47
  ".": {
48
48
  "require": "./dist/cjs/index.cjs",
@@ -1,20 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const jsxRuntime = require("react/jsx-runtime");
4
- const react = require("react");
5
- const Tab = require("@mui/base/Tab");
6
- const uikitReactCore = require("@hitachivantara/uikit-react-core");
7
- const Tab_styles = require("./Tab.styles.cjs");
8
- const HvCanvasTab = react.forwardRef(
9
- (props, ref) => {
10
- const {
11
- classes: classesProp,
12
- className,
13
- ...others
14
- } = uikitReactCore.useDefaultProps("HvCanvasTab", props);
15
- const { classes, cx } = Tab_styles.useClasses(classesProp);
16
- return /* @__PURE__ */ jsxRuntime.jsx(Tab.Tab, { ref, className: cx(classes.root, className), ...others });
17
- }
18
- );
19
- exports.canvasTabClasses = Tab_styles.staticClasses;
20
- exports.HvCanvasTab = HvCanvasTab;
@@ -1,32 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const jsxRuntime = require("react/jsx-runtime");
4
- const react = require("react");
5
- const Tabs = require("@mui/base/Tabs");
6
- const TabsList = require("@mui/base/TabsList");
7
- const uikitReactCore = require("@hitachivantara/uikit-react-core");
8
- const Tabs_styles = require("./Tabs.styles.cjs");
9
- const HvCanvasTabs = react.forwardRef(
10
- (props, ref) => {
11
- const {
12
- selectionFollowsFocus = true,
13
- children,
14
- className,
15
- classes: classesProp,
16
- ...others
17
- } = uikitReactCore.useDefaultProps("HvCanvasTabs", props);
18
- const { classes, cx } = Tabs_styles.useClasses(classesProp);
19
- return /* @__PURE__ */ jsxRuntime.jsx(
20
- Tabs.Tabs,
21
- {
22
- ref,
23
- className: cx(classes.root, className),
24
- selectionFollowsFocus,
25
- ...others,
26
- children: /* @__PURE__ */ jsxRuntime.jsx(TabsList.TabsList, { className: classes.list, children })
27
- }
28
- );
29
- }
30
- );
31
- exports.canvasTabsClasses = Tabs_styles.staticClasses;
32
- exports.HvCanvasTabs = HvCanvasTabs;
@@ -1,21 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { forwardRef } from "react";
3
- import { Tab } from "@mui/base/Tab";
4
- import { useDefaultProps } from "@hitachivantara/uikit-react-core";
5
- import { useClasses } from "./Tab.styles.js";
6
- import { staticClasses } from "./Tab.styles.js";
7
- const HvCanvasTab = forwardRef(
8
- (props, ref) => {
9
- const {
10
- classes: classesProp,
11
- className,
12
- ...others
13
- } = useDefaultProps("HvCanvasTab", props);
14
- const { classes, cx } = useClasses(classesProp);
15
- return /* @__PURE__ */ jsx(Tab, { ref, className: cx(classes.root, className), ...others });
16
- }
17
- );
18
- export {
19
- HvCanvasTab,
20
- staticClasses as canvasTabClasses
21
- };
@@ -1 +0,0 @@
1
- {"version":3,"file":"Tab.js","sources":["../../../../src/Canvas/Tab/Tab.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport { Tab, TabProps } from \"@mui/base/Tab\";\nimport {\n ExtractNames,\n useDefaultProps,\n} from \"@hitachivantara/uikit-react-core\";\n\nimport { staticClasses, useClasses } from \"./Tab.styles\";\n\nexport { staticClasses as canvasTabClasses };\n\nexport type HvCanvasTabClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvCanvasTabProps extends TabProps {\n /** A Jss Object used to override or extend the styles applied. */\n classes?: HvCanvasTabClasses;\n}\n\n/**\n * The tab component to use inside `HvCanvasTabs`.\n */\nexport const HvCanvasTab = forwardRef<HTMLButtonElement, HvCanvasTabProps>(\n (props, ref) => {\n const {\n classes: classesProp,\n className,\n ...others\n } = useDefaultProps(\"HvCanvasTab\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n return (\n <Tab ref={ref} className={cx(classes.root, className)} {...others} />\n );\n },\n);\n"],"names":[],"mappings":";;;;;;AAqBO,MAAM,cAAc;AAAA,EACzB,CAAC,OAAO,QAAQ;AACR,UAAA;AAAA,MACJ,SAAS;AAAA,MACT;AAAA,MACA,GAAG;AAAA,IAAA,IACD,gBAAgB,eAAe,KAAK;AAExC,UAAM,EAAE,SAAS,GAAG,IAAI,WAAW,WAAW;AAG5C,WAAA,oBAAC,KAAI,EAAA,KAAU,WAAW,GAAG,QAAQ,MAAM,SAAS,GAAI,GAAG,OAAQ,CAAA;AAAA,EAEvE;AACF;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Tab.styles.js","sources":["../../../../src/Canvas/Tab/Tab.styles.tsx"],"sourcesContent":["import { tabClasses } from \"@mui/base/Tab\";\nimport {\n createClasses,\n outlineStyles,\n theme,\n} from \"@hitachivantara/uikit-react-core\";\n\nexport const { staticClasses, useClasses } = createClasses(\"HvCanvasTab\", {\n root: {\n height: \"100%\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n flex: 1,\n borderRadius: \"16px 16px 0 0\",\n backgroundColor: theme.colors.atmo2,\n color: theme.colors.secondary_60,\n overflow: \"hidden\",\n width: \"100%\",\n boxShadow: \"0px -2px 8px 0px #4141410F\",\n paddingInlineEnd: 0,\n paddingInlineStart: 0,\n \"& svg .color0\": {\n fill: \"currentcolor\",\n },\n \"&:hover\": {\n cursor: \"pointer\",\n },\n \"&:focus\": {\n backgroundColor: theme.colors.atmo1,\n },\n [`&.${tabClasses.selected}`]: {\n backgroundColor: theme.colors.atmo1,\n ...theme.typography.label,\n },\n \"&:focus-visible\": {\n ...outlineStyles,\n },\n },\n});\n"],"names":[],"mappings":";;AAOO,MAAM,EAAE,eAAe,eAAe,cAAc,eAAe;AAAA,EACxE,MAAM;AAAA,IACJ,QAAQ;AAAA,IACR,SAAS;AAAA,IACT,YAAY;AAAA,IACZ,gBAAgB;AAAA,IAChB,MAAM;AAAA,IACN,cAAc;AAAA,IACd,iBAAiB,MAAM,OAAO;AAAA,IAC9B,OAAO,MAAM,OAAO;AAAA,IACpB,UAAU;AAAA,IACV,OAAO;AAAA,IACP,WAAW;AAAA,IACX,kBAAkB;AAAA,IAClB,oBAAoB;AAAA,IACpB,iBAAiB;AAAA,MACf,MAAM;AAAA,IACR;AAAA,IACA,WAAW;AAAA,MACT,QAAQ;AAAA,IACV;AAAA,IACA,WAAW;AAAA,MACT,iBAAiB,MAAM,OAAO;AAAA,IAChC;AAAA,IACA,CAAC,KAAK,WAAW,QAAQ,EAAE,GAAG;AAAA,MAC5B,iBAAiB,MAAM,OAAO;AAAA,MAC9B,GAAG,MAAM,WAAW;AAAA,IACtB;AAAA,IACA,mBAAmB;AAAA,MACjB,GAAG;AAAA,IACL;AAAA,EACF;AACF,CAAC;"}
@@ -1,33 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { forwardRef } from "react";
3
- import { Tabs } from "@mui/base/Tabs";
4
- import { TabsList } from "@mui/base/TabsList";
5
- import { useDefaultProps } from "@hitachivantara/uikit-react-core";
6
- import { useClasses } from "./Tabs.styles.js";
7
- import { staticClasses } from "./Tabs.styles.js";
8
- const HvCanvasTabs = forwardRef(
9
- (props, ref) => {
10
- const {
11
- selectionFollowsFocus = true,
12
- children,
13
- className,
14
- classes: classesProp,
15
- ...others
16
- } = useDefaultProps("HvCanvasTabs", props);
17
- const { classes, cx } = useClasses(classesProp);
18
- return /* @__PURE__ */ jsx(
19
- Tabs,
20
- {
21
- ref,
22
- className: cx(classes.root, className),
23
- selectionFollowsFocus,
24
- ...others,
25
- children: /* @__PURE__ */ jsx(TabsList, { className: classes.list, children })
26
- }
27
- );
28
- }
29
- );
30
- export {
31
- HvCanvasTabs,
32
- staticClasses as canvasTabsClasses
33
- };
@@ -1 +0,0 @@
1
- {"version":3,"file":"Tabs.js","sources":["../../../../src/Canvas/Tabs/Tabs.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport { Tabs, TabsProps } from \"@mui/base/Tabs\";\nimport { TabsList } from \"@mui/base/TabsList\";\nimport {\n ExtractNames,\n useDefaultProps,\n} from \"@hitachivantara/uikit-react-core\";\n\nimport { staticClasses, useClasses } from \"./Tabs.styles\";\n\nexport { staticClasses as canvasTabsClasses };\n\nexport type HvCanvasTabsClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvCanvasTabsProps extends TabsProps {\n /** A Jss Object used to override or extend the styles applied. */\n classes?: HvCanvasTabsClasses;\n}\n\n/**\n * A tabs component to use in a canvas context.\n */\nexport const HvCanvasTabs = forwardRef<HTMLDivElement, HvCanvasTabsProps>(\n (props, ref) => {\n const {\n selectionFollowsFocus = true,\n children,\n className,\n classes: classesProp,\n ...others\n } = useDefaultProps(\"HvCanvasTabs\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n return (\n <Tabs\n ref={ref}\n className={cx(classes.root, className)}\n selectionFollowsFocus={selectionFollowsFocus}\n {...others}\n >\n <TabsList className={classes.list}>{children}</TabsList>\n </Tabs>\n );\n },\n);\n"],"names":[],"mappings":";;;;;;;AAsBO,MAAM,eAAe;AAAA,EAC1B,CAAC,OAAO,QAAQ;AACR,UAAA;AAAA,MACJ,wBAAwB;AAAA,MACxB;AAAA,MACA;AAAA,MACA,SAAS;AAAA,MACT,GAAG;AAAA,IAAA,IACD,gBAAgB,gBAAgB,KAAK;AAEzC,UAAM,EAAE,SAAS,GAAG,IAAI,WAAW,WAAW;AAG5C,WAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,WAAW,GAAG,QAAQ,MAAM,SAAS;AAAA,QACrC;AAAA,QACC,GAAG;AAAA,QAEJ,UAAC,oBAAA,UAAA,EAAS,WAAW,QAAQ,MAAO,UAAS;AAAA,MAAA;AAAA,IAAA;AAAA,EAGnD;AACF;"}
@@ -1,13 +0,0 @@
1
- import { createClasses } from "@hitachivantara/uikit-react-core";
2
- const { staticClasses, useClasses } = createClasses("HvCanvasTabs", {
3
- root: {},
4
- list: {
5
- display: "flex",
6
- width: "100%",
7
- height: 48
8
- }
9
- });
10
- export {
11
- staticClasses,
12
- useClasses
13
- };
@@ -1 +0,0 @@
1
- {"version":3,"file":"Tabs.styles.js","sources":["../../../../src/Canvas/Tabs/Tabs.styles.tsx"],"sourcesContent":["import { createClasses } from \"@hitachivantara/uikit-react-core\";\n\nexport const { staticClasses, useClasses } = createClasses(\"HvCanvasTabs\", {\n root: {},\n list: {\n display: \"flex\",\n width: \"100%\",\n height: 48,\n },\n});\n"],"names":[],"mappings":";AAEO,MAAM,EAAE,eAAe,eAAe,cAAc,gBAAgB;AAAA,EACzE,MAAM,CAAC;AAAA,EACP,MAAM;AAAA,IACJ,SAAS;AAAA,IACT,OAAO;AAAA,IACP,QAAQ;AAAA,EACV;AACF,CAAC;"}