@navikt/ds-react
Version:
React components from the Norwegian Labour and Welfare Administration.
118 lines • 6.23 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
const react_1 = require("@floating-ui/react");
const react_2 = __importStar(require("react"));
const Theme_1 = require("../../theme/Theme");
const useMergeRefs_1 = require("../../util/hooks/useMergeRefs");
const i18n_hooks_1 = require("../../util/i18n/i18n.hooks");
const usePeriodContext_1 = require("../hooks/usePeriodContext");
const useRowContext_1 = require("../hooks/useRowContext");
const useTimelineContext_1 = require("../hooks/useTimelineContext");
const period_1 = require("../utils/period");
const ClickablePeriod = react_2.default.memo(({ onSelectPeriod, start, end, status, cropped, direction, left, width, icon, children, isActive, statusLabel, restProps, periodRef, }) => {
var _a, _b;
const { cn } = (0, Theme_1.useRenameCSS)();
const [open, setOpen] = (0, react_2.useState)(false);
const { index } = (0, useRowContext_1.useRowContext)();
const { firstFocus } = (0, usePeriodContext_1.usePeriodContext)();
const { initiate, addFocusable } = (0, useTimelineContext_1.useTimelineContext)();
const translate = (0, i18n_hooks_1.useI18n)("Timeline");
const { context, placement, refs, floatingStyles } = (0, react_1.useFloating)({
placement: (_a = restProps === null || restProps === void 0 ? void 0 : restProps.placement) !== null && _a !== void 0 ? _a : "top",
open,
onOpenChange: (_open) => setOpen(_open),
whileElementsMounted: react_1.autoUpdate,
middleware: [
(0, react_1.offset)(8),
(0, react_1.shift)(),
(0, react_1.flip)({ padding: 5, fallbackPlacements: ["bottom", "top"] }),
],
});
const hover = (0, react_1.useHover)(context, {
handleClose: (0, react_1.safePolygon)(),
restMs: 25,
delay: { open: 1000 },
move: false,
});
const focus = (0, react_1.useFocus)(context);
const dismiss = (0, react_1.useDismiss)(context);
const { getFloatingProps, getReferenceProps } = (0, react_1.useInteractions)([
hover,
focus,
dismiss,
]);
const mergedRef = (0, useMergeRefs_1.useMergeRefs)(refs.setReference, periodRef);
const label = (0, period_1.ariaLabel)(start, end, status, statusLabel, translate);
return (react_2.default.createElement(react_2.default.Fragment, null,
react_2.default.createElement("button", Object.assign({}, restProps, { "data-color": (_b = restProps === null || restProps === void 0 ? void 0 : restProps["data-color"]) !== null && _b !== void 0 ? _b : status, type: "button", ref: (r) => {
firstFocus && addFocusable(r, index);
mergedRef(r);
}, "aria-label": label, className: cn("navds-timeline__period--clickable", (0, period_1.getConditionalClasses)(cropped, direction, status), restProps === null || restProps === void 0 ? void 0 : restProps.className, {
"navds-timeline__period--selected": isActive,
}), "aria-expanded": children ? open : undefined, "aria-current": isActive || undefined }, getReferenceProps({
onFocus: () => {
initiate(index);
},
onKeyDown: (e) => {
var _a;
(_a = restProps === null || restProps === void 0 ? void 0 : restProps.onKeydown) === null || _a === void 0 ? void 0 : _a.call(restProps, e);
if (e.key === "Enter") {
setOpen((prev) => !prev);
}
if (e.key === " ") {
onSelectPeriod === null || onSelectPeriod === void 0 ? void 0 : onSelectPeriod(e);
setOpen(false);
}
},
style: {
width: `${width}%`,
[direction]: `${left}%`,
},
onClick: (e) => {
var _a;
(_a = restProps === null || restProps === void 0 ? void 0 : restProps.onClick) === null || _a === void 0 ? void 0 : _a.call(restProps, e);
if (e.detail === 0) {
return;
}
onSelectPeriod === null || onSelectPeriod === void 0 ? void 0 : onSelectPeriod(e);
},
})),
react_2.default.createElement("span", { className: cn("navds-timeline__period--inner") }, icon)),
children && open && (react_2.default.createElement(react_1.FloatingFocusManager, { context: context, modal: false, initialFocus: -1, returnFocus: false },
react_2.default.createElement("div", Object.assign({ className: cn("navds-timeline__popover"), "data-placement": placement, ref: refs.setFloating, role: "dialog", "aria-label": label }, getFloatingProps(), { style: floatingStyles }), children)))));
});
exports.default = ClickablePeriod;
//# sourceMappingURL=ClickablePeriod.js.map