reka-ui
Version:
Vue port for Radix UI Primitives.
94 lines (92 loc) • 4.13 kB
JavaScript
import { assert } from "../utils/assert.js";
import { getPanelGroupElement, getResizeHandleElementsForGroup, getResizeHandlePanelIds } from "../utils/dom.js";
import { calculateAriaValues } from "../utils/calculate.js";
import { fuzzyNumbersEqual } from "../utils/compare.js";
import { adjustLayoutByDelta } from "../utils/layout.js";
import { determinePivotIndices } from "../utils/pivot.js";
import { watchEffect } from "vue";
//#region src/Splitter/utils/composables/useWindowSplitterPanelGroupBehavior.ts
function useWindowSplitterPanelGroupBehavior({ eagerValuesRef, groupId, layout, panelDataArray, panelGroupElement, setLayout }) {
watchEffect((onCleanup) => {
const _panelGroupElement = panelGroupElement.value;
if (!_panelGroupElement) return;
const resizeHandleElements = getResizeHandleElementsForGroup(groupId, _panelGroupElement);
for (let index = 0; index < panelDataArray.length - 1; index++) {
const { valueMax, valueMin, valueNow } = calculateAriaValues({
layout: layout.value,
panelsArray: panelDataArray,
pivotIndices: [index, index + 1]
});
const resizeHandleElement = resizeHandleElements[index];
if (resizeHandleElement == null) {} else {
const panelData = panelDataArray[index];
assert(panelData);
resizeHandleElement.setAttribute("aria-controls", panelData.id);
resizeHandleElement.setAttribute("aria-valuemax", `${Math.round(valueMax)}`);
resizeHandleElement.setAttribute("aria-valuemin", `${Math.round(valueMin)}`);
resizeHandleElement.setAttribute("aria-valuenow", valueNow != null ? `${Math.round(valueNow)}` : "");
}
}
onCleanup(() => {
resizeHandleElements.forEach((resizeHandleElement) => {
resizeHandleElement.removeAttribute("aria-controls");
resizeHandleElement.removeAttribute("aria-valuemax");
resizeHandleElement.removeAttribute("aria-valuemin");
resizeHandleElement.removeAttribute("aria-valuenow");
});
});
});
watchEffect((onCleanup) => {
const _panelGroupElement = panelGroupElement.value;
if (!_panelGroupElement) return;
const eagerValues = eagerValuesRef.value;
assert(eagerValues);
const { panelDataArray: panelDataArray$1 } = eagerValues;
const groupElement = getPanelGroupElement(groupId, _panelGroupElement);
assert(groupElement != null, `No group found for id "${groupId}"`);
const handles = getResizeHandleElementsForGroup(groupId, _panelGroupElement);
assert(handles);
const cleanupFunctions = handles.map((handle) => {
const handleId = handle.getAttribute("data-panel-resize-handle-id");
assert(handleId);
const [idBefore, idAfter] = getResizeHandlePanelIds(groupId, handleId, panelDataArray$1, _panelGroupElement);
if (idBefore == null || idAfter == null) return () => {};
const onKeyDown = (event) => {
if (event.defaultPrevented) return;
switch (event.key) {
case "Enter": {
event.preventDefault();
const index = panelDataArray$1.findIndex((panelData) => panelData.id === idBefore);
if (index >= 0) {
const panelData = panelDataArray$1[index];
assert(panelData);
const size = layout.value[index];
const { collapsedSize = 0, collapsible, minSize = 0 } = panelData.constraints;
if (size != null && collapsible) {
const nextLayout = adjustLayoutByDelta({
delta: fuzzyNumbersEqual(size, collapsedSize) ? minSize - collapsedSize : collapsedSize - size,
layout: layout.value,
panelConstraints: panelDataArray$1.map((panelData$1) => panelData$1.constraints),
pivotIndices: determinePivotIndices(groupId, handleId, _panelGroupElement),
trigger: "keyboard"
});
if (layout.value !== nextLayout) setLayout(nextLayout);
}
}
break;
}
}
};
handle.addEventListener("keydown", onKeyDown);
return () => {
handle.removeEventListener("keydown", onKeyDown);
};
});
onCleanup(() => {
cleanupFunctions.forEach((cleanupFunction) => cleanupFunction());
});
});
}
//#endregion
export { useWindowSplitterPanelGroupBehavior };
//# sourceMappingURL=useWindowSplitterPanelGroupBehavior.js.map