shared-design-system 1.21.0 → 1.25.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.
- package/dist/src/components/Alert.d.ts +1 -1
- package/dist/src/components/Alert.js +34 -20
- package/dist/src/components/Alert.js.map +1 -1
- package/dist/src/components/Avatar.d.ts +7 -2
- package/dist/src/components/Avatar.js +15 -12
- package/dist/src/components/Avatar.js.map +1 -1
- package/dist/src/components/Badge.d.ts +1 -1
- package/dist/src/components/Badge.js +113 -89
- package/dist/src/components/Badge.js.map +1 -1
- package/dist/src/components/Breadcrumbs.d.ts +1 -1
- package/dist/src/components/Breadcrumbs.js +7 -9
- package/dist/src/components/Breadcrumbs.js.map +1 -1
- package/dist/src/components/Button.d.ts +2 -1
- package/dist/src/components/Button.js +6 -4
- package/dist/src/components/Button.js.map +1 -1
- package/dist/src/components/Card.d.ts +2 -0
- package/dist/src/components/Card.js +6 -6
- package/dist/src/components/Card.js.map +1 -1
- package/dist/src/components/ConfigProvider.d.ts +17 -0
- package/dist/src/components/ConfigProvider.js +54 -0
- package/dist/src/components/ConfigProvider.js.map +1 -0
- package/dist/src/components/ConfirmModal.d.ts +1 -1
- package/dist/src/components/ConfirmModal.js +82 -72
- package/dist/src/components/ConfirmModal.js.map +1 -1
- package/dist/src/components/DatePicker.d.ts +1 -1
- package/dist/src/components/DatePicker.js +33 -10
- package/dist/src/components/DatePicker.js.map +1 -1
- package/dist/src/components/Descriptions.d.ts +15 -0
- package/dist/src/components/Descriptions.js +44 -0
- package/dist/src/components/Descriptions.js.map +1 -0
- package/dist/src/components/Divider.d.ts +2 -1
- package/dist/src/components/Divider.js +23 -17
- package/dist/src/components/Divider.js.map +1 -1
- package/dist/src/components/Drawer.d.ts +1 -1
- package/dist/src/components/Drawer.js +81 -68
- package/dist/src/components/Drawer.js.map +1 -1
- package/dist/src/components/Dropdown.d.ts +17 -0
- package/dist/src/components/Dropdown.js +129 -0
- package/dist/src/components/Dropdown.js.map +1 -0
- package/dist/src/components/InputComponents.d.ts +4 -4
- package/dist/src/components/InputComponents.js +57 -26
- package/dist/src/components/InputComponents.js.map +1 -1
- package/dist/src/components/ListComponents.d.ts +4 -2
- package/dist/src/components/ListComponents.js +36 -15
- package/dist/src/components/ListComponents.js.map +1 -1
- package/dist/src/components/Modal.d.ts +1 -1
- package/dist/src/components/Modal.js +90 -77
- package/dist/src/components/Modal.js.map +1 -1
- package/dist/src/components/MultiSelect.d.ts +1 -1
- package/dist/src/components/MultiSelect.js +65 -20
- package/dist/src/components/MultiSelect.js.map +1 -1
- package/dist/src/components/Popconfirm.d.ts +12 -0
- package/dist/src/components/Popconfirm.js +24 -0
- package/dist/src/components/Popconfirm.js.map +1 -0
- package/dist/src/components/Popover.d.ts +10 -0
- package/dist/src/components/Popover.js +123 -0
- package/dist/src/components/Popover.js.map +1 -0
- package/dist/src/components/Portal.d.ts +11 -0
- package/dist/src/components/Portal.js +30 -0
- package/dist/src/components/Portal.js.map +1 -0
- package/dist/src/components/Radio.d.ts +14 -4
- package/dist/src/components/Radio.js +13 -7
- package/dist/src/components/Radio.js.map +1 -1
- package/dist/src/components/Result.d.ts +9 -0
- package/dist/src/components/Result.js +52 -0
- package/dist/src/components/Result.js.map +1 -0
- package/dist/src/components/Select.d.ts +1 -1
- package/dist/src/components/Select.js +70 -19
- package/dist/src/components/Select.js.map +1 -1
- package/dist/src/components/Skeleton.d.ts +1 -1
- package/dist/src/components/Skeleton.js +10 -7
- package/dist/src/components/Skeleton.js.map +1 -1
- package/dist/src/components/Steps.d.ts +2 -1
- package/dist/src/components/Steps.js +18 -15
- package/dist/src/components/Steps.js.map +1 -1
- package/dist/src/components/Switch.d.ts +1 -1
- package/dist/src/components/Switch.js +6 -6
- package/dist/src/components/Switch.js.map +1 -1
- package/dist/src/components/Table.d.ts +20 -7
- package/dist/src/components/Table.js +140 -113
- package/dist/src/components/Table.js.map +1 -1
- package/dist/src/components/Tabs.d.ts +4 -2
- package/dist/src/components/Tabs.js +15 -10
- package/dist/src/components/Tabs.js.map +1 -1
- package/dist/src/components/Tag.d.ts +3 -1
- package/dist/src/components/Tag.js +17 -8
- package/dist/src/components/Tag.js.map +1 -1
- package/dist/src/components/Timeline.d.ts +13 -0
- package/dist/src/components/Timeline.js +35 -0
- package/dist/src/components/Timeline.js.map +1 -0
- package/dist/src/components/Tooltip.d.ts +1 -1
- package/dist/src/components/Tooltip.js +17 -10
- package/dist/src/components/Tooltip.js.map +1 -1
- package/dist/src/components/Typography.d.ts +5 -5
- package/dist/src/components/Typography.js +38 -23
- package/dist/src/components/Typography.js.map +1 -1
- package/dist/src/index.d.ts +19 -4
- package/dist/src/index.js +12 -5
- package/dist/src/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -7,4 +7,4 @@ export interface AlertProps extends Omit<React.HTMLAttributes<HTMLDivElement>, '
|
|
|
7
7
|
onClose?: () => void;
|
|
8
8
|
action?: React.ReactNode;
|
|
9
9
|
}
|
|
10
|
-
export declare const Alert: React.
|
|
10
|
+
export declare const Alert: React.ForwardRefExoticComponent<AlertProps & React.RefAttributes<HTMLDivElement>>;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { useState } from 'react';
|
|
2
|
+
import React, { useState } from 'react';
|
|
3
3
|
import { tokens } from '../tokens';
|
|
4
4
|
const SEVERITY_CONFIG = {
|
|
5
5
|
success: {
|
|
@@ -41,7 +41,7 @@ const DEFAULT_ICONS = {
|
|
|
41
41
|
error: (_jsxs("svg", { width: "18", height: "18", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2.5, strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("circle", { cx: "12", cy: "12", r: "10" }), _jsx("line", { x1: "15", y1: "9", x2: "9", y2: "15" }), _jsx("line", { x1: "9", y1: "9", x2: "15", y2: "15" })] })),
|
|
42
42
|
info: (_jsxs("svg", { width: "18", height: "18", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2.5, strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("circle", { cx: "12", cy: "12", r: "10" }), _jsx("line", { x1: "12", y1: "16", x2: "12", y2: "12" }), _jsx("line", { x1: "12", y1: "8", x2: "12.01", y2: "8" })] })),
|
|
43
43
|
};
|
|
44
|
-
export const Alert = ({ severity = 'info', title, children, className = '', style = {}, variant = 'standard', icon, onClose, action, ...props }) => {
|
|
44
|
+
export const Alert = React.forwardRef(({ severity = 'info', title, children, className = '', style = {}, variant = 'standard', icon, onClose, action, ...props }, ref) => {
|
|
45
45
|
const [dismissed, setDismissed] = useState(false);
|
|
46
46
|
if (dismissed)
|
|
47
47
|
return null;
|
|
@@ -58,31 +58,44 @@ export const Alert = ({ severity = 'info', title, children, className = '', styl
|
|
|
58
58
|
position: 'relative',
|
|
59
59
|
overflow: 'hidden',
|
|
60
60
|
fontFamily: tokens.font.family,
|
|
61
|
-
...(isFilled
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
61
|
+
...(isFilled
|
|
62
|
+
? {
|
|
63
|
+
backgroundColor: s.filledBg,
|
|
64
|
+
color: '#fff',
|
|
65
|
+
border: 'none',
|
|
66
|
+
boxShadow: `0 4px 12px ${s.filledBg}40`,
|
|
67
|
+
}
|
|
68
|
+
: isOutlined
|
|
69
|
+
? {
|
|
70
|
+
backgroundColor: 'transparent',
|
|
71
|
+
color: s.darkText,
|
|
72
|
+
border: `1.5px solid ${s.accentBar}`,
|
|
73
|
+
}
|
|
74
|
+
: {
|
|
75
|
+
backgroundColor: s.bg,
|
|
76
|
+
color: s.darkText,
|
|
77
|
+
border: `1px solid ${s.border}`,
|
|
78
|
+
borderLeft: `4px solid ${s.accentBar}`,
|
|
79
|
+
}),
|
|
76
80
|
...style,
|
|
77
81
|
};
|
|
78
82
|
const iconColor = isFilled ? '#fff' : s.text;
|
|
79
83
|
const resolvedIcon = icon || DEFAULT_ICONS[severity];
|
|
80
|
-
return (_jsxs("div", { style: baseStyle, className: `ds-alert ds-alert--${severity} ds-alert--${variant} ${className}`, ...props, children: [_jsx("div", { style: {
|
|
84
|
+
return (_jsxs("div", { ref: ref, role: "alert", style: baseStyle, className: `ds-alert ds-alert--${severity} ds-alert--${variant} ${className}`, ...props, children: [_jsx("div", { style: {
|
|
85
|
+
color: iconColor,
|
|
86
|
+
flexShrink: 0,
|
|
87
|
+
marginTop: '2px',
|
|
88
|
+
display: 'flex',
|
|
89
|
+
alignItems: 'flex-start',
|
|
90
|
+
}, children: resolvedIcon }), _jsxs("div", { style: { flex: 1, minWidth: 0 }, children: [title && (_jsx("div", { style: {
|
|
81
91
|
fontWeight: tokens.font.weightBold,
|
|
82
92
|
marginBottom: children ? '3px' : 0,
|
|
83
93
|
fontSize: tokens.font.sm,
|
|
84
94
|
lineHeight: 1.4,
|
|
85
|
-
}, children: title })), children && (_jsx("div", { style: { opacity: isFilled ? 0.9 : 1, fontWeight: tokens.font.weightMedium }, children: children })), action &&
|
|
95
|
+
}, children: title })), children && (_jsx("div", { style: { opacity: isFilled ? 0.9 : 1, fontWeight: tokens.font.weightMedium }, children: children })), action && _jsx("div", { style: { marginTop: tokens.spacing['2'] }, children: action })] }), onClose && (_jsx("button", { type: "button", onClick: () => {
|
|
96
|
+
setDismissed(true);
|
|
97
|
+
onClose();
|
|
98
|
+
}, "aria-label": "Close alert", style: {
|
|
86
99
|
background: 'none',
|
|
87
100
|
border: 'none',
|
|
88
101
|
cursor: 'pointer',
|
|
@@ -96,5 +109,6 @@ export const Alert = ({ severity = 'info', title, children, className = '', styl
|
|
|
96
109
|
opacity: 0.65,
|
|
97
110
|
transition: tokens.transition.fast,
|
|
98
111
|
}, onMouseEnter: (e) => (e.currentTarget.style.opacity = '1'), onMouseLeave: (e) => (e.currentTarget.style.opacity = '0.65'), children: _jsx("svg", { width: "15", height: "15", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2.5, strokeLinecap: "round", children: _jsx("path", { d: "M18 6L6 18M6 6l12 12" }) }) }))] }));
|
|
99
|
-
};
|
|
112
|
+
});
|
|
113
|
+
Alert.displayName = 'Alert';
|
|
100
114
|
//# sourceMappingURL=Alert.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Alert.js","sourceRoot":"","sources":["../../../src/components/Alert.tsx"],"names":[],"mappings":";AAAA,
|
|
1
|
+
{"version":3,"file":"Alert.js","sourceRoot":"","sources":["../../../src/components/Alert.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAoBnC,MAAM,eAAe,GAAmC;IACtD,OAAO,EAAE;QACP,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS;QAC1B,MAAM,EAAE,uBAAuB;QAC/B,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO;QAC1B,QAAQ,EAAE,SAAS;QACnB,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO;QAC/B,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO;KAC/B;IACD,OAAO,EAAE;QACP,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS;QAC1B,MAAM,EAAE,wBAAwB;QAChC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO;QAC1B,QAAQ,EAAE,SAAS;QACnB,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO;QAC/B,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO;KAC/B;IACD,KAAK,EAAE;QACL,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,QAAQ;QACzB,MAAM,EAAE,wBAAwB;QAChC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM;QACzB,QAAQ,EAAE,SAAS;QACnB,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM;QAC9B,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM;KAC9B;IACD,IAAI,EAAE;QACJ,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM;QACvB,MAAM,EAAE,yBAAyB;QACjC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI;QACvB,QAAQ,EAAE,SAAS;QACnB,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI;QAC5B,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI;KAC5B;CACF,CAAC;AAEF,MAAM,aAAa,GAAoC;IACrD,OAAO,EAAE,CACP,eAAK,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAE,GAAG,EAAE,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,aAC9I,eAAM,CAAC,EAAC,mCAAmC,GAAG,EAC9C,mBAAU,MAAM,EAAC,uBAAuB,GAAG,IACvC,CACP;IACD,OAAO,EAAE,CACP,eAAK,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAE,GAAG,EAAE,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,aAC9I,eAAM,CAAC,EAAC,qFAAqF,GAAG,EAChG,eAAM,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,GAAG,EACvC,eAAM,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,OAAO,EAAC,EAAE,EAAC,IAAI,GAAG,IACvC,CACP;IACD,KAAK,EAAE,CACL,eAAK,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAE,GAAG,EAAE,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,aAC9I,iBAAQ,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,IAAI,GAAG,EACjC,eAAM,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,IAAI,GAAG,EACtC,eAAM,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,GAAG,IAClC,CACP;IACD,IAAI,EAAE,CACJ,eAAK,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAE,GAAG,EAAE,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,aAC9I,iBAAQ,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,IAAI,GAAG,EACjC,eAAM,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,GAAG,EACxC,eAAM,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,OAAO,EAAC,EAAE,EAAC,GAAG,GAAG,IACrC,CACP;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,KAAK,GAAG,KAAK,CAAC,UAAU,CACnC,CACE,EACE,QAAQ,GAAG,MAAM,EACjB,KAAK,EACL,QAAQ,EACR,SAAS,GAAG,EAAE,EACd,KAAK,GAAG,EAAE,EACV,OAAO,GAAG,UAAU,EACpB,IAAI,EACJ,OAAO,EACP,MAAM,EACN,GAAG,KAAK,EACT,EACD,GAAG,EACH,EAAE;IACF,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,IAAI,SAAS;QAAE,OAAO,IAAI,CAAC;IAE3B,MAAM,CAAC,GAAG,eAAe,CAAC,QAAQ,CAAC,IAAI,eAAe,CAAC,IAAI,CAAC;IAC5D,MAAM,QAAQ,GAAG,OAAO,KAAK,QAAQ,CAAC;IACtC,MAAM,UAAU,GAAG,OAAO,KAAK,UAAU,CAAC;IAE1C,MAAM,SAAS,GAAwB;QACrC,OAAO,EAAE,MAAM;QACf,GAAG,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC;QACxB,OAAO,EAAE,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QACxD,YAAY,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE;QAC9B,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE;QACxB,UAAU,EAAE,IAAI;QAChB,QAAQ,EAAE,UAAU;QACpB,QAAQ,EAAE,QAAQ;QAClB,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM;QAC9B,GAAG,CAAC,QAAQ;YACV,CAAC,CAAC;gBACE,eAAe,EAAE,CAAC,CAAC,QAAQ;gBAC3B,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,MAAM;gBACd,SAAS,EAAE,cAAc,CAAC,CAAC,QAAQ,IAAI;aACxC;YACH,CAAC,CAAC,UAAU;gBACZ,CAAC,CAAC;oBACE,eAAe,EAAE,aAAa;oBAC9B,KAAK,EAAE,CAAC,CAAC,QAAQ;oBACjB,MAAM,EAAE,eAAe,CAAC,CAAC,SAAS,EAAE;iBACrC;gBACH,CAAC,CAAC;oBACE,eAAe,EAAE,CAAC,CAAC,EAAE;oBACrB,KAAK,EAAE,CAAC,CAAC,QAAQ;oBACjB,MAAM,EAAE,aAAa,CAAC,CAAC,MAAM,EAAE;oBAC/B,UAAU,EAAE,aAAa,CAAC,CAAC,SAAS,EAAE;iBACvC,CAAC;QACN,GAAG,KAAK;KACT,CAAC;IAEF,MAAM,SAAS,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC7C,MAAM,YAAY,GAAG,IAAI,IAAI,aAAa,CAAC,QAAQ,CAAC,CAAC;IAErD,OAAO,CACL,eACE,GAAG,EAAE,GAAG,EACR,IAAI,EAAC,OAAO,EACZ,KAAK,EAAE,SAAS,EAChB,SAAS,EAAE,sBAAsB,QAAQ,cAAc,OAAO,IAAI,SAAS,EAAE,KACzE,KAAK,aAET,cACE,KAAK,EAAE;oBACL,KAAK,EAAE,SAAS;oBAChB,UAAU,EAAE,CAAC;oBACb,SAAS,EAAE,KAAK;oBAChB,OAAO,EAAE,MAAM;oBACf,UAAU,EAAE,YAAY;iBACzB,YAEA,YAAY,GACT,EACN,eAAK,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,aACjC,KAAK,IAAI,CACR,cACE,KAAK,EAAE;4BACL,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU;4BAClC,YAAY,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;4BAClC,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE;4BACxB,UAAU,EAAE,GAAG;yBAChB,YAEA,KAAK,GACF,CACP,EACA,QAAQ,IAAI,CACX,cAAK,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,YAC9E,QAAQ,GACL,CACP,EACA,MAAM,IAAI,cAAK,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,YAAG,MAAM,GAAO,IACrE,EACL,OAAO,IAAI,CACV,iBACE,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,GAAG,EAAE;oBACZ,YAAY,CAAC,IAAI,CAAC,CAAC;oBACnB,OAAO,EAAE,CAAC;gBACZ,CAAC,gBACU,aAAa,EACxB,KAAK,EAAE;oBACL,UAAU,EAAE,MAAM;oBAClB,MAAM,EAAE,MAAM;oBACd,MAAM,EAAE,SAAS;oBACjB,OAAO,EAAE,KAAK;oBACd,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ;oBACtD,OAAO,EAAE,MAAM;oBACf,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,QAAQ;oBACxB,YAAY,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE;oBAC9B,UAAU,EAAE,CAAC;oBACb,OAAO,EAAE,IAAI;oBACb,UAAU,EAAE,MAAM,CAAC,UAAU,CAAC,IAAI;iBACnC,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC,EAC1D,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,YAE7D,cACE,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,MAAM,EAAC,cAAc,EACrB,WAAW,EAAE,GAAG,EAChB,aAAa,EAAC,OAAO,YAErB,eAAM,CAAC,EAAC,sBAAsB,GAAG,GAC7B,GACC,CACV,IACG,CACP,CAAC;AACJ,CAAC,CACF,CAAC;AACF,KAAK,CAAC,WAAW,GAAG,OAAO,CAAC"}
|
|
@@ -9,10 +9,15 @@ export interface AvatarProps extends React.HTMLAttributes<HTMLElement> {
|
|
|
9
9
|
ring?: boolean;
|
|
10
10
|
ringColor?: string;
|
|
11
11
|
}
|
|
12
|
-
export
|
|
12
|
+
export interface AvatarComponent extends React.ForwardRefExoticComponent<AvatarProps & React.RefAttributes<HTMLDivElement>> {
|
|
13
|
+
Group: typeof AvatarGroup;
|
|
14
|
+
}
|
|
15
|
+
export declare const Avatar: AvatarComponent;
|
|
13
16
|
export interface AvatarGroupProps {
|
|
14
17
|
max?: number;
|
|
15
18
|
size?: AvatarProps['size'];
|
|
16
19
|
children: React.ReactElement<AvatarProps>[];
|
|
20
|
+
className?: string;
|
|
21
|
+
style?: React.CSSProperties;
|
|
17
22
|
}
|
|
18
|
-
export declare const AvatarGroup: React.
|
|
23
|
+
export declare const AvatarGroup: React.ForwardRefExoticComponent<AvatarGroupProps & React.RefAttributes<HTMLDivElement>>;
|
|
@@ -29,11 +29,9 @@ function getGradientForInitials(text) {
|
|
|
29
29
|
hash = text.charCodeAt(i) + ((hash << 5) - hash);
|
|
30
30
|
return GRADIENT_POOL[Math.abs(hash) % GRADIENT_POOL.length];
|
|
31
31
|
}
|
|
32
|
-
export const Avatar = ({ src, alt, children, size = 'md', variant = 'circle', status, initials, ring = false, ringColor, className = '', style = {}, ...props }) => {
|
|
32
|
+
export const Avatar = React.forwardRef(({ src, alt, children, size = 'md', variant = 'circle', status, initials, ring = false, ringColor, className = '', style = {}, ...props }, ref) => {
|
|
33
33
|
const dims = SIZE_MAP[size] || '40px';
|
|
34
|
-
const borderRadius = variant === 'circle' ? '50%' :
|
|
35
|
-
variant === 'rounded' ? tokens.radius.lg :
|
|
36
|
-
tokens.radius.md;
|
|
34
|
+
const borderRadius = variant === 'circle' ? '50%' : variant === 'rounded' ? tokens.radius.lg : tokens.radius.md;
|
|
37
35
|
const fallbackLabel = initials || (typeof children === 'string' ? children : undefined);
|
|
38
36
|
const gradientBg = fallbackLabel ? getGradientForInitials(fallbackLabel) : undefined;
|
|
39
37
|
const statusDotSize = size === 'xs' || size === 'sm' ? '8px' : '10px';
|
|
@@ -52,9 +50,11 @@ export const Avatar = ({ src, alt, children, size = 'md', variant = 'circle', st
|
|
|
52
50
|
display: 'flex',
|
|
53
51
|
alignItems: 'center',
|
|
54
52
|
justifyContent: 'center',
|
|
55
|
-
...(src
|
|
56
|
-
|
|
57
|
-
|
|
53
|
+
...(src
|
|
54
|
+
? {}
|
|
55
|
+
: {
|
|
56
|
+
background: gradientBg || tokens.color.slate100,
|
|
57
|
+
}),
|
|
58
58
|
color: '#fff',
|
|
59
59
|
fontSize: `calc(${dims} / 2.5)`,
|
|
60
60
|
fontWeight: tokens.font.weightBold,
|
|
@@ -77,14 +77,15 @@ export const Avatar = ({ src, alt, children, size = 'md', variant = 'circle', st
|
|
|
77
77
|
border: `2px solid ${tokens.color.white}`,
|
|
78
78
|
boxShadow: '0 1px 3px rgba(0,0,0,0.15)',
|
|
79
79
|
};
|
|
80
|
-
return (_jsxs("div", { style: containerStyle, className: `ds-avatar ${className}`, children: [src ? (_jsx("img", { src: src, alt: alt || 'Avatar', style: innerStyle, ...props })) : (_jsx("div", { style: innerStyle, ...props, children: fallbackLabel || children })), status && _jsx("div", { style: statusStyle })] }));
|
|
81
|
-
};
|
|
82
|
-
|
|
80
|
+
return (_jsxs("div", { ref: ref, style: containerStyle, className: `ds-avatar ds-avatar--${size} ${className}`, children: [src ? (_jsx("img", { src: src, alt: alt || 'Avatar', style: innerStyle, ...props })) : (_jsx("div", { style: innerStyle, ...props, children: fallbackLabel || children })), status && (_jsx("div", { style: statusStyle, "aria-label": `Status: ${status}`, role: "status", title: `Status: ${status}` }))] }));
|
|
81
|
+
});
|
|
82
|
+
Avatar.displayName = 'Avatar';
|
|
83
|
+
export const AvatarGroup = React.forwardRef(({ max = 4, size = 'md', children, className = '', style = {} }, ref) => {
|
|
83
84
|
const visible = children.slice(0, max);
|
|
84
85
|
const overflow = children.length - max;
|
|
85
86
|
const dims = SIZE_MAP[size] || '40px';
|
|
86
87
|
const offset = `calc(${dims} * -0.3)`;
|
|
87
|
-
return (_jsxs("div", { style: { display: 'flex', alignItems: 'center' }, children: [visible.map((child, i) => React.cloneElement(child, {
|
|
88
|
+
return (_jsxs("div", { ref: ref, role: "group", "aria-label": "Avatar group", style: { display: 'flex', alignItems: 'center', ...style }, className: `ds-avatar-group ${className}`, children: [visible.map((child, i) => React.cloneElement(child, {
|
|
88
89
|
key: i,
|
|
89
90
|
size,
|
|
90
91
|
ring: true,
|
|
@@ -104,5 +105,7 @@ export const AvatarGroup = ({ max = 4, size = 'md', children, }) => {
|
|
|
104
105
|
boxShadow: `0 0 0 2.5px ${tokens.color.surface}`,
|
|
105
106
|
userSelect: 'none',
|
|
106
107
|
}, children: ["+", overflow] }))] }));
|
|
107
|
-
};
|
|
108
|
+
});
|
|
109
|
+
AvatarGroup.displayName = 'Avatar.Group';
|
|
110
|
+
Avatar.Group = AvatarGroup;
|
|
108
111
|
//# sourceMappingURL=Avatar.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Avatar.js","sourceRoot":"","sources":["../../../src/components/Avatar.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAanC,MAAM,QAAQ,GAA2B;IACvC,EAAE,EAAG,MAAM;IACX,EAAE,EAAG,MAAM;IACX,EAAE,EAAG,MAAM;IACX,EAAE,EAAG,MAAM;IACX,EAAE,EAAG,MAAM;IACX,KAAK,EAAE,MAAM;CACd,CAAC;AAEF,MAAM,gBAAgB,GAA2B;IAC/C,MAAM,EAAG,MAAM,CAAC,KAAK,CAAC,OAAO;IAC7B,IAAI,EAAK,MAAM,CAAC,KAAK,CAAC,MAAM;IAC5B,IAAI,EAAK,MAAM,CAAC,KAAK,CAAC,OAAO;IAC7B,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,QAAQ;CAC/B,CAAC;AAEF,MAAM,aAAa,GAAG;IACpB,mDAAmD;IACnD,mDAAmD;IACnD,mDAAmD;IACnD,mDAAmD;IACnD,mDAAmD;IACnD,mDAAmD;CACpD,CAAC;AAEF,SAAS,sBAAsB,CAAC,IAAY;IAC1C,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE;QAAE,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;IACvF,OAAO,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;AAC9D,CAAC;
|
|
1
|
+
{"version":3,"file":"Avatar.js","sourceRoot":"","sources":["../../../src/components/Avatar.tsx"],"names":[],"mappings":"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"}
|
|
@@ -6,4 +6,4 @@ export interface BadgeProps extends React.HTMLAttributes<HTMLSpanElement> {
|
|
|
6
6
|
dot?: boolean;
|
|
7
7
|
icon?: React.ReactNode;
|
|
8
8
|
}
|
|
9
|
-
export declare const Badge: React.
|
|
9
|
+
export declare const Badge: React.ForwardRefExoticComponent<BadgeProps & React.RefAttributes<HTMLSpanElement>>;
|
|
@@ -1,107 +1,130 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
2
3
|
import { tokens } from '../tokens';
|
|
3
|
-
export const Badge = ({ children, variant = 'slate', type = 'subtle', size = 'md', dot = false, icon, className = '', style = {}, ...props }) => {
|
|
4
|
+
export const Badge = React.forwardRef(({ children, variant = 'slate', type = 'subtle', size = 'md', dot = false, icon, className = '', style = {}, ...props }, ref) => {
|
|
4
5
|
const getVariantStyles = () => {
|
|
5
6
|
const isSubtle = type === 'subtle';
|
|
6
7
|
const isOutline = type === 'outline';
|
|
7
8
|
switch (variant) {
|
|
8
9
|
case 'primary':
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
10
|
+
return isSubtle
|
|
11
|
+
? {
|
|
12
|
+
backgroundColor: tokens.color.primaryLight,
|
|
13
|
+
color: tokens.color.primary,
|
|
14
|
+
borderColor: 'rgba(190, 17, 40, 0.2)',
|
|
15
|
+
}
|
|
16
|
+
: isOutline
|
|
17
|
+
? {
|
|
18
|
+
backgroundColor: 'transparent',
|
|
19
|
+
color: tokens.color.primary,
|
|
20
|
+
borderColor: tokens.color.primary,
|
|
21
|
+
}
|
|
22
|
+
: {
|
|
23
|
+
backgroundColor: tokens.color.primary,
|
|
24
|
+
color: '#fff',
|
|
25
|
+
borderColor: 'transparent',
|
|
26
|
+
};
|
|
23
27
|
case 'success':
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
28
|
+
return isSubtle
|
|
29
|
+
? {
|
|
30
|
+
backgroundColor: tokens.color.successBg,
|
|
31
|
+
color: tokens.color.success,
|
|
32
|
+
borderColor: 'rgba(79, 168, 0, 0.2)',
|
|
33
|
+
}
|
|
34
|
+
: isOutline
|
|
35
|
+
? {
|
|
36
|
+
backgroundColor: 'transparent',
|
|
37
|
+
color: tokens.color.success,
|
|
38
|
+
borderColor: tokens.color.success,
|
|
39
|
+
}
|
|
40
|
+
: {
|
|
41
|
+
backgroundColor: tokens.color.success,
|
|
42
|
+
color: '#fff',
|
|
43
|
+
borderColor: 'transparent',
|
|
44
|
+
};
|
|
38
45
|
case 'warning':
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
46
|
+
return isSubtle
|
|
47
|
+
? {
|
|
48
|
+
backgroundColor: tokens.color.warningBg,
|
|
49
|
+
color: tokens.color.warning,
|
|
50
|
+
borderColor: 'rgba(245, 102, 0, 0.2)',
|
|
51
|
+
}
|
|
52
|
+
: isOutline
|
|
53
|
+
? {
|
|
54
|
+
backgroundColor: 'transparent',
|
|
55
|
+
color: tokens.color.warning,
|
|
56
|
+
borderColor: tokens.color.warning,
|
|
57
|
+
}
|
|
58
|
+
: {
|
|
59
|
+
backgroundColor: tokens.color.warning,
|
|
60
|
+
color: '#fff',
|
|
61
|
+
borderColor: 'transparent',
|
|
62
|
+
};
|
|
53
63
|
case 'danger':
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
64
|
+
return isSubtle
|
|
65
|
+
? {
|
|
66
|
+
backgroundColor: tokens.color.dangerBg,
|
|
67
|
+
color: tokens.color.danger,
|
|
68
|
+
borderColor: 'rgba(209, 36, 33, 0.2)',
|
|
69
|
+
}
|
|
70
|
+
: isOutline
|
|
71
|
+
? {
|
|
72
|
+
backgroundColor: 'transparent',
|
|
73
|
+
color: tokens.color.danger,
|
|
74
|
+
borderColor: tokens.color.danger,
|
|
75
|
+
}
|
|
76
|
+
: {
|
|
77
|
+
backgroundColor: tokens.color.danger,
|
|
78
|
+
color: '#fff',
|
|
79
|
+
borderColor: 'transparent',
|
|
80
|
+
};
|
|
68
81
|
case 'info':
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
82
|
+
return isSubtle
|
|
83
|
+
? {
|
|
84
|
+
backgroundColor: tokens.color.infoBg,
|
|
85
|
+
color: tokens.color.info,
|
|
86
|
+
borderColor: 'rgba(24, 144, 255, 0.2)',
|
|
87
|
+
}
|
|
88
|
+
: isOutline
|
|
89
|
+
? {
|
|
90
|
+
backgroundColor: 'transparent',
|
|
91
|
+
color: tokens.color.info,
|
|
92
|
+
borderColor: tokens.color.info,
|
|
93
|
+
}
|
|
94
|
+
: {
|
|
95
|
+
backgroundColor: tokens.color.info,
|
|
96
|
+
color: '#fff',
|
|
97
|
+
borderColor: 'transparent',
|
|
98
|
+
};
|
|
83
99
|
case 'slate':
|
|
84
100
|
default:
|
|
85
|
-
return isSubtle
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
101
|
+
return isSubtle
|
|
102
|
+
? {
|
|
103
|
+
backgroundColor: tokens.color.slate100,
|
|
104
|
+
color: tokens.color.slate600,
|
|
105
|
+
borderColor: tokens.color.slate200,
|
|
106
|
+
}
|
|
107
|
+
: isOutline
|
|
108
|
+
? {
|
|
109
|
+
backgroundColor: 'transparent',
|
|
110
|
+
color: tokens.color.slate600,
|
|
111
|
+
borderColor: tokens.color.slate400,
|
|
112
|
+
}
|
|
113
|
+
: {
|
|
114
|
+
backgroundColor: tokens.color.slate700,
|
|
115
|
+
color: '#fff',
|
|
116
|
+
borderColor: 'transparent',
|
|
117
|
+
};
|
|
98
118
|
}
|
|
99
119
|
};
|
|
100
120
|
const getSizeStyles = () => {
|
|
101
121
|
switch (size) {
|
|
102
|
-
case 'sm':
|
|
103
|
-
|
|
104
|
-
|
|
122
|
+
case 'sm':
|
|
123
|
+
return { padding: '1px 7px', fontSize: '10px', gap: '4px' };
|
|
124
|
+
case 'lg':
|
|
125
|
+
return { padding: '4px 14px', fontSize: '12px', gap: '6px' };
|
|
126
|
+
default:
|
|
127
|
+
return { padding: '2px 10px', fontSize: '11px', gap: '5px' };
|
|
105
128
|
}
|
|
106
129
|
};
|
|
107
130
|
const baseStyle = {
|
|
@@ -121,12 +144,13 @@ export const Badge = ({ children, variant = 'slate', type = 'subtle', size = 'md
|
|
|
121
144
|
...getVariantStyles(),
|
|
122
145
|
...style,
|
|
123
146
|
};
|
|
124
|
-
return (_jsxs("span", { style: baseStyle, className: `ds-badge ${className}`, ...props, children: [dot && (_jsx("span", { style: {
|
|
147
|
+
return (_jsxs("span", { ref: ref, style: baseStyle, className: `ds-badge ${className}`, ...props, children: [dot && (_jsx("span", { style: {
|
|
125
148
|
width: '6px',
|
|
126
149
|
height: '6px',
|
|
127
150
|
borderRadius: '50%',
|
|
128
151
|
backgroundColor: 'currentColor',
|
|
129
152
|
flexShrink: 0,
|
|
130
153
|
} })), icon && _jsx("span", { style: { display: 'inline-flex', alignItems: 'center', flexShrink: 0 }, children: icon }), children] }));
|
|
131
|
-
};
|
|
154
|
+
});
|
|
155
|
+
Badge.displayName = 'Badge';
|
|
132
156
|
//# sourceMappingURL=Badge.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Badge.js","sourceRoot":"","sources":["../../../src/components/Badge.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"Badge.js","sourceRoot":"","sources":["../../../src/components/Badge.tsx"],"names":[],"mappings":"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"}
|
|
@@ -10,4 +10,4 @@ export interface BreadcrumbsProps extends React.HTMLAttributes<HTMLElement> {
|
|
|
10
10
|
size?: 'sm' | 'md';
|
|
11
11
|
maxItems?: number;
|
|
12
12
|
}
|
|
13
|
-
export declare const Breadcrumbs: React.
|
|
13
|
+
export declare const Breadcrumbs: React.ForwardRefExoticComponent<BreadcrumbsProps & React.RefAttributes<HTMLElement>>;
|
|
@@ -1,20 +1,17 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
2
3
|
import { tokens } from '../tokens';
|
|
3
4
|
const ChevronSeparator = () => (_jsx("svg", { width: "14", height: "14", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2.5, strokeLinecap: "round", strokeLinejoin: "round", style: { opacity: 0.35, flexShrink: 0 }, children: _jsx("polyline", { points: "9 18 15 12 9 6" }) }));
|
|
4
|
-
export const Breadcrumbs = ({ items = [], separator, size = 'sm', maxItems, className = '', style = {},
|
|
5
|
+
export const Breadcrumbs = React.forwardRef(({ items = [], separator, size = 'sm', maxItems, className = '', style = {} }, ref) => {
|
|
5
6
|
const fontSize = size === 'sm' ? tokens.font.xs : tokens.font.sm;
|
|
6
7
|
const resolvedSeparator = separator || _jsx(ChevronSeparator, {});
|
|
7
8
|
let displayItems = items;
|
|
8
9
|
if (maxItems && items.length > maxItems) {
|
|
9
10
|
const front = items.slice(0, 1);
|
|
10
11
|
const back = items.slice(-Math.max(1, maxItems - 2));
|
|
11
|
-
displayItems = [
|
|
12
|
-
...front,
|
|
13
|
-
{ label: '…' },
|
|
14
|
-
...back,
|
|
15
|
-
];
|
|
12
|
+
displayItems = [...front, { label: '…' }, ...back];
|
|
16
13
|
}
|
|
17
|
-
return (_jsx("nav", { "aria-label": "Breadcrumb", className: `ds-breadcrumbs ${className}`, children: _jsx("ol", { style: {
|
|
14
|
+
return (_jsx("nav", { ref: ref, "aria-label": "Breadcrumb", className: `ds-breadcrumbs ${className}`, children: _jsx("ol", { style: {
|
|
18
15
|
display: 'flex',
|
|
19
16
|
alignItems: 'center',
|
|
20
17
|
gap: tokens.spacing[1],
|
|
@@ -54,7 +51,8 @@ export const Breadcrumbs = ({ items = [], separator, size = 'sm', maxItems, clas
|
|
|
54
51
|
}, onMouseLeave: (e) => {
|
|
55
52
|
if (item.onClick)
|
|
56
53
|
e.currentTarget.style.color = '';
|
|
57
|
-
}, children: [item.icon && _jsx("span", { style: { display: 'inline-flex', flexShrink: 0 }, children: item.icon }), item.label] }), _jsx("span", { style: { display: 'inline-flex', alignItems: 'center' }, children: resolvedSeparator })] })) }, index));
|
|
54
|
+
}, children: [item.icon && (_jsx("span", { style: { display: 'inline-flex', flexShrink: 0 }, children: item.icon })), item.label] }), _jsx("span", { "aria-hidden": "true", style: { display: 'inline-flex', alignItems: 'center' }, children: resolvedSeparator })] })) }, index));
|
|
58
55
|
}) }) }));
|
|
59
|
-
};
|
|
56
|
+
});
|
|
57
|
+
Breadcrumbs.displayName = 'Breadcrumbs';
|
|
60
58
|
//# sourceMappingURL=Breadcrumbs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Breadcrumbs.js","sourceRoot":"","sources":["../../../src/components/Breadcrumbs.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"Breadcrumbs.js","sourceRoot":"","sources":["../../../src/components/Breadcrumbs.tsx"],"names":[],"mappings":"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"}
|
|
@@ -5,7 +5,8 @@ export interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElemen
|
|
|
5
5
|
isActive?: boolean;
|
|
6
6
|
startIcon?: React.ReactNode;
|
|
7
7
|
endIcon?: React.ReactNode;
|
|
8
|
+
icon?: React.ReactNode;
|
|
8
9
|
loading?: boolean;
|
|
9
10
|
fullWidth?: boolean;
|
|
10
11
|
}
|
|
11
|
-
export declare const Button: React.
|
|
12
|
+
export declare const Button: React.ForwardRefExoticComponent<ButtonProps & React.RefAttributes<HTMLButtonElement>>;
|
|
@@ -84,7 +84,7 @@ const SIZE_STYLES = {
|
|
|
84
84
|
lg: { padding: `${tokens.spacing[3]} ${tokens.spacing[8]}`, fontSize: tokens.font.md, height: '48px', borderRadius: tokens.radius.xl },
|
|
85
85
|
};
|
|
86
86
|
const SpinnerInline = ({ color }) => (_jsxs("svg", { width: "14", height: "14", viewBox: "0 0 50 50", style: { animation: 'ds-spin 0.7s linear infinite', flexShrink: 0 }, children: [_jsx("circle", { cx: "25", cy: "25", r: "20", fill: "none", stroke: color, strokeWidth: "5", strokeDasharray: "80,150", strokeLinecap: "round" }), _jsx("style", { children: `@keyframes ds-spin { to { transform: rotate(360deg); }}` })] }));
|
|
87
|
-
export const Button = ({ children, variant = 'primary', size = 'md', disabled = false, loading = false, fullWidth = false, onClick, style = {}, className = '', isActive = false, startIcon, endIcon, ...props }) => {
|
|
87
|
+
export const Button = React.forwardRef(({ children, variant = 'primary', size = 'md', disabled = false, loading = false, fullWidth = false, onClick, style = {}, className = '', isActive = false, startIcon, endIcon, icon, ...props }, ref) => {
|
|
88
88
|
const [isHovered, setIsHovered] = React.useState(false);
|
|
89
89
|
const vs = VARIANT_STYLES[variant] || VARIANT_STYLES.primary;
|
|
90
90
|
const ss = SIZE_STYLES[size] || SIZE_STYLES.md;
|
|
@@ -105,7 +105,7 @@ export const Button = ({ children, variant = 'primary', size = 'md', disabled =
|
|
|
105
105
|
outline: 'none',
|
|
106
106
|
userSelect: 'none',
|
|
107
107
|
opacity: isEffectivelyDisabled ? 0.5 : 1,
|
|
108
|
-
backgroundColor: isPrimaryHover ? 'transparent' :
|
|
108
|
+
backgroundColor: isPrimaryHover ? 'transparent' : showHover ? vs.hoverBg : vs.bg,
|
|
109
109
|
backgroundImage: isPrimaryHover ? vs.gradient : 'none',
|
|
110
110
|
color: showHover ? vs.hoverColor : vs.color,
|
|
111
111
|
border: showHover ? vs.hoverBorder : vs.border,
|
|
@@ -113,8 +113,10 @@ export const Button = ({ children, variant = 'primary', size = 'md', disabled =
|
|
|
113
113
|
transform: showHover && !isEffectivelyDisabled ? 'translateY(-1px)' : 'translateY(0)',
|
|
114
114
|
whiteSpace: 'nowrap',
|
|
115
115
|
letterSpacing: '0.01em',
|
|
116
|
+
position: 'relative',
|
|
116
117
|
...style,
|
|
117
118
|
};
|
|
118
|
-
return (_jsxs("button", { style: baseStyle, className: `ds-button ds-button--${variant} ds-button--${size} ${className}`, disabled: isEffectivelyDisabled, onClick: isEffectivelyDisabled ? undefined : onClick, onMouseEnter: () => !isEffectivelyDisabled && setIsHovered(true), onMouseLeave: () => !isEffectivelyDisabled && setIsHovered(false), ...props, children: [loading ? (_jsx(SpinnerInline, { color: showHover ? vs.hoverColor : vs.color })) : (startIcon && _jsx("span", { style: { display: 'flex', alignItems: 'center', flexShrink: 0 }, children: startIcon })), children, !loading && endIcon && (_jsx("span", { style: { display: 'flex', alignItems: 'center', flexShrink: 0 }, children: endIcon }))] }));
|
|
119
|
-
};
|
|
119
|
+
return (_jsxs("button", { ref: ref, style: baseStyle, className: `ds-button ds-button--${variant} ds-button--${size} ${className}`, disabled: isEffectivelyDisabled, onClick: isEffectivelyDisabled ? undefined : onClick, onMouseEnter: () => !isEffectivelyDisabled && setIsHovered(true), onMouseLeave: () => !isEffectivelyDisabled && setIsHovered(false), "aria-busy": loading, "aria-disabled": isEffectivelyDisabled, ...props, children: [loading ? (_jsx(SpinnerInline, { color: showHover ? vs.hoverColor : vs.color })) : ((startIcon || icon) && _jsx("span", { style: { display: 'flex', alignItems: 'center', flexShrink: 0 }, children: startIcon || icon })), _jsx("span", { style: { opacity: loading ? 0 : 1, display: 'inline-flex', alignItems: 'center', gap: tokens.spacing[2] }, children: children }), !loading && endIcon && (_jsx("span", { style: { display: 'flex', alignItems: 'center', flexShrink: 0 }, children: endIcon }))] }));
|
|
120
|
+
});
|
|
121
|
+
Button.displayName = 'Button';
|
|
120
122
|
//# sourceMappingURL=Button.js.map
|