@roadlittledawn/docs-design-system-react 0.11.0 → 0.11.1
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/USAGE.md +762 -311
- package/dist/components/Collapser.d.ts +3 -0
- package/dist/components/Collapser.js +3 -11
- package/dist/components/CollapserGroup.js +2 -2
- package/dist/styles.css +7 -2
- package/package.json +1 -1
|
@@ -41,3 +41,6 @@ export interface CollapserProps {
|
|
|
41
41
|
stepNumber?: number;
|
|
42
42
|
}
|
|
43
43
|
export declare function Collapser({ title, id, defaultOpen, open: controlledOpen, onToggle, children, className, align, icon, stepNumber, }: CollapserProps): import("react/jsx-runtime").JSX.Element;
|
|
44
|
+
export declare namespace Collapser {
|
|
45
|
+
var displayName: string;
|
|
46
|
+
}
|
|
@@ -1,25 +1,18 @@
|
|
|
1
1
|
'use client';
|
|
2
2
|
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
-
import { useState
|
|
3
|
+
import { useState } from "react";
|
|
4
4
|
import { useKeyPress } from "../hooks/useKeyPress";
|
|
5
5
|
export function Collapser(_a) {
|
|
6
6
|
var title = _a.title, id = _a.id, _b = _a.defaultOpen, defaultOpen = _b === void 0 ? false : _b, controlledOpen = _a.open, onToggle = _a.onToggle, children = _a.children, _c = _a.className, className = _c === void 0 ? "" : _c, _d = _a.align, align = _d === void 0 ? 'left' : _d, icon = _a.icon, stepNumber = _a.stepNumber;
|
|
7
7
|
var _e = useState(defaultOpen), uncontrolledOpen = _e[0], setUncontrolledOpen = _e[1];
|
|
8
8
|
var isControlled = controlledOpen !== undefined;
|
|
9
9
|
var isOpen = isControlled ? controlledOpen : uncontrolledOpen;
|
|
10
|
-
var _f = useState(undefined), height = _f[0], setHeight = _f[1];
|
|
11
|
-
var contentRef = useRef(null);
|
|
12
10
|
// Keyboard shortcuts: 's' or 'f' to show, 'h' to hide
|
|
13
11
|
useKeyPress(['s', 'f', 'h'], function (e) {
|
|
14
12
|
if (!isControlled) {
|
|
15
13
|
setUncontrolledOpen(e.key !== 'h');
|
|
16
14
|
}
|
|
17
15
|
});
|
|
18
|
-
useEffect(function () {
|
|
19
|
-
if (contentRef.current) {
|
|
20
|
-
setHeight(contentRef.current.scrollHeight);
|
|
21
|
-
}
|
|
22
|
-
}, [children]);
|
|
23
16
|
var toggleOpen = function () {
|
|
24
17
|
if (onToggle) {
|
|
25
18
|
onToggle();
|
|
@@ -35,7 +28,6 @@ export function Collapser(_a) {
|
|
|
35
28
|
]
|
|
36
29
|
.filter(Boolean)
|
|
37
30
|
.join(" ");
|
|
38
|
-
return (_jsxs("div", { className: collapserClasses, children: [_jsxs("button", { onClick: toggleOpen, type: "button", className: "dds-collapser-button", "aria-expanded": isOpen, children: [stepNumber !== undefined && (_jsxs("span", { className: "dds-collapser-step-number", children: [stepNumber, "."] })), icon && (_jsx("span", { className: "dds-collapser-header-icon", "aria-hidden": "true", children: icon })), _jsx("h5", { id: id, className: "dds-collapser-title", children: title }), _jsx("svg", { className: "dds-collapser-icon ".concat(isOpen ? "dds-collapser-icon-open" : ""), width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: _jsx("polyline", { points: "6 9 12 15 18 9" }) })] }), _jsx("div", { className: "dds-collapser-content-wrapper",
|
|
39
|
-
height: isOpen ? height : 0,
|
|
40
|
-
}, children: _jsx("div", { ref: contentRef, className: "dds-collapser-content", children: children }) })] }));
|
|
31
|
+
return (_jsxs("div", { className: collapserClasses, children: [_jsxs("button", { onClick: toggleOpen, type: "button", className: "dds-collapser-button", "aria-expanded": isOpen, children: [stepNumber !== undefined && (_jsxs("span", { className: "dds-collapser-step-number", children: [stepNumber, "."] })), icon && (_jsx("span", { className: "dds-collapser-header-icon", "aria-hidden": "true", children: icon })), _jsx("h5", { id: id, className: "dds-collapser-title", children: title }), _jsx("svg", { className: "dds-collapser-icon ".concat(isOpen ? "dds-collapser-icon-open" : ""), width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: _jsx("polyline", { points: "6 9 12 15 18 9" }) })] }), _jsx("div", { className: "dds-collapser-content-wrapper".concat(isOpen ? " dds-collapser-content-wrapper--open" : ""), children: _jsx("div", { className: "dds-collapser-content", children: children }) })] }));
|
|
41
32
|
}
|
|
33
|
+
Collapser.displayName = 'Collapser';
|
|
@@ -21,7 +21,6 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
|
21
21
|
};
|
|
22
22
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
23
23
|
import { useState, Children, cloneElement, isValidElement } from 'react';
|
|
24
|
-
import { Collapser } from './Collapser';
|
|
25
24
|
export var CollapserGroup = function (_a) {
|
|
26
25
|
var children = _a.children, _b = _a.spacing, spacing = _b === void 0 ? '0.5rem' : _b, _c = _a.allowMultiple, allowMultiple = _c === void 0 ? true : _c, defaultOpen = _a.defaultOpen, onChange = _a.onChange, _d = _a.className, className = _d === void 0 ? '' : _d, _e = _a.numbered, numbered = _e === void 0 ? false : _e;
|
|
27
26
|
var _f = useState(function () {
|
|
@@ -45,10 +44,11 @@ export var CollapserGroup = function (_a) {
|
|
|
45
44
|
});
|
|
46
45
|
};
|
|
47
46
|
return (_jsx("div", { className: "dds-collapser-group ".concat(className).trim(), style: { gap: spacing }, children: Children.map(children, function (child, index) {
|
|
47
|
+
var _a;
|
|
48
48
|
if (!isValidElement(child))
|
|
49
49
|
return child;
|
|
50
50
|
// Only inject props if child is a Collapser component
|
|
51
|
-
if (child.type === Collapser) {
|
|
51
|
+
if (((_a = child.type) === null || _a === void 0 ? void 0 : _a.displayName) === 'Collapser') {
|
|
52
52
|
return cloneElement(child, __assign(__assign(__assign({}, child.props), { open: openIndexes.includes(index), onToggle: function () { return handleToggle(index); } }), (numbered ? { stepNumber: index + 1 } : {})));
|
|
53
53
|
}
|
|
54
54
|
return child;
|
package/dist/styles.css
CHANGED
|
@@ -1270,10 +1270,15 @@ a.no-text-decoration {
|
|
|
1270
1270
|
transform: rotate(180deg);
|
|
1271
1271
|
}
|
|
1272
1272
|
.dds-collapser-content-wrapper {
|
|
1273
|
-
|
|
1274
|
-
|
|
1273
|
+
display: grid;
|
|
1274
|
+
grid-template-rows: 0fr;
|
|
1275
|
+
transition: grid-template-rows 0.3s ease;
|
|
1276
|
+
}
|
|
1277
|
+
.dds-collapser-content-wrapper--open {
|
|
1278
|
+
grid-template-rows: 1fr;
|
|
1275
1279
|
}
|
|
1276
1280
|
.dds-collapser-content {
|
|
1281
|
+
overflow: hidden;
|
|
1277
1282
|
border-top: 1px solid var(--dds-collapser-border);
|
|
1278
1283
|
padding: var(--dds-collapser-content-padding);
|
|
1279
1284
|
color: var(--dds-collapser-text);
|