@apia/components 3.0.17 → 3.0.18
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.
- package/dist/index.js +35 -25
- package/dist/index.js.map +1 -1
- package/package.json +8 -8
package/dist/index.js
CHANGED
|
@@ -1722,7 +1722,7 @@ const Item = observer(({ tab }) => {
|
|
|
1722
1722
|
"aria-controls": `tabpanel-${tab.controller.id}-${tab.state.id}`,
|
|
1723
1723
|
"aria-selected": tab.state.isOpen ?? false,
|
|
1724
1724
|
id: `tab-${tab.controller.id}-${tab.id}`,
|
|
1725
|
-
tabIndex: tab.state.
|
|
1725
|
+
tabIndex: tab.state.isOpen ? 0 : -1,
|
|
1726
1726
|
role: "tab",
|
|
1727
1727
|
variant: "inherit"
|
|
1728
1728
|
};
|
|
@@ -1730,31 +1730,37 @@ const Item = observer(({ tab }) => {
|
|
|
1730
1730
|
});
|
|
1731
1731
|
var Item$1 = Item;
|
|
1732
1732
|
|
|
1733
|
+
function useShowScrollButtons() {
|
|
1734
|
+
const [showScrollButtons, setShowScrollButtons] = useState(false);
|
|
1735
|
+
const [ref, setRef] = useState(null);
|
|
1736
|
+
const controller = useTabsContext();
|
|
1737
|
+
useEffect(() => {
|
|
1738
|
+
if (ref && controller) {
|
|
1739
|
+
const observer = new MutationObserver(([{ addedNodes }]) => {
|
|
1740
|
+
const fixedTabsElement = ref.querySelector(".tabsList__fixedTabs");
|
|
1741
|
+
const hasFixedTabsScroll = (fixedTabsElement?.clientWidth ?? 0) < (fixedTabsElement?.scrollWidth ?? 0);
|
|
1742
|
+
const nonFixedTabsElement = ref.querySelector(".tabs__list");
|
|
1743
|
+
const hasFixedNonTabsScroll = (nonFixedTabsElement?.clientWidth ?? 0) < (nonFixedTabsElement?.scrollWidth ?? 0);
|
|
1744
|
+
setShowScrollButtons(hasFixedTabsScroll || hasFixedNonTabsScroll);
|
|
1745
|
+
if (addedNodes) {
|
|
1746
|
+
ref.querySelector(".tabs__list").scrollLeft = 9999999;
|
|
1747
|
+
}
|
|
1748
|
+
});
|
|
1749
|
+
observer.observe(ref, { childList: true, subtree: true });
|
|
1750
|
+
return () => {
|
|
1751
|
+
observer.disconnect();
|
|
1752
|
+
};
|
|
1753
|
+
}
|
|
1754
|
+
return () => {
|
|
1755
|
+
};
|
|
1756
|
+
}, [controller, ref]);
|
|
1757
|
+
return [showScrollButtons, setRef];
|
|
1758
|
+
}
|
|
1759
|
+
|
|
1733
1760
|
const TabsList = observer(
|
|
1734
1761
|
({ arrowsBehavior = "focus" }) => {
|
|
1735
1762
|
const controller = useTabsContext();
|
|
1736
|
-
const [showScrollButtons,
|
|
1737
|
-
const [ref, setRef] = React__default.useState(null);
|
|
1738
|
-
React__default.useEffect(() => {
|
|
1739
|
-
if (ref && controller) {
|
|
1740
|
-
const observer2 = new MutationObserver(([{ addedNodes }]) => {
|
|
1741
|
-
const fixedTabsElement = ref.querySelector(".tabsList__fixedTabs");
|
|
1742
|
-
const hasFixedTabsScroll = (fixedTabsElement?.clientWidth ?? 0) < (fixedTabsElement?.scrollWidth ?? 0);
|
|
1743
|
-
const nonFixedTabsElement = ref.querySelector(".tabs__list");
|
|
1744
|
-
const hasFixedNonTabsScroll = (nonFixedTabsElement?.clientWidth ?? 0) < (nonFixedTabsElement?.scrollWidth ?? 0);
|
|
1745
|
-
setShowScrollButtons(hasFixedTabsScroll || hasFixedNonTabsScroll);
|
|
1746
|
-
if (addedNodes) {
|
|
1747
|
-
ref.querySelector(".tabs__list").scrollLeft = 9999999;
|
|
1748
|
-
}
|
|
1749
|
-
});
|
|
1750
|
-
observer2.observe(ref, { childList: true, subtree: true });
|
|
1751
|
-
return () => {
|
|
1752
|
-
observer2.disconnect();
|
|
1753
|
-
};
|
|
1754
|
-
}
|
|
1755
|
-
return () => {
|
|
1756
|
-
};
|
|
1757
|
-
}, [controller, ref]);
|
|
1763
|
+
const [showScrollButtons, setRef] = useShowScrollButtons();
|
|
1758
1764
|
const onClickPrev = React__default.useCallback(() => {
|
|
1759
1765
|
if (arrowsBehavior === "focus")
|
|
1760
1766
|
controller?.focusPreviousTab();
|
|
@@ -1993,7 +1999,7 @@ class TabsController {
|
|
|
1993
1999
|
}
|
|
1994
2000
|
}
|
|
1995
2001
|
this.state.openTabs.delete(tab);
|
|
1996
|
-
this.getActiveTab()
|
|
2002
|
+
this.getActiveTab()?.open();
|
|
1997
2003
|
this.state.tabs.delete(tab.id);
|
|
1998
2004
|
this.props?.onCloseTab?.(tab);
|
|
1999
2005
|
}
|
|
@@ -2118,6 +2124,8 @@ class TabsController {
|
|
|
2118
2124
|
} catch (e) {
|
|
2119
2125
|
}
|
|
2120
2126
|
tab.state.isOpen = true;
|
|
2127
|
+
tab.state.isFocused = true;
|
|
2128
|
+
document.querySelector(`.tabs__item__wrapper[data-id="${tab.id}"]`)?.focus();
|
|
2121
2129
|
tab.state.onFocus?.(tab);
|
|
2122
2130
|
if (this.state.openTabs.has(tab)) {
|
|
2123
2131
|
this.state.openTabs.delete(tab);
|
|
@@ -4800,7 +4808,9 @@ const DateInput = React__default.forwardRef(
|
|
|
4800
4808
|
`#DateInput${id} input`
|
|
4801
4809
|
)?.focus();
|
|
4802
4810
|
},
|
|
4803
|
-
type: "button"
|
|
4811
|
+
type: "button",
|
|
4812
|
+
title: getLabel("btnAiDelete").text,
|
|
4813
|
+
"aria-label": getLabel("btnAiDelete").text
|
|
4804
4814
|
}
|
|
4805
4815
|
),
|
|
4806
4816
|
[id, onDelete, setCalendarValue]
|