@adamjanicki/ui 1.7.8 → 1.8.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.
@@ -29,7 +29,7 @@ var Avatar = React.forwardRef(function (_a, ref) {
29
29
  var _c = useState(false), imageError = _c[0], setImageError = _c[1];
30
30
  var useFallback = imageError || !backgroundImage;
31
31
  var color = chooseColor(username);
32
- var avatarClassName = null;
32
+ var avatarClassName = undefined;
33
33
  if (useFallback) {
34
34
  avatarClassName = classNames(avatarClassName, "aui-avatar-".concat(color));
35
35
  }
@@ -0,0 +1,43 @@
1
+ import React from "react";
2
+ import type { Children } from "../../utils/types";
3
+ type FallbackProps = {
4
+ error: Error;
5
+ reset: () => void;
6
+ };
7
+ type Props = {
8
+ /**
9
+ * Component to render when an error is caught
10
+ */
11
+ Fallback: React.ComponentType<FallbackProps>;
12
+ /**
13
+ * Children wrapped by the error boundary
14
+ */
15
+ children: Children;
16
+ /**
17
+ * Called when an error is caught
18
+ */
19
+ onError?: (error: Error, info: React.ErrorInfo) => void;
20
+ /**
21
+ * Called when the error state is reset
22
+ */
23
+ onReset?: () => void;
24
+ /**
25
+ * Dependencies to trigger a reset on change
26
+ */
27
+ deps?: unknown[];
28
+ };
29
+ type State = {
30
+ error: Error | null;
31
+ };
32
+ export default class ErrorBoundary extends React.Component<Props, State> {
33
+ state: State;
34
+ static getDerivedStateFromError(error: Error): {
35
+ error: Error;
36
+ };
37
+ componentDidCatch(error: Error, info: React.ErrorInfo): void;
38
+ componentDidUpdate(prevProps: Readonly<Props>): void;
39
+ private resetErrorBoundary;
40
+ private depsUpdated;
41
+ render(): string | number | bigint | boolean | Iterable<React.ReactNode> | Promise<string | number | bigint | boolean | React.ReactPortal | React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode> | null | undefined> | import("react/jsx-runtime").JSX.Element | null | undefined;
42
+ }
43
+ export {};
@@ -0,0 +1,61 @@
1
+ var __extends = (this && this.__extends) || (function () {
2
+ var extendStatics = function (d, b) {
3
+ extendStatics = Object.setPrototypeOf ||
4
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
5
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
6
+ return extendStatics(d, b);
7
+ };
8
+ return function (d, b) {
9
+ if (typeof b !== "function" && b !== null)
10
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
11
+ extendStatics(d, b);
12
+ function __() { this.constructor = d; }
13
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
14
+ };
15
+ })();
16
+ import { jsx as _jsx } from "react/jsx-runtime";
17
+ import React from "react";
18
+ var ErrorBoundary = /** @class */ (function (_super) {
19
+ __extends(ErrorBoundary, _super);
20
+ function ErrorBoundary() {
21
+ var _this = _super !== null && _super.apply(this, arguments) || this;
22
+ _this.state = { error: null };
23
+ _this.resetErrorBoundary = function () {
24
+ var _a, _b;
25
+ if (_this.state.error !== null) {
26
+ _this.setState({ error: null });
27
+ (_b = (_a = _this.props).onReset) === null || _b === void 0 ? void 0 : _b.call(_a);
28
+ }
29
+ };
30
+ return _this;
31
+ }
32
+ ErrorBoundary.getDerivedStateFromError = function (error) {
33
+ return { error: error };
34
+ };
35
+ ErrorBoundary.prototype.componentDidCatch = function (error, info) {
36
+ var _a, _b;
37
+ (_b = (_a = this.props).onError) === null || _b === void 0 ? void 0 : _b.call(_a, error, info);
38
+ };
39
+ ErrorBoundary.prototype.componentDidUpdate = function (prevProps) {
40
+ if (this.depsUpdated(this.props.deps, prevProps.deps)) {
41
+ this.resetErrorBoundary();
42
+ }
43
+ };
44
+ ErrorBoundary.prototype.depsUpdated = function (nextDeps, prevDeps) {
45
+ if (!nextDeps || !prevDeps)
46
+ return false;
47
+ if (nextDeps.length !== prevDeps.length)
48
+ return true;
49
+ return nextDeps.some(function (dep, i) { return !Object.is(dep, prevDeps[i]); });
50
+ };
51
+ ErrorBoundary.prototype.render = function () {
52
+ var _a = this.props, Fallback = _a.Fallback, children = _a.children;
53
+ var error = this.state.error;
54
+ if (!error) {
55
+ return children;
56
+ }
57
+ return _jsx(Fallback, { error: error, reset: this.resetErrorBoundary });
58
+ };
59
+ return ErrorBoundary;
60
+ }(React.Component));
61
+ export default ErrorBoundary;
@@ -0,0 +1,2 @@
1
+ import ErrorBoundary from "./ErrorBoundary";
2
+ export default ErrorBoundary;
@@ -0,0 +1,2 @@
1
+ import ErrorBoundary from "./ErrorBoundary";
2
+ export default ErrorBoundary;
@@ -48,7 +48,7 @@ var Layer = React.forwardRef(function (_a, ref) {
48
48
  };
49
49
  }, [onClose, returnFocusOnEscape]);
50
50
  var mergedRef = useMergeRefs(focusRef, children.props.ref);
51
- return (_jsx(Box, __assign({ vfx: __assign({ pos: "fixed", axis: "y", align: "center", justify: "center", z: "max" }, vfx) }, rest, { className: classNames("aui-layer-backdrop", className), onMouseDown: function (e) {
51
+ return (_jsx(Box, __assign({ vfx: __assign({ axis: "y", align: "center", justify: "center", z: "max" }, vfx) }, rest, { className: classNames("aui-layer-backdrop", className), onMouseDown: function (e) {
52
52
  onMouseDown === null || onMouseDown === void 0 ? void 0 : onMouseDown(e);
53
53
  onClose === null || onClose === void 0 ? void 0 : onClose();
54
54
  }, ref: ref, children: React.cloneElement(children, {
@@ -4,4 +4,4 @@
4
4
  * @param classNames list of class names to concatenate
5
5
  * @returns single aggregated string of classnames
6
6
  */
7
- export default function classNames(...classNames: Array<string | null | undefined>): string;
7
+ export default function classNames(...classNames: Array<string | null | undefined>): string | undefined;
@@ -9,8 +9,8 @@ export default function classNames() {
9
9
  for (var _i = 0; _i < arguments.length; _i++) {
10
10
  classNames[_i] = arguments[_i];
11
11
  }
12
- return classNames
12
+ return (classNames
13
13
  .map(function (className) { return className === null || className === void 0 ? void 0 : className.trim(); })
14
14
  .filter(Boolean)
15
- .join(" ");
15
+ .join(" ") || undefined);
16
16
  }
@@ -0,0 +1,8 @@
1
+ type DeviceType = "mobile" | "desktop";
2
+ /**
3
+ * Best effort checks to determine the device being used
4
+ *
5
+ * @returns the type of device
6
+ */
7
+ export default function getDeviceType(): DeviceType;
8
+ export {};
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Best effort checks to determine the device being used
3
+ *
4
+ * @returns the type of device
5
+ */
6
+ export default function getDeviceType() {
7
+ if (!navigator)
8
+ return "desktop";
9
+ var _a = navigator.userAgent, userAgent = _a === void 0 ? "" : _a, _b = navigator.maxTouchPoints, maxTouchPoints = _b === void 0 ? 0 : _b, platform = navigator.platform;
10
+ var isTouchScreen = maxTouchPoints > 0;
11
+ var isMobileUserAgent = /mobi|android|iphone|ipod|ipad/i.test(userAgent);
12
+ var isNewIpad = platform === "MacIntel" && maxTouchPoints > 1;
13
+ if ((isMobileUserAgent && isTouchScreen) || isNewIpad) {
14
+ return "mobile";
15
+ }
16
+ return "desktop";
17
+ }
@@ -1,4 +1,5 @@
1
1
  import classNames from "./classNames";
2
2
  import scrollToId from "./scrollToId";
3
3
  import assertDefined from "./assertDefined";
4
- export { classNames, scrollToId, assertDefined };
4
+ import getDeviceType from "./getDeviceType";
5
+ export { classNames, scrollToId, assertDefined, getDeviceType };
@@ -1,4 +1,5 @@
1
1
  import classNames from "./classNames";
2
2
  import scrollToId from "./scrollToId";
3
3
  import assertDefined from "./assertDefined";
4
- export { classNames, scrollToId, assertDefined };
4
+ import getDeviceType from "./getDeviceType";
5
+ export { classNames, scrollToId, assertDefined, getDeviceType };
@@ -1,23 +1,33 @@
1
1
  import { useEffect } from "react";
2
+ var globalLockCount = 0;
2
3
  var lockScroll = function () {
4
+ globalLockCount += 1;
5
+ if (globalLockCount > 1) {
6
+ return function () {
7
+ globalLockCount -= 1;
8
+ };
9
+ }
3
10
  var scrollPosition = window.scrollY;
4
11
  var style = document.body.style;
5
- var htmlStyle = document.documentElement.style;
6
12
  var overflow = style.overflow, position = style.position, top = style.top, width = style.width;
7
- var scrollBehavior = htmlStyle.scrollBehavior;
8
- htmlStyle.scrollBehavior = "auto";
9
13
  style.overflow = "hidden";
10
14
  style.position = "fixed";
11
15
  style.top = "-".concat(scrollPosition, "px");
12
16
  style.width = "100%";
13
17
  return function () {
18
+ globalLockCount -= 1;
19
+ if (globalLockCount > 0) {
20
+ return;
21
+ }
14
22
  style.overflow = overflow;
15
23
  style.position = position;
16
24
  style.top = top;
17
25
  style.width = width;
18
- // Restore scroll position without smooth behavior
19
- window.scrollTo(0, scrollPosition);
20
- htmlStyle.scrollBehavior = scrollBehavior;
26
+ window.scrollTo({
27
+ top: scrollPosition,
28
+ left: 0,
29
+ behavior: "instant",
30
+ });
21
31
  };
22
32
  };
23
33
  /**
package/index.d.ts CHANGED
@@ -9,6 +9,7 @@ export { default as Button } from "./components/Button";
9
9
  export * from "./components/Button";
10
10
  export { default as Carousel } from "./components/Carousel";
11
11
  export { default as ClickOutside } from "./components/ClickOutside";
12
+ export { default as ErrorBoundary } from "./components/ErrorBoundary";
12
13
  export { default as Hamburger } from "./components/Hamburger";
13
14
  export * from "./components/Hamburger";
14
15
  export { default as Icon } from "./components/Icon";
package/index.js CHANGED
@@ -10,6 +10,7 @@ export { default as Button } from "./components/Button";
10
10
  export * from "./components/Button";
11
11
  export { default as Carousel } from "./components/Carousel";
12
12
  export { default as ClickOutside } from "./components/ClickOutside";
13
+ export { default as ErrorBoundary } from "./components/ErrorBoundary";
13
14
  export { default as Hamburger } from "./components/Hamburger";
14
15
  export * from "./components/Hamburger";
15
16
  export { default as Icon } from "./components/Icon";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@adamjanicki/ui",
3
- "version": "1.7.8",
3
+ "version": "1.8.0",
4
4
  "description": "Basic UI components and hooks for React in TypeScript",
5
5
  "type": "module",
6
6
  "main": "./index.js",
package/style.css CHANGED
@@ -1 +1 @@
1
- :root{--aui-xxs: 2px;--aui-xs: 4px;--aui-s: 8px;--aui-m: 16px;--aui-l: 24px;--aui-xl: 32px;--aui-xxl: 64px;--aui-moon-gray: #ccc;--aui-dark-gray: #555;--aui-darkest-gray: #333;--aui-obsidian: #121212;--aui-focus-ring-color: #b2dbfa;--aui-color-default: black;--aui-color-muted: var(--aui-dark-gray);--aui-default-background: white;--aui-default-border: var(--aui-moon-gray);--aui-opacity-disabled: 0.5;--aui-opacity-dim: 0.75;--aui-default-transition: 0.25s ease-in-out;--aui-floating-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);--aui-radius-none: 0;--aui-radius-subtle: 4px;--aui-radius-rounded: 8px;--aui-radius-max: 10000px;--aui-button-primary-background: black;--aui-button-primary-color: white;--aui-button-secondary-border-hover: var(--aui-darkest-gray);--aui-subtle-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.16);--aui-button-primary-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.36);--aui-success-background: #dff2e1;--aui-success-color: #1b5e20;--aui-success-border: #b2dfb1;--aui-warning-background: #fceeb6;--aui-warning-color: #b23904;--aui-warning-border: #e6d5a2;--aui-error-background: #fdecea;--aui-error-color: #b71c1c;--aui-error-border: #f5b7b7;--aui-info-background: #e3f2fd;--aui-info-color: #0d47a1;--aui-info-border: #90caf9;--aui-avatar-purple: #bc54d6;--aui-avatar-blue: #618bdc;--aui-avatar-red: #ee6060;--aui-avatar-green: #add386;--aui-avatar-yellow: #f5c76d;--aui-static-background: #e8e8e8;--aui-static-color: var(--aui-color-default);--aui-static-border: var(--aui-default-border);--aui-layer-backdrop-background: rgba(200, 200, 200, 0.6);--aui-link-color: #0070ff}[data-theme=dark]{--aui-focus-ring-color: #6699cc;--aui-color-default: white;--aui-color-muted: var(--aui-moon-gray);--aui-default-background: var(--aui-obsidian);--aui-default-border: var(--aui-dark-gray);--aui-floating-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);--aui-button-primary-background: white;--aui-button-primary-color: var(--aui-obsidian);--aui-button-secondary-border-hover: var(--aui-moon-gray);--aui-subtle-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);--aui-button-primary-box-shadow: 0 1px 2px rgba(64, 64, 64, 0.8);--aui-success-background: #2a5733;--aui-success-color: #d9efd8;--aui-success-border: #439e4a;--aui-warning-background: #736230;--aui-warning-color: #fff6d1;--aui-warning-border: #927a3b;--aui-error-background: #663232;--aui-error-color: #f9dadc;--aui-error-border: #8d2a2a;--aui-info-background: #335f72;--aui-info-color: #d4f1f5;--aui-info-border: #1d8ea4;--aui-static-background: var(--aui-darkest-gray);--aui-static-color: var(--aui-color-default);--aui-static-border: var(--aui-default-border);--aui-avatar-purple: #771199;--aui-avatar-blue: #0b4cce;--aui-avatar-red: #bb1111;--aui-avatar-green: #307040;--aui-avatar-yellow: #bb8822;--aui-layer-backdrop-background: rgba(55, 55, 55, 0.7);--aui-link-color: #33bfff}.aui-content-success{background-color:var(--aui-success-background);color:var(--aui-success-color);border-color:var(--aui-success-border)}.aui-content-warning{background-color:var(--aui-warning-background);color:var(--aui-warning-color);border-color:var(--aui-warning-border)}.aui-content-error{background-color:var(--aui-error-background);color:var(--aui-error-color);border-color:var(--aui-error-border)}.aui-content-info{background-color:var(--aui-info-background);color:var(--aui-info-color);border-color:var(--aui-info-border)}.aui-content-static{background-color:var(--aui-static-background);color:var(--aui-static-color);border-color:var(--aui-static-border)}.aui-alert,.aui-badge{border-style:solid;border-width:1px}.aui-action{color:inherit;text-decoration:none;cursor:pointer;outline-color:var(--aui-link-color)}.aui-action:focus:not(:focus-visible){outline:none}.aui-button{background:none;border:none;padding:0}.aui-button:disabled{cursor:default !important;opacity:var(--aui-opacity-disabled)}.aui-button-primary{background-color:var(--aui-button-primary-background);border:1px solid var(--aui-button-primary-background);color:var(--aui-button-primary-color);box-shadow:var(--aui-button-primary-box-shadow);transition:opacity var(--aui-default-transition)}.aui-button-secondary{color:var(--aui-color-default);background-color:var(--aui-default-background);border:1px solid var(--aui-default-border);box-shadow:var(--aui-subtle-box-shadow);transition:border var(--aui-default-transition)}.aui-dim,.aui-undim{transition:opacity var(--aui-default-transition)}.aui-dim{opacity:1}.aui-undim{opacity:var(--aui-opacity-dim)}.aui-link{color:var(--aui-link-color);transition:opacity var(--aui-default-transition)}@media(hover: hover){.aui-button-primary:not([disabled]):hover,.aui-dim:not([disabled]):hover,.aui-link:hover{opacity:var(--aui-opacity-dim)}.aui-button-secondary:not([disabled]):hover{border-color:var(--aui-button-secondary-border-hover)}.aui-undim:not([disabled]):hover{opacity:1}}.aui-input-base{outline:none;border:none;background-color:inherit;color:inherit;padding:var(--aui-s);font-weight:400}.aui-input-base::selection{background-color:var(--aui-focus-ring-color)}.aui-input,.aui-select-container{transition:box-shadow var(--aui-default-transition);border:1px solid var(--aui-default-border);box-shadow:var(--aui-subtle-box-shadow);background-color:var(--aui-default-background)}.aui-input:disabled{opacity:var(--aui-opacity-disabled);cursor:default}.aui-input:not([disabled]):focus-within,.aui-select-container:not([disabled]):focus-within{box-shadow:var(--aui-subtle-box-shadow),0 0 0 3px var(--aui-focus-ring-color)}.aui-select{width:100%;color:inherit;border:none;outline:none;box-shadow:none;cursor:pointer;background-color:rgba(0,0,0,0);padding:var(--aui-s) 28px var(--aui-s) var(--aui-s);font-weight:600;appearance:none;-webkit-appearance:none;-moz-appearance:none}.aui-select-disabled *{opacity:var(--aui-opacity-disabled);cursor:default}.aui-layer-backdrop{top:0;left:0;width:100vw;height:100vh;background:var(--aui-layer-backdrop-background)}.aui-icon *{color:currentColor;fill:currentColor}.aui-spinner{animation:aui-spinner-animation 1s linear infinite;transform-origin:center;height:var(--aui-l)}@keyframes aui-spinner-animation{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.aui-carousel-item{flex:0 0 100%}.aui-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:var(--aui-l);height:var(--aui-l)}.aui-carousel-dots{position:absolute;bottom:var(--aui-s);transform:translateX(-50%);left:50%}.aui-carousel-dot{width:var(--aui-m);height:var(--aui-s)}.aui-pos-static{position:static}.aui-pos-relative{position:relative}.aui-pos-absolute{position:absolute}.aui-pos-fixed{position:fixed}.aui-pos-sticky{position:sticky}.aui-flex-x{display:flex;flex-direction:row}.aui-flex-y{display:flex;flex-direction:column}.aui-flex--x{display:flex;flex-direction:row-reverse}.aui-flex--y{display:flex;flex-direction:column-reverse}.aui-flex-wrap{flex-wrap:wrap}.aui-align-start{align-items:flex-start}.aui-align-center{align-items:center}.aui-align-end{align-items:flex-end}.aui-justify-start{justify-content:flex-start}.aui-justify-center{justify-content:center}.aui-justify-end{justify-content:flex-end}.aui-justify-between{justify-content:space-between}.aui-justify-around{justify-content:space-around}.aui-avatar-red{background-color:var(--aui-avatar-red)}.aui-avatar-yellow{background-color:var(--aui-avatar-yellow)}.aui-avatar-green{background-color:var(--aui-avatar-green)}.aui-avatar-blue{background-color:var(--aui-avatar-blue)}.aui-avatar-purple{background-color:var(--aui-avatar-purple)}.aui-avatar-xxs{width:12px;height:12px;line-height:12px;font-size:9.6px}.aui-avatar-xs{width:16px;height:16px;line-height:16px;font-size:12.8px}.aui-avatar-s{width:24px;height:24px;line-height:24px;font-size:19.2px}.aui-avatar-m{width:32px;height:32px;line-height:32px;font-size:25.6px}.aui-avatar-l{width:48px;height:48px;line-height:48px;font-size:38.4px}.aui-avatar-xl{width:64px;height:64px;line-height:64px;font-size:51.2px}.aui-avatar-xxl{width:128px;height:128px;line-height:128px;font-size:102.4px}.aui-icon-xxs{width:8px;height:8px}.aui-icon-xs{width:12px;height:12px}.aui-icon-s{width:16px;height:16px}.aui-icon-m{width:24px;height:24px}.aui-icon-l{width:32px;height:32px}.aui-icon-xl{width:48px;height:48px}.aui-icon-xxl{width:64px;height:64px}.aui-pa-none{padding:0}.aui-pa-xxs{padding:var(--aui-xxs)}.aui-pa-xs{padding:var(--aui-xs)}.aui-pa-s{padding:var(--aui-s)}.aui-pa-m{padding:var(--aui-m)}.aui-pa-l{padding:var(--aui-l)}.aui-pa-xl{padding:var(--aui-xl)}.aui-pa-xxl{padding:var(--aui-xxl)}.aui-pt-none{padding-top:0}.aui-pt-xxs{padding-top:var(--aui-xxs)}.aui-pt-xs{padding-top:var(--aui-xs)}.aui-pt-s{padding-top:var(--aui-s)}.aui-pt-m{padding-top:var(--aui-m)}.aui-pt-l{padding-top:var(--aui-l)}.aui-pt-xl{padding-top:var(--aui-xl)}.aui-pt-xxl{padding-top:var(--aui-xxl)}.aui-pb-none{padding-bottom:0}.aui-pb-xxs{padding-bottom:var(--aui-xxs)}.aui-pb-xs{padding-bottom:var(--aui-xs)}.aui-pb-s{padding-bottom:var(--aui-s)}.aui-pb-m{padding-bottom:var(--aui-m)}.aui-pb-l{padding-bottom:var(--aui-l)}.aui-pb-xl{padding-bottom:var(--aui-xl)}.aui-pb-xxl{padding-bottom:var(--aui-xxl)}.aui-pl-none{padding-left:0}.aui-pl-xxs{padding-left:var(--aui-xxs)}.aui-pl-xs{padding-left:var(--aui-xs)}.aui-pl-s{padding-left:var(--aui-s)}.aui-pl-m{padding-left:var(--aui-m)}.aui-pl-l{padding-left:var(--aui-l)}.aui-pl-xl{padding-left:var(--aui-xl)}.aui-pl-xxl{padding-left:var(--aui-xxl)}.aui-pr-none{padding-right:0}.aui-pr-xxs{padding-right:var(--aui-xxs)}.aui-pr-xs{padding-right:var(--aui-xs)}.aui-pr-s{padding-right:var(--aui-s)}.aui-pr-m{padding-right:var(--aui-m)}.aui-pr-l{padding-right:var(--aui-l)}.aui-pr-xl{padding-right:var(--aui-xl)}.aui-pr-xxl{padding-right:var(--aui-xxl)}.aui-ma-auto{margin:auto}.aui-ma-none{margin:0}.aui-ma-xxs{margin:var(--aui-xxs)}.aui-ma-xs{margin:var(--aui-xs)}.aui-ma-s{margin:var(--aui-s)}.aui-ma-m{margin:var(--aui-m)}.aui-ma-l{margin:var(--aui-l)}.aui-ma-xl{margin:var(--aui-xl)}.aui-ma-xxl{margin:var(--aui-xxl)}.aui-mt-auto{margin-top:auto}.aui-mt-none{margin-top:0}.aui-mt-xxs{margin-top:var(--aui-xxs)}.aui-mt-xs{margin-top:var(--aui-xs)}.aui-mt-s{margin-top:var(--aui-s)}.aui-mt-m{margin-top:var(--aui-m)}.aui-mt-l{margin-top:var(--aui-l)}.aui-mt-xl{margin-top:var(--aui-xl)}.aui-mt-xxl{margin-top:var(--aui-xxl)}.aui-mb-auto{margin-bottom:auto}.aui-mb-none{margin-bottom:0}.aui-mb-xxs{margin-bottom:var(--aui-xxs)}.aui-mb-xs{margin-bottom:var(--aui-xs)}.aui-mb-s{margin-bottom:var(--aui-s)}.aui-mb-m{margin-bottom:var(--aui-m)}.aui-mb-l{margin-bottom:var(--aui-l)}.aui-mb-xl{margin-bottom:var(--aui-xl)}.aui-mb-xxl{margin-bottom:var(--aui-xxl)}.aui-ml-auto{margin-left:auto}.aui-ml-none{margin-left:0}.aui-ml-xxs{margin-left:var(--aui-xxs)}.aui-ml-xs{margin-left:var(--aui-xs)}.aui-ml-s{margin-left:var(--aui-s)}.aui-ml-m{margin-left:var(--aui-m)}.aui-ml-l{margin-left:var(--aui-l)}.aui-ml-xl{margin-left:var(--aui-xl)}.aui-ml-xxl{margin-left:var(--aui-xxl)}.aui-mr-auto{margin-right:auto}.aui-mr-none{margin-right:0}.aui-mr-xxs{margin-right:var(--aui-xxs)}.aui-mr-xs{margin-right:var(--aui-xs)}.aui-mr-s{margin-right:var(--aui-s)}.aui-mr-m{margin-right:var(--aui-m)}.aui-mr-l{margin-right:var(--aui-l)}.aui-mr-xl{margin-right:var(--aui-xl)}.aui-mr-xxl{margin-right:var(--aui-xxl)}.aui-gap-none{gap:0}.aui-gap-xxs{gap:var(--aui-xxs)}.aui-gap-xs{gap:var(--aui-xs)}.aui-gap-s{gap:var(--aui-s)}.aui-gap-m{gap:var(--aui-m)}.aui-gap-l{gap:var(--aui-l)}.aui-gap-xl{gap:var(--aui-xl)}.aui-gap-xxl{gap:var(--aui-xxl)}.aui-w-full{width:100%}.aui-w-fit{width:fit-content}.aui-w-min{width:min-content}.aui-w-max{width:max-content}.aui-mw-full{max-width:100%}.aui-mw-fit{max-width:fit-content}.aui-mw-min{max-width:min-content}.aui-mw-max{max-width:max-content}.aui-h-full{height:100%}.aui-h-fit{height:fit-content}.aui-h-min{height:min-content}.aui-h-max{height:max-content}.aui-mh-full{max-height:100%}.aui-mh-fit{max-height:fit-content}.aui-mh-min{max-height:min-content}.aui-mh-max{max-height:max-content}.aui-radius-none{border-radius:var(--aui-radius-none)}.aui-radius-subtle{border-radius:var(--aui-radius-subtle)}.aui-radius-rounded{border-radius:var(--aui-radius-rounded)}.aui-radius-max{border-radius:var(--aui-radius-max)}.aui-ba{border:1px solid var(--aui-default-border)}.aui-bt{border-top:1px solid var(--aui-default-border)}.aui-br{border-right:1px solid var(--aui-default-border)}.aui-bb{border-bottom:1px solid var(--aui-default-border)}.aui-bl{border-left:1px solid var(--aui-default-border)}.aui-bw-none{border-width:0px}.aui-bw-xs{border-width:1px}.aui-bw-s{border-width:2px}.aui-bw-m{border-width:4px}.aui-bw-l{border-width:8px}.aui-bw-xl{border-width:16px}.aui-bs-solid{border-style:solid}.aui-bs-dotted{border-style:dotted}.aui-bs-dashed{border-style:dashed}.aui-bs-none{border-style:none}.aui-bc-default{border-color:var(--aui-default-border)}.aui-bc-primary{border-color:var(--aui-color-default)}.aui-shadow-subtle{box-shadow:var(--aui-subtle-box-shadow)}.aui-shadow-floating{box-shadow:var(--aui-floating-box-shadow)}.aui-shadow-none{box-shadow:none}.aui-op-none{opacity:0}.aui-op-disabled{opacity:var(--aui-opacity-disabled)}.aui-op-dim{opacity:var(--aui-opacity-dim)}.aui-op-full{opacity:1}.aui-f-xxs{font-size:10px}.aui-f-xs{font-size:12px}.aui-f-s{font-size:14px}.aui-f-default{font-size:16px}.aui-f-m{font-size:20px}.aui-f-l{font-size:24px}.aui-f-xl{font-size:32px}.aui-f-xxl{font-size:48px}.aui-fw-1{font-weight:100}.aui-fw-2{font-weight:200}.aui-fw-3{font-weight:300}.aui-fw-4{font-weight:400}.aui-fw-5{font-weight:500}.aui-fw-6{font-weight:600}.aui-fw-7{font-weight:700}.aui-fw-8{font-weight:800}.aui-fw-9{font-weight:900}.aui-ta-left{text-align:left}.aui-ta-right{text-align:right}.aui-ta-center{text-align:center}.aui-it{font-style:italic}.aui-c-default{color:var(--aui-color-default)}.aui-c-muted{color:var(--aui-color-muted)}.aui-c-inherit{color:inherit}.aui-c-transparent{color:rgba(0,0,0,0)}.aui-bg-default{background-color:var(--aui-default-background)}.aui-bg-muted{background-color:var(--aui-static-background)}.aui-bg-inherit{background-color:inherit}.aui-bg-transparent{background-color:rgba(0,0,0,0)}.aui-ov-scroll{overflow:scroll}.aui-ov-x-scroll{overflow-x:scroll}.aui-ov-y-scroll{overflow-y:scroll}.aui-ov-hidden{overflow:hidden}.aui-ov-x-hidden{overflow-x:hidden}.aui-ov-y-hidden{overflow-y:hidden}.aui-z-auto{z-index:auto}.aui-z-floating{z-index:100}.aui-z-nav{z-index:1000}.aui-z-max{z-index:10000}.aui-cursor-auto{cursor:auto}.aui-cursor-pointer{cursor:pointer}.aui-select-icon{--size: 10px;color:var(--aui-color-muted);width:var(--size);height:var(--size);position:absolute;top:calc(50% + 1px);transform:translateY(-50%);right:var(--size);pointer-events:none}
1
+ :root{--aui-xxs: 2px;--aui-xs: 4px;--aui-s: 8px;--aui-m: 16px;--aui-l: 24px;--aui-xl: 32px;--aui-xxl: 64px;--aui-moon-gray: #ccc;--aui-dark-gray: #555;--aui-darkest-gray: #333;--aui-obsidian: #121212;--aui-focus-ring-color: #b2dbfa;--aui-color-default: black;--aui-color-muted: var(--aui-dark-gray);--aui-default-background: white;--aui-default-border: var(--aui-moon-gray);--aui-opacity-disabled: 0.5;--aui-opacity-dim: 0.75;--aui-default-transition: 0.25s ease-in-out;--aui-floating-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);--aui-radius-none: 0;--aui-radius-subtle: 4px;--aui-radius-rounded: 8px;--aui-radius-max: 10000px;--aui-button-primary-background: black;--aui-button-primary-color: white;--aui-button-secondary-border-hover: var(--aui-darkest-gray);--aui-subtle-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.16);--aui-button-primary-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.36);--aui-success-background: #dff2e1;--aui-success-color: #1b5e20;--aui-success-border: #b2dfb1;--aui-warning-background: #fceeb6;--aui-warning-color: #b23904;--aui-warning-border: #e6d5a2;--aui-error-background: #fdecea;--aui-error-color: #b71c1c;--aui-error-border: #f5b7b7;--aui-info-background: #e3f2fd;--aui-info-color: #0d47a1;--aui-info-border: #90caf9;--aui-avatar-purple: #bc54d6;--aui-avatar-blue: #618bdc;--aui-avatar-red: #ee6060;--aui-avatar-green: #add386;--aui-avatar-yellow: #f5c76d;--aui-static-background: #e8e8e8;--aui-static-color: var(--aui-color-default);--aui-static-border: var(--aui-default-border);--aui-layer-backdrop-background: rgba(200, 200, 200, 0.6);--aui-link-color: #0070ff}[data-theme=dark]{--aui-focus-ring-color: #6699cc;--aui-color-default: white;--aui-color-muted: var(--aui-moon-gray);--aui-default-background: var(--aui-obsidian);--aui-default-border: var(--aui-dark-gray);--aui-floating-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);--aui-button-primary-background: white;--aui-button-primary-color: var(--aui-obsidian);--aui-button-secondary-border-hover: var(--aui-moon-gray);--aui-subtle-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);--aui-button-primary-box-shadow: 0 1px 2px rgba(64, 64, 64, 0.8);--aui-success-background: #2a5733;--aui-success-color: #d9efd8;--aui-success-border: #439e4a;--aui-warning-background: #736230;--aui-warning-color: #fff6d1;--aui-warning-border: #927a3b;--aui-error-background: #663232;--aui-error-color: #f9dadc;--aui-error-border: #8d2a2a;--aui-info-background: #335f72;--aui-info-color: #d4f1f5;--aui-info-border: #1d8ea4;--aui-static-background: var(--aui-darkest-gray);--aui-static-color: var(--aui-color-default);--aui-static-border: var(--aui-default-border);--aui-avatar-purple: #771199;--aui-avatar-blue: #0b4cce;--aui-avatar-red: #bb1111;--aui-avatar-green: #307040;--aui-avatar-yellow: #bb8822;--aui-layer-backdrop-background: rgba(55, 55, 55, 0.7);--aui-link-color: #33bfff}*{box-sizing:border-box}html{font-family:system-ui,"Helvetica Neue",Helvetica,Arial,sans-serif;-webkit-text-size-adjust:100%;line-height:1.15;tab-size:4;-webkit-font-smoothing:antialiased}body{margin:0}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}.aui-content-success{background-color:var(--aui-success-background);color:var(--aui-success-color);border-color:var(--aui-success-border)}.aui-content-warning{background-color:var(--aui-warning-background);color:var(--aui-warning-color);border-color:var(--aui-warning-border)}.aui-content-error{background-color:var(--aui-error-background);color:var(--aui-error-color);border-color:var(--aui-error-border)}.aui-content-info{background-color:var(--aui-info-background);color:var(--aui-info-color);border-color:var(--aui-info-border)}.aui-content-static{background-color:var(--aui-static-background);color:var(--aui-static-color);border-color:var(--aui-static-border)}.aui-alert,.aui-badge{border-style:solid;border-width:1px}.aui-action{color:inherit;text-decoration:none;cursor:pointer;outline-color:var(--aui-link-color)}.aui-action:focus:not(:focus-visible){outline:none}.aui-button{background:none;border:none;padding:0}.aui-button:disabled{cursor:default !important;opacity:var(--aui-opacity-disabled)}.aui-button-primary{background-color:var(--aui-button-primary-background);border:1px solid var(--aui-button-primary-background);color:var(--aui-button-primary-color);box-shadow:var(--aui-button-primary-box-shadow);transition:opacity var(--aui-default-transition)}.aui-button-secondary{color:var(--aui-color-default);background-color:var(--aui-default-background);border:1px solid var(--aui-default-border);box-shadow:var(--aui-subtle-box-shadow);transition:border var(--aui-default-transition)}.aui-dim,.aui-undim{transition:opacity var(--aui-default-transition)}.aui-dim{opacity:1}.aui-undim{opacity:var(--aui-opacity-dim)}.aui-link{color:var(--aui-link-color);transition:opacity var(--aui-default-transition)}@media(hover: hover){.aui-button-primary:not([disabled]):hover,.aui-dim:not([disabled]):hover,.aui-link:hover{opacity:var(--aui-opacity-dim)}.aui-button-secondary:not([disabled]):hover{border-color:var(--aui-button-secondary-border-hover)}.aui-undim:not([disabled]):hover{opacity:1}}.aui-input-base{outline:none;border:none;background-color:inherit;color:inherit;padding:var(--aui-s);font-weight:400}.aui-input-base::selection{background-color:var(--aui-focus-ring-color)}.aui-input,.aui-select-container{transition:box-shadow var(--aui-default-transition);border:1px solid var(--aui-default-border);box-shadow:var(--aui-subtle-box-shadow);background-color:var(--aui-default-background)}.aui-input:disabled{opacity:var(--aui-opacity-disabled);cursor:default}.aui-input:not([disabled]):focus-within,.aui-select-container:not([disabled]):focus-within{box-shadow:var(--aui-subtle-box-shadow),0 0 0 3px var(--aui-focus-ring-color)}.aui-select{width:100%;color:inherit;border:none;outline:none;box-shadow:none;cursor:pointer;background-color:rgba(0,0,0,0);padding:var(--aui-s) 28px var(--aui-s) var(--aui-s);font-weight:600;appearance:none;-webkit-appearance:none;-moz-appearance:none}.aui-select-disabled *{opacity:var(--aui-opacity-disabled);cursor:default}.aui-layer-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--aui-layer-backdrop-background)}.aui-icon *{color:currentColor;fill:currentColor}.aui-spinner{animation:aui-spinner-animation 1s linear infinite;transform-origin:center;height:var(--aui-l)}@keyframes aui-spinner-animation{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.aui-carousel-item{flex:0 0 100%}.aui-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:var(--aui-l);height:var(--aui-l)}.aui-carousel-dots{position:absolute;bottom:var(--aui-s);transform:translateX(-50%);left:50%}.aui-carousel-dot{width:var(--aui-m);height:var(--aui-s)}.aui-pos-static{position:static}.aui-pos-relative{position:relative}.aui-pos-absolute{position:absolute}.aui-pos-fixed{position:fixed}.aui-pos-sticky{position:sticky}.aui-flex-x{display:flex;flex-direction:row}.aui-flex-y{display:flex;flex-direction:column}.aui-flex--x{display:flex;flex-direction:row-reverse}.aui-flex--y{display:flex;flex-direction:column-reverse}.aui-flex-wrap{flex-wrap:wrap}.aui-align-start{align-items:flex-start}.aui-align-center{align-items:center}.aui-align-end{align-items:flex-end}.aui-justify-start{justify-content:flex-start}.aui-justify-center{justify-content:center}.aui-justify-end{justify-content:flex-end}.aui-justify-between{justify-content:space-between}.aui-justify-around{justify-content:space-around}.aui-avatar-red{background-color:var(--aui-avatar-red)}.aui-avatar-yellow{background-color:var(--aui-avatar-yellow)}.aui-avatar-green{background-color:var(--aui-avatar-green)}.aui-avatar-blue{background-color:var(--aui-avatar-blue)}.aui-avatar-purple{background-color:var(--aui-avatar-purple)}.aui-avatar-xxs{width:12px;height:12px;line-height:12px;font-size:9.6px}.aui-avatar-xs{width:16px;height:16px;line-height:16px;font-size:12.8px}.aui-avatar-s{width:24px;height:24px;line-height:24px;font-size:19.2px}.aui-avatar-m{width:32px;height:32px;line-height:32px;font-size:25.6px}.aui-avatar-l{width:48px;height:48px;line-height:48px;font-size:38.4px}.aui-avatar-xl{width:64px;height:64px;line-height:64px;font-size:51.2px}.aui-avatar-xxl{width:128px;height:128px;line-height:128px;font-size:102.4px}.aui-icon-xxs{width:8px;height:8px}.aui-icon-xs{width:12px;height:12px}.aui-icon-s{width:16px;height:16px}.aui-icon-m{width:24px;height:24px}.aui-icon-l{width:32px;height:32px}.aui-icon-xl{width:48px;height:48px}.aui-icon-xxl{width:64px;height:64px}.aui-pa-none{padding:0}.aui-pa-xxs{padding:var(--aui-xxs)}.aui-pa-xs{padding:var(--aui-xs)}.aui-pa-s{padding:var(--aui-s)}.aui-pa-m{padding:var(--aui-m)}.aui-pa-l{padding:var(--aui-l)}.aui-pa-xl{padding:var(--aui-xl)}.aui-pa-xxl{padding:var(--aui-xxl)}.aui-pt-none{padding-top:0}.aui-pt-xxs{padding-top:var(--aui-xxs)}.aui-pt-xs{padding-top:var(--aui-xs)}.aui-pt-s{padding-top:var(--aui-s)}.aui-pt-m{padding-top:var(--aui-m)}.aui-pt-l{padding-top:var(--aui-l)}.aui-pt-xl{padding-top:var(--aui-xl)}.aui-pt-xxl{padding-top:var(--aui-xxl)}.aui-pb-none{padding-bottom:0}.aui-pb-xxs{padding-bottom:var(--aui-xxs)}.aui-pb-xs{padding-bottom:var(--aui-xs)}.aui-pb-s{padding-bottom:var(--aui-s)}.aui-pb-m{padding-bottom:var(--aui-m)}.aui-pb-l{padding-bottom:var(--aui-l)}.aui-pb-xl{padding-bottom:var(--aui-xl)}.aui-pb-xxl{padding-bottom:var(--aui-xxl)}.aui-pl-none{padding-left:0}.aui-pl-xxs{padding-left:var(--aui-xxs)}.aui-pl-xs{padding-left:var(--aui-xs)}.aui-pl-s{padding-left:var(--aui-s)}.aui-pl-m{padding-left:var(--aui-m)}.aui-pl-l{padding-left:var(--aui-l)}.aui-pl-xl{padding-left:var(--aui-xl)}.aui-pl-xxl{padding-left:var(--aui-xxl)}.aui-pr-none{padding-right:0}.aui-pr-xxs{padding-right:var(--aui-xxs)}.aui-pr-xs{padding-right:var(--aui-xs)}.aui-pr-s{padding-right:var(--aui-s)}.aui-pr-m{padding-right:var(--aui-m)}.aui-pr-l{padding-right:var(--aui-l)}.aui-pr-xl{padding-right:var(--aui-xl)}.aui-pr-xxl{padding-right:var(--aui-xxl)}.aui-ma-auto{margin:auto}.aui-ma-none{margin:0}.aui-ma-xxs{margin:var(--aui-xxs)}.aui-ma-xs{margin:var(--aui-xs)}.aui-ma-s{margin:var(--aui-s)}.aui-ma-m{margin:var(--aui-m)}.aui-ma-l{margin:var(--aui-l)}.aui-ma-xl{margin:var(--aui-xl)}.aui-ma-xxl{margin:var(--aui-xxl)}.aui-mt-auto{margin-top:auto}.aui-mt-none{margin-top:0}.aui-mt-xxs{margin-top:var(--aui-xxs)}.aui-mt-xs{margin-top:var(--aui-xs)}.aui-mt-s{margin-top:var(--aui-s)}.aui-mt-m{margin-top:var(--aui-m)}.aui-mt-l{margin-top:var(--aui-l)}.aui-mt-xl{margin-top:var(--aui-xl)}.aui-mt-xxl{margin-top:var(--aui-xxl)}.aui-mb-auto{margin-bottom:auto}.aui-mb-none{margin-bottom:0}.aui-mb-xxs{margin-bottom:var(--aui-xxs)}.aui-mb-xs{margin-bottom:var(--aui-xs)}.aui-mb-s{margin-bottom:var(--aui-s)}.aui-mb-m{margin-bottom:var(--aui-m)}.aui-mb-l{margin-bottom:var(--aui-l)}.aui-mb-xl{margin-bottom:var(--aui-xl)}.aui-mb-xxl{margin-bottom:var(--aui-xxl)}.aui-ml-auto{margin-left:auto}.aui-ml-none{margin-left:0}.aui-ml-xxs{margin-left:var(--aui-xxs)}.aui-ml-xs{margin-left:var(--aui-xs)}.aui-ml-s{margin-left:var(--aui-s)}.aui-ml-m{margin-left:var(--aui-m)}.aui-ml-l{margin-left:var(--aui-l)}.aui-ml-xl{margin-left:var(--aui-xl)}.aui-ml-xxl{margin-left:var(--aui-xxl)}.aui-mr-auto{margin-right:auto}.aui-mr-none{margin-right:0}.aui-mr-xxs{margin-right:var(--aui-xxs)}.aui-mr-xs{margin-right:var(--aui-xs)}.aui-mr-s{margin-right:var(--aui-s)}.aui-mr-m{margin-right:var(--aui-m)}.aui-mr-l{margin-right:var(--aui-l)}.aui-mr-xl{margin-right:var(--aui-xl)}.aui-mr-xxl{margin-right:var(--aui-xxl)}.aui-gap-none{gap:0}.aui-gap-xxs{gap:var(--aui-xxs)}.aui-gap-xs{gap:var(--aui-xs)}.aui-gap-s{gap:var(--aui-s)}.aui-gap-m{gap:var(--aui-m)}.aui-gap-l{gap:var(--aui-l)}.aui-gap-xl{gap:var(--aui-xl)}.aui-gap-xxl{gap:var(--aui-xxl)}.aui-w-full{width:100%}.aui-w-fit{width:fit-content}.aui-w-min{width:min-content}.aui-w-max{width:max-content}.aui-mw-full{max-width:100%}.aui-mw-fit{max-width:fit-content}.aui-mw-min{max-width:min-content}.aui-mw-max{max-width:max-content}.aui-h-full{height:100%}.aui-h-fit{height:fit-content}.aui-h-min{height:min-content}.aui-h-max{height:max-content}.aui-mh-full{max-height:100%}.aui-mh-fit{max-height:fit-content}.aui-mh-min{max-height:min-content}.aui-mh-max{max-height:max-content}.aui-radius-none{border-radius:var(--aui-radius-none)}.aui-radius-subtle{border-radius:var(--aui-radius-subtle)}.aui-radius-rounded{border-radius:var(--aui-radius-rounded)}.aui-radius-max{border-radius:var(--aui-radius-max)}.aui-ba{border:1px solid var(--aui-default-border)}.aui-bt{border-top:1px solid var(--aui-default-border)}.aui-br{border-right:1px solid var(--aui-default-border)}.aui-bb{border-bottom:1px solid var(--aui-default-border)}.aui-bl{border-left:1px solid var(--aui-default-border)}.aui-bw-none{border-width:0px}.aui-bw-xs{border-width:1px}.aui-bw-s{border-width:2px}.aui-bw-m{border-width:4px}.aui-bw-l{border-width:8px}.aui-bw-xl{border-width:16px}.aui-bs-solid{border-style:solid}.aui-bs-dotted{border-style:dotted}.aui-bs-dashed{border-style:dashed}.aui-bs-none{border-style:none}.aui-bc-default{border-color:var(--aui-default-border)}.aui-bc-primary{border-color:var(--aui-color-default)}.aui-shadow-subtle{box-shadow:var(--aui-subtle-box-shadow)}.aui-shadow-floating{box-shadow:var(--aui-floating-box-shadow)}.aui-shadow-none{box-shadow:none}.aui-op-none{opacity:0}.aui-op-disabled{opacity:var(--aui-opacity-disabled)}.aui-op-dim{opacity:var(--aui-opacity-dim)}.aui-op-full{opacity:1}.aui-f-xxs{font-size:10px}.aui-f-xs{font-size:12px}.aui-f-s{font-size:14px}.aui-f-default{font-size:16px}.aui-f-m{font-size:20px}.aui-f-l{font-size:24px}.aui-f-xl{font-size:32px}.aui-f-xxl{font-size:48px}.aui-fw-1{font-weight:100}.aui-fw-2{font-weight:200}.aui-fw-3{font-weight:300}.aui-fw-4{font-weight:400}.aui-fw-5{font-weight:500}.aui-fw-6{font-weight:600}.aui-fw-7{font-weight:700}.aui-fw-8{font-weight:800}.aui-fw-9{font-weight:900}.aui-ta-left{text-align:left}.aui-ta-right{text-align:right}.aui-ta-center{text-align:center}.aui-it{font-style:italic}.aui-c-default{color:var(--aui-color-default)}.aui-c-muted{color:var(--aui-color-muted)}.aui-c-inherit{color:inherit}.aui-c-transparent{color:rgba(0,0,0,0)}.aui-bg-default{background-color:var(--aui-default-background)}.aui-bg-muted{background-color:var(--aui-static-background)}.aui-bg-inherit{background-color:inherit}.aui-bg-transparent{background-color:rgba(0,0,0,0)}.aui-ov-scroll{overflow:scroll}.aui-ov-x-scroll{overflow-x:scroll}.aui-ov-y-scroll{overflow-y:scroll}.aui-ov-hidden{overflow:hidden}.aui-ov-x-hidden{overflow-x:hidden}.aui-ov-y-hidden{overflow-y:hidden}.aui-z-auto{z-index:auto}.aui-z-floating{z-index:100}.aui-z-nav{z-index:1000}.aui-z-max{z-index:10000}.aui-cursor-auto{cursor:auto}.aui-cursor-pointer{cursor:pointer}.aui-select-icon{--size: 10px;color:var(--aui-color-muted);width:var(--size);height:var(--size);position:absolute;top:calc(50% + 1px);transform:translateY(-50%);right:var(--size);pointer-events:none}
@@ -1,186 +1,194 @@
1
1
  var transformers = {
2
2
  // --- Layout ---
3
- pos: function (classes, _a) {
3
+ pos: function (_a) {
4
4
  var pos = _a.pos;
5
- return classes.push("aui-pos-".concat(pos));
5
+ return "aui-pos-".concat(pos);
6
6
  },
7
- axis: function (classes, _a) {
7
+ axis: function (_a) {
8
8
  var axis = _a.axis;
9
- return classes.push("aui-flex-".concat(axis));
9
+ return "aui-flex-".concat(axis);
10
10
  },
11
- gap: function (classes, _a) {
11
+ gap: function (_a) {
12
12
  var gap = _a.gap;
13
- return classes.push("aui-gap-".concat(gap));
13
+ return "aui-gap-".concat(gap);
14
14
  },
15
- align: function (classes, _a) {
15
+ align: function (_a) {
16
16
  var align = _a.align;
17
- return classes.push("aui-align-".concat(align));
17
+ return "aui-align-".concat(align);
18
18
  },
19
- justify: function (classes, _a) {
19
+ justify: function (_a) {
20
20
  var justify = _a.justify;
21
- return classes.push("aui-justify-".concat(justify));
21
+ return "aui-justify-".concat(justify);
22
22
  },
23
- wrap: function (classes) { return classes.push("aui-flex-wrap"); },
24
- overflow: function (classes, _a) {
23
+ wrap: function () { return "aui-flex-wrap"; },
24
+ overflow: function (_a) {
25
25
  var overflow = _a.overflow;
26
- return classes.push("aui-ov-".concat(overflow));
26
+ return "aui-ov-".concat(overflow);
27
27
  },
28
- overflowX: function (classes, _a) {
28
+ overflowX: function (_a) {
29
29
  var overflowX = _a.overflowX;
30
- return classes.push("aui-ov-x-".concat(overflowX));
30
+ return "aui-ov-x-".concat(overflowX);
31
31
  },
32
- overflowY: function (classes, _a) {
32
+ overflowY: function (_a) {
33
33
  var overflowY = _a.overflowY;
34
- return classes.push("aui-ov-y-".concat(overflowY));
34
+ return "aui-ov-y-".concat(overflowY);
35
35
  },
36
- z: function (classes, _a) {
36
+ z: function (_a) {
37
37
  var z = _a.z;
38
- return classes.push("aui-z-".concat(z));
38
+ return "aui-z-".concat(z);
39
39
  },
40
40
  // --- Spacing ---
41
- padding: function (classes, _a) {
41
+ padding: function (_a) {
42
42
  var padding = _a.padding;
43
- return classes.push("aui-pa-".concat(padding));
43
+ return "aui-pa-".concat(padding);
44
44
  },
45
- paddingX: function (classes, _a) {
45
+ paddingX: function (_a) {
46
46
  var paddingX = _a.paddingX, paddingLeft = _a.paddingLeft, paddingRight = _a.paddingRight;
47
+ var result = [];
47
48
  if (!paddingLeft)
48
- classes.push("aui-pl-".concat(paddingX));
49
+ result.push("aui-pl-".concat(paddingX));
49
50
  if (!paddingRight)
50
- classes.push("aui-pr-".concat(paddingX));
51
+ result.push("aui-pr-".concat(paddingX));
52
+ return result.join(" ");
51
53
  },
52
- paddingY: function (classes, _a) {
54
+ paddingY: function (_a) {
53
55
  var paddingY = _a.paddingY, paddingTop = _a.paddingTop, paddingBottom = _a.paddingBottom;
56
+ var result = [];
54
57
  if (!paddingTop)
55
- classes.push("aui-pt-".concat(paddingY));
58
+ result.push("aui-pt-".concat(paddingY));
56
59
  if (!paddingBottom)
57
- classes.push("aui-pb-".concat(paddingY));
60
+ result.push("aui-pb-".concat(paddingY));
61
+ return result.join(" ");
58
62
  },
59
- paddingTop: function (classes, _a) {
63
+ paddingTop: function (_a) {
60
64
  var paddingTop = _a.paddingTop;
61
- return classes.push("aui-pt-".concat(paddingTop));
65
+ return "aui-pt-".concat(paddingTop);
62
66
  },
63
- paddingBottom: function (classes, _a) {
67
+ paddingBottom: function (_a) {
64
68
  var paddingBottom = _a.paddingBottom;
65
- return classes.push("aui-pb-".concat(paddingBottom));
69
+ return "aui-pb-".concat(paddingBottom);
66
70
  },
67
- paddingLeft: function (classes, _a) {
71
+ paddingLeft: function (_a) {
68
72
  var paddingLeft = _a.paddingLeft;
69
- return classes.push("aui-pl-".concat(paddingLeft));
73
+ return "aui-pl-".concat(paddingLeft);
70
74
  },
71
- paddingRight: function (classes, _a) {
75
+ paddingRight: function (_a) {
72
76
  var paddingRight = _a.paddingRight;
73
- return classes.push("aui-pr-".concat(paddingRight));
77
+ return "aui-pr-".concat(paddingRight);
74
78
  },
75
- margin: function (classes, _a) {
79
+ margin: function (_a) {
76
80
  var margin = _a.margin;
77
- return classes.push("aui-ma-".concat(margin));
81
+ return "aui-ma-".concat(margin);
78
82
  },
79
- marginX: function (classes, _a) {
83
+ marginX: function (_a) {
80
84
  var marginX = _a.marginX, marginLeft = _a.marginLeft, marginRight = _a.marginRight;
85
+ var result = [];
81
86
  if (!marginLeft)
82
- classes.push("aui-ml-".concat(marginX));
87
+ result.push("aui-ml-".concat(marginX));
83
88
  if (!marginRight)
84
- classes.push("aui-mr-".concat(marginX));
89
+ result.push("aui-mr-".concat(marginX));
90
+ return result.join(" ");
85
91
  },
86
- marginY: function (classes, _a) {
92
+ marginY: function (_a) {
87
93
  var marginY = _a.marginY, marginTop = _a.marginTop, marginBottom = _a.marginBottom;
94
+ var result = [];
88
95
  if (!marginTop)
89
- classes.push("aui-mt-".concat(marginY));
96
+ result.push("aui-mt-".concat(marginY));
90
97
  if (!marginBottom)
91
- classes.push("aui-mb-".concat(marginY));
98
+ result.push("aui-mb-".concat(marginY));
99
+ return result.join(" ");
92
100
  },
93
- marginTop: function (classes, _a) {
101
+ marginTop: function (_a) {
94
102
  var marginTop = _a.marginTop;
95
- return classes.push("aui-mt-".concat(marginTop));
103
+ return "aui-mt-".concat(marginTop);
96
104
  },
97
- marginBottom: function (classes, _a) {
105
+ marginBottom: function (_a) {
98
106
  var marginBottom = _a.marginBottom;
99
- return classes.push("aui-mb-".concat(marginBottom));
107
+ return "aui-mb-".concat(marginBottom);
100
108
  },
101
- marginLeft: function (classes, _a) {
109
+ marginLeft: function (_a) {
102
110
  var marginLeft = _a.marginLeft;
103
- return classes.push("aui-ml-".concat(marginLeft));
111
+ return "aui-ml-".concat(marginLeft);
104
112
  },
105
- marginRight: function (classes, _a) {
113
+ marginRight: function (_a) {
106
114
  var marginRight = _a.marginRight;
107
- return classes.push("aui-mr-".concat(marginRight));
115
+ return "aui-mr-".concat(marginRight);
108
116
  },
109
117
  // --- Dimensions ---
110
- width: function (classes, _a) {
118
+ width: function (_a) {
111
119
  var width = _a.width;
112
- return classes.push("aui-w-".concat(width));
120
+ return "aui-w-".concat(width);
113
121
  },
114
- maxWidth: function (classes, _a) {
122
+ maxWidth: function (_a) {
115
123
  var maxWidth = _a.maxWidth;
116
- return classes.push("aui-mw-".concat(maxWidth));
124
+ return "aui-mw-".concat(maxWidth);
117
125
  },
118
- height: function (classes, _a) {
126
+ height: function (_a) {
119
127
  var height = _a.height;
120
- return classes.push("aui-h-".concat(height));
128
+ return "aui-h-".concat(height);
121
129
  },
122
- maxHeight: function (classes, _a) {
130
+ maxHeight: function (_a) {
123
131
  var maxHeight = _a.maxHeight;
124
- return classes.push("aui-mh-".concat(maxHeight));
132
+ return "aui-mh-".concat(maxHeight);
125
133
  },
126
134
  // --- Borders ---
127
- radius: function (classes, _a) {
135
+ radius: function (_a) {
128
136
  var radius = _a.radius;
129
- return classes.push("aui-radius-".concat(radius));
130
- },
131
- border: function (classes) { return classes.push("aui-ba"); },
132
- borderTop: function (classes) { return classes.push("aui-bt"); },
133
- borderBottom: function (classes) { return classes.push("aui-bb"); },
134
- borderLeft: function (classes) { return classes.push("aui-bl"); },
135
- borderRight: function (classes) { return classes.push("aui-br"); },
136
- borderWidth: function (classes, _a) {
137
+ return "aui-radius-".concat(radius);
138
+ },
139
+ border: function () { return "aui-ba"; },
140
+ borderTop: function () { return "aui-bt"; },
141
+ borderBottom: function () { return "aui-bb"; },
142
+ borderLeft: function () { return "aui-bl"; },
143
+ borderRight: function () { return "aui-br"; },
144
+ borderWidth: function (_a) {
137
145
  var borderWidth = _a.borderWidth;
138
- return classes.push("aui-bw-".concat(borderWidth));
146
+ return "aui-bw-".concat(borderWidth);
139
147
  },
140
- borderStyle: function (classes, _a) {
148
+ borderStyle: function (_a) {
141
149
  var borderStyle = _a.borderStyle;
142
- return classes.push("aui-bs-".concat(borderStyle));
150
+ return "aui-bs-".concat(borderStyle);
143
151
  },
144
- borderColor: function (classes, _a) {
152
+ borderColor: function (_a) {
145
153
  var borderColor = _a.borderColor;
146
- return classes.push("aui-bc-".concat(borderColor));
154
+ return "aui-bc-".concat(borderColor);
147
155
  },
148
156
  // --- Effects ---
149
- shadow: function (classes, _a) {
157
+ shadow: function (_a) {
150
158
  var shadow = _a.shadow;
151
- return classes.push("aui-shadow-".concat(shadow));
159
+ return "aui-shadow-".concat(shadow);
152
160
  },
153
- opacity: function (classes, _a) {
161
+ opacity: function (_a) {
154
162
  var opacity = _a.opacity;
155
- return classes.push("aui-op-".concat(opacity));
163
+ return "aui-op-".concat(opacity);
156
164
  },
157
165
  // --- Typography ---
158
- fontSize: function (classes, _a) {
166
+ fontSize: function (_a) {
159
167
  var fontSize = _a.fontSize;
160
- return classes.push("aui-f-".concat(fontSize));
168
+ return "aui-f-".concat(fontSize);
161
169
  },
162
- fontWeight: function (classes, _a) {
170
+ fontWeight: function (_a) {
163
171
  var fontWeight = _a.fontWeight;
164
- return classes.push("aui-fw-".concat(fontWeight));
172
+ return "aui-fw-".concat(fontWeight);
165
173
  },
166
- textAlign: function (classes, _a) {
174
+ textAlign: function (_a) {
167
175
  var textAlign = _a.textAlign;
168
- return classes.push("aui-ta-".concat(textAlign));
176
+ return "aui-ta-".concat(textAlign);
169
177
  },
170
- italics: function (classes) { return classes.push("aui-it"); },
178
+ italics: function () { return "aui-it"; },
171
179
  // --- Colors ---
172
- color: function (classes, _a) {
180
+ color: function (_a) {
173
181
  var color = _a.color;
174
- return classes.push("aui-c-".concat(color));
182
+ return "aui-c-".concat(color);
175
183
  },
176
- backgroundColor: function (classes, _a) {
184
+ backgroundColor: function (_a) {
177
185
  var backgroundColor = _a.backgroundColor;
178
- return classes.push("aui-bg-".concat(backgroundColor));
186
+ return "aui-bg-".concat(backgroundColor);
179
187
  },
180
188
  // --- Misc ---
181
- cursor: function (classes, _a) {
189
+ cursor: function (_a) {
182
190
  var cursor = _a.cursor;
183
- return classes.push("aui-cursor-".concat(cursor));
191
+ return "aui-cursor-".concat(cursor);
184
192
  },
185
193
  };
186
194
  // Main function
@@ -190,9 +198,10 @@ export default function transformVfx(vfx) {
190
198
  var classes = [];
191
199
  Object.entries(vfx).forEach(function (_a) {
192
200
  var key = _a[0], value = _a[1];
193
- if (value) {
194
- var transformer = transformers[key];
195
- transformer(classes, vfx);
201
+ var transformer = transformers[key];
202
+ var result = transformer(vfx);
203
+ if (value && result) {
204
+ classes.push(result);
196
205
  }
197
206
  });
198
207
  return classes.join(" ") || null;