@stack-spot/portal-layout 0.0.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.
Files changed (110) hide show
  1. package/dist/Layout.d.ts +22 -0
  2. package/dist/Layout.d.ts.map +1 -0
  3. package/dist/Layout.js +21 -0
  4. package/dist/Layout.js.map +1 -0
  5. package/dist/LayoutOverlayManager.d.ts +32 -0
  6. package/dist/LayoutOverlayManager.d.ts.map +1 -0
  7. package/dist/LayoutOverlayManager.js +154 -0
  8. package/dist/LayoutOverlayManager.js.map +1 -0
  9. package/dist/components/BottomNotification.d.ts +1 -0
  10. package/dist/components/BottomNotification.d.ts.map +1 -0
  11. package/dist/components/BottomNotification.js +2 -0
  12. package/dist/components/BottomNotification.js.map +1 -0
  13. package/dist/components/BottomPanel.d.ts +1 -0
  14. package/dist/components/BottomPanel.d.ts.map +1 -0
  15. package/dist/components/BottomPanel.js +2 -0
  16. package/dist/components/BottomPanel.js.map +1 -0
  17. package/dist/components/Dialog.d.ts +21 -0
  18. package/dist/components/Dialog.d.ts.map +1 -0
  19. package/dist/components/Dialog.js +19 -0
  20. package/dist/components/Dialog.js.map +1 -0
  21. package/dist/components/Header.d.ts +12 -0
  22. package/dist/components/Header.d.ts.map +1 -0
  23. package/dist/components/Header.js +6 -0
  24. package/dist/components/Header.js.map +1 -0
  25. package/dist/components/Logo.d.ts +2 -0
  26. package/dist/components/Logo.d.ts.map +1 -0
  27. package/dist/components/Logo.js +4 -0
  28. package/dist/components/Logo.js.map +1 -0
  29. package/dist/components/Menu/MenuContent.d.ts +3 -0
  30. package/dist/components/Menu/MenuContent.d.ts.map +1 -0
  31. package/dist/components/Menu/MenuContent.js +126 -0
  32. package/dist/components/Menu/MenuContent.js.map +1 -0
  33. package/dist/components/Menu/MenuSections.d.ts +3 -0
  34. package/dist/components/Menu/MenuSections.d.ts.map +1 -0
  35. package/dist/components/Menu/MenuSections.js +70 -0
  36. package/dist/components/Menu/MenuSections.js.map +1 -0
  37. package/dist/components/Menu/PageSelector.d.ts +3 -0
  38. package/dist/components/Menu/PageSelector.d.ts.map +1 -0
  39. package/dist/components/Menu/PageSelector.js +87 -0
  40. package/dist/components/Menu/PageSelector.js.map +1 -0
  41. package/dist/components/Menu/constants.d.ts +3 -0
  42. package/dist/components/Menu/constants.d.ts.map +1 -0
  43. package/dist/components/Menu/constants.js +3 -0
  44. package/dist/components/Menu/constants.js.map +1 -0
  45. package/dist/components/Menu/types.d.ts +45 -0
  46. package/dist/components/Menu/types.d.ts.map +1 -0
  47. package/dist/components/Menu/types.js +2 -0
  48. package/dist/components/Menu/types.js.map +1 -0
  49. package/dist/components/OverlayContent.d.ts +15 -0
  50. package/dist/components/OverlayContent.d.ts.map +1 -0
  51. package/dist/components/OverlayContent.js +26 -0
  52. package/dist/components/OverlayContent.js.map +1 -0
  53. package/dist/components/SelectionList.d.ts +34 -0
  54. package/dist/components/SelectionList.d.ts.map +1 -0
  55. package/dist/components/SelectionList.js +104 -0
  56. package/dist/components/SelectionList.js.map +1 -0
  57. package/dist/components/Toaster.d.ts +3 -0
  58. package/dist/components/Toaster.d.ts.map +1 -0
  59. package/dist/components/Toaster.js +8 -0
  60. package/dist/components/Toaster.js.map +1 -0
  61. package/dist/components/UserMenu.d.ts +9 -0
  62. package/dist/components/UserMenu.d.ts.map +1 -0
  63. package/dist/components/UserMenu.js +57 -0
  64. package/dist/components/UserMenu.js.map +1 -0
  65. package/dist/components/types.d.ts +6 -0
  66. package/dist/components/types.d.ts.map +1 -0
  67. package/dist/components/types.js +2 -0
  68. package/dist/components/types.js.map +1 -0
  69. package/dist/errors.d.ts +7 -0
  70. package/dist/errors.d.ts.map +1 -0
  71. package/dist/errors.js +11 -0
  72. package/dist/errors.js.map +1 -0
  73. package/dist/index.d.ts +11 -0
  74. package/dist/index.d.ts.map +1 -0
  75. package/dist/index.js +11 -0
  76. package/dist/index.js.map +1 -0
  77. package/dist/layout.css +383 -0
  78. package/dist/toaster.d.ts +23 -0
  79. package/dist/toaster.d.ts.map +1 -0
  80. package/dist/toaster.js +41 -0
  81. package/dist/toaster.js.map +1 -0
  82. package/dist/utils.d.ts +2 -0
  83. package/dist/utils.d.ts.map +1 -0
  84. package/dist/utils.js +8 -0
  85. package/dist/utils.js.map +1 -0
  86. package/package.json +39 -0
  87. package/src/Layout.tsx +68 -0
  88. package/src/LayoutOverlayManager.tsx +180 -0
  89. package/src/citric.fix.d.ts +7 -0
  90. package/src/components/BottomNotification.tsx +0 -0
  91. package/src/components/BottomPanel.tsx +0 -0
  92. package/src/components/Dialog.tsx +55 -0
  93. package/src/components/Header.tsx +23 -0
  94. package/src/components/Logo.tsx +35 -0
  95. package/src/components/Menu/MenuContent.tsx +179 -0
  96. package/src/components/Menu/MenuSections.tsx +105 -0
  97. package/src/components/Menu/PageSelector.tsx +108 -0
  98. package/src/components/Menu/constants.ts +2 -0
  99. package/src/components/Menu/types.ts +53 -0
  100. package/src/components/OverlayContent.tsx +50 -0
  101. package/src/components/SelectionList.tsx +200 -0
  102. package/src/components/Toaster.tsx +12 -0
  103. package/src/components/UserMenu.tsx +91 -0
  104. package/src/components/types.ts +5 -0
  105. package/src/errors.ts +11 -0
  106. package/src/index.ts +10 -0
  107. package/src/layout.css +383 -0
  108. package/src/toaster.tsx +72 -0
  109. package/src/utils.ts +7 -0
  110. package/tsconfig.json +8 -0
@@ -0,0 +1,70 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ /* eslint-disable @typescript-eslint/no-unused-vars */
3
+ import { IconBox, Text } from '@citric/core';
4
+ import { ChevronLeft, Menu as MenuIcon } from '@citric/icons';
5
+ import { useCallback, useMemo, useState } from 'react';
6
+ import { MenuContent } from './MenuContent';
7
+ const ARROW_HEIGHT = 24;
8
+ const HIDE_OVERLAY_DELAY_MS = 400;
9
+ const MENU_OVERLAY_ID = 'menuContentOverlay';
10
+ let hideOverlayTask;
11
+ function hideOverlay() {
12
+ if (hideOverlayTask !== undefined)
13
+ return;
14
+ hideOverlayTask = window.setTimeout(hideOverlayImmediately, HIDE_OVERLAY_DELAY_MS);
15
+ }
16
+ function hideOverlayImmediately() {
17
+ document.getElementById(MENU_OVERLAY_ID)?.classList.remove('visible');
18
+ }
19
+ function cancelHideOverlayTask() {
20
+ if (hideOverlayTask === undefined)
21
+ return;
22
+ clearTimeout(hideOverlayTask);
23
+ hideOverlayTask = undefined;
24
+ }
25
+ function showOverlay() {
26
+ cancelHideOverlayTask();
27
+ document.getElementById(MENU_OVERLAY_ID)?.classList.add('visible');
28
+ }
29
+ function isMenuContentVisible() {
30
+ return !!document.getElementById('layout')?.classList?.contains('menu-content-visible');
31
+ }
32
+ function renderSection({ icon, label, href, onClick, active, content }, setOverlayContent) {
33
+ function shouldShowOverlay() {
34
+ return !!content && (!active || !isMenuContentVisible());
35
+ }
36
+ function showOverlayAndFixArrowPosition(event) {
37
+ if (!shouldShowOverlay())
38
+ return;
39
+ const rect = event.target?.getBoundingClientRect();
40
+ const arrow = document.querySelector(`#${MENU_OVERLAY_ID} .arrow`);
41
+ setOverlayContent(content);
42
+ showOverlay();
43
+ if (rect && arrow) {
44
+ arrow.style.top = `${rect.top + rect.height / 2 - ARROW_HEIGHT / 2}px`;
45
+ }
46
+ }
47
+ function click() {
48
+ if (onClick)
49
+ onClick();
50
+ hideOverlayImmediately();
51
+ }
52
+ return (_jsx("li", { title: label, className: active ? 'active' : undefined, children: _jsxs("a", { href: href, onClick: click, onMouseEnter: showOverlayAndFixArrowPosition, onMouseLeave: () => shouldShowOverlay() && hideOverlay(), children: [icon, _jsx(Text, { appearance: "microtext1", className: "section-label", children: label })] }) }, label));
53
+ }
54
+ export const MenuSections = ({ sections }) => {
55
+ const toggleMenu = useCallback(() => {
56
+ const layout = document.getElementById('layout');
57
+ if (!layout)
58
+ return;
59
+ if (layout.classList.contains('menu-content-visible')) {
60
+ layout.classList.remove('menu-content-visible');
61
+ }
62
+ else {
63
+ layout.classList.add('menu-content-visible');
64
+ }
65
+ }, []);
66
+ const [overlayContent, setOverlayContent] = useState();
67
+ const sectionItems = useMemo(() => sections.map(s => renderSection(s, setOverlayContent)), [sections]);
68
+ return (_jsxs(_Fragment, { children: [_jsx("ul", { children: sectionItems }), _jsx("button", { className: "toggle", onClick: toggleMenu, title: "Toggle menu panel visibility", children: _jsxs(IconBox, { children: [_jsx(MenuIcon, { className: "expand" }), _jsx(ChevronLeft, { className: "collapse" })] }) }), _jsxs("div", { id: "menuContentOverlay", onMouseEnter: showOverlay, onMouseLeave: hideOverlay, children: [overlayContent && _jsx("div", { children: _jsx(MenuContent, { ...overlayContent }) }), _jsx("div", { className: "arrow" })] })] }));
69
+ };
70
+ //# sourceMappingURL=MenuSections.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MenuSections.js","sourceRoot":"","sources":["../../../src/components/Menu/MenuSections.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Selector } from './types';
2
+ export declare const PageSelector: ({ options, value, button }: Selector) => import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=PageSelector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PageSelector.d.ts","sourceRoot":"","sources":["../../../src/components/Menu/PageSelector.tsx"],"names":[],"mappings":"AAOA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAkElC,eAAO,MAAM,YAAY,+BAAgC,QAAQ,4CAkChE,CAAA"}
@@ -0,0 +1,87 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { IconBox, Text } from '@citric/core';
3
+ import { ArrowRight, Select } from '@citric/icons';
4
+ import { theme } from '@stack-spot/portal-theme';
5
+ import { useMemo, useState } from 'react';
6
+ import { styled } from 'styled-components';
7
+ import { SelectionList } from '../SelectionList';
8
+ import { MENU_CONTENT_PADDING as PADDING } from './constants';
9
+ const SelectorBox = styled.div `
10
+ position: relative;
11
+ margin: ${PADDING}px;
12
+ margin-bottom: 28px;
13
+
14
+ > a {
15
+ display: flex;
16
+ gap: 8px;
17
+ align-items: center;
18
+ border-radius: 0.25rem;
19
+ border: 1px solid ${theme.color.light['500']};
20
+ padding: 8px;
21
+ transition: background-color 0.2s;
22
+
23
+ &:hover {
24
+ background-color: ${theme.color.light['500']};
25
+ }
26
+
27
+ .label {
28
+ flex: 1;
29
+ }
30
+ }
31
+
32
+ .selection-list {
33
+ position: absolute;
34
+ top: 0;
35
+ left: 0;
36
+ right: 0;
37
+ box-shadow: none;
38
+ border-radius: 0.25rem;
39
+
40
+ .selection-list-content {
41
+ padding: 8px;
42
+ border-radius: 0.25rem;
43
+ border: none;
44
+ ul {
45
+ display: flex;
46
+ flex-direction: column;
47
+ gap: 8px;
48
+ }
49
+ }
50
+
51
+ li > a {
52
+ border: 1px solid ${theme.color.light['500']};
53
+ background-color: ${theme.color.light['400']};
54
+
55
+ &:hover {
56
+ background-color: ${theme.color.light['500']};
57
+ }
58
+ }
59
+
60
+ .view-all {
61
+ background: ${theme.color.light['500']};
62
+ border-radius: 0.25rem;
63
+ outline: none;
64
+ height: 40px;
65
+ display: flex;
66
+ align-items: center;
67
+ justify-content: center;
68
+ margin-top: 8px;
69
+ }
70
+ }
71
+ `;
72
+ export const PageSelector = ({ options, value, button }) => {
73
+ const [visible, setVisible] = useState(false);
74
+ const { optionsWithIcon, selected } = useMemo(() => {
75
+ let selected = options[0];
76
+ const optionsWithIcon = options.map((option) => {
77
+ if (option.key === value) {
78
+ selected = option;
79
+ return { ...option, active: true };
80
+ }
81
+ return { ...option, iconRight: _jsx(ArrowRight, {}) };
82
+ });
83
+ return { optionsWithIcon, selected };
84
+ }, [options, value, button]);
85
+ return (_jsxs(SelectorBox, { children: [_jsxs("a", { onClick: () => setVisible(true), "aria-label": value, children: [selected?.icon && _jsx(IconBox, { children: selected?.icon }), _jsx(Text, { appearance: "body2", className: "label", children: selected?.label ?? button?.label ?? value }), _jsx(IconBox, { size: "xs", children: _jsx(Select, {}) })] }), _jsx(SelectionList, { visible: visible, items: optionsWithIcon, onHide: () => setVisible(false), after: button ? _jsx("a", { className: "view-all", href: button.href, onClick: button.onClick, children: button.label }) : undefined })] }));
86
+ };
87
+ //# sourceMappingURL=PageSelector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PageSelector.js","sourceRoot":"","sources":["../../../src/components/Menu/PageSelector.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export declare const MENU_CONTENT_PADDING = 20;
2
+ export declare const MENU_CONTENT_ITEM_PADDING = 12;
3
+ //# sourceMappingURL=constants.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/components/Menu/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,oBAAoB,KAAK,CAAA;AACtC,eAAO,MAAM,yBAAyB,KAAK,CAAA"}
@@ -0,0 +1,3 @@
1
+ export const MENU_CONTENT_PADDING = 20;
2
+ export const MENU_CONTENT_ITEM_PADDING = 12;
3
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/components/Menu/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,oBAAoB,GAAG,EAAE,CAAA;AACtC,MAAM,CAAC,MAAM,yBAAyB,GAAG,EAAE,CAAA"}
@@ -0,0 +1,45 @@
1
+ import { ReactElement } from 'react';
2
+ import { Action } from '../types';
3
+ export interface ItemGroup {
4
+ label: string;
5
+ children: MenuItem[];
6
+ open?: boolean;
7
+ hidden?: boolean;
8
+ }
9
+ export interface MenuAction extends Action {
10
+ active?: boolean;
11
+ hidden?: boolean;
12
+ }
13
+ export type MenuItem = ItemGroup | MenuAction;
14
+ export interface MenuButton extends Action {
15
+ icon?: ReactElement;
16
+ }
17
+ export interface SelectorItem extends Action {
18
+ key: string;
19
+ icon?: ReactElement;
20
+ }
21
+ export interface Selector {
22
+ value?: string;
23
+ options: SelectorItem[];
24
+ button?: Action;
25
+ title?: string;
26
+ subtitle?: string;
27
+ }
28
+ export interface MenuSectionContent {
29
+ goBack?: Action;
30
+ title?: string;
31
+ subtitle?: string;
32
+ pageSelector?: Selector;
33
+ options?: MenuItem[];
34
+ }
35
+ export interface MenuSection extends Action {
36
+ icon: ReactElement;
37
+ content?: MenuSectionContent;
38
+ active?: boolean;
39
+ }
40
+ export interface MenuProps {
41
+ sections: MenuSection[];
42
+ content?: MenuSectionContent;
43
+ compact?: boolean;
44
+ }
45
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/components/Menu/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,OAAO,CAAA;AACpC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AAEjC,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,QAAQ,EAAE,CAAC;IACrB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,UAAW,SAAQ,MAAM;IACxC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,MAAM,QAAQ,GAAG,SAAS,GAAG,UAAU,CAAA;AAE7C,MAAM,WAAW,UAAW,SAAQ,MAAM;IACxC,IAAI,CAAC,EAAE,YAAY,CAAC;CACrB;AAED,MAAM,WAAW,YAAa,SAAQ,MAAM;IAC1C,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,CAAC,EAAE,YAAY,CAAC;CACrB;AAED,MAAM,WAAW,QAAQ;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,YAAY,EAAE,CAAC;IACxB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,QAAQ,CAAC;IACxB,OAAO,CAAC,EAAE,QAAQ,EAAE,CAAC;CACtB;AAED,MAAM,WAAW,WAAY,SAAQ,MAAM;IACzC,IAAI,EAAE,YAAY,CAAC;IACnB,OAAO,CAAC,EAAE,kBAAkB,CAAC;IAC7B,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,SAAS;IACxB,QAAQ,EAAE,WAAW,EAAE,CAAC;IACxB,OAAO,CAAC,EAAE,kBAAkB,CAAC;IAC7B,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/components/Menu/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,15 @@
1
+ import { WithStyle } from '@stack-spot/portal-theme';
2
+ import { ReactNode } from 'react';
3
+ export interface OverlayContentProps extends WithStyle {
4
+ title: string;
5
+ subtitle?: string;
6
+ children: ReactNode;
7
+ onClose?: () => void;
8
+ }
9
+ interface Props extends OverlayContentProps {
10
+ onClose: () => void;
11
+ type: 'modal' | 'panel';
12
+ }
13
+ export declare const OverlayContent: ({ children, title, subtitle, className, style, onClose, type }: Props) => import("react/jsx-runtime").JSX.Element;
14
+ export {};
15
+ //# sourceMappingURL=OverlayContent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverlayContent.d.ts","sourceRoot":"","sources":["../../src/components/OverlayContent.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAsB,MAAM,0BAA0B,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAGjC,MAAM,WAAW,mBAAoB,SAAQ,SAAS;IACpD,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,SAAS,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;CACtB;AAED,UAAU,KAAM,SAAQ,mBAAmB;IACzC,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC;CACzB;AAqBD,eAAO,MAAM,cAAc,mEAAoE,KAAK,4CAWnG,CAAA"}
@@ -0,0 +1,26 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Flex, Text } from '@citric/core';
3
+ import { TimesMini } from '@citric/icons';
4
+ import { IconButton } from '@citric/ui';
5
+ import { listToClass, theme } from '@stack-spot/portal-theme';
6
+ import { styled } from 'styled-components';
7
+ const ContentBox = styled.section `
8
+ display: flex;
9
+ flex-direction: column;
10
+ border-radius: 1rem;
11
+ background-color: ${theme.color.light['400']};
12
+ &.modal {
13
+ padding: 32px;
14
+ }
15
+ &.panel {
16
+ padding: 20px;
17
+ }
18
+ header {
19
+ display: flex;
20
+ flex-direction: row;
21
+ flex: 1;
22
+ margin-bottom: 1.25rem;
23
+ }
24
+ `;
25
+ export const OverlayContent = ({ children, title, subtitle, className, style, onClose, type }) => (_jsxs(ContentBox, { style: style, className: listToClass([className, type]), children: [_jsxs("header", { children: [_jsxs(Flex, { flexDirection: "column", flex: 1, children: [_jsx(Text, { appearance: type === 'modal' ? 'h3' : 'h4', children: title }), subtitle && _jsx(Text, { appearance: "body2", colorScheme: "light.700", children: subtitle })] }), _jsx(IconButton, { onClick: onClose, title: "close", "aria-label": "close", children: _jsx(TimesMini, {}) })] }), children] }));
26
+ //# sourceMappingURL=OverlayContent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverlayContent.js","sourceRoot":"","sources":["../../src/components/OverlayContent.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AACvC,OAAO,EAAa,WAAW,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAA;AAExE,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAc1C,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAA;;;;sBAIX,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC;;;;;;;;;;;;;CAa7C,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAS,EAAE,EAAE,CAAC,CACvG,MAAC,UAAU,IAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,aACjE,6BACE,MAAC,IAAI,IAAC,aAAa,EAAC,QAAQ,EAAC,IAAI,EAAE,CAAC,aAClC,KAAC,IAAI,IAAC,UAAU,EAAE,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,YAAG,KAAK,GAAQ,EAC/D,QAAQ,IAAI,KAAC,IAAI,IAAC,UAAU,EAAC,OAAO,EAAC,WAAW,EAAC,WAAW,YAAE,QAAQ,GAAQ,IAC1E,EACP,KAAC,UAAU,IAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAC,OAAO,gBAAY,OAAO,YAAC,KAAC,SAAS,KAAG,GAAa,IAClF,EACR,QAAQ,IACE,CACd,CAAA"}
@@ -0,0 +1,34 @@
1
+ import { WithStyle } from '@stack-spot/portal-theme';
2
+ import { ReactElement } from 'react';
3
+ import { Action } from './types';
4
+ interface ItemWithIcon {
5
+ icon?: React.ReactElement;
6
+ iconRight?: React.ReactElement;
7
+ }
8
+ export interface ListAction extends ItemWithIcon, Action {
9
+ active?: boolean;
10
+ }
11
+ interface ListGroup {
12
+ type?: 'section' | 'collapsible';
13
+ children: ListItem[];
14
+ }
15
+ interface ListSection extends ListGroup {
16
+ type: 'section';
17
+ label?: string;
18
+ }
19
+ interface ListCollapsible extends ListGroup, ItemWithIcon {
20
+ type?: 'collapsible';
21
+ label: string;
22
+ }
23
+ type ListItem = ListSection | ListCollapsible | ListAction;
24
+ export interface SelectionListProps extends WithStyle {
25
+ visible?: boolean;
26
+ items: ListItem[];
27
+ onHide?: () => void;
28
+ maxHeight?: string;
29
+ before?: ReactElement;
30
+ after?: ReactElement;
31
+ }
32
+ export declare const SelectionList: ({ items, className, style, visible, maxHeight, onHide, before, after, }: SelectionListProps) => import("react/jsx-runtime").JSX.Element;
33
+ export {};
34
+ //# sourceMappingURL=SelectionList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectionList.d.ts","sourceRoot":"","sources":["../../src/components/SelectionList.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAsB,MAAM,0BAA0B,CAAA;AACxE,OAAO,EAAE,YAAY,EAAqD,MAAM,OAAO,CAAA;AAEvF,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAEhC,UAAU,YAAY;IACpB,IAAI,CAAC,EAAE,KAAK,CAAC,YAAY,CAAC;IAC1B,SAAS,CAAC,EAAE,KAAK,CAAC,YAAY,CAAC;CAChC;AAED,MAAM,WAAW,UAAW,SAAQ,YAAY,EAAE,MAAM;IACtD,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,UAAU,SAAS;IACjB,IAAI,CAAC,EAAE,SAAS,GAAG,aAAa,CAAC;IACjC,QAAQ,EAAE,QAAQ,EAAE,CAAC;CACtB;AAED,UAAU,WAAY,SAAQ,SAAS;IACrC,IAAI,EAAE,SAAS,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,UAAU,eAAgB,SAAQ,SAAS,EAAE,YAAY;IACvD,IAAI,CAAC,EAAE,aAAa,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,KAAK,QAAQ,GAAG,WAAW,GAAG,eAAe,GAAG,UAAU,CAAA;AAU1D,MAAM,WAAW,kBAAmB,SAAQ,SAAS;IACnD,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,YAAY,CAAC;IACtB,KAAK,CAAC,EAAE,YAAY,CAAC;CACtB;AA6FD,eAAO,MAAM,aAAa,4EAEvB,kBAAkB,4CAuDpB,CAAA"}
@@ -0,0 +1,104 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Flex, IconBox, Text } from '@citric/core';
3
+ import { ArrowLeft, Check, ChevronRight } from '@citric/icons';
4
+ import { IconButton } from '@citric/ui';
5
+ import { listToClass, theme } from '@stack-spot/portal-theme';
6
+ import { useCallback, useEffect, useMemo, useRef, useState } from 'react';
7
+ import { styled } from 'styled-components';
8
+ const ANIMATION_DURATION_MS = 300;
9
+ const SelectionBox = styled.div `
10
+ max-height: 0;
11
+ overflow: hidden;
12
+ transition: max-height ease-in ${ANIMATION_DURATION_MS / 1000}s;
13
+ z-index: 1;
14
+ box-shadow: 4px 4px 48px #000;
15
+ border-radius: 0.5rem;
16
+
17
+ .selection-list-content {
18
+ display: flex;
19
+ flex-direction: column;
20
+ border-radius: 0.5rem;
21
+ background: ${theme.color.light['500']};
22
+ border-radius: 0.5rem;
23
+ border: 1px solid ${theme.color.light['600']};
24
+ background-color: ${theme.color.light['300']};
25
+ }
26
+
27
+ .section-title, li > a {
28
+ height: 40px;
29
+ padding: 0 8px;
30
+ display: flex;
31
+ flex-direction: row;
32
+ align-items: center;
33
+ }
34
+
35
+ li > a {
36
+ gap: 4px;
37
+ transition: background-color 0.2s;
38
+ &:hover {
39
+ background: ${theme.color.light['400']};
40
+ }
41
+ .label {
42
+ flex: 1;
43
+ }
44
+ }
45
+
46
+ li.section {
47
+ border-bottom: 2px solid ${theme.color.light['600']};
48
+ &:last-child {
49
+ border-bottom: none;
50
+ }
51
+ }
52
+
53
+ &.visible {
54
+ max-height: ${({ $maxHeight }) => $maxHeight};
55
+ }
56
+ `;
57
+ function renderAction({ label, href, onClick, icon, iconRight, active }) {
58
+ return (_jsx("li", { className: "action", children: _jsxs("a", { href: href, onClick: onClick, children: [icon && _jsx(IconBox, { children: icon }), _jsx(Text, { appearance: "body2", className: "label", children: label }), iconRight && _jsx(IconBox, { children: iconRight }), active && _jsx(IconBox, { children: _jsx(Check, {}) })] }) }, label));
59
+ }
60
+ function renderCollapsible({ label, icon, iconRight, children }, setCurrent) {
61
+ return (_jsx("li", { className: "collapsible", children: _jsxs("a", { onClick: () => setCurrent({ items: children, label }), children: [icon && _jsx(IconBox, { children: icon }), _jsx(Text, { appearance: "body2", className: "label", children: label }), iconRight && _jsx(IconBox, { children: iconRight }), _jsx(IconBox, { children: _jsx(ChevronRight, {}) })] }) }, label));
62
+ }
63
+ function renderSection({ label, children }, setCurrent) {
64
+ return (_jsxs("li", { className: "section", children: [label && _jsx(Text, { appearance: "overheader2", colorScheme: "primary", className: "section-title", children: label }), _jsx("ul", { children: children.map(i => renderItem(i, setCurrent)) })] }, label ?? children.map(c => c.label).join('-')));
65
+ }
66
+ function renderItem(item, setCurrent) {
67
+ if ('children' in item) {
68
+ return item.type === 'section' ? renderSection(item, setCurrent) : renderCollapsible(item, setCurrent);
69
+ }
70
+ return renderAction(item);
71
+ }
72
+ export const SelectionList = ({ items, className, style, visible = true, maxHeight = '300px', onHide, before, after, }) => {
73
+ const wrapper = useRef(null);
74
+ const itemsRef = useRef(items);
75
+ const [current, setCurrent] = useState({ items });
76
+ const listItems = useMemo(() => current.items.map(i => renderItem(i, (next) => setCurrent({ ...next, parent: current }))), [current]);
77
+ const hide = useCallback((event) => {
78
+ const target = event.target;
79
+ // if the element is not in the DOM anymore, we'll consider the click was inside the selection list
80
+ const isClickInsideSelectionList = !target?.isConnected || wrapper.current?.contains(target);
81
+ const isAction = target?.classList?.contains('action') || !!target?.closest('.action');
82
+ if (!isClickInsideSelectionList || isAction) {
83
+ if (onHide)
84
+ onHide();
85
+ setTimeout(() => setCurrent({ items: itemsRef.current }), ANIMATION_DURATION_MS);
86
+ document.removeEventListener('click', hide);
87
+ }
88
+ }, []);
89
+ useEffect(() => {
90
+ if (!onHide)
91
+ return;
92
+ if (visible)
93
+ setTimeout(() => document.addEventListener('click', hide), 50);
94
+ }, [visible]);
95
+ useEffect(() => {
96
+ itemsRef.current = items;
97
+ if (!wrapper.current?.classList.contains('visible'))
98
+ setCurrent({ items });
99
+ }, [items]);
100
+ return (_jsx(SelectionBox, { ref: wrapper, "$maxHeight": maxHeight, style: style, className: listToClass(['selection-list', visible ? 'visible' : undefined, className]), children: _jsxs("div", { className: "selection-list-content", children: [before, current.parent
101
+ ? (_jsxs(Flex, { mt: 5, mb: 1, alignItems: "center", children: [_jsx(IconButton, { onClick: () => setCurrent(current.parent ?? { items }), sx: { mr: 3 }, children: _jsx(ArrowLeft, {}) }), _jsx(Text, { appearance: "microtext1", children: current.label })] }))
102
+ : undefined, _jsx("ul", { children: listItems }), after] }) }));
103
+ };
104
+ //# sourceMappingURL=SelectionList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectionList.js","sourceRoot":"","sources":["../../src/components/SelectionList.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import 'react-toastify/dist/ReactToastify.css';
2
+ export declare const Toaster: () => import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=Toaster.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toaster.d.ts","sourceRoot":"","sources":["../../src/components/Toaster.tsx"],"names":[],"mappings":"AAGA,OAAO,uCAAuC,CAAA;AAQ9C,eAAO,MAAM,OAAO,+CAAqD,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { TimesMini } from '@citric/icons';
3
+ import { IconButton } from '@citric/ui';
4
+ import { ToastContainer } from 'react-toastify';
5
+ import 'react-toastify/dist/ReactToastify.css';
6
+ const CloseButton = ({ closeToast }) => (_jsx(IconButton, { onClick: () => closeToast(null), title: "Dismiss", children: _jsx(TimesMini, {}) }));
7
+ export const Toaster = () => _jsx(ToastContainer, { closeButton: CloseButton });
8
+ //# sourceMappingURL=Toaster.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toaster.js","sourceRoot":"","sources":["../../src/components/Toaster.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AACvC,OAAO,EAAoB,cAAc,EAAE,MAAM,gBAAgB,CAAA;AACjE,OAAO,uCAAuC,CAAA;AAE9C,MAAM,WAAW,GAAG,CAAC,EAAE,UAAU,EAAoB,EAAE,EAAE,CAAC,CACxD,KAAC,UAAU,IAAC,OAAO,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,IAAW,CAAC,EAAE,KAAK,EAAC,SAAS,YACjE,KAAC,SAAS,KAAG,GACF,CACd,CAAA;AAED,MAAM,CAAC,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,KAAC,cAAc,IAAC,WAAW,EAAE,WAAW,GAAI,CAAA"}
@@ -0,0 +1,9 @@
1
+ import { SelectionListProps } from './SelectionList';
2
+ interface Props {
3
+ userName: string;
4
+ email?: string;
5
+ options?: SelectionListProps['items'];
6
+ }
7
+ export declare const UserMenu: ({ userName, email, options }: Props) => import("react/jsx-runtime").JSX.Element;
8
+ export {};
9
+ //# sourceMappingURL=UserMenu.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserMenu.d.ts","sourceRoot":"","sources":["../../src/components/UserMenu.tsx"],"names":[],"mappings":"AAMA,OAAO,EAAiB,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AAEnE,UAAU,KAAK;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,kBAAkB,CAAC,OAAO,CAAC,CAAC;CACvC;AAoDD,eAAO,MAAM,QAAQ,iCAAkC,KAAK,4CA0B3D,CAAA"}
@@ -0,0 +1,57 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Flex, IconBox, LinkBox, Text } from '@citric/core';
3
+ import { ChevronDown } from '@citric/icons';
4
+ import { Avatar } from '@citric/ui';
5
+ import { theme } from '@stack-spot/portal-theme';
6
+ import { useState } from 'react';
7
+ import { styled } from 'styled-components';
8
+ import { SelectionList } from './SelectionList';
9
+ const UserMenuBox = styled.div `
10
+ .user-menu-header {
11
+ display: flex;
12
+ flex-direction: column;
13
+ justify-content: center;
14
+ align-items: center;
15
+ padding: 12px;
16
+ border-bottom: 2px solid ${theme.color.light['600']};
17
+ }
18
+
19
+ .selection-list {
20
+ position: absolute;
21
+ top: var(--header-height);
22
+ right: 20px;
23
+ width: 266px;
24
+
25
+ .selection-list-content {
26
+ border: none;
27
+ padding: 16px 16px 8px;
28
+ background-color: ${theme.color.light['400']};
29
+ }
30
+
31
+ li {
32
+ margin: 8px 0;
33
+ & > a {
34
+ border-radius: 6px;
35
+ &:hover {
36
+ background: ${theme.color.light['500']};
37
+ }
38
+ }
39
+ }
40
+ }
41
+
42
+ .username {
43
+ margin: 5px 0 2px 0;
44
+ }
45
+
46
+ .chevron {
47
+ transition: transform ease-out 0.3s;
48
+ }
49
+ `;
50
+ const UserMenuHeader = ({ userName, email }) => (_jsxs("div", { className: "user-menu-header", children: [_jsx(Avatar, { size: "xs", children: userName }), _jsx(Text, { appearance: "body1", className: "username", children: userName }), email && _jsx(Text, { appearance: "microtext1", className: "email", colorScheme: "light.700", children: email })] }));
51
+ export const UserMenu = ({ userName, email, options }) => {
52
+ const [visible, setVisible] = useState(false);
53
+ return (_jsxs(UserMenuBox, { children: [_jsx(LinkBox, { as: "button", onClick: () => setVisible(true), children: _jsxs(Flex, { alignItems: "center", children: [_jsx(Avatar, { size: "xs", children: userName }), _jsx(IconBox, { colorScheme: "inverse", className: "chevron", style: visible ? { transform: 'rotate(180deg)' } : undefined, children: _jsx(ChevronDown, {}) })] }) }), options?.length
54
+ ? _jsx(SelectionList, { visible: visible, before: _jsx(UserMenuHeader, { userName: userName, email: email }), items: options, onHide: () => setVisible(false), maxHeight: "600px" })
55
+ : null] }));
56
+ };
57
+ //# sourceMappingURL=UserMenu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserMenu.js","sourceRoot":"","sources":["../../src/components/UserMenu.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAC3C,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAA;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAC1C,OAAO,EAAE,aAAa,EAAsB,MAAM,iBAAiB,CAAA;AAQnE,MAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;+BAOC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC;;;;;;;;;;;;0BAY7B,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC;;;;;;;;wBAQ1B,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC;;;;;;;;;;;;;CAa/C,CAAA;AAED,MAAM,cAAc,GAAG,CAAC,EAAE,QAAQ,EAAE,KAAK,EAA0B,EAAE,EAAE,CAAC,CACtE,eAAK,SAAS,EAAC,kBAAkB,aAC/B,KAAC,MAAM,IAAC,IAAI,EAAC,IAAI,YAAE,QAAQ,GAAU,EACrC,KAAC,IAAI,IAAC,UAAU,EAAC,OAAO,EAAC,SAAS,EAAC,UAAU,YAAE,QAAQ,GAAQ,EAC9D,KAAK,IAAI,KAAC,IAAI,IAAC,UAAU,EAAC,YAAY,EAAC,SAAS,EAAC,OAAO,EAAC,WAAW,EAAC,WAAW,YAAE,KAAK,GAAQ,IAC5F,CACP,CAAA;AAED,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAS,EAAE,EAAE;IAC9D,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAE7C,OAAO,CACL,MAAC,WAAW,eACV,KAAC,OAAO,IAAC,EAAE,EAAC,QAAQ,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,YAClD,MAAC,IAAI,IAAC,UAAU,EAAC,QAAQ,aACvB,KAAC,MAAM,IAAC,IAAI,EAAC,IAAI,YAAE,QAAQ,GAAU,EACrC,KAAC,OAAO,IAAC,WAAW,EAAC,SAAS,EAAC,SAAS,EAAC,SAAS,EAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC,CAAC,CAAC,SAAS,YAC7G,KAAC,WAAW,KAAG,GACP,IACL,GACC,EAET,OAAO,EAAE,MAAM;gBACd,CAAC,CAAC,KAAC,aAAa,IACd,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,KAAC,cAAc,IAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,GAAI,EAC5D,KAAK,EAAE,OAAQ,EACf,MAAM,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,EAC/B,SAAS,EAAC,OAAO,GACjB;gBACF,CAAC,CAAC,IAAI,IAEI,CACf,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,6 @@
1
+ export interface Action {
2
+ label: string;
3
+ onClick?: () => void;
4
+ href?: string;
5
+ }
6
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/components/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,MAAM;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/components/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,7 @@
1
+ export declare class LayoutError extends Error {
2
+ constructor(message: string);
3
+ }
4
+ export declare class ElementNotFound extends LayoutError {
5
+ constructor(elementName: string, elementId: string);
6
+ }
7
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,WAAY,SAAQ,KAAK;gBACxB,OAAO,EAAE,MAAM;CAG5B;AAED,qBAAa,eAAgB,SAAQ,WAAW;gBAClC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;CAGnD"}
package/dist/errors.js ADDED
@@ -0,0 +1,11 @@
1
+ export class LayoutError extends Error {
2
+ constructor(message) {
3
+ super(`Layout error: ${message}`);
4
+ }
5
+ }
6
+ export class ElementNotFound extends LayoutError {
7
+ constructor(elementName, elementId) {
8
+ super(`unable to create ${elementName} because no element with id "${elementId}" was found in the view.`);
9
+ }
10
+ }
11
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.js","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,WAAY,SAAQ,KAAK;IACpC,YAAY,OAAe;QACzB,KAAK,CAAC,iBAAiB,OAAO,EAAE,CAAC,CAAA;IACnC,CAAC;CACF;AAED,MAAM,OAAO,eAAgB,SAAQ,WAAW;IAC9C,YAAY,WAAmB,EAAE,SAAiB;QAChD,KAAK,CAAC,oBAAoB,WAAW,gCAAgC,SAAS,0BAA0B,CAAC,CAAA;IAC3G,CAAC;CACF"}
@@ -0,0 +1,11 @@
1
+ export { Layout } from './Layout';
2
+ export { overlay } from './LayoutOverlayManager';
3
+ export { Header, HeaderProps } from './components/Header';
4
+ export { StackspotLogo } from './components/Logo';
5
+ export { MenuContent } from './components/Menu/MenuContent';
6
+ export { MenuSections } from './components/Menu/MenuSections';
7
+ export * from './components/Menu/types';
8
+ export { ListAction, SelectionList, SelectionListProps } from './components/SelectionList';
9
+ export * from './components/types';
10
+ export * from './errors';
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAA;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAA;AAC7D,cAAc,yBAAyB,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAA;AAC1F,cAAc,oBAAoB,CAAA;AAClC,cAAc,UAAU,CAAA"}