react-ui89 0.36.2 → 0.38.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/esm/components/Ui89Button.d.ts +6 -1
- package/dist/esm/components/Ui89LinkStealth.d.ts +10 -0
- package/dist/esm/components/Ui89LinkStealth.stories.d.ts +6 -0
- package/dist/esm/components/Ui89LinkUnderline.d.ts +0 -1
- package/dist/esm/components/Ui89LinkUnderline.stories.d.ts +1 -11
- package/dist/esm/components/private/LinkBase.d.ts +11 -0
- package/dist/esm/components/private/LinkBase.stories.d.ts +16 -0
- package/dist/esm/index.css +2 -1
- package/dist/esm/index.d.ts +3 -1
- package/dist/esm/index.js +67 -19
- package/dist/esm/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -8,6 +8,10 @@ export declare enum Ui89ButtonPropsSize {
|
|
|
8
8
|
standard = "standard",
|
|
9
9
|
square = "square"
|
|
10
10
|
}
|
|
11
|
+
export declare enum Ui89ButtonPropsType {
|
|
12
|
+
submit = "submit",
|
|
13
|
+
reset = "reset"
|
|
14
|
+
}
|
|
11
15
|
export interface Ui89ButtonProps {
|
|
12
16
|
theme?: Ui89Theme | keyof typeof Ui89Theme;
|
|
13
17
|
size?: Ui89ButtonPropsSize | keyof typeof Ui89ButtonPropsSize;
|
|
@@ -18,5 +22,6 @@ export interface Ui89ButtonProps {
|
|
|
18
22
|
autoDisableOnClick?: boolean;
|
|
19
23
|
disabled?: boolean;
|
|
20
24
|
activated?: boolean;
|
|
25
|
+
type?: keyof typeof Ui89ButtonPropsType;
|
|
21
26
|
}
|
|
22
|
-
export declare function Ui89Button({ theme, size, block, onClick, href, children, autoDisableOnClick, disabled, activated, }: Ui89ButtonProps): React.JSX.Element;
|
|
27
|
+
export declare function Ui89Button({ theme, size, type, block, onClick, href, children, autoDisableOnClick, disabled, activated, }: Ui89ButtonProps): React.JSX.Element;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "./Ui89LinkStealth.css";
|
|
3
|
+
export interface Ui89LinkStealthProps {
|
|
4
|
+
onClick?: () => void | Promise<void>;
|
|
5
|
+
href?: string;
|
|
6
|
+
children: React.ReactNode;
|
|
7
|
+
autoDisableOnClick?: boolean;
|
|
8
|
+
disabled?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare function Ui89LinkStealth(props: Ui89LinkStealthProps): React.JSX.Element;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from "@storybook/react";
|
|
2
|
+
import { Ui89LinkStealth } from "./Ui89LinkStealth";
|
|
3
|
+
import { Ui89OverrideProviderProps } from "../Ui89Override";
|
|
4
|
+
declare const meta: Meta<typeof Ui89LinkStealth>;
|
|
5
|
+
export default meta;
|
|
6
|
+
export declare const Link: StoryObj<Ui89OverrideProviderProps>;
|
|
@@ -3,14 +3,4 @@ import { Ui89LinkUnderline } from "./Ui89LinkUnderline";
|
|
|
3
3
|
import { Ui89OverrideProviderProps } from "../Ui89Override";
|
|
4
4
|
declare const meta: Meta<typeof Ui89LinkUnderline>;
|
|
5
5
|
export default meta;
|
|
6
|
-
|
|
7
|
-
export declare const NoLink: Story;
|
|
8
|
-
export declare const OverrideRouterPush: StoryObj<Ui89OverrideProviderProps>;
|
|
9
|
-
export declare const CallsClickEventHandler: StoryObj<{
|
|
10
|
-
routerPush: any;
|
|
11
|
-
onClick: any;
|
|
12
|
-
}>;
|
|
13
|
-
export declare const IgnoresHrefWhenThereIsAClickEventHandler: StoryObj<{
|
|
14
|
-
routerPush: any;
|
|
15
|
-
onClick: any;
|
|
16
|
-
}>;
|
|
6
|
+
export declare const Link: StoryObj<Ui89OverrideProviderProps>;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "../../style/reset.css";
|
|
3
|
+
export interface Ui89LinkBaseProps {
|
|
4
|
+
className?: string;
|
|
5
|
+
onClick?: () => void | Promise<void>;
|
|
6
|
+
href?: string;
|
|
7
|
+
children: React.ReactNode;
|
|
8
|
+
autoDisableOnClick?: boolean;
|
|
9
|
+
disabled?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export declare function Ui89LinkBase(props: Ui89LinkBaseProps): React.JSX.Element;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from "@storybook/react";
|
|
2
|
+
import { Ui89LinkBase } from "./LinkBase";
|
|
3
|
+
import { Ui89OverrideProviderProps } from "../../Ui89Override";
|
|
4
|
+
declare const meta: Meta<typeof Ui89LinkBase>;
|
|
5
|
+
export default meta;
|
|
6
|
+
type Story = StoryObj<typeof meta>;
|
|
7
|
+
export declare const NoLink: Story;
|
|
8
|
+
export declare const OverrideRouterPush: StoryObj<Ui89OverrideProviderProps>;
|
|
9
|
+
export declare const CallsClickEventHandler: StoryObj<{
|
|
10
|
+
routerPush: any;
|
|
11
|
+
onClick: any;
|
|
12
|
+
}>;
|
|
13
|
+
export declare const IgnoresHrefWhenThereIsAClickEventHandler: StoryObj<{
|
|
14
|
+
routerPush: any;
|
|
15
|
+
onClick: any;
|
|
16
|
+
}>;
|
package/dist/esm/index.css
CHANGED
|
@@ -16,11 +16,12 @@
|
|
|
16
16
|
.ui89-input-file-upload{display:flex;gap:calc(var(--ui89-safe-space) * 1);align-items:center;}.ui89-input-file-upload__info{min-width:0;}
|
|
17
17
|
.ui89-text-unbreakable{white-space:nowrap;}.ui89-text-ellipsis{overflow:hidden;text-overflow:ellipsis;}.ui89-text-single-line{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.ui89-text-single-line--ellipsis-left{direction:rtl;}
|
|
18
18
|
.ui89-input-select{position:relative;}.ui89-input-select__menu{position:absolute;top:100%;left:0;width:100%;max-height:300px;overflow:auto;display:none;background:var(--ui89-input-bg-color);color:var(--ui89-input-text-color);z-index:1;}.ui89-input-select__menu__content{display:inline-flex;flex-direction:column;min-width:100%;}.ui89-input-select:focus-within .ui89-input-select__menu{display:block;animation:ui89-input-select__appear var(--ui89-animation-speed);}@keyframes ui89-input-select__appear{from{transform:translateY(-5px);}to{transform:translateY(0%);}}.ui89-input-select__menu__item{display:inline-flex;align-items:center;background:var(--ui89-input-bg-color);color:var(--ui89-input-text-color);height:var(--ui89-input-height);padding:0 var(--ui89-safe-space);white-space:nowrap;user-select:none;}.ui89-input-select__menu__item:not(.ui89-input-select__menu__item--disabled){cursor:pointer;}.ui89-input-select__menu__item:not(.ui89-input-select__menu__item--disabled):hover,.ui89-input-select__menu__item.ui89-input-select__menu__item--selected{background:var(--ui89-input-text-color);color:var(--ui89-input-bg-color);}.ui89-input-select__menu__item--disabled{color:var(--ui89-palette-white);}
|
|
19
|
+
.ui89-link-stealth{color:currentColor;cursor:pointer;}.ui89-link-stealth:hover{color:currentColor;background:var(--ui89-scene-highlight-color);}
|
|
19
20
|
.ui89-link-underline{color:currentColor;text-decoration:underline;cursor:pointer;}.ui89-link-underline:hover{color:currentColor;}
|
|
20
21
|
.ui89-menu-bar{display:flex;height:16px;color:var(--ui89-theme-primary-text-color);background:var(--ui89-theme-primary-bg-color);}.ui89-menu-bar__item{cursor:var(--ui89-cursor-pointer);padding:0 calc(var(--ui89-safe-space) * 2);}.ui89-menu-bar__item:hover,.ui89-menu-bar__item:active{color:var(--ui89-theme-primary-bg-color);background:var(--ui89-theme-primary-text-color);}
|
|
21
22
|
.ui89-scrollbar ::-webkit-scrollbar{background:var(--ui89-scene-bg-color);width:calc(var(--ui89-safe-space) * 2);}.ui89-scrollbar ::-webkit-scrollbar-track{background:var(--ui89-scene-bg-color);background:var(--ui89-palette-dark-gray);border:1px solid var(--ui89-palette-dark-gray);}.ui89-scrollbar ::-webkit-scrollbar-thumb{background:var(--ui89-palette-light-gray);border:1px solid transparent;}.ui89-scrollbar ::-webkit-scrollbar-thumb:vertical{border-top-color:var(--ui89-palette-dark-gray);border-bottom-color:var(--ui89-palette-dark-gray);}.ui89-scrollbar ::-webkit-scrollbar-thumb:horizontal{border-left-color:var(--ui89-palette-dark-gray);border-right-color:var(--ui89-palette-dark-gray);}.ui89-scrollbar ::-webkit-scrollbar-button:single-button{background-color:#bbbbbb;display:block;border-style:solid;height:calc(var(--ui89-safe-space) * 2);}.ui89-scrollbar ::-webkit-scrollbar-button:single-button:vertical:decrement{border-width:0 var(--ui89-safe-space) var(--ui89-safe-space) var(--ui89-safe-space);border-color:transparent transparent var(--ui89-palette-black) transparent;}.ui89-scrollbar ::-webkit-scrollbar-button:single-button:vertical:decrement:active{background:var(--ui89-palette-dark-gray);}.ui89-scrollbar ::-webkit-scrollbar-button:single-button:vertical:increment{border-width:var(--ui89-safe-space) var(--ui89-safe-space) 0 var(--ui89-safe-space);border-color:var(--ui89-palette-black) transparent transparent transparent;}.ui89-scrollbar ::-webkit-scrollbar-button:single-button:vertical:increment:active{background:var(--ui89-palette-dark-gray);}.ui89-scrollbar ::-webkit-scrollbar-button:single-button:horizontal:decrement{border-width:var(--ui89-safe-space) var(--ui89-safe-space) var(--ui89-safe-space) 0;border-color:transparent var(--ui89-palette-black) transparent transparent;}.ui89-scrollbar ::-webkit-scrollbar-button:single-button:horizontal:decrement:active{background:var(--ui89-palette-dark-gray);}.ui89-scrollbar ::-webkit-scrollbar-button:single-button:horizontal:increment{border-width:var(--ui89-safe-space) 0 var(--ui89-safe-space) var(--ui89-safe-space);border-color:transparent transparent transparent var(--ui89-palette-black);}.ui89-scrollbar ::-webkit-scrollbar-button:single-button:horizontal:increment:active{background:var(--ui89-palette-dark-gray);}
|
|
22
23
|
.ui89-scene{background-color:var(--ui89-scene-bg-color);color:var(--ui89-scene-text-color);overflow:visible;}
|
|
23
|
-
.ui-89-look-main{--ui89-scene-text-color:var(--ui89-palette-white);--ui89-scene-text-subtle-color:var(--ui89-palette-light-gray);--ui89-scene-bg-color:var(--ui89-palette-dark-blue);--ui89-scene-highlight-color:rgba(255,255,255,
|
|
24
|
+
.ui-89-look-main{--ui89-scene-text-color:var(--ui89-palette-white);--ui89-scene-text-subtle-color:var(--ui89-palette-light-gray);--ui89-scene-bg-color:var(--ui89-palette-dark-blue);--ui89-scene-highlight-color:rgba(255,255,255,0.2);--ui89-scene-card-bg-color:var(--ui89-palette-dark-blue);--ui89-scene-card-text-color:var(--ui89-palette-white);--ui89-theme-primary-text-color:var(--ui89-palette-white);--ui89-theme-primary-bg-color:var(--ui89-palette-light-blue);--ui89-theme-secondary-text-color:var(--ui89-palette-black);--ui89-theme-secondary-bg-color:var(--ui89-palette-light-gray);}.ui-89-look-side{--ui89-scene-text-color:var(--ui89-palette-white);--ui89-scene-text-subtle-color:var(--ui89-palette-dark-gray);--ui89-scene-bg-color:var(--ui89-palette-light-gray);--ui89-scene-highlight-color:rgba(255,255,255,0.2);--ui89-scene-card-bg-color:var(--ui89-palette-light-gray);--ui89-scene-card-text-color:var(--ui89-palette-white);--ui89-theme-primary-text-color:var(--ui89-palette-white);--ui89-theme-primary-bg-color:var(--ui89-palette-light-blue);--ui89-theme-secondary-text-color:var(--ui89-palette-black);--ui89-theme-secondary-bg-color:var(--ui89-palette-white);}
|
|
24
25
|
.ui89-grid-expand-trick{display:grid;}.ui89-grid-expand-trick>*{min-height:0;min-width:0;}
|
|
25
26
|
.ui89-scroll-container{overflow:auto;}
|
|
26
27
|
.ui89-modal-dialog{position:fixed;inset:0px;display:none;animation:ui89-modal-dialog__appear var(--ui89-animation-speed);}.ui89-modal-dialog--open{display:block;}.ui89-modal-dialog__backdrop{position:absolute;inset:0px;background-color:rgba(0,0,0,0.4);}.ui89-modal-dialog__box{position:absolute;inset:0;border:none;border-radius:0;outline:none;margin:auto;word-break:break-word;max-height:100%;min-height:0;bottom:auto;overflow:auto;display:flex;flex-direction:column;}.ui89-modal-dialog__spacer{min-height:0;height:100px;}.ui89-modal-dialog__box>*:not(.ui89-modal-dialog__spacer){flex:1 0;min-height:0;}.ui89-modal-dialog__box--size-big{max-width:700px;}.ui89-modal-dialog__box--size-medium{max-width:500px;}.ui89-modal-dialog__box--size-small{max-width:300px;}@keyframes ui89-modal-dialog__appear{from{opacity:0;}to{opacity:1;}}
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -3,7 +3,7 @@ export { Ui89Theme, Ui89Look } from "./theme";
|
|
|
3
3
|
export { Ui89Breadcrumbs } from "./components/Ui89Breadcrumbs";
|
|
4
4
|
export type { Ui89BreadcrumbsProps, Ui89BreadcrumbsPropsItem, Ui89BreadcrumbsPropsOnSelect, } from "./components/Ui89Breadcrumbs";
|
|
5
5
|
export { Ui89Button } from "./components/Ui89Button";
|
|
6
|
-
export type { Ui89ButtonProps, Ui89ButtonPropsSize, } from "./components/Ui89Button";
|
|
6
|
+
export type { Ui89ButtonProps, Ui89ButtonPropsSize, Ui89ButtonPropsType, } from "./components/Ui89Button";
|
|
7
7
|
export { Ui89Card } from "./components/Ui89Card";
|
|
8
8
|
export type { Ui89CardProps } from "./components/Ui89Card";
|
|
9
9
|
export { Ui89CardHorizontalConnection } from "./components/Ui89CardHorizontalConnection";
|
|
@@ -32,6 +32,8 @@ export { Ui89InputText } from "./components/Ui89InputText";
|
|
|
32
32
|
export type { Ui89InputTextProps } from "./components/Ui89InputText";
|
|
33
33
|
export { Ui89InputTextNumber } from "./components/Ui89InputTextNumber";
|
|
34
34
|
export type { Ui89InputTextNumberProps } from "./components/Ui89InputTextNumber";
|
|
35
|
+
export { Ui89LinkStealth } from "./components/Ui89LinkStealth";
|
|
36
|
+
export type { Ui89LinkStealthProps } from "./components/Ui89LinkStealth";
|
|
35
37
|
export { Ui89LinkUnderline } from "./components/Ui89LinkUnderline";
|
|
36
38
|
export type { Ui89LinkUnderlineProps } from "./components/Ui89LinkUnderline";
|
|
37
39
|
export { Ui89MenuBar } from "./components/Ui89MenuBar";
|
package/dist/esm/index.js
CHANGED
|
@@ -66,7 +66,12 @@ var Ui89ButtonPropsSize;
|
|
|
66
66
|
Ui89ButtonPropsSize["standard"] = "standard";
|
|
67
67
|
Ui89ButtonPropsSize["square"] = "square";
|
|
68
68
|
})(Ui89ButtonPropsSize || (Ui89ButtonPropsSize = {}));
|
|
69
|
-
|
|
69
|
+
var Ui89ButtonPropsType;
|
|
70
|
+
(function (Ui89ButtonPropsType) {
|
|
71
|
+
Ui89ButtonPropsType["submit"] = "submit";
|
|
72
|
+
Ui89ButtonPropsType["reset"] = "reset";
|
|
73
|
+
})(Ui89ButtonPropsType || (Ui89ButtonPropsType = {}));
|
|
74
|
+
function Ui89Button({ theme = Ui89Theme.primary, size = Ui89ButtonPropsSize.standard, type, block, onClick, href, children, autoDisableOnClick = true, disabled, activated, }) {
|
|
70
75
|
const overrides = useUi89Overrides();
|
|
71
76
|
const [clicking, setClicking] = useState(false);
|
|
72
77
|
let localDisabled = disabled || (autoDisableOnClick && clicking);
|
|
@@ -127,7 +132,7 @@ function Ui89Button({ theme = Ui89Theme.primary, size = Ui89ButtonPropsSize.stan
|
|
|
127
132
|
].join(" ");
|
|
128
133
|
return (React__default.createElement("div", { className: containerClass },
|
|
129
134
|
React__default.createElement(HoverShadow, null, href ? (React__default.createElement("a", { className: "ui-89-reset-a", role: "button", href: href, onClick: onAnchorClick },
|
|
130
|
-
React__default.createElement("span", { className: buttonClass }, children))) : (React__default.createElement("button", { className: "ui-89-reset-button", type: "button", onClick: onButtonClick, disabled: localDisabled },
|
|
135
|
+
React__default.createElement("span", { className: buttonClass }, children))) : (React__default.createElement("button", { className: "ui-89-reset-button", type: type || "button", onClick: onButtonClick, disabled: localDisabled },
|
|
131
136
|
React__default.createElement("span", { className: buttonClass }, children))))));
|
|
132
137
|
}
|
|
133
138
|
|
|
@@ -546,7 +551,7 @@ function Ui89InputPassword({ value, placeholder, onChange, }) {
|
|
|
546
551
|
React__default.createElement("input", { type: "password", className: `ui89-input-box ui89-typo-special`, role: "textbox", value: intermediateValue, onChange: implOnChange, placeholder: placeholder })));
|
|
547
552
|
}
|
|
548
553
|
|
|
549
|
-
function
|
|
554
|
+
function Ui89LinkBase(props) {
|
|
550
555
|
const overrides = useUi89Overrides();
|
|
551
556
|
const [clicking, setClicking] = useState(false);
|
|
552
557
|
let localDisabled = props.disabled || ((props.autoDisableOnClick ?? true) && clicking);
|
|
@@ -579,8 +584,15 @@ function Ui89LinkUnderline(props) {
|
|
|
579
584
|
setClicking(false);
|
|
580
585
|
}
|
|
581
586
|
}
|
|
582
|
-
|
|
583
|
-
|
|
587
|
+
return (React__default.createElement("a", { className: `ui-89-reset-a ${props.className}`, role: "link", href: props.href, onClick: onClick }, props.children));
|
|
588
|
+
}
|
|
589
|
+
|
|
590
|
+
function Ui89LinkStealth(props) {
|
|
591
|
+
return React__default.createElement(Ui89LinkBase, { className: "ui89-link-stealth", ...props });
|
|
592
|
+
}
|
|
593
|
+
|
|
594
|
+
function Ui89LinkUnderline(props) {
|
|
595
|
+
return React__default.createElement(Ui89LinkBase, { className: "ui89-link-underline", ...props });
|
|
584
596
|
}
|
|
585
597
|
|
|
586
598
|
function Ui89MenuBar({ items }) {
|
|
@@ -805,12 +817,23 @@ const useScrollYPosition = (ref) => {
|
|
|
805
817
|
return scrollY;
|
|
806
818
|
};
|
|
807
819
|
|
|
820
|
+
function popAnyEntry(map) {
|
|
821
|
+
const iterator = map.keys().next();
|
|
822
|
+
if (!iterator.done) {
|
|
823
|
+
const key = iterator.value;
|
|
824
|
+
const value = map.get(key);
|
|
825
|
+
map.delete(key);
|
|
826
|
+
return value;
|
|
827
|
+
}
|
|
828
|
+
return undefined;
|
|
829
|
+
}
|
|
808
830
|
/**
|
|
809
831
|
* Virtualization at row level. Great for long lists.
|
|
810
832
|
*
|
|
811
833
|
* Can be used to implement table components with few columns.
|
|
812
834
|
*/
|
|
813
835
|
const Ui89VirtualList = React__default.memo((props) => {
|
|
836
|
+
const keyCounter = useRef(0);
|
|
814
837
|
const scrollContainer = useRef(null);
|
|
815
838
|
const scrollAreaContainer = useRef(null);
|
|
816
839
|
const { size } = useResizeObserver(scrollContainer);
|
|
@@ -825,28 +848,53 @@ const Ui89VirtualList = React__default.memo((props) => {
|
|
|
825
848
|
}
|
|
826
849
|
const firstIndex = Math.max(0, Math.floor(scrollY / rowHeight) - 1);
|
|
827
850
|
const length = Math.min(props.rows.length - firstIndex, Math.ceil(size.height / rowHeight) + 2);
|
|
851
|
+
const deletedRows = new Map(visibleRows);
|
|
852
|
+
// Must find the ones that are no longer visible.
|
|
853
|
+
for (let index = firstIndex; index < firstIndex + length; index++) {
|
|
854
|
+
let row = props.rows[index];
|
|
855
|
+
let key = props.getRowKey ? props.getRowKey(row) : String(index);
|
|
856
|
+
deletedRows.delete(key);
|
|
857
|
+
}
|
|
828
858
|
const newVisibleRows = new Map();
|
|
829
859
|
for (let index = firstIndex; index < firstIndex + length; index++) {
|
|
830
860
|
let row = props.rows[index];
|
|
831
861
|
let key = props.getRowKey ? props.getRowKey(row) : String(index);
|
|
832
862
|
let existingRow = visibleRows.get(key);
|
|
833
863
|
if (existingRow !== undefined) {
|
|
834
|
-
if (existingRow.row === row)
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
|
|
864
|
+
if (existingRow.row === row) ;
|
|
865
|
+
else {
|
|
866
|
+
// Data has changed, must update render.
|
|
867
|
+
existingRow.render = props.renderRow({ index, row });
|
|
838
868
|
}
|
|
869
|
+
newVisibleRows.set(key, existingRow);
|
|
870
|
+
continue;
|
|
839
871
|
}
|
|
840
|
-
|
|
841
|
-
|
|
842
|
-
|
|
843
|
-
|
|
844
|
-
|
|
845
|
-
|
|
846
|
-
|
|
872
|
+
let oldRow = popAnyEntry(deletedRows);
|
|
873
|
+
if (oldRow !== undefined) {
|
|
874
|
+
oldRow.index = index;
|
|
875
|
+
oldRow.row = row;
|
|
876
|
+
oldRow.userKey = key;
|
|
877
|
+
oldRow.render = props.renderRow({ index, row });
|
|
878
|
+
oldRow.style = {
|
|
879
|
+
transform: `translateY(${index * rowHeight}px)`,
|
|
847
880
|
height: `${rowHeight}px`,
|
|
848
|
-
}
|
|
849
|
-
|
|
881
|
+
};
|
|
882
|
+
newVisibleRows.set(key, oldRow);
|
|
883
|
+
}
|
|
884
|
+
else {
|
|
885
|
+
// New row.
|
|
886
|
+
newVisibleRows.set(key, {
|
|
887
|
+
index,
|
|
888
|
+
row,
|
|
889
|
+
key: keyCounter.current++,
|
|
890
|
+
userKey: key,
|
|
891
|
+
render: props.renderRow({ index, row }),
|
|
892
|
+
style: {
|
|
893
|
+
transform: `translateY(${index * rowHeight}px)`,
|
|
894
|
+
height: `${rowHeight}px`,
|
|
895
|
+
},
|
|
896
|
+
});
|
|
897
|
+
}
|
|
850
898
|
}
|
|
851
899
|
setVisibleRows(newVisibleRows);
|
|
852
900
|
}, [props.rows, scrollY, size.height]);
|
|
@@ -941,5 +989,5 @@ const Ui89VirtualTable = React__default.memo((props) => {
|
|
|
941
989
|
React__default.createElement(Ui89TagBox, { theme: "warning" }, "Empty")))));
|
|
942
990
|
});
|
|
943
991
|
|
|
944
|
-
export { Ui89Breadcrumbs, Ui89Button, Ui89Card, Ui89CardHorizontalConnection, Ui89DateTimePicker, Ui89DigitalClock, Ui89HighlightText, Ui89Hr, Ui89InputCheckBox, Ui89InputCheckText, Ui89InputFileUpload, Ui89InputNumber, Ui89InputPassword, Ui89InputSelect, Ui89InputText, Ui89InputTextNumber, Ui89LinkUnderline, Ui89Look, Ui89MenuBar, Ui89ModalDialog, Ui89NameValuePair, Ui89OverrideProvider, Ui89Scene, Ui89Shortcut, Ui89SpacePadding, Ui89SpaceVertical, Ui89TabbedCard, Ui89Tabs, Ui89TagBox, Ui89Theme, Ui89ThemeBackground, Ui89TitleBox, Ui89TitleUnderline, Ui89Toaster, Ui89VirtualList, Ui89VirtualTable, useUi89Toaster };
|
|
992
|
+
export { Ui89Breadcrumbs, Ui89Button, Ui89Card, Ui89CardHorizontalConnection, Ui89DateTimePicker, Ui89DigitalClock, Ui89HighlightText, Ui89Hr, Ui89InputCheckBox, Ui89InputCheckText, Ui89InputFileUpload, Ui89InputNumber, Ui89InputPassword, Ui89InputSelect, Ui89InputText, Ui89InputTextNumber, Ui89LinkStealth, Ui89LinkUnderline, Ui89Look, Ui89MenuBar, Ui89ModalDialog, Ui89NameValuePair, Ui89OverrideProvider, Ui89Scene, Ui89Shortcut, Ui89SpacePadding, Ui89SpaceVertical, Ui89TabbedCard, Ui89Tabs, Ui89TagBox, Ui89Theme, Ui89ThemeBackground, Ui89TitleBox, Ui89TitleUnderline, Ui89Toaster, Ui89VirtualList, Ui89VirtualTable, useUi89Toaster };
|
|
945
993
|
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/theme.ts","../../src/Ui89Override.tsx","../../src/components/Ui89Breadcrumbs.tsx","../../src/components/private/HoverShadow.tsx","../../src/components/Ui89Button.tsx","../../src/components/Ui89Card.tsx","../../src/components/Ui89CardHorizontalConnection.tsx","../../src/components/Ui89DateTimePicker.tsx","../../src/components/private/TimeAnimation.tsx","../../src/date-utils.ts","../../src/components/Ui89DigitalClock.tsx","../../src/components/Ui89HighlightText.tsx","../../src/components/Ui89Hr.tsx","../../src/components/Ui89InputCheckBox.tsx","../../src/components/Ui89InputCheckText.tsx","../../src/components/Ui89InputFileUpload.tsx","../../src/components/Ui89InputSelect.tsx","../../src/timeout.ts","../../src/useDelayedOnChange.ts","../../src/components/Ui89InputText.tsx","../../src/text-utils.ts","../../src/components/Ui89InputTextNumber.tsx","../../src/components/Ui89InputNumber.tsx","../../src/components/Ui89InputPassword.tsx","../../src/components/Ui89LinkUnderline.tsx","../../src/components/Ui89MenuBar.tsx","../../src/components/Ui89Scene.tsx","../../src/components/private/GridExpandTrick.tsx","../../src/components/private/ScrollContainer.tsx","../../src/components/Ui89ModalDialog.tsx","../../src/components/Ui89NameValuePair.tsx","../../src/images/shortcut.svg","../../src/components/Ui89SpaceVertical.tsx","../../src/components/Ui89Shortcut.tsx","../../src/components/Ui89SpacePadding.tsx","../../src/components/Ui89Tabs.tsx","../../src/components/Ui89TabbedCard.tsx","../../src/components/Ui89TagBox.tsx","../../src/components/Ui89ThemeBackground.tsx","../../src/components/Ui89TitleBox.tsx","../../src/components/Ui89TitleUnderline.tsx","../../src/components/Ui89Toaster.tsx","../../src/useResizeObserver.ts","../../src/useScrollYPosition.ts","../../src/components/Ui89VirtualList.tsx","../../src/components/Ui89VirtualTable.tsx"],"sourcesContent":["export enum Ui89Theme {\n primary = \"primary\",\n secondary = \"secondary\",\n info = \"info\",\n success = \"success\",\n warning = \"warning\",\n danger = \"danger\",\n}\n\nexport enum Ui89Look {\n main = \"main\",\n side = \"side\",\n}\n","import React, { createContext, useContext, ReactNode } from \"react\"\n\ntype RouterPush = (url: string) => void | Promise<void>\n\ninterface Ui89OverrideContextType {\n routerPush?: RouterPush\n}\n\nexport interface Ui89OverrideProviderProps {\n children?: ReactNode\n routerPush?: RouterPush\n}\n\nconst Ui89OverrideContext = createContext<Ui89OverrideContextType>({})\n\nexport const Ui89OverrideProvider: React.FC<Ui89OverrideProviderProps> = ({\n routerPush,\n children,\n}) => {\n return (\n <Ui89OverrideContext.Provider value={{ routerPush }}>\n {children}\n </Ui89OverrideContext.Provider>\n )\n}\n\nexport const useUi89Overrides = (): Ui89OverrideContextType => {\n const context = useContext(Ui89OverrideContext)\n\n if (context === undefined) {\n throw new Error(\n \"useUi89Overrides must be used within a Ui89OverrideProvider\",\n )\n }\n\n return context\n}\n","import React, { useState } from \"react\"\n\nimport \"./Ui89Breadcrumbs.css\"\nimport \"../style/typo.css\"\nimport \"../style/reset.css\"\nimport \"../style/chosen-theme.css\"\n\nimport { Ui89Theme } from \"../theme\"\nimport { useUi89Overrides } from \"../Ui89Override\"\n\nexport type Ui89BreadcrumbsPropsOnSelect = (e: {\n item: Ui89BreadcrumbsPropsItem\n}) => void | Promise<void>\n\nexport interface Ui89BreadcrumbsPropsItem {\n label: React.ReactNode\n url?: string\n}\n\nexport interface Ui89BreadcrumbsProps {\n theme?: Ui89Theme | keyof typeof Ui89Theme\n items: Ui89BreadcrumbsPropsItem[]\n onSelect?: Ui89BreadcrumbsPropsOnSelect\n}\n\nexport function Ui89BreadcrumbsItem({\n index,\n item,\n onSelect,\n}: {\n index: number\n item: Ui89BreadcrumbsPropsItem\n onSelect?: Ui89BreadcrumbsPropsOnSelect\n}) {\n const style = { \"--ui89-index\": index } as React.CSSProperties\n const tagname = item.url !== undefined ? \"a\" : \"div\"\n const overrides = useUi89Overrides()\n\n const onClick: React.MouseEventHandler<HTMLAnchorElement> = (e) => {\n if (item.url !== undefined) {\n if (item.url.startsWith(\"/\")) {\n if (overrides.routerPush !== undefined) {\n e.preventDefault()\n overrides.routerPush(item.url)\n }\n }\n }\n }\n\n return (\n <a\n className={`ui-89-reset-a ui89-breadcrumbs__item`}\n href={item.url}\n style={style}\n onClick={onClick}\n >\n <div className=\"ui89-breadcrumbs__item__background\"></div>\n {item.label}\n </a>\n )\n}\n\nexport function Ui89Breadcrumbs({\n theme = Ui89Theme.primary,\n items,\n onSelect,\n}: Ui89BreadcrumbsProps) {\n return (\n <div\n className={`ui89-breadcrumbs ui89-typo-special ui89-chosen-theme-${theme}`}\n >\n {[...items.entries()].reverse().map(([index, item]) => (\n <Ui89BreadcrumbsItem\n key={index}\n index={index}\n item={item}\n onSelect={onSelect}\n />\n ))}\n </div>\n )\n}\n","import React from \"react\"\nimport \"./HoverShadow.css\"\n\nexport default function HoverShadow({\n children,\n}: {\n children: React.ReactNode\n}) {\n return (\n <span className=\"ui89-hover-shadow\">\n <span className=\"ui89-hover-shadow__bottom\"></span>\n <span className=\"ui89-hover-shadow__right\"></span>\n {children}\n </span>\n )\n}\n","import React, { useState } from \"react\"\n\nimport \"./Ui89Button.css\"\nimport \"../style/typo.css\"\nimport \"../style/chosen-theme.css\"\nimport \"../style/reset.css\"\n\nimport HoverShadow from \"./private/HoverShadow\"\n\nimport { Ui89Theme } from \"../theme\"\nimport { useUi89Overrides } from \"../Ui89Override\"\n\nexport enum Ui89ButtonPropsSize {\n standard = \"standard\",\n square = \"square\",\n}\n\nexport interface Ui89ButtonProps {\n theme?: Ui89Theme | keyof typeof Ui89Theme\n size?: Ui89ButtonPropsSize | keyof typeof Ui89ButtonPropsSize\n block?: boolean\n onClick?: () => void | Promise<void>\n href?: string\n children: React.ReactNode\n autoDisableOnClick?: boolean\n disabled?: boolean\n activated?: boolean\n}\n\nexport function Ui89Button({\n theme = Ui89Theme.primary,\n size = Ui89ButtonPropsSize.standard,\n block,\n onClick,\n href,\n children,\n autoDisableOnClick = true,\n disabled,\n activated,\n}: Ui89ButtonProps) {\n const overrides = useUi89Overrides()\n const [clicking, setClicking] = useState(false)\n\n let localDisabled = disabled || (autoDisableOnClick && clicking)\n\n async function onAnchorClick(e: React.MouseEvent<HTMLAnchorElement>) {\n if (localDisabled) {\n // The anchor tag does not support the disabled attribute so we do this.\n return\n }\n\n if (clicking) {\n // No double clicking allowed.\n return\n }\n\n try {\n setClicking(true)\n\n if (href !== undefined) {\n if (href.startsWith(\"/\")) {\n if (overrides.routerPush !== undefined) {\n e.preventDefault()\n overrides.routerPush(href)\n }\n }\n }\n } finally {\n setClicking(false)\n }\n }\n\n async function onButtonClick(e: React.MouseEvent<HTMLButtonElement>) {\n if (localDisabled) {\n // The anchor tag does not support the disabled attribute so we do this.\n return\n }\n\n if (clicking) {\n // No double clicking allowed.\n return\n }\n\n try {\n setClicking(true)\n\n if (onClick === undefined) {\n // No handler.\n return\n }\n\n await onClick()\n } finally {\n setClicking(false)\n }\n }\n\n let containerClass = [\"ui89-button\", `ui89-button--size-${size}`].join(\" \")\n\n let buttonClass = [\n \"ui89-button__button\",\n \"ui89-typo-special\",\n `ui89-chosen-theme-${theme}`,\n activated ? \"ui89-button__button--active\" : undefined,\n block ? \"ui89-button__button--block\" : undefined,\n disabled ? \"ui89-button__button--disabled\" : undefined,\n clicking ? \"ui89-button__button--active\" : undefined,\n ].join(\" \")\n\n return (\n <div className={containerClass}>\n <HoverShadow>\n {href ? (\n <a\n className=\"ui-89-reset-a\"\n role=\"button\"\n href={href}\n onClick={onAnchorClick}\n >\n <span className={buttonClass}>{children}</span>\n </a>\n ) : (\n <button\n className=\"ui-89-reset-button\"\n type=\"button\"\n onClick={onButtonClick}\n disabled={localDisabled}\n >\n <span className={buttonClass}>{children}</span>\n </button>\n )}\n </HoverShadow>\n </div>\n )\n}\n","import React from \"react\"\nimport \"./Ui89Card.css\"\n\nexport interface Ui89CardProps {\n topLeftCenter?: React.ReactNode\n topCenter?: React.ReactNode\n children: React.ReactNode\n}\n\nexport function Ui89Card({\n topLeftCenter,\n topCenter,\n children,\n}: Ui89CardProps) {\n const hasTopContent = topLeftCenter || topCenter\n\n return (\n <div className={`ui89-card ${hasTopContent ? \"ui89-card--has-top\" : \"\"}`}>\n <div className=\"ui89-card__inside\">\n {topLeftCenter && (\n <div className=\"ui89-card__top-left-center\">{topLeftCenter}</div>\n )}\n {topCenter && <div className=\"ui89-card__top-center\">{topCenter}</div>}\n\n {hasTopContent && <div className=\"space-vertical-1\"></div>}\n\n {children}\n\n {hasTopContent && <div className=\"space-vertical-1\"></div>}\n </div>\n </div>\n )\n}\n","import React from \"react\"\nimport \"./Ui89Card.css\"\n\nexport interface Ui89CardHorizontalConnectionProps {\n children: React.ReactNode\n overflow?: boolean\n}\n\nexport function Ui89CardHorizontalConnection({\n children,\n overflow,\n}: Ui89CardHorizontalConnectionProps) {\n return (\n <div\n className={`ui89-card__horizontal-connection ${overflow ? \"ui89-card__horizontal-connection--overflow\" : \"\"}`}\n >\n {children}\n </div>\n )\n}\n","import React from \"react\"\nimport DatePicker from \"react-datepicker\"\n\nimport \"../../node_modules/react-datepicker/dist/react-datepicker.css\"\nimport \"./Ui89DateTimePicker.css\"\n\nimport \"../style/input-box.css\"\nimport \"../style/typo.css\"\n\nexport interface Ui89DateTimePickerProps {\n value?: Date | null\n onChange?: (value: Date | null) => void\n}\n\nexport function Ui89DateTimePicker(props: Ui89DateTimePickerProps) {\n function datepickerOnChange(value: Date | null) {\n if (props.onChange) {\n props.onChange(value)\n }\n }\n\n return (\n <span className=\"ui89-date-time-picker\">\n <DatePicker\n className={[\"ui89-input-box\", \"ui89-typo-normal\"].join(\" \")}\n calendarClassName=\"ui89-typo-normal\"\n showTimeSelect\n dateFormat=\"MM/dd/yyyy HH:mm:ss\"\n timeFormat=\"HH:mm\"\n selected={props.value}\n onChange={datepickerOnChange}\n popperPlacement=\"bottom-start\"\n />\n </span>\n )\n}\n","import React, { useState, useEffect } from \"react\"\n\nexport interface TimeAnimationPropsChildrenProps {\n now: Date\n}\n\nexport interface TimeAnimationProps {\n children: (props: TimeAnimationPropsChildrenProps) => React.ReactNode\n}\n\nexport const TimeAnimation: React.FC<TimeAnimationProps> = ({ children }) => {\n const [currentTime, setCurrentTime] = useState(new Date())\n\n useEffect(() => {\n const tick = () => {\n const now = new Date()\n setCurrentTime(now)\n\n // Calculate time until the next exact second\n const msUntilNextSecond = 1000 - now.getMilliseconds()\n setTimeout(tick, msUntilNextSecond)\n }\n\n // Start the first tick\n const msUntilNextSecond = 1000 - currentTime.getMilliseconds()\n const timeoutId = setTimeout(tick, msUntilNextSecond)\n\n return () => clearTimeout(timeoutId)\n }, [])\n\n return <>{children({ now: currentTime })}</>\n}\n","export interface DateComponents {\n hours: number\n minutes: number\n seconds: number\n milliseconds: number\n day: number\n month: number\n year: number\n}\n\nfunction dateComponents(date: Date): DateComponents {\n return {\n hours: date.getHours(),\n minutes: date.getMinutes(),\n seconds: date.getSeconds(),\n milliseconds: date.getMilliseconds(),\n day: date.getDate(),\n month: date.getMonth() + 1,\n year: date.getFullYear(),\n }\n}\n\nexport function dateFormat(date: Date, format: string) {\n const placeholders: Record<string, string> = {\n YYYY: date.getFullYear().toString(),\n MM: (date.getMonth() + 1).toString().padStart(2, \"0\"),\n DD: date.getDate().toString().padStart(2, \"0\"),\n HH: date.getHours().toString().padStart(2, \"0\"),\n mm: date.getMinutes().toString().padStart(2, \"0\"),\n ss: date.getSeconds().toString().padStart(2, \"0\"),\n hh: (date.getHours() % 12 || 12).toString().padStart(2, \"0\"),\n A: date.getHours() >= 12 ? \"PM\" : \"AM\",\n }\n\n // Replace placeholders in the format string\n let formattedDate = format\n for (const [key, value] of Object.entries(placeholders)) {\n formattedDate = formattedDate.replace(key, value)\n }\n\n return formattedDate\n}\n","import React, { useRef } from \"react\"\nimport \"../style/typo.css\"\nimport {\n TimeAnimation,\n TimeAnimationPropsChildrenProps,\n} from \"./private/TimeAnimation\"\nimport { dateFormat } from \"../date-utils\"\n\nexport interface Ui89DigitalClockProps {\n format?: string // Custom format string\n}\n\nexport function Ui89DigitalClock({\n format = \"HH:mm:ss\",\n}: Ui89DigitalClockProps) {\n function render({ now }: TimeAnimationPropsChildrenProps) {\n return dateFormat(now, format)\n }\n\n return (\n <span className=\"ui89-typo-special\">\n <TimeAnimation>{render}</TimeAnimation>\n </span>\n )\n}\n","import React from \"react\"\n\nimport { Ui89Theme } from \"../theme\"\nimport \"../style/chosen-theme.css\"\n\nimport \"./Ui89HighlightText.css\"\n\nexport interface Ui89HighlightTextProps {\n theme: Ui89Theme | keyof typeof Ui89Theme\n block?: boolean\n children: React.ReactNode\n}\n\nexport function Ui89HighlightText({\n theme,\n block,\n children,\n}: Ui89HighlightTextProps) {\n return (\n <span\n className={`ui89-highlight-text ui89-chosen-theme-${theme} ${block ? \"ui89-highlight-text--block\" : null}`}\n >\n {children}\n </span>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89Hr.css\"\nimport { Ui89Theme } from \"../theme\"\nimport \"../style/chosen-theme.css\"\n\nexport enum Ui89HrPropsLook {\n straight = \"straight\",\n dotted = \"dotted\",\n dashed = \"dashed\",\n double = \"double\",\n}\n\nexport interface Ui89HrProps {\n look?: Ui89HrPropsLook | keyof typeof Ui89HrPropsLook\n theme?: Ui89Theme | keyof typeof Ui89Theme\n}\n\nexport function Ui89Hr({ look = \"straight\", theme }: Ui89HrProps) {\n return (\n <div\n className={`ui-89-hr ${`ui-89-hr--${look}`} ${theme !== undefined ? \"ui-89-hr--use-theme\" : \"\"} ${theme !== undefined ? `ui89-chosen-theme-${theme}` : \"\"}`}\n >\n <div className=\"ui-89-hr__double\"></div>\n </div>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89InputCheckBox.css\"\n\nexport interface Ui89InputCheckBoxProps {\n value: boolean\n onChange?: (value: boolean) => void\n}\n\nexport function Ui89InputCheckBox(props: Ui89InputCheckBoxProps) {\n function toggle() {\n if (props.onChange) {\n props.onChange(!props.value)\n }\n }\n\n return (\n <span className=\"ui89-input-check-box\" onClick={toggle}>\n <span className=\"ui89-input-check-box__x\">\n {props.value ? <>X</> : <> </>}\n </span>\n </span>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89InputCheckText.css\"\n\nexport interface Ui89InputCheckTextProps {\n value: any\n onChange?: (value: boolean) => void\n}\n\nexport function Ui89InputCheckText(props: Ui89InputCheckTextProps) {\n function toggle() {\n if (props.onChange) {\n props.onChange(!props.value)\n }\n }\n\n return (\n <span className=\"ui89-input-check-text\" onClick={toggle}>\n {props.value ? \"[X]\" : \"[ ]\"}\n </span>\n )\n}\n","import React, { useRef } from \"react\"\n\nimport \"./Ui89InputFileUpload.css\"\nimport \"../style/typo.css\"\nimport \"../style/text.css\"\nimport { Ui89Button } from \"./Ui89Button\"\n\nexport interface Ui89InputFileUploadProps {\n value?: any\n onChange?: (value: File | null) => void\n}\n\nexport function Ui89InputFileUpload({\n value,\n onChange,\n}: Ui89InputFileUploadProps) {\n const inputRef = useRef<HTMLInputElement>(null)\n\n function implOnChange(e: React.ChangeEvent<HTMLInputElement>) {\n if (!onChange) {\n return\n }\n\n if (e.target.files === null) {\n onChange(null)\n return\n }\n\n if (e.target.files.length === 0) {\n onChange(null)\n return\n }\n\n onChange(e.target.files[0])\n }\n\n function onClick() {\n if (inputRef.current === null) {\n return\n }\n\n inputRef.current.click()\n }\n\n return (\n <div>\n <input\n ref={inputRef}\n className=\"ui89-typo-special\"\n type=\"file\"\n onChange={implOnChange}\n hidden\n />\n\n {value ? (\n <div className=\"ui89-input-file-upload\">\n <Ui89Button onClick={onClick}>Change</Ui89Button>\n <span\n className={`ui89-input-file-upload__info ui89-text-single-line ui89-text-single-line--ellipsis-left`}\n title={value.name}\n >\n {value.name}\n </span>\n </div>\n ) : (\n <Ui89Button onClick={onClick}>Upload</Ui89Button>\n )}\n </div>\n )\n}\n","import React, { useMemo, useState } from \"react\"\n\nimport \"./Ui89InputSelect.css\"\nimport \"../style/input-box.css\"\nimport \"../style/text.css\"\n\nexport interface Ui89InputSelectProps<T> {\n /**\n * Available options.\n */\n options?: T[]\n\n /**\n * The selected option.\n */\n value?: T\n\n /**\n * Called whenever an option is selected.\n */\n onChange?: (option: T) => void\n\n /**\n * Retrieves the value that uniquely identifies the option. This is what is\n * used to determine which option is currently selected.\n */\n getOptionKey?: (option: T) => any\n\n /**\n * Customize how an option should be rendered.\n */\n renderOption?: (option: T) => any\n}\n\n/**\n * This is a very performant and customizable dropdown selector that\n * allows you to choose from a list of options.\n */\nexport function Ui89InputSelect<T>(props: Ui89InputSelectProps<T>) {\n const getOptionKey = useMemo(() => {\n return props.getOptionKey ?? ((option: any) => option)\n }, [props.getOptionKey])\n\n const options = useMemo(() => {\n if (props.options === undefined) {\n return []\n }\n\n return props.options\n }, [props.options])\n\n const optionsMap = useMemo(() => {\n return new Map(options.map((option) => [getOptionKey(option), option]))\n }, [options])\n\n function isOptionSelected(option: T) {\n if (props.value === undefined) {\n // Definitely not selected.\n return false\n }\n\n return getOptionKey(option) === getOptionKey(props.value)\n }\n\n function selectOption(option: T) {\n if (props.onChange !== undefined) {\n props.onChange(option)\n }\n\n if (document.activeElement !== null) {\n // @ts-expect-error\n document.activeElement.blur()\n }\n }\n\n function optionTitle(option: T) {\n return String(option)\n }\n\n return (\n <div className=\"ui89-input-select\">\n <div\n className={[\n \"ui89-input-box\",\n \"ui89-input-box--unselectable\",\n \"ui89-input-box--clickable\",\n \"ui89-text-single-line\",\n ].join(\" \")}\n tabIndex={0}\n title={props.value !== undefined ? optionTitle(props.value) : undefined}\n >\n {props.value !== undefined ? (\n <>\n {props.renderOption !== undefined\n ? props.renderOption(props.value)\n : props.value}\n </>\n ) : (\n <>Select...</>\n )}\n </div>\n\n <div className=\"ui89-input-select__menu\" tabIndex={0}>\n <div className=\"ui89-input-select__menu__content\">\n {options.length > 0 ? (\n options.map((o) => {\n const isSelected = isOptionSelected(o)\n\n return (\n <div\n className={[\n \"ui89-input-select__menu__item\",\n isSelected\n ? \"ui89-input-select__menu__item--selected\"\n : null,\n ].join(\" \")}\n title={optionTitle(o)}\n key={getOptionKey(o)}\n onClick={() => selectOption(o)}\n >\n {props.renderOption !== undefined ? props.renderOption(o) : o}\n </div>\n )\n })\n ) : (\n <div\n className={[\n \"ui89-input-select__menu__item\",\n \"ui89-input-select__menu__item--disabled\",\n ].join(\" \")}\n >\n <empty>\n </div>\n )}\n </div>\n </div>\n </div>\n )\n}\n","import Timeout from \"smart-timeout\"\n\nlet uniqueId = 0\n\nexport function throttledTimeout() {\n const id = String(uniqueId++)\n let callback: () => void\n\n return {\n call(delay: number, f: () => void) {\n callback = f\n\n if (Timeout.pending(id)) {\n Timeout.restart(id)\n } else {\n Timeout.set(id, () => callback(), delay)\n }\n },\n\n /**\n * If there is a call that has been scheduled, remove it from the queue.\n */\n abort() {\n Timeout.clear(id, true)\n },\n }\n}\n\nexport function spacedTimeout() {\n const id = String(uniqueId++)\n let callback: () => void\n\n return {\n call(delay: number, f: () => void) {\n callback = f\n\n if (!Timeout.pending(id)) {\n Timeout.set(id, () => callback(), delay)\n }\n },\n }\n}\n","import { useEffect, useRef, useState } from \"react\"\nimport { throttledTimeout } from \"./timeout\"\n\ninterface UseDelayedOnChangeState {\n value: any\n setValue: (newVal: any) => void\n onChange: (newVal: any) => void\n onFocus: () => void\n onBlur: () => void\n}\n\nexport function useDelayedOnChange(props: {\n defaultValue?: any\n value: any\n onChange?: (value: any) => void\n filter?: (value: any) => any\n}): UseDelayedOnChangeState {\n const onChangeRef = useRef(props.onChange)\n\n useEffect(() => {\n onChangeRef.current = props.onChange\n }, [props.onChange])\n\n const [intermediateValue, setIntermediateValue] = useState<any>(\n props.defaultValue || props.value,\n )\n\n useEffect(() => {\n stateRef.current.setValue(props.value)\n }, [props.value])\n\n function callOnChange() {\n let newVal = stateRef.current.value\n\n if (props.filter !== undefined) {\n newVal = props.filter(newVal)\n }\n\n onChangeRef.current?.call(null, newVal)\n return newVal\n }\n\n class StateUnknown implements UseDelayedOnChangeState {\n state = \"unknown\"\n\n value: any\n\n throttledTimeout: any\n\n constructor() {\n this.throttledTimeout = throttledTimeout()\n }\n\n setValue(newVal: any) {\n setIntermediateValue(newVal)\n }\n\n onChange(newVal: any) {\n setIntermediateValue(newVal)\n stateRef.current.throttledTimeout.call(300, callOnChange)\n }\n\n onFocus() {\n let newState = new StateFocus()\n newState.value = stateRef.current.value\n setState(newState)\n }\n\n onBlur() {}\n }\n\n class StateFocus implements UseDelayedOnChangeState {\n state = \"focus\"\n\n value: any\n\n throttledTimeout: any\n\n constructor() {\n this.throttledTimeout = throttledTimeout()\n }\n\n setValue(newVal: any) {\n // Ignore.\n }\n\n onChange(newVal: any) {\n setIntermediateValue(newVal)\n stateRef.current.throttledTimeout.call(300, callOnChange)\n }\n\n onFocus() {}\n\n onBlur() {\n let newVal = callOnChange()\n setIntermediateValue(newVal)\n let newState = new StateUnknown()\n newState.value = newVal\n setState(newState)\n }\n }\n\n const [state, setState] = useState<UseDelayedOnChangeState>(() => {\n let newState = new StateUnknown()\n newState.value = intermediateValue\n return newState\n })\n\n const stateRef = useRef(state)\n\n useEffect(() => {\n stateRef.current = state\n }, [state])\n\n stateRef.current.value = intermediateValue\n\n return state\n}\n","import React, { useMemo } from \"react\"\nimport { useState, useEffect, useRef } from \"react\"\nimport { throttledTimeout } from \"../timeout\"\n\nimport \"../style/input-box.css\"\nimport \"../style/typo.css\"\nimport { useDelayedOnChange } from \"../useDelayedOnChange\"\n\nconst THROTTLE_DELAY = 200\n\nexport interface Ui89InputTextProps {\n value?: any\n placeholder?: string\n autoTrim?: boolean\n onChange?: (value: any) => void\n onTyping?: (value: boolean) => void\n onFocus?: () => void\n onBlur?: () => void\n}\n\nfunction convertAnyToText(value: any) {\n return value ?? \"\"\n}\n\nexport function Ui89InputText({\n value,\n placeholder,\n autoTrim = true,\n onChange,\n onTyping,\n onFocus,\n onBlur,\n}: Ui89InputTextProps) {\n const delayedState = useDelayedOnChange({\n defaultValue: \"\",\n value,\n onChange,\n filter(value: any) {\n if (autoTrim) {\n if (typeof value === \"string\") {\n value = value.replace(/\\s+/g, \" \").trim()\n }\n }\n\n return value\n },\n })\n\n return (\n <div>\n <input\n className={`ui89-input-box ui89-typo-special`}\n type=\"text\"\n value={delayedState.value}\n onChange={(e) => delayedState.onChange(e.target.value)}\n onBlur={delayedState.onBlur}\n onFocus={delayedState.onFocus}\n placeholder={placeholder}\n />\n </div>\n )\n}\n","export function stringRemoveAllWhitespace(str: string): string {\n return str.replace(/\\s+/g, \"\")\n}\n","import React from \"react\"\nimport { useState, useEffect } from \"react\"\nimport { Ui89InputText } from \"./Ui89InputText\"\nimport { stringRemoveAllWhitespace } from \"../text-utils\"\n\nexport interface Ui89InputTextNumberProps {\n emptyValue?: any\n value?: any\n min?: number\n max?: number\n onChange?: (value: any) => void\n precision?: number\n}\n\nexport function isTextNumber(text: string): boolean {\n return /\\b\\d+(\\.\\d+)?\\b/.test(text)\n}\n\nfunction displayText(value: any, emptyValue: any) {\n if (value === undefined) {\n // No idea how to display this.\n return \"\"\n } else if (value === emptyValue) {\n // Display emptiness.\n return \"\"\n } else if (isNaN(value)) {\n // No idea what to display.\n return \"\"\n }\n\n return value.toString()\n}\n\nexport function Ui89InputTextNumber({\n /**\n * The value that is emitted when the input is emptied.\n */\n emptyValue = null,\n value,\n min,\n max,\n onChange,\n precision,\n}: Ui89InputTextNumberProps) {\n const [isTyping, setIsTyping] = useState(false)\n const [intermediateValue, setIntermediateValue] = useState(\n displayText(value, emptyValue),\n )\n\n function implOnChange(value: string) {\n if (onChange === undefined) {\n return\n }\n\n if (value === \"\") {\n // Use empty value.\n onChange(emptyValue)\n return\n }\n\n value = stringRemoveAllWhitespace(value)\n\n if (!isTextNumber(value)) {\n // We end here.\n return\n }\n\n const numberValue = Number(value)\n\n if (min !== undefined) {\n if (numberValue <= min) {\n value = String(min)\n }\n }\n\n if (max !== undefined) {\n if (numberValue >= max) {\n value = String(max)\n }\n }\n\n onChange(value)\n }\n\n useEffect(() => {\n if (!isTyping) {\n setIntermediateValue(displayText(value, emptyValue))\n }\n }, [isTyping, value])\n\n return (\n <Ui89InputText\n value={intermediateValue}\n onChange={implOnChange}\n onTyping={setIsTyping}\n />\n )\n}\n","import React from \"react\"\nimport { useMemo } from \"react\"\n\nimport { Ui89InputTextNumber } from \"./Ui89InputTextNumber\"\n\nexport interface Ui89InputNumberProps {\n emptyValue?: any\n value?: any\n min?: number\n max?: number\n onChange?: (value: any) => void\n precision?: number\n}\n\nexport function Ui89InputNumber(props: Ui89InputNumberProps) {\n const wrappedValue = useMemo(() => {\n if (props.value !== undefined && props.value !== null) {\n return Number(props.value)\n } else {\n return undefined\n }\n }, [props.value])\n\n function wrappedOnChange(value: any) {\n if (props.onChange === undefined) {\n return\n }\n\n if (value === props.emptyValue) {\n // Pass along.\n props.onChange(value)\n } else {\n if (value !== undefined && value !== null) {\n props.onChange(Number(value))\n } else {\n props.onChange(null)\n }\n }\n }\n\n return (\n <Ui89InputTextNumber\n emptyValue={props.emptyValue}\n value={wrappedValue}\n onChange={wrappedOnChange}\n min={props.min}\n max={props.max}\n precision={props.precision}\n />\n )\n}\n","import React from \"react\"\nimport { useState } from \"react\"\n\nimport \"../style/input-box.css\"\nimport \"../style/typo.css\"\n\nexport interface Ui89InputPasswordProps {\n value?: any\n placeholder?: string\n onChange?: (value: any) => void\n}\n\nexport function Ui89InputPassword({\n value,\n placeholder,\n onChange,\n}: Ui89InputPasswordProps) {\n const [intermediateValue, setIntermediateValue] = useState(value ?? \"\")\n\n const implOnChange: React.ChangeEventHandler<HTMLInputElement> = (e) => {\n const newValue = e.target.value\n\n setIntermediateValue(newValue)\n\n if (onChange) {\n onChange(newValue)\n }\n }\n\n return (\n <div>\n <input\n type=\"password\"\n className={`ui89-input-box ui89-typo-special`}\n role=\"textbox\"\n value={intermediateValue}\n onChange={implOnChange}\n placeholder={placeholder}\n />\n </div>\n )\n}\n","import React, { useState } from \"react\"\n\nimport \"../style/reset.css\"\nimport \"./Ui89LinkUnderline.css\"\n\nimport { useUi89Overrides } from \"../Ui89Override\"\n\nexport interface Ui89LinkUnderlineProps {\n onClick?: () => void | Promise<void>\n href?: string\n children: React.ReactNode\n autoDisableOnClick?: boolean\n disabled?: boolean\n}\n\nexport function Ui89LinkUnderline(props: Ui89LinkUnderlineProps) {\n const overrides = useUi89Overrides()\n const [clicking, setClicking] = useState(false)\n\n let localDisabled =\n props.disabled || ((props.autoDisableOnClick ?? true) && clicking)\n\n async function onClick(e: React.MouseEvent<HTMLAnchorElement>) {\n if (localDisabled) {\n // The anchor tag does not support the disabled attribute so we do this.\n return\n }\n\n try {\n setClicking(true)\n\n if (props.onClick !== undefined) {\n // A function takes over control.\n e.preventDefault()\n await props.onClick()\n } else if (props.href !== undefined) {\n if (props.href.startsWith(\"/\")) {\n if (overrides.routerPush !== undefined) {\n e.preventDefault()\n overrides.routerPush(props.href)\n }\n }\n } else {\n // Do nothing.\n e.preventDefault()\n }\n } finally {\n setClicking(false)\n }\n }\n\n let containerClass = [\"ui89-link-underline\"].join(\" \")\n\n return (\n <a\n className={`ui-89-reset-a ${containerClass}`}\n role=\"link\"\n href={props.href}\n onClick={onClick}\n >\n {props.children}\n </a>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89MenuBar.css\"\nimport \"../style/typo.css\"\nimport \"../style/scrollbar.css\"\n\nexport interface Ui89MenuBarPropsItem {\n label: React.ReactNode\n onClick?: () => void\n children?: Ui89MenuBarPropsItem[]\n}\n\nexport interface Ui89MenuBarProps {\n items: Ui89MenuBarPropsItem[]\n}\n\nexport function Ui89MenuBar({ items }: Ui89MenuBarProps) {\n return (\n <div className={`ui89-menu-bar ui89-typo-special ui89-scrollbar`}>\n {items.map((item, index) => {\n function onNativeClick() {\n if (item.onClick !== undefined) {\n item.onClick()\n }\n }\n\n return (\n <div\n key={index}\n className=\"ui89-menu-bar__item\"\n onClick={onNativeClick}\n >\n {item.label}\n </div>\n )\n })}\n </div>\n )\n}\n","import React from \"react\"\n\nimport { Ui89Look } from \"../theme\"\n\nimport \"./Ui89Scene.css\"\nimport \"../style/look.css\"\nimport \"../style/typo.css\"\nimport \"../style/scrollbar.css\"\n\nexport interface Ui89SceneProps {\n look?: Ui89Look | string\n children: React.ReactNode\n}\n\nexport function Ui89Scene({ look = Ui89Look.main, children }: Ui89SceneProps) {\n return (\n <div\n className={`ui89-scene ui-89-look-${look} ui89-typo-normal ui89-scrollbar`}\n >\n {children}\n </div>\n )\n}\n","import React from \"react\"\nimport \"./GridExpandTrick.css\"\n\nexport default function GridExpandTrick({\n children,\n}: {\n children: React.ReactNode\n}) {\n return <span className=\"ui89-grid-expand-trick\">{children}</span>\n}\n","import React from \"react\"\nimport \"./ScrollContainer.css\"\n\nexport default function ScrollContainer({\n children,\n}: {\n children: React.ReactNode\n}) {\n return <span className=\"ui89-scroll-container\">{children}</span>\n}\n","import React, { useMemo } from \"react\"\nimport { createPortal } from \"react-dom\"\nimport { Ui89Card } from \"./Ui89Card\"\nimport HoverShadow from \"./private/HoverShadow\"\nimport { Ui89Scene } from \"./Ui89Scene\"\nimport GridExpandTrick from \"./private/GridExpandTrick\"\nimport ScrollContainer from \"./private/ScrollContainer\"\n\nimport \"./Ui89ModalDialog.css\"\n\nexport interface Ui89ModalDialogProps {\n open: boolean\n size?: string\n children?: React.ReactNode\n topCenter?: React.ReactNode\n onRequestClose?: () => void\n}\n\nconst portalRoot: HTMLElement | null =\n typeof document !== \"undefined\" ? document.body : null\n\nexport function Ui89ModalDialog({\n open,\n size = \"medium\",\n children,\n topCenter,\n onRequestClose,\n}: Ui89ModalDialogProps) {\n const dialogClass = useMemo(() => {\n return [\"ui89-modal-dialog\", open ? \"ui89-modal-dialog--open\" : \"\"].join(\n \" \",\n )\n }, [size, open])\n\n const dialogBoxClass = useMemo(() => {\n return [\n \"ui89-modal-dialog__box\",\n `ui89-modal-dialog__box--size-${size}`,\n ].join(\" \")\n }, [size, open])\n\n function onClickBackdrop() {\n if (onRequestClose !== undefined) {\n onRequestClose()\n }\n }\n\n const vdom = (\n <div className={dialogClass} role=\"dialog\" style={{ zIndex: 1 }}>\n <div\n className=\"ui89-modal-dialog__backdrop\"\n role=\"presentation\"\n onClick={onClickBackdrop}\n ></div>\n\n <div className={dialogBoxClass}>\n <div className=\"ui89-modal-dialog__spacer\"></div>\n\n <HoverShadow>\n <GridExpandTrick>\n <Ui89Scene>\n <Ui89Card topCenter={topCenter}>\n <ScrollContainer>{children}</ScrollContainer>\n </Ui89Card>\n </Ui89Scene>\n </GridExpandTrick>\n </HoverShadow>\n </div>\n </div>\n )\n\n return portalRoot !== null ? createPortal(vdom, portalRoot) : vdom\n}\n","import React from \"react\"\n\nimport \"./Ui89NameValuePair.css\"\n\nexport interface Ui89NameValuePairProps {\n name: React.ReactNode\n value: React.ReactNode\n leftMaxWidth?: number\n}\n\nexport function Ui89NameValuePair({\n name,\n value,\n leftMaxWidth,\n}: Ui89NameValuePairProps) {\n return (\n <div className=\"ui-89-name-value-pair\">\n <div\n className=\"ui-89-name-value-pair__name-wrapper\"\n style={{ maxWidth: `${leftMaxWidth}px` }}\n >\n <div className=\"ui-89-name-value-pair__name\">{name}</div>\n <div className=\"ui-89-name-value-pair__dots\"></div>\n </div>\n <div className=\"ui-89-name-value-pair__value\">{value}</div>\n </div>\n )\n}\n","import * as React from \"react\";\nconst SvgShortcut = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 100, height: 100, viewBox: \"0 0 100 100\", ...props }, /* @__PURE__ */ React.createElement(\"rect\", { x: 0, y: 0, width: 100, height: 100, fill: \"white\" }), /* @__PURE__ */ React.createElement(\"line\", { x1: 80, y1: 80, x2: 20, y2: 20, stroke: \"black\", strokeWidth: 15 }), /* @__PURE__ */ React.createElement(\"line\", { x1: 20, y1: 20, x2: 50, y2: 20, stroke: \"black\", strokeWidth: 15, strokeLinecap: \"round\" }), /* @__PURE__ */ React.createElement(\"line\", { x1: 20, y1: 20, x2: 20, y2: 50, stroke: \"black\", strokeWidth: 15, strokeLinecap: \"round\" }));\nexport default SvgShortcut;\n","import React from \"react\"\n\nexport interface Ui89SpaceVerticalProps {\n gap?: number\n}\n\nexport function Ui89SpaceVertical({ gap = 1 }: Ui89SpaceVerticalProps) {\n const style = {\n paddingTop: `calc(var(--ui89-safe-space) * ${gap})`,\n }\n\n return <div style={style}></div>\n}\n","import React from \"react\"\n\nimport ShortcutSvg from \"../images/shortcut.svg\"\n\nimport \"./Ui89Shortcut.css\"\nimport \"../style/typo.css\"\n\nimport { Ui89SpaceVertical } from \"./Ui89SpaceVertical\"\n\nexport interface Ui89ShortcutProps {\n imageUrl: string\n label: React.ReactNode\n onClick?: () => void\n}\n\nexport function Ui89Shortcut({\n imageUrl,\n label,\n onClick = () => {},\n}: Ui89ShortcutProps) {\n function onNativeClick() {\n onClick()\n }\n\n return (\n <div className=\"ui89-shortcut\" onClick={onNativeClick}>\n <div className=\"ui89-shortcut__image-container\">\n <img className=\"ui89-shortcut__image\" src={imageUrl} />\n\n <div className=\"ui89-shortcut__shortcut-icon-container\">\n <ShortcutSvg\n className=\"ui89-shortcut__shortcut-icon\"\n width={16}\n height={16}\n />\n </div>\n </div>\n\n <Ui89SpaceVertical gap={1} />\n\n <div\n className={`ui89-shortcut__label ui89-typo-small-bold`}\n onClick={onNativeClick}\n >\n {label}\n </div>\n </div>\n )\n}\n","import React from \"react\"\n\nexport interface Ui89SpacePaddingProps {\n gap?: number\n gapVertical?: number\n gapHorizontal?: number\n gapTop?: number\n gapRight?: number\n gapBottom?: number\n gapLeft?: number\n children?: React.ReactNode\n}\n\nexport function Ui89SpacePadding(props: Ui89SpacePaddingProps) {\n const gap = props.gap ?? 1\n\n const style = {\n paddingTop: `calc(var(--ui89-safe-space) * ${props.gapTop ?? props.gapVertical ?? gap})`,\n paddingRight: `calc(var(--ui89-safe-space) * ${props.gapRight ?? props.gapHorizontal ?? gap})`,\n paddingBottom: `calc(var(--ui89-safe-space) * ${props.gapBottom ?? props.gapVertical ?? gap})`,\n paddingLeft: `calc(var(--ui89-safe-space) * ${props.gapLeft ?? props.gapHorizontal ?? gap})`,\n }\n\n return <div style={style}>{props.children}</div>\n}\n","import React from \"react\"\n\nimport \"./Ui89Tabs.css\"\nimport \"../style/typo.css\"\n\nexport interface Ui89TabsPropsOption {\n value: string | number\n label: React.ReactNode\n}\n\nexport interface Ui89TabsProps {\n selected?: any\n onChange?: (value: string | number) => void\n options?: Ui89TabsPropsOption[]\n\n /**\n * Stretch options such that they evenly take up the entire width.\n */\n stretch?: boolean\n}\n\nexport function Ui89Tabs({\n selected,\n onChange = () => {},\n options = [],\n stretch,\n}: Ui89TabsProps) {\n function handleOnChange(value: string | number) {\n onChange(value)\n }\n\n return (\n <div\n className={[\"ui89-tabs\", stretch ? \"ui89-tabs--stretch\" : \"\"].join(\" \")}\n >\n {options.map((option) => (\n <div\n className={[\n \"ui89-tabs__item\",\n \"ui89-typo-small-bold\",\n selected === option.value ? \"ui89-tabs__item--selected\" : \"\",\n ].join(\" \")}\n key={option.value}\n onClick={() => handleOnChange(option.value)}\n >\n {option.label}\n </div>\n ))}\n </div>\n )\n}\n","import { Ui89Card } from \"./Ui89Card\"\nimport { Ui89Tabs } from \"./Ui89Tabs\"\nimport React, { useCallback, useMemo } from \"react\"\n\nexport interface Ui89TabbedCardProps {\n selected?: any\n onChange?: (value: string | number) => void\n options?: Ui89TabbedCardPropsOption[]\n}\n\nexport interface Ui89TabbedCardPropsOption {\n value: string | number\n label: React.ReactNode\n render: () => React.JSX.Element\n}\n\nexport function Ui89TabbedCard({\n selected,\n onChange,\n options = [],\n}: Ui89TabbedCardProps) {\n const selectedItem = useMemo<Ui89TabbedCardPropsOption | null>(() => {\n return options.find((item) => item.value === selected) ?? null\n }, [selected, options])\n\n const render = useMemo(() => {\n return selectedItem !== null ? selectedItem.render : () => <></>\n }, [selectedItem])\n\n const renderKey = useMemo(() => {\n return selectedItem !== null ? selectedItem.value : undefined\n }, [selectedItem])\n\n return (\n <Ui89Card\n topCenter={\n <Ui89Tabs selected={selected} options={options} onChange={onChange} />\n }\n >\n <React.Fragment key={renderKey}>{render()}</React.Fragment>\n </Ui89Card>\n )\n}\n","import React from \"react\"\n\nimport { Ui89Theme } from \"../theme\"\nimport \"../style/typo.css\"\nimport \"../style/chosen-theme.css\"\n\nimport \"./Ui89TagBox.css\"\n\nexport interface Ui89TagBoxProps {\n theme: Ui89Theme | keyof typeof Ui89Theme\n children: React.ReactNode\n}\n\nexport function Ui89TagBox({ theme, children }: Ui89TagBoxProps) {\n return (\n <div\n className={`ui89-tag-box ui89-typo-special ui89-chosen-theme-${theme}`}\n >\n {children}\n </div>\n )\n}\n","import React, { useState } from \"react\"\n\nimport \"./Ui89ThemeBackground.css\"\nimport \"../style/chosen-theme.css\"\n\nimport { Ui89Theme } from \"../theme\"\n\nexport interface Ui89ThemeBackgroundProps {\n theme?: Ui89Theme | keyof typeof Ui89Theme\n children: React.ReactNode\n}\n\nexport function Ui89ThemeBackground({\n theme = Ui89Theme.primary,\n children,\n}: Ui89ThemeBackgroundProps) {\n return (\n <div className={`ui89-theme-background ui89-chosen-theme-${theme}`}>\n {children}\n </div>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89TitleBox.css\"\nimport \"../style/typo.css\"\nimport \"../style/text.css\"\n\nexport interface Ui89TitleBoxProps {\n children: React.ReactNode\n}\n\nexport function Ui89TitleBox({ children }: Ui89TitleBoxProps) {\n return (\n <div className={`ui89-title-box ui89-typo-special`}>\n <div className={`ui89-title-box__inside ui89-text-single-line`}>\n {children}\n </div>\n </div>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89TitleUnderline.css\"\nimport \"../style/typo.css\"\nimport \"../style/text.css\"\n\nexport interface Ui89TitleUnderlineProps {\n children: React.ReactNode\n}\n\nexport function Ui89TitleUnderline({ children }: Ui89TitleUnderlineProps) {\n return (\n <div className={`ui89-title-underline ui89-typo-special`}>\n <div className={`ui89-title-underline__inside ui89-text-single-line`}>\n {children}\n </div>\n </div>\n )\n}\n","import React from \"react\"\nimport { ToastContainer, toast } from \"react-toastify\"\n\nimport \"./Ui89Toaster.css\"\nimport \"../style/typo.css\"\nimport \"../style/chosen-theme.css\"\nimport { Ui89Theme } from \"../theme\"\n\nexport interface Ui89ToasterOptions {\n theme?: Ui89Theme | keyof typeof Ui89Theme\n autoClose?: boolean\n duration?: number\n}\n\nexport function useUi89Toaster() {\n return {\n toast(\n content: React.ReactNode,\n options: Ui89ToasterOptions = { theme: Ui89Theme.primary },\n ) {\n const classNames = [\"ui89-toaster\", \"ui89-typo-normal\"]\n\n if (options.theme !== undefined) {\n classNames.push(`ui89-chosen-theme-${options.theme}`)\n }\n\n let autoClose: boolean | number = 5000\n\n if (options.duration !== undefined) {\n autoClose = options.duration\n }\n\n if (options.autoClose !== undefined) {\n if (!options.autoClose) {\n autoClose = false\n }\n }\n\n return toast(() => content, {\n className: classNames.join(\" \"),\n type: \"default\",\n autoClose,\n closeButton: false,\n hideProgressBar: true,\n closeOnClick: true,\n })\n },\n }\n}\n\nexport function Ui89Toaster() {\n return <ToastContainer />\n}\n","import { useState, useEffect, useRef } from \"react\"\n\ntype Size = { width: number; height: number }\n\ninterface UseResizeObserverResult {\n size: Size\n}\n\nexport const useResizeObserver = <T extends HTMLElement>(\n ref: React.RefObject<T>,\n): UseResizeObserverResult => {\n const [size, setSize] = useState<Size>({ width: 0, height: 0 })\n\n useEffect(() => {\n const observer = new ResizeObserver((entries) => {\n for (let entry of entries) {\n setSize({\n width:\n entry.borderBoxSize?.[0]?.inlineSize ?? entry.contentRect.width,\n height:\n entry.borderBoxSize?.[0]?.blockSize ?? entry.contentRect.height,\n })\n }\n })\n\n if (ref.current) {\n observer.observe(ref.current)\n }\n\n return () => {\n observer.disconnect()\n }\n }, [ref.current])\n\n return {\n size,\n }\n}\n","import { useState, useEffect, useRef, RefObject } from \"react\"\n\nexport const useScrollYPosition = (ref: RefObject<HTMLElement>): number => {\n const [scrollY, setScrollY] = useState(0)\n const ticking = useRef(false)\n const observer = useRef<MutationObserver | null>(null)\n\n useEffect(() => {\n const element = ref.current\n if (!element) return\n\n const handleScroll = () => {\n if (!ticking.current) {\n requestAnimationFrame(() => {\n setScrollY(element.scrollTop)\n ticking.current = false\n })\n ticking.current = true\n }\n }\n\n element.addEventListener(\"scroll\", handleScroll, { passive: true })\n\n observer.current = new MutationObserver(() => {\n if (ref.current !== element) {\n element.removeEventListener(\"scroll\", handleScroll)\n ref.current?.addEventListener(\"scroll\", handleScroll, { passive: true })\n }\n })\n\n observer.current.observe(document.body, { childList: true, subtree: true })\n\n return () => {\n element.removeEventListener(\"scroll\", handleScroll)\n observer.current?.disconnect()\n }\n }, [ref])\n\n return scrollY\n}\n","import React, { useState, useEffect, useRef, useMemo } from \"react\"\n\nimport \"./Ui89VirtualList.css\"\nimport { useResizeObserver } from \"../useResizeObserver\"\nimport { useScrollYPosition } from \"../useScrollYPosition\"\n\nexport interface Ui89VirtualListPropsRenderRowProps<T> {\n index: number\n row: T\n}\n\nexport interface Ui89VirtualListProps<T> {\n maxHeight?: string\n rows: T[]\n rowHeight?: number\n renderRow: (props: Ui89VirtualListPropsRenderRowProps<T>) => React.ReactNode\n getRowKey?: (row: T) => string\n}\n\ninterface VisibleRow<T> {\n index: number\n row: T\n key: string\n render: React.ReactNode\n style: React.CSSProperties\n}\n\n/**\n * Virtualization at row level. Great for long lists.\n *\n * Can be used to implement table components with few columns.\n */\nexport const Ui89VirtualList = React.memo(\n <T,>(props: Ui89VirtualListProps<T>) => {\n const scrollContainer = useRef<HTMLDivElement>(null)\n const scrollAreaContainer = useRef<HTMLDivElement>(null)\n\n const { size } = useResizeObserver(scrollContainer)\n const scrollY = useScrollYPosition(scrollContainer)\n\n const rowHeight = props.rowHeight ?? 50\n\n const totalHeight = rowHeight * props.rows.length\n\n const [visibleRows, setVisibleRows] = useState<Map<string, VisibleRow<T>>>(\n new Map(),\n )\n\n useEffect(() => {\n if (size.height === 0) {\n setVisibleRows(new Map())\n return\n }\n\n const firstIndex = Math.max(0, Math.floor(scrollY / rowHeight) - 1)\n const length = Math.min(\n props.rows.length - firstIndex,\n Math.ceil(size.height / rowHeight) + 2,\n )\n\n const newVisibleRows = new Map<string, VisibleRow<T>>()\n\n for (let index = firstIndex; index < firstIndex + length; index++) {\n let row = props.rows[index]\n let key = props.getRowKey ? props.getRowKey(row) : String(index)\n\n let existingRow = visibleRows.get(key)\n\n if (existingRow !== undefined) {\n if (existingRow.row === row) {\n // Data has technically not changed so we can reuse.\n newVisibleRows.set(key, existingRow)\n continue\n }\n }\n\n newVisibleRows.set(key, {\n index,\n row,\n key,\n render: props.renderRow({ index, row }),\n style: {\n top: `${index * rowHeight}px`,\n height: `${rowHeight}px`,\n },\n })\n }\n\n setVisibleRows(newVisibleRows)\n }, [props.rows, scrollY, size.height])\n\n const orderedVisibleRows = useMemo(() => {\n return Array.from(visibleRows.values()).sort((a, b) => a.index - b.index)\n }, [visibleRows])\n\n return (\n <div\n ref={scrollContainer}\n className=\"ui89-virtual-list\"\n style={{ maxHeight: props.maxHeight }}\n >\n <div\n ref={scrollAreaContainer}\n className=\"ui89-virtual-list__scroll-area\"\n style={{ height: `${totalHeight}px` }}\n >\n {orderedVisibleRows.map((visibleRow) => (\n <div\n key={visibleRow.key}\n className=\"ui89-virtual-list__row\"\n style={visibleRow.style}\n >\n {visibleRow.render}\n </div>\n ))}\n </div>\n </div>\n )\n },\n) as <T>(props: Ui89VirtualListProps<T>) => JSX.Element\n","import React, { forwardRef, useCallback, useMemo } from \"react\"\nimport \"./Ui89VirtualTable.css\"\nimport \"../style/typo.css\"\nimport { Ui89TagBox } from \"./Ui89TagBox\"\nimport {\n Ui89VirtualList,\n Ui89VirtualListPropsRenderRowProps,\n} from \"./Ui89VirtualList\"\n\nexport enum Ui89VirtualTablePropsColumnAlign {\n left = \"left\",\n right = \"right\",\n center = \"center\",\n}\n\nexport interface Ui89VirtualTablePropsColumnRenderHeaderParams<T> {\n index: number\n column: Ui89VirtualTablePropsColumn<T>\n}\n\nexport interface Ui89VirtualTablePropsColumnRenderBodyParams<T> {\n index: number\n row: T\n}\n\nexport interface Ui89VirtualTablePropsColumn<T> {\n width?: number\n halign?: keyof typeof Ui89VirtualTablePropsColumnAlign\n renderHeader?: (\n props: Ui89VirtualTablePropsColumnRenderHeaderParams<T>,\n ) => React.ReactNode\n renderBody: (\n props: Ui89VirtualTablePropsColumnRenderBodyParams<T>,\n ) => React.ReactNode\n}\n\nexport interface Ui89VirtualTableProps<T> {\n maxHeight?: string\n rows?: T[]\n columns?: Ui89VirtualTablePropsColumn<T>[]\n rowHeight?: number\n}\n\nexport const Ui89VirtualTable = React.memo(\n <T,>(props: Ui89VirtualTableProps<T>) => {\n const rows = useMemo<(T | undefined)[]>(() => {\n let rows: any[] = props.rows !== undefined ? props.rows.slice() : []\n\n rows.unshift(undefined)\n\n return rows\n }, [props.rows])\n\n const columns = useMemo(() => {\n return props.columns !== undefined ? props.columns : []\n }, [props.columns])\n\n const rowHeight = props.rowHeight ?? 20\n\n function getColumnWidth(index: number): number {\n return columns[index].width ?? 100\n }\n\n function getColumnHorizontalOffset(columnIndex: number) {\n let offset = 0\n\n for (let i = 0; i < columnIndex; i++) {\n offset += getColumnWidth(i)\n }\n\n return offset\n }\n\n function isLastColumn(columnIndex: number): boolean {\n return columnIndex === columns.length - 1\n }\n\n function getRowClass(rowIndex: number): string {\n const classes = [\"ui89-virtual-table__row\"]\n\n if (rowIndex === 0) {\n classes.push(\"ui89-virtual-table__row--first\")\n classes.push(\"ui89-typo-normal-bold\")\n }\n\n if (rowIndex === rows.length) {\n classes.push(\"ui89-virtual-table__row--last\")\n }\n\n return classes.join(\" \")\n }\n\n function getColumnClass(columnIndex: number): string {\n const halign = columns[columnIndex].halign ?? \"left\"\n\n const classes = [\n \"ui89-virtual-table__cell\",\n `ui89-virtual-table__cell--halign-${halign}`,\n ]\n\n if (columnIndex === 0) {\n classes.push(\"ui89-virtual-table__cell--column-first\")\n }\n\n if (isLastColumn(columnIndex)) {\n classes.push(\"ui89-virtual-table__cell--column-last\")\n }\n\n return classes.join(\" \")\n }\n\n /**\n * The width of an entire row.\n */\n function rowWidth() {\n return getColumnHorizontalOffset(columns.length)\n }\n\n const renderRow = useCallback(\n ({ index, row }: Ui89VirtualListPropsRenderRowProps<T>) => {\n return (\n <div\n className={getRowClass(index)}\n style={{ minWidth: rowWidth() + \"px\", height: \"100%\" }}\n >\n {columns.map((column, columnIndex) => {\n return (\n <div\n key={columnIndex}\n className={getColumnClass(columnIndex)}\n style={{\n top: 0,\n height: \"100%\",\n width: getColumnWidth(columnIndex) + \"px\",\n left: getColumnHorizontalOffset(columnIndex) + \"px\",\n }}\n >\n {index === 0\n ? columns[columnIndex].renderHeader\n ? columns[columnIndex].renderHeader({\n index: columnIndex,\n column: column,\n })\n : \"\"\n : columns[columnIndex].renderBody({\n index: index,\n row: row,\n })}\n </div>\n )\n })}\n </div>\n )\n },\n [columns, rowHeight],\n )\n\n return (\n <>\n {rows.length > 1 ? (\n <Ui89VirtualList\n maxHeight={props.maxHeight}\n rows={rows as T[]}\n rowHeight={rowHeight}\n renderRow={renderRow}\n />\n ) : (\n <div className=\"ui89-virtual-table__empty\">\n <Ui89TagBox theme=\"warning\">Empty</Ui89TagBox>\n </div>\n )}\n </>\n )\n },\n) as <T>(props: Ui89VirtualTableProps<T>) => JSX.Element\n"],"names":["React","ShortcutSvg"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/theme.ts","../../src/Ui89Override.tsx","../../src/components/Ui89Breadcrumbs.tsx","../../src/components/private/HoverShadow.tsx","../../src/components/Ui89Button.tsx","../../src/components/Ui89Card.tsx","../../src/components/Ui89CardHorizontalConnection.tsx","../../src/components/Ui89DateTimePicker.tsx","../../src/components/private/TimeAnimation.tsx","../../src/date-utils.ts","../../src/components/Ui89DigitalClock.tsx","../../src/components/Ui89HighlightText.tsx","../../src/components/Ui89Hr.tsx","../../src/components/Ui89InputCheckBox.tsx","../../src/components/Ui89InputCheckText.tsx","../../src/components/Ui89InputFileUpload.tsx","../../src/components/Ui89InputSelect.tsx","../../src/timeout.ts","../../src/useDelayedOnChange.ts","../../src/components/Ui89InputText.tsx","../../src/text-utils.ts","../../src/components/Ui89InputTextNumber.tsx","../../src/components/Ui89InputNumber.tsx","../../src/components/Ui89InputPassword.tsx","../../src/components/private/LinkBase.tsx","../../src/components/Ui89LinkStealth.tsx","../../src/components/Ui89LinkUnderline.tsx","../../src/components/Ui89MenuBar.tsx","../../src/components/Ui89Scene.tsx","../../src/components/private/GridExpandTrick.tsx","../../src/components/private/ScrollContainer.tsx","../../src/components/Ui89ModalDialog.tsx","../../src/components/Ui89NameValuePair.tsx","../../src/images/shortcut.svg","../../src/components/Ui89SpaceVertical.tsx","../../src/components/Ui89Shortcut.tsx","../../src/components/Ui89SpacePadding.tsx","../../src/components/Ui89Tabs.tsx","../../src/components/Ui89TabbedCard.tsx","../../src/components/Ui89TagBox.tsx","../../src/components/Ui89ThemeBackground.tsx","../../src/components/Ui89TitleBox.tsx","../../src/components/Ui89TitleUnderline.tsx","../../src/components/Ui89Toaster.tsx","../../src/useResizeObserver.ts","../../src/useScrollYPosition.ts","../../src/components/Ui89VirtualList.tsx","../../src/components/Ui89VirtualTable.tsx"],"sourcesContent":["export enum Ui89Theme {\n primary = \"primary\",\n secondary = \"secondary\",\n info = \"info\",\n success = \"success\",\n warning = \"warning\",\n danger = \"danger\",\n}\n\nexport enum Ui89Look {\n main = \"main\",\n side = \"side\",\n}\n","import React, { createContext, useContext, ReactNode } from \"react\"\n\ntype RouterPush = (url: string) => void | Promise<void>\n\ninterface Ui89OverrideContextType {\n routerPush?: RouterPush\n}\n\nexport interface Ui89OverrideProviderProps {\n children?: ReactNode\n routerPush?: RouterPush\n}\n\nconst Ui89OverrideContext = createContext<Ui89OverrideContextType>({})\n\nexport const Ui89OverrideProvider: React.FC<Ui89OverrideProviderProps> = ({\n routerPush,\n children,\n}) => {\n return (\n <Ui89OverrideContext.Provider value={{ routerPush }}>\n {children}\n </Ui89OverrideContext.Provider>\n )\n}\n\nexport const useUi89Overrides = (): Ui89OverrideContextType => {\n const context = useContext(Ui89OverrideContext)\n\n if (context === undefined) {\n throw new Error(\n \"useUi89Overrides must be used within a Ui89OverrideProvider\",\n )\n }\n\n return context\n}\n","import React, { useState } from \"react\"\n\nimport \"./Ui89Breadcrumbs.css\"\nimport \"../style/typo.css\"\nimport \"../style/reset.css\"\nimport \"../style/chosen-theme.css\"\n\nimport { Ui89Theme } from \"../theme\"\nimport { useUi89Overrides } from \"../Ui89Override\"\n\nexport type Ui89BreadcrumbsPropsOnSelect = (e: {\n item: Ui89BreadcrumbsPropsItem\n}) => void | Promise<void>\n\nexport interface Ui89BreadcrumbsPropsItem {\n label: React.ReactNode\n url?: string\n}\n\nexport interface Ui89BreadcrumbsProps {\n theme?: Ui89Theme | keyof typeof Ui89Theme\n items: Ui89BreadcrumbsPropsItem[]\n onSelect?: Ui89BreadcrumbsPropsOnSelect\n}\n\nexport function Ui89BreadcrumbsItem({\n index,\n item,\n onSelect,\n}: {\n index: number\n item: Ui89BreadcrumbsPropsItem\n onSelect?: Ui89BreadcrumbsPropsOnSelect\n}) {\n const style = { \"--ui89-index\": index } as React.CSSProperties\n const tagname = item.url !== undefined ? \"a\" : \"div\"\n const overrides = useUi89Overrides()\n\n const onClick: React.MouseEventHandler<HTMLAnchorElement> = (e) => {\n if (item.url !== undefined) {\n if (item.url.startsWith(\"/\")) {\n if (overrides.routerPush !== undefined) {\n e.preventDefault()\n overrides.routerPush(item.url)\n }\n }\n }\n }\n\n return (\n <a\n className={`ui-89-reset-a ui89-breadcrumbs__item`}\n href={item.url}\n style={style}\n onClick={onClick}\n >\n <div className=\"ui89-breadcrumbs__item__background\"></div>\n {item.label}\n </a>\n )\n}\n\nexport function Ui89Breadcrumbs({\n theme = Ui89Theme.primary,\n items,\n onSelect,\n}: Ui89BreadcrumbsProps) {\n return (\n <div\n className={`ui89-breadcrumbs ui89-typo-special ui89-chosen-theme-${theme}`}\n >\n {[...items.entries()].reverse().map(([index, item]) => (\n <Ui89BreadcrumbsItem\n key={index}\n index={index}\n item={item}\n onSelect={onSelect}\n />\n ))}\n </div>\n )\n}\n","import React from \"react\"\nimport \"./HoverShadow.css\"\n\nexport default function HoverShadow({\n children,\n}: {\n children: React.ReactNode\n}) {\n return (\n <span className=\"ui89-hover-shadow\">\n <span className=\"ui89-hover-shadow__bottom\"></span>\n <span className=\"ui89-hover-shadow__right\"></span>\n {children}\n </span>\n )\n}\n","import React, { useState } from \"react\"\n\nimport \"./Ui89Button.css\"\nimport \"../style/typo.css\"\nimport \"../style/chosen-theme.css\"\nimport \"../style/reset.css\"\n\nimport HoverShadow from \"./private/HoverShadow\"\n\nimport { Ui89Theme } from \"../theme\"\nimport { useUi89Overrides } from \"../Ui89Override\"\n\nexport enum Ui89ButtonPropsSize {\n standard = \"standard\",\n square = \"square\",\n}\n\nexport enum Ui89ButtonPropsType {\n submit = \"submit\",\n reset = \"reset\",\n}\n\nexport interface Ui89ButtonProps {\n theme?: Ui89Theme | keyof typeof Ui89Theme\n size?: Ui89ButtonPropsSize | keyof typeof Ui89ButtonPropsSize\n block?: boolean\n onClick?: () => void | Promise<void>\n href?: string\n children: React.ReactNode\n autoDisableOnClick?: boolean\n disabled?: boolean\n activated?: boolean\n type?: keyof typeof Ui89ButtonPropsType\n}\n\nexport function Ui89Button({\n theme = Ui89Theme.primary,\n size = Ui89ButtonPropsSize.standard,\n type,\n block,\n onClick,\n href,\n children,\n autoDisableOnClick = true,\n disabled,\n activated,\n}: Ui89ButtonProps) {\n const overrides = useUi89Overrides()\n const [clicking, setClicking] = useState(false)\n\n let localDisabled = disabled || (autoDisableOnClick && clicking)\n\n async function onAnchorClick(e: React.MouseEvent<HTMLAnchorElement>) {\n if (localDisabled) {\n // The anchor tag does not support the disabled attribute so we do this.\n return\n }\n\n if (clicking) {\n // No double clicking allowed.\n return\n }\n\n try {\n setClicking(true)\n\n if (href !== undefined) {\n if (href.startsWith(\"/\")) {\n if (overrides.routerPush !== undefined) {\n e.preventDefault()\n overrides.routerPush(href)\n }\n }\n }\n } finally {\n setClicking(false)\n }\n }\n\n async function onButtonClick(e: React.MouseEvent<HTMLButtonElement>) {\n if (localDisabled) {\n // The anchor tag does not support the disabled attribute so we do this.\n return\n }\n\n if (clicking) {\n // No double clicking allowed.\n return\n }\n\n try {\n setClicking(true)\n\n if (onClick === undefined) {\n // No handler.\n return\n }\n\n await onClick()\n } finally {\n setClicking(false)\n }\n }\n\n let containerClass = [\"ui89-button\", `ui89-button--size-${size}`].join(\" \")\n\n let buttonClass = [\n \"ui89-button__button\",\n \"ui89-typo-special\",\n `ui89-chosen-theme-${theme}`,\n activated ? \"ui89-button__button--active\" : undefined,\n block ? \"ui89-button__button--block\" : undefined,\n disabled ? \"ui89-button__button--disabled\" : undefined,\n clicking ? \"ui89-button__button--active\" : undefined,\n ].join(\" \")\n\n return (\n <div className={containerClass}>\n <HoverShadow>\n {href ? (\n <a\n className=\"ui-89-reset-a\"\n role=\"button\"\n href={href}\n onClick={onAnchorClick}\n >\n <span className={buttonClass}>{children}</span>\n </a>\n ) : (\n <button\n className=\"ui-89-reset-button\"\n type={type || \"button\"}\n onClick={onButtonClick}\n disabled={localDisabled}\n >\n <span className={buttonClass}>{children}</span>\n </button>\n )}\n </HoverShadow>\n </div>\n )\n}\n","import React from \"react\"\nimport \"./Ui89Card.css\"\n\nexport interface Ui89CardProps {\n topLeftCenter?: React.ReactNode\n topCenter?: React.ReactNode\n children: React.ReactNode\n}\n\nexport function Ui89Card({\n topLeftCenter,\n topCenter,\n children,\n}: Ui89CardProps) {\n const hasTopContent = topLeftCenter || topCenter\n\n return (\n <div className={`ui89-card ${hasTopContent ? \"ui89-card--has-top\" : \"\"}`}>\n <div className=\"ui89-card__inside\">\n {topLeftCenter && (\n <div className=\"ui89-card__top-left-center\">{topLeftCenter}</div>\n )}\n {topCenter && <div className=\"ui89-card__top-center\">{topCenter}</div>}\n\n {hasTopContent && <div className=\"space-vertical-1\"></div>}\n\n {children}\n\n {hasTopContent && <div className=\"space-vertical-1\"></div>}\n </div>\n </div>\n )\n}\n","import React from \"react\"\nimport \"./Ui89Card.css\"\n\nexport interface Ui89CardHorizontalConnectionProps {\n children: React.ReactNode\n overflow?: boolean\n}\n\nexport function Ui89CardHorizontalConnection({\n children,\n overflow,\n}: Ui89CardHorizontalConnectionProps) {\n return (\n <div\n className={`ui89-card__horizontal-connection ${overflow ? \"ui89-card__horizontal-connection--overflow\" : \"\"}`}\n >\n {children}\n </div>\n )\n}\n","import React from \"react\"\nimport DatePicker from \"react-datepicker\"\n\nimport \"../../node_modules/react-datepicker/dist/react-datepicker.css\"\nimport \"./Ui89DateTimePicker.css\"\n\nimport \"../style/input-box.css\"\nimport \"../style/typo.css\"\n\nexport interface Ui89DateTimePickerProps {\n value?: Date | null\n onChange?: (value: Date | null) => void\n}\n\nexport function Ui89DateTimePicker(props: Ui89DateTimePickerProps) {\n function datepickerOnChange(value: Date | null) {\n if (props.onChange) {\n props.onChange(value)\n }\n }\n\n return (\n <span className=\"ui89-date-time-picker\">\n <DatePicker\n className={[\"ui89-input-box\", \"ui89-typo-normal\"].join(\" \")}\n calendarClassName=\"ui89-typo-normal\"\n showTimeSelect\n dateFormat=\"MM/dd/yyyy HH:mm:ss\"\n timeFormat=\"HH:mm\"\n selected={props.value}\n onChange={datepickerOnChange}\n popperPlacement=\"bottom-start\"\n />\n </span>\n )\n}\n","import React, { useState, useEffect } from \"react\"\n\nexport interface TimeAnimationPropsChildrenProps {\n now: Date\n}\n\nexport interface TimeAnimationProps {\n children: (props: TimeAnimationPropsChildrenProps) => React.ReactNode\n}\n\nexport const TimeAnimation: React.FC<TimeAnimationProps> = ({ children }) => {\n const [currentTime, setCurrentTime] = useState(new Date())\n\n useEffect(() => {\n const tick = () => {\n const now = new Date()\n setCurrentTime(now)\n\n // Calculate time until the next exact second\n const msUntilNextSecond = 1000 - now.getMilliseconds()\n setTimeout(tick, msUntilNextSecond)\n }\n\n // Start the first tick\n const msUntilNextSecond = 1000 - currentTime.getMilliseconds()\n const timeoutId = setTimeout(tick, msUntilNextSecond)\n\n return () => clearTimeout(timeoutId)\n }, [])\n\n return <>{children({ now: currentTime })}</>\n}\n","export interface DateComponents {\n hours: number\n minutes: number\n seconds: number\n milliseconds: number\n day: number\n month: number\n year: number\n}\n\nfunction dateComponents(date: Date): DateComponents {\n return {\n hours: date.getHours(),\n minutes: date.getMinutes(),\n seconds: date.getSeconds(),\n milliseconds: date.getMilliseconds(),\n day: date.getDate(),\n month: date.getMonth() + 1,\n year: date.getFullYear(),\n }\n}\n\nexport function dateFormat(date: Date, format: string) {\n const placeholders: Record<string, string> = {\n YYYY: date.getFullYear().toString(),\n MM: (date.getMonth() + 1).toString().padStart(2, \"0\"),\n DD: date.getDate().toString().padStart(2, \"0\"),\n HH: date.getHours().toString().padStart(2, \"0\"),\n mm: date.getMinutes().toString().padStart(2, \"0\"),\n ss: date.getSeconds().toString().padStart(2, \"0\"),\n hh: (date.getHours() % 12 || 12).toString().padStart(2, \"0\"),\n A: date.getHours() >= 12 ? \"PM\" : \"AM\",\n }\n\n // Replace placeholders in the format string\n let formattedDate = format\n for (const [key, value] of Object.entries(placeholders)) {\n formattedDate = formattedDate.replace(key, value)\n }\n\n return formattedDate\n}\n","import React, { useRef } from \"react\"\nimport \"../style/typo.css\"\nimport {\n TimeAnimation,\n TimeAnimationPropsChildrenProps,\n} from \"./private/TimeAnimation\"\nimport { dateFormat } from \"../date-utils\"\n\nexport interface Ui89DigitalClockProps {\n format?: string // Custom format string\n}\n\nexport function Ui89DigitalClock({\n format = \"HH:mm:ss\",\n}: Ui89DigitalClockProps) {\n function render({ now }: TimeAnimationPropsChildrenProps) {\n return dateFormat(now, format)\n }\n\n return (\n <span className=\"ui89-typo-special\">\n <TimeAnimation>{render}</TimeAnimation>\n </span>\n )\n}\n","import React from \"react\"\n\nimport { Ui89Theme } from \"../theme\"\nimport \"../style/chosen-theme.css\"\n\nimport \"./Ui89HighlightText.css\"\n\nexport interface Ui89HighlightTextProps {\n theme: Ui89Theme | keyof typeof Ui89Theme\n block?: boolean\n children: React.ReactNode\n}\n\nexport function Ui89HighlightText({\n theme,\n block,\n children,\n}: Ui89HighlightTextProps) {\n return (\n <span\n className={`ui89-highlight-text ui89-chosen-theme-${theme} ${block ? \"ui89-highlight-text--block\" : null}`}\n >\n {children}\n </span>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89Hr.css\"\nimport { Ui89Theme } from \"../theme\"\nimport \"../style/chosen-theme.css\"\n\nexport enum Ui89HrPropsLook {\n straight = \"straight\",\n dotted = \"dotted\",\n dashed = \"dashed\",\n double = \"double\",\n}\n\nexport interface Ui89HrProps {\n look?: Ui89HrPropsLook | keyof typeof Ui89HrPropsLook\n theme?: Ui89Theme | keyof typeof Ui89Theme\n}\n\nexport function Ui89Hr({ look = \"straight\", theme }: Ui89HrProps) {\n return (\n <div\n className={`ui-89-hr ${`ui-89-hr--${look}`} ${theme !== undefined ? \"ui-89-hr--use-theme\" : \"\"} ${theme !== undefined ? `ui89-chosen-theme-${theme}` : \"\"}`}\n >\n <div className=\"ui-89-hr__double\"></div>\n </div>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89InputCheckBox.css\"\n\nexport interface Ui89InputCheckBoxProps {\n value: boolean\n onChange?: (value: boolean) => void\n}\n\nexport function Ui89InputCheckBox(props: Ui89InputCheckBoxProps) {\n function toggle() {\n if (props.onChange) {\n props.onChange(!props.value)\n }\n }\n\n return (\n <span className=\"ui89-input-check-box\" onClick={toggle}>\n <span className=\"ui89-input-check-box__x\">\n {props.value ? <>X</> : <> </>}\n </span>\n </span>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89InputCheckText.css\"\n\nexport interface Ui89InputCheckTextProps {\n value: any\n onChange?: (value: boolean) => void\n}\n\nexport function Ui89InputCheckText(props: Ui89InputCheckTextProps) {\n function toggle() {\n if (props.onChange) {\n props.onChange(!props.value)\n }\n }\n\n return (\n <span className=\"ui89-input-check-text\" onClick={toggle}>\n {props.value ? \"[X]\" : \"[ ]\"}\n </span>\n )\n}\n","import React, { useRef } from \"react\"\n\nimport \"./Ui89InputFileUpload.css\"\nimport \"../style/typo.css\"\nimport \"../style/text.css\"\nimport { Ui89Button } from \"./Ui89Button\"\n\nexport interface Ui89InputFileUploadProps {\n value?: any\n onChange?: (value: File | null) => void\n}\n\nexport function Ui89InputFileUpload({\n value,\n onChange,\n}: Ui89InputFileUploadProps) {\n const inputRef = useRef<HTMLInputElement>(null)\n\n function implOnChange(e: React.ChangeEvent<HTMLInputElement>) {\n if (!onChange) {\n return\n }\n\n if (e.target.files === null) {\n onChange(null)\n return\n }\n\n if (e.target.files.length === 0) {\n onChange(null)\n return\n }\n\n onChange(e.target.files[0])\n }\n\n function onClick() {\n if (inputRef.current === null) {\n return\n }\n\n inputRef.current.click()\n }\n\n return (\n <div>\n <input\n ref={inputRef}\n className=\"ui89-typo-special\"\n type=\"file\"\n onChange={implOnChange}\n hidden\n />\n\n {value ? (\n <div className=\"ui89-input-file-upload\">\n <Ui89Button onClick={onClick}>Change</Ui89Button>\n <span\n className={`ui89-input-file-upload__info ui89-text-single-line ui89-text-single-line--ellipsis-left`}\n title={value.name}\n >\n {value.name}\n </span>\n </div>\n ) : (\n <Ui89Button onClick={onClick}>Upload</Ui89Button>\n )}\n </div>\n )\n}\n","import React, { useMemo, useState } from \"react\"\n\nimport \"./Ui89InputSelect.css\"\nimport \"../style/input-box.css\"\nimport \"../style/text.css\"\n\nexport interface Ui89InputSelectProps<T> {\n /**\n * Available options.\n */\n options?: T[]\n\n /**\n * The selected option.\n */\n value?: T\n\n /**\n * Called whenever an option is selected.\n */\n onChange?: (option: T) => void\n\n /**\n * Retrieves the value that uniquely identifies the option. This is what is\n * used to determine which option is currently selected.\n */\n getOptionKey?: (option: T) => any\n\n /**\n * Customize how an option should be rendered.\n */\n renderOption?: (option: T) => any\n}\n\n/**\n * This is a very performant and customizable dropdown selector that\n * allows you to choose from a list of options.\n */\nexport function Ui89InputSelect<T>(props: Ui89InputSelectProps<T>) {\n const getOptionKey = useMemo(() => {\n return props.getOptionKey ?? ((option: any) => option)\n }, [props.getOptionKey])\n\n const options = useMemo(() => {\n if (props.options === undefined) {\n return []\n }\n\n return props.options\n }, [props.options])\n\n const optionsMap = useMemo(() => {\n return new Map(options.map((option) => [getOptionKey(option), option]))\n }, [options])\n\n function isOptionSelected(option: T) {\n if (props.value === undefined) {\n // Definitely not selected.\n return false\n }\n\n return getOptionKey(option) === getOptionKey(props.value)\n }\n\n function selectOption(option: T) {\n if (props.onChange !== undefined) {\n props.onChange(option)\n }\n\n if (document.activeElement !== null) {\n // @ts-expect-error\n document.activeElement.blur()\n }\n }\n\n function optionTitle(option: T) {\n return String(option)\n }\n\n return (\n <div className=\"ui89-input-select\">\n <div\n className={[\n \"ui89-input-box\",\n \"ui89-input-box--unselectable\",\n \"ui89-input-box--clickable\",\n \"ui89-text-single-line\",\n ].join(\" \")}\n tabIndex={0}\n title={props.value !== undefined ? optionTitle(props.value) : undefined}\n >\n {props.value !== undefined ? (\n <>\n {props.renderOption !== undefined\n ? props.renderOption(props.value)\n : props.value}\n </>\n ) : (\n <>Select...</>\n )}\n </div>\n\n <div className=\"ui89-input-select__menu\" tabIndex={0}>\n <div className=\"ui89-input-select__menu__content\">\n {options.length > 0 ? (\n options.map((o) => {\n const isSelected = isOptionSelected(o)\n\n return (\n <div\n className={[\n \"ui89-input-select__menu__item\",\n isSelected\n ? \"ui89-input-select__menu__item--selected\"\n : null,\n ].join(\" \")}\n title={optionTitle(o)}\n key={getOptionKey(o)}\n onClick={() => selectOption(o)}\n >\n {props.renderOption !== undefined ? props.renderOption(o) : o}\n </div>\n )\n })\n ) : (\n <div\n className={[\n \"ui89-input-select__menu__item\",\n \"ui89-input-select__menu__item--disabled\",\n ].join(\" \")}\n >\n <empty>\n </div>\n )}\n </div>\n </div>\n </div>\n )\n}\n","import Timeout from \"smart-timeout\"\n\nlet uniqueId = 0\n\nexport function throttledTimeout() {\n const id = String(uniqueId++)\n let callback: () => void\n\n return {\n call(delay: number, f: () => void) {\n callback = f\n\n if (Timeout.pending(id)) {\n Timeout.restart(id)\n } else {\n Timeout.set(id, () => callback(), delay)\n }\n },\n\n /**\n * If there is a call that has been scheduled, remove it from the queue.\n */\n abort() {\n Timeout.clear(id, true)\n },\n }\n}\n\nexport function spacedTimeout() {\n const id = String(uniqueId++)\n let callback: () => void\n\n return {\n call(delay: number, f: () => void) {\n callback = f\n\n if (!Timeout.pending(id)) {\n Timeout.set(id, () => callback(), delay)\n }\n },\n }\n}\n","import { useEffect, useRef, useState } from \"react\"\nimport { throttledTimeout } from \"./timeout\"\n\ninterface UseDelayedOnChangeState {\n value: any\n setValue: (newVal: any) => void\n onChange: (newVal: any) => void\n onFocus: () => void\n onBlur: () => void\n}\n\nexport function useDelayedOnChange(props: {\n defaultValue?: any\n value: any\n onChange?: (value: any) => void\n filter?: (value: any) => any\n}): UseDelayedOnChangeState {\n const onChangeRef = useRef(props.onChange)\n\n useEffect(() => {\n onChangeRef.current = props.onChange\n }, [props.onChange])\n\n const [intermediateValue, setIntermediateValue] = useState<any>(\n props.defaultValue || props.value,\n )\n\n useEffect(() => {\n stateRef.current.setValue(props.value)\n }, [props.value])\n\n function callOnChange() {\n let newVal = stateRef.current.value\n\n if (props.filter !== undefined) {\n newVal = props.filter(newVal)\n }\n\n onChangeRef.current?.call(null, newVal)\n return newVal\n }\n\n class StateUnknown implements UseDelayedOnChangeState {\n state = \"unknown\"\n\n value: any\n\n throttledTimeout: any\n\n constructor() {\n this.throttledTimeout = throttledTimeout()\n }\n\n setValue(newVal: any) {\n setIntermediateValue(newVal)\n }\n\n onChange(newVal: any) {\n setIntermediateValue(newVal)\n stateRef.current.throttledTimeout.call(300, callOnChange)\n }\n\n onFocus() {\n let newState = new StateFocus()\n newState.value = stateRef.current.value\n setState(newState)\n }\n\n onBlur() {}\n }\n\n class StateFocus implements UseDelayedOnChangeState {\n state = \"focus\"\n\n value: any\n\n throttledTimeout: any\n\n constructor() {\n this.throttledTimeout = throttledTimeout()\n }\n\n setValue(newVal: any) {\n // Ignore.\n }\n\n onChange(newVal: any) {\n setIntermediateValue(newVal)\n stateRef.current.throttledTimeout.call(300, callOnChange)\n }\n\n onFocus() {}\n\n onBlur() {\n let newVal = callOnChange()\n setIntermediateValue(newVal)\n let newState = new StateUnknown()\n newState.value = newVal\n setState(newState)\n }\n }\n\n const [state, setState] = useState<UseDelayedOnChangeState>(() => {\n let newState = new StateUnknown()\n newState.value = intermediateValue\n return newState\n })\n\n const stateRef = useRef(state)\n\n useEffect(() => {\n stateRef.current = state\n }, [state])\n\n stateRef.current.value = intermediateValue\n\n return state\n}\n","import React, { useMemo } from \"react\"\nimport { useState, useEffect, useRef } from \"react\"\nimport { throttledTimeout } from \"../timeout\"\n\nimport \"../style/input-box.css\"\nimport \"../style/typo.css\"\nimport { useDelayedOnChange } from \"../useDelayedOnChange\"\n\nconst THROTTLE_DELAY = 200\n\nexport interface Ui89InputTextProps {\n value?: any\n placeholder?: string\n autoTrim?: boolean\n onChange?: (value: any) => void\n onTyping?: (value: boolean) => void\n onFocus?: () => void\n onBlur?: () => void\n}\n\nfunction convertAnyToText(value: any) {\n return value ?? \"\"\n}\n\nexport function Ui89InputText({\n value,\n placeholder,\n autoTrim = true,\n onChange,\n onTyping,\n onFocus,\n onBlur,\n}: Ui89InputTextProps) {\n const delayedState = useDelayedOnChange({\n defaultValue: \"\",\n value,\n onChange,\n filter(value: any) {\n if (autoTrim) {\n if (typeof value === \"string\") {\n value = value.replace(/\\s+/g, \" \").trim()\n }\n }\n\n return value\n },\n })\n\n return (\n <div>\n <input\n className={`ui89-input-box ui89-typo-special`}\n type=\"text\"\n value={delayedState.value}\n onChange={(e) => delayedState.onChange(e.target.value)}\n onBlur={delayedState.onBlur}\n onFocus={delayedState.onFocus}\n placeholder={placeholder}\n />\n </div>\n )\n}\n","export function stringRemoveAllWhitespace(str: string): string {\n return str.replace(/\\s+/g, \"\")\n}\n","import React from \"react\"\nimport { useState, useEffect } from \"react\"\nimport { Ui89InputText } from \"./Ui89InputText\"\nimport { stringRemoveAllWhitespace } from \"../text-utils\"\n\nexport interface Ui89InputTextNumberProps {\n emptyValue?: any\n value?: any\n min?: number\n max?: number\n onChange?: (value: any) => void\n precision?: number\n}\n\nexport function isTextNumber(text: string): boolean {\n return /\\b\\d+(\\.\\d+)?\\b/.test(text)\n}\n\nfunction displayText(value: any, emptyValue: any) {\n if (value === undefined) {\n // No idea how to display this.\n return \"\"\n } else if (value === emptyValue) {\n // Display emptiness.\n return \"\"\n } else if (isNaN(value)) {\n // No idea what to display.\n return \"\"\n }\n\n return value.toString()\n}\n\nexport function Ui89InputTextNumber({\n /**\n * The value that is emitted when the input is emptied.\n */\n emptyValue = null,\n value,\n min,\n max,\n onChange,\n precision,\n}: Ui89InputTextNumberProps) {\n const [isTyping, setIsTyping] = useState(false)\n const [intermediateValue, setIntermediateValue] = useState(\n displayText(value, emptyValue),\n )\n\n function implOnChange(value: string) {\n if (onChange === undefined) {\n return\n }\n\n if (value === \"\") {\n // Use empty value.\n onChange(emptyValue)\n return\n }\n\n value = stringRemoveAllWhitespace(value)\n\n if (!isTextNumber(value)) {\n // We end here.\n return\n }\n\n const numberValue = Number(value)\n\n if (min !== undefined) {\n if (numberValue <= min) {\n value = String(min)\n }\n }\n\n if (max !== undefined) {\n if (numberValue >= max) {\n value = String(max)\n }\n }\n\n onChange(value)\n }\n\n useEffect(() => {\n if (!isTyping) {\n setIntermediateValue(displayText(value, emptyValue))\n }\n }, [isTyping, value])\n\n return (\n <Ui89InputText\n value={intermediateValue}\n onChange={implOnChange}\n onTyping={setIsTyping}\n />\n )\n}\n","import React from \"react\"\nimport { useMemo } from \"react\"\n\nimport { Ui89InputTextNumber } from \"./Ui89InputTextNumber\"\n\nexport interface Ui89InputNumberProps {\n emptyValue?: any\n value?: any\n min?: number\n max?: number\n onChange?: (value: any) => void\n precision?: number\n}\n\nexport function Ui89InputNumber(props: Ui89InputNumberProps) {\n const wrappedValue = useMemo(() => {\n if (props.value !== undefined && props.value !== null) {\n return Number(props.value)\n } else {\n return undefined\n }\n }, [props.value])\n\n function wrappedOnChange(value: any) {\n if (props.onChange === undefined) {\n return\n }\n\n if (value === props.emptyValue) {\n // Pass along.\n props.onChange(value)\n } else {\n if (value !== undefined && value !== null) {\n props.onChange(Number(value))\n } else {\n props.onChange(null)\n }\n }\n }\n\n return (\n <Ui89InputTextNumber\n emptyValue={props.emptyValue}\n value={wrappedValue}\n onChange={wrappedOnChange}\n min={props.min}\n max={props.max}\n precision={props.precision}\n />\n )\n}\n","import React from \"react\"\nimport { useState } from \"react\"\n\nimport \"../style/input-box.css\"\nimport \"../style/typo.css\"\n\nexport interface Ui89InputPasswordProps {\n value?: any\n placeholder?: string\n onChange?: (value: any) => void\n}\n\nexport function Ui89InputPassword({\n value,\n placeholder,\n onChange,\n}: Ui89InputPasswordProps) {\n const [intermediateValue, setIntermediateValue] = useState(value ?? \"\")\n\n const implOnChange: React.ChangeEventHandler<HTMLInputElement> = (e) => {\n const newValue = e.target.value\n\n setIntermediateValue(newValue)\n\n if (onChange) {\n onChange(newValue)\n }\n }\n\n return (\n <div>\n <input\n type=\"password\"\n className={`ui89-input-box ui89-typo-special`}\n role=\"textbox\"\n value={intermediateValue}\n onChange={implOnChange}\n placeholder={placeholder}\n />\n </div>\n )\n}\n","import React, { useState } from \"react\"\n\nimport \"../../style/reset.css\"\n\nimport { useUi89Overrides } from \"../../Ui89Override\"\n\nexport interface Ui89LinkBaseProps {\n className?: string\n onClick?: () => void | Promise<void>\n href?: string\n children: React.ReactNode\n autoDisableOnClick?: boolean\n disabled?: boolean\n}\n\nexport function Ui89LinkBase(props: Ui89LinkBaseProps) {\n const overrides = useUi89Overrides()\n const [clicking, setClicking] = useState(false)\n\n let localDisabled =\n props.disabled || ((props.autoDisableOnClick ?? true) && clicking)\n\n async function onClick(e: React.MouseEvent<HTMLAnchorElement>) {\n if (localDisabled) {\n // The anchor tag does not support the disabled attribute so we do this.\n return\n }\n\n try {\n setClicking(true)\n\n if (props.onClick !== undefined) {\n // A function takes over control.\n e.preventDefault()\n await props.onClick()\n } else if (props.href !== undefined) {\n if (props.href.startsWith(\"/\")) {\n if (overrides.routerPush !== undefined) {\n e.preventDefault()\n overrides.routerPush(props.href)\n }\n }\n } else {\n // Do nothing.\n e.preventDefault()\n }\n } finally {\n setClicking(false)\n }\n }\n\n return (\n <a\n className={`ui-89-reset-a ${props.className}`}\n role=\"link\"\n href={props.href}\n onClick={onClick}\n >\n {props.children}\n </a>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89LinkStealth.css\"\n\nimport { Ui89LinkBase } from \"./private/LinkBase\"\n\nexport interface Ui89LinkStealthProps {\n onClick?: () => void | Promise<void>\n href?: string\n children: React.ReactNode\n autoDisableOnClick?: boolean\n disabled?: boolean\n}\n\nexport function Ui89LinkStealth(props: Ui89LinkStealthProps) {\n return <Ui89LinkBase className=\"ui89-link-stealth\" {...props} />\n}\n","import React from \"react\"\n\nimport \"./Ui89LinkUnderline.css\"\n\nimport { Ui89LinkBase } from \"./private/LinkBase\"\n\nexport interface Ui89LinkUnderlineProps {\n onClick?: () => void | Promise<void>\n href?: string\n children: React.ReactNode\n autoDisableOnClick?: boolean\n disabled?: boolean\n}\n\nexport function Ui89LinkUnderline(props: Ui89LinkUnderlineProps) {\n return <Ui89LinkBase className=\"ui89-link-underline\" {...props} />\n}\n","import React from \"react\"\n\nimport \"./Ui89MenuBar.css\"\nimport \"../style/typo.css\"\nimport \"../style/scrollbar.css\"\n\nexport interface Ui89MenuBarPropsItem {\n label: React.ReactNode\n onClick?: () => void\n children?: Ui89MenuBarPropsItem[]\n}\n\nexport interface Ui89MenuBarProps {\n items: Ui89MenuBarPropsItem[]\n}\n\nexport function Ui89MenuBar({ items }: Ui89MenuBarProps) {\n return (\n <div className={`ui89-menu-bar ui89-typo-special ui89-scrollbar`}>\n {items.map((item, index) => {\n function onNativeClick() {\n if (item.onClick !== undefined) {\n item.onClick()\n }\n }\n\n return (\n <div\n key={index}\n className=\"ui89-menu-bar__item\"\n onClick={onNativeClick}\n >\n {item.label}\n </div>\n )\n })}\n </div>\n )\n}\n","import React from \"react\"\n\nimport { Ui89Look } from \"../theme\"\n\nimport \"./Ui89Scene.css\"\nimport \"../style/look.css\"\nimport \"../style/typo.css\"\nimport \"../style/scrollbar.css\"\n\nexport interface Ui89SceneProps {\n look?: Ui89Look | string\n children: React.ReactNode\n}\n\nexport function Ui89Scene({ look = Ui89Look.main, children }: Ui89SceneProps) {\n return (\n <div\n className={`ui89-scene ui-89-look-${look} ui89-typo-normal ui89-scrollbar`}\n >\n {children}\n </div>\n )\n}\n","import React from \"react\"\nimport \"./GridExpandTrick.css\"\n\nexport default function GridExpandTrick({\n children,\n}: {\n children: React.ReactNode\n}) {\n return <span className=\"ui89-grid-expand-trick\">{children}</span>\n}\n","import React from \"react\"\nimport \"./ScrollContainer.css\"\n\nexport default function ScrollContainer({\n children,\n}: {\n children: React.ReactNode\n}) {\n return <span className=\"ui89-scroll-container\">{children}</span>\n}\n","import React, { useMemo } from \"react\"\nimport { createPortal } from \"react-dom\"\nimport { Ui89Card } from \"./Ui89Card\"\nimport HoverShadow from \"./private/HoverShadow\"\nimport { Ui89Scene } from \"./Ui89Scene\"\nimport GridExpandTrick from \"./private/GridExpandTrick\"\nimport ScrollContainer from \"./private/ScrollContainer\"\n\nimport \"./Ui89ModalDialog.css\"\n\nexport interface Ui89ModalDialogProps {\n open: boolean\n size?: string\n children?: React.ReactNode\n topCenter?: React.ReactNode\n onRequestClose?: () => void\n}\n\nconst portalRoot: HTMLElement | null =\n typeof document !== \"undefined\" ? document.body : null\n\nexport function Ui89ModalDialog({\n open,\n size = \"medium\",\n children,\n topCenter,\n onRequestClose,\n}: Ui89ModalDialogProps) {\n const dialogClass = useMemo(() => {\n return [\"ui89-modal-dialog\", open ? \"ui89-modal-dialog--open\" : \"\"].join(\n \" \",\n )\n }, [size, open])\n\n const dialogBoxClass = useMemo(() => {\n return [\n \"ui89-modal-dialog__box\",\n `ui89-modal-dialog__box--size-${size}`,\n ].join(\" \")\n }, [size, open])\n\n function onClickBackdrop() {\n if (onRequestClose !== undefined) {\n onRequestClose()\n }\n }\n\n const vdom = (\n <div className={dialogClass} role=\"dialog\" style={{ zIndex: 1 }}>\n <div\n className=\"ui89-modal-dialog__backdrop\"\n role=\"presentation\"\n onClick={onClickBackdrop}\n ></div>\n\n <div className={dialogBoxClass}>\n <div className=\"ui89-modal-dialog__spacer\"></div>\n\n <HoverShadow>\n <GridExpandTrick>\n <Ui89Scene>\n <Ui89Card topCenter={topCenter}>\n <ScrollContainer>{children}</ScrollContainer>\n </Ui89Card>\n </Ui89Scene>\n </GridExpandTrick>\n </HoverShadow>\n </div>\n </div>\n )\n\n return portalRoot !== null ? createPortal(vdom, portalRoot) : vdom\n}\n","import React from \"react\"\n\nimport \"./Ui89NameValuePair.css\"\n\nexport interface Ui89NameValuePairProps {\n name: React.ReactNode\n value: React.ReactNode\n leftMaxWidth?: number\n}\n\nexport function Ui89NameValuePair({\n name,\n value,\n leftMaxWidth,\n}: Ui89NameValuePairProps) {\n return (\n <div className=\"ui-89-name-value-pair\">\n <div\n className=\"ui-89-name-value-pair__name-wrapper\"\n style={{ maxWidth: `${leftMaxWidth}px` }}\n >\n <div className=\"ui-89-name-value-pair__name\">{name}</div>\n <div className=\"ui-89-name-value-pair__dots\"></div>\n </div>\n <div className=\"ui-89-name-value-pair__value\">{value}</div>\n </div>\n )\n}\n","import * as React from \"react\";\nconst SvgShortcut = (props) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 100, height: 100, viewBox: \"0 0 100 100\", ...props }, /* @__PURE__ */ React.createElement(\"rect\", { x: 0, y: 0, width: 100, height: 100, fill: \"white\" }), /* @__PURE__ */ React.createElement(\"line\", { x1: 80, y1: 80, x2: 20, y2: 20, stroke: \"black\", strokeWidth: 15 }), /* @__PURE__ */ React.createElement(\"line\", { x1: 20, y1: 20, x2: 50, y2: 20, stroke: \"black\", strokeWidth: 15, strokeLinecap: \"round\" }), /* @__PURE__ */ React.createElement(\"line\", { x1: 20, y1: 20, x2: 20, y2: 50, stroke: \"black\", strokeWidth: 15, strokeLinecap: \"round\" }));\nexport default SvgShortcut;\n","import React from \"react\"\n\nexport interface Ui89SpaceVerticalProps {\n gap?: number\n}\n\nexport function Ui89SpaceVertical({ gap = 1 }: Ui89SpaceVerticalProps) {\n const style = {\n paddingTop: `calc(var(--ui89-safe-space) * ${gap})`,\n }\n\n return <div style={style}></div>\n}\n","import React from \"react\"\n\nimport ShortcutSvg from \"../images/shortcut.svg\"\n\nimport \"./Ui89Shortcut.css\"\nimport \"../style/typo.css\"\n\nimport { Ui89SpaceVertical } from \"./Ui89SpaceVertical\"\n\nexport interface Ui89ShortcutProps {\n imageUrl: string\n label: React.ReactNode\n onClick?: () => void\n}\n\nexport function Ui89Shortcut({\n imageUrl,\n label,\n onClick = () => {},\n}: Ui89ShortcutProps) {\n function onNativeClick() {\n onClick()\n }\n\n return (\n <div className=\"ui89-shortcut\" onClick={onNativeClick}>\n <div className=\"ui89-shortcut__image-container\">\n <img className=\"ui89-shortcut__image\" src={imageUrl} />\n\n <div className=\"ui89-shortcut__shortcut-icon-container\">\n <ShortcutSvg\n className=\"ui89-shortcut__shortcut-icon\"\n width={16}\n height={16}\n />\n </div>\n </div>\n\n <Ui89SpaceVertical gap={1} />\n\n <div\n className={`ui89-shortcut__label ui89-typo-small-bold`}\n onClick={onNativeClick}\n >\n {label}\n </div>\n </div>\n )\n}\n","import React from \"react\"\n\nexport interface Ui89SpacePaddingProps {\n gap?: number\n gapVertical?: number\n gapHorizontal?: number\n gapTop?: number\n gapRight?: number\n gapBottom?: number\n gapLeft?: number\n children?: React.ReactNode\n}\n\nexport function Ui89SpacePadding(props: Ui89SpacePaddingProps) {\n const gap = props.gap ?? 1\n\n const style = {\n paddingTop: `calc(var(--ui89-safe-space) * ${props.gapTop ?? props.gapVertical ?? gap})`,\n paddingRight: `calc(var(--ui89-safe-space) * ${props.gapRight ?? props.gapHorizontal ?? gap})`,\n paddingBottom: `calc(var(--ui89-safe-space) * ${props.gapBottom ?? props.gapVertical ?? gap})`,\n paddingLeft: `calc(var(--ui89-safe-space) * ${props.gapLeft ?? props.gapHorizontal ?? gap})`,\n }\n\n return <div style={style}>{props.children}</div>\n}\n","import React from \"react\"\n\nimport \"./Ui89Tabs.css\"\nimport \"../style/typo.css\"\n\nexport interface Ui89TabsPropsOption {\n value: string | number\n label: React.ReactNode\n}\n\nexport interface Ui89TabsProps {\n selected?: any\n onChange?: (value: string | number) => void\n options?: Ui89TabsPropsOption[]\n\n /**\n * Stretch options such that they evenly take up the entire width.\n */\n stretch?: boolean\n}\n\nexport function Ui89Tabs({\n selected,\n onChange = () => {},\n options = [],\n stretch,\n}: Ui89TabsProps) {\n function handleOnChange(value: string | number) {\n onChange(value)\n }\n\n return (\n <div\n className={[\"ui89-tabs\", stretch ? \"ui89-tabs--stretch\" : \"\"].join(\" \")}\n >\n {options.map((option) => (\n <div\n className={[\n \"ui89-tabs__item\",\n \"ui89-typo-small-bold\",\n selected === option.value ? \"ui89-tabs__item--selected\" : \"\",\n ].join(\" \")}\n key={option.value}\n onClick={() => handleOnChange(option.value)}\n >\n {option.label}\n </div>\n ))}\n </div>\n )\n}\n","import { Ui89Card } from \"./Ui89Card\"\nimport { Ui89Tabs } from \"./Ui89Tabs\"\nimport React, { useCallback, useMemo } from \"react\"\n\nexport interface Ui89TabbedCardProps {\n selected?: any\n onChange?: (value: string | number) => void\n options?: Ui89TabbedCardPropsOption[]\n}\n\nexport interface Ui89TabbedCardPropsOption {\n value: string | number\n label: React.ReactNode\n render: () => React.JSX.Element\n}\n\nexport function Ui89TabbedCard({\n selected,\n onChange,\n options = [],\n}: Ui89TabbedCardProps) {\n const selectedItem = useMemo<Ui89TabbedCardPropsOption | null>(() => {\n return options.find((item) => item.value === selected) ?? null\n }, [selected, options])\n\n const render = useMemo(() => {\n return selectedItem !== null ? selectedItem.render : () => <></>\n }, [selectedItem])\n\n const renderKey = useMemo(() => {\n return selectedItem !== null ? selectedItem.value : undefined\n }, [selectedItem])\n\n return (\n <Ui89Card\n topCenter={\n <Ui89Tabs selected={selected} options={options} onChange={onChange} />\n }\n >\n <React.Fragment key={renderKey}>{render()}</React.Fragment>\n </Ui89Card>\n )\n}\n","import React from \"react\"\n\nimport { Ui89Theme } from \"../theme\"\nimport \"../style/typo.css\"\nimport \"../style/chosen-theme.css\"\n\nimport \"./Ui89TagBox.css\"\n\nexport interface Ui89TagBoxProps {\n theme: Ui89Theme | keyof typeof Ui89Theme\n children: React.ReactNode\n}\n\nexport function Ui89TagBox({ theme, children }: Ui89TagBoxProps) {\n return (\n <div\n className={`ui89-tag-box ui89-typo-special ui89-chosen-theme-${theme}`}\n >\n {children}\n </div>\n )\n}\n","import React, { useState } from \"react\"\n\nimport \"./Ui89ThemeBackground.css\"\nimport \"../style/chosen-theme.css\"\n\nimport { Ui89Theme } from \"../theme\"\n\nexport interface Ui89ThemeBackgroundProps {\n theme?: Ui89Theme | keyof typeof Ui89Theme\n children: React.ReactNode\n}\n\nexport function Ui89ThemeBackground({\n theme = Ui89Theme.primary,\n children,\n}: Ui89ThemeBackgroundProps) {\n return (\n <div className={`ui89-theme-background ui89-chosen-theme-${theme}`}>\n {children}\n </div>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89TitleBox.css\"\nimport \"../style/typo.css\"\nimport \"../style/text.css\"\n\nexport interface Ui89TitleBoxProps {\n children: React.ReactNode\n}\n\nexport function Ui89TitleBox({ children }: Ui89TitleBoxProps) {\n return (\n <div className={`ui89-title-box ui89-typo-special`}>\n <div className={`ui89-title-box__inside ui89-text-single-line`}>\n {children}\n </div>\n </div>\n )\n}\n","import React from \"react\"\n\nimport \"./Ui89TitleUnderline.css\"\nimport \"../style/typo.css\"\nimport \"../style/text.css\"\n\nexport interface Ui89TitleUnderlineProps {\n children: React.ReactNode\n}\n\nexport function Ui89TitleUnderline({ children }: Ui89TitleUnderlineProps) {\n return (\n <div className={`ui89-title-underline ui89-typo-special`}>\n <div className={`ui89-title-underline__inside ui89-text-single-line`}>\n {children}\n </div>\n </div>\n )\n}\n","import React from \"react\"\nimport { ToastContainer, toast } from \"react-toastify\"\n\nimport \"./Ui89Toaster.css\"\nimport \"../style/typo.css\"\nimport \"../style/chosen-theme.css\"\nimport { Ui89Theme } from \"../theme\"\n\nexport interface Ui89ToasterOptions {\n theme?: Ui89Theme | keyof typeof Ui89Theme\n autoClose?: boolean\n duration?: number\n}\n\nexport function useUi89Toaster() {\n return {\n toast(\n content: React.ReactNode,\n options: Ui89ToasterOptions = { theme: Ui89Theme.primary },\n ) {\n const classNames = [\"ui89-toaster\", \"ui89-typo-normal\"]\n\n if (options.theme !== undefined) {\n classNames.push(`ui89-chosen-theme-${options.theme}`)\n }\n\n let autoClose: boolean | number = 5000\n\n if (options.duration !== undefined) {\n autoClose = options.duration\n }\n\n if (options.autoClose !== undefined) {\n if (!options.autoClose) {\n autoClose = false\n }\n }\n\n return toast(() => content, {\n className: classNames.join(\" \"),\n type: \"default\",\n autoClose,\n closeButton: false,\n hideProgressBar: true,\n closeOnClick: true,\n })\n },\n }\n}\n\nexport function Ui89Toaster() {\n return <ToastContainer />\n}\n","import { useState, useEffect, useRef } from \"react\"\n\ntype Size = { width: number; height: number }\n\ninterface UseResizeObserverResult {\n size: Size\n}\n\nexport const useResizeObserver = <T extends HTMLElement>(\n ref: React.RefObject<T>,\n): UseResizeObserverResult => {\n const [size, setSize] = useState<Size>({ width: 0, height: 0 })\n\n useEffect(() => {\n const observer = new ResizeObserver((entries) => {\n for (let entry of entries) {\n setSize({\n width:\n entry.borderBoxSize?.[0]?.inlineSize ?? entry.contentRect.width,\n height:\n entry.borderBoxSize?.[0]?.blockSize ?? entry.contentRect.height,\n })\n }\n })\n\n if (ref.current) {\n observer.observe(ref.current)\n }\n\n return () => {\n observer.disconnect()\n }\n }, [ref.current])\n\n return {\n size,\n }\n}\n","import { useState, useEffect, useRef, RefObject } from \"react\"\n\nexport const useScrollYPosition = (ref: RefObject<HTMLElement>): number => {\n const [scrollY, setScrollY] = useState(0)\n const ticking = useRef(false)\n const observer = useRef<MutationObserver | null>(null)\n\n useEffect(() => {\n const element = ref.current\n if (!element) return\n\n const handleScroll = () => {\n if (!ticking.current) {\n requestAnimationFrame(() => {\n setScrollY(element.scrollTop)\n ticking.current = false\n })\n ticking.current = true\n }\n }\n\n element.addEventListener(\"scroll\", handleScroll, { passive: true })\n\n observer.current = new MutationObserver(() => {\n if (ref.current !== element) {\n element.removeEventListener(\"scroll\", handleScroll)\n ref.current?.addEventListener(\"scroll\", handleScroll, { passive: true })\n }\n })\n\n observer.current.observe(document.body, { childList: true, subtree: true })\n\n return () => {\n element.removeEventListener(\"scroll\", handleScroll)\n observer.current?.disconnect()\n }\n }, [ref])\n\n return scrollY\n}\n","import React, { useState, useEffect, useRef, useMemo } from \"react\"\n\nimport \"./Ui89VirtualList.css\"\nimport { useResizeObserver } from \"../useResizeObserver\"\nimport { useScrollYPosition } from \"../useScrollYPosition\"\n\nexport interface Ui89VirtualListPropsRenderRowProps<T> {\n index: number\n row: T\n}\n\nexport interface Ui89VirtualListProps<T> {\n maxHeight?: string\n rows: T[]\n rowHeight?: number\n renderRow: (props: Ui89VirtualListPropsRenderRowProps<T>) => React.ReactNode\n getRowKey?: (row: T) => string\n}\n\ninterface VisibleRow<T> {\n userKey: string\n index: number\n row: T\n key: number\n render: React.ReactNode\n style: React.CSSProperties\n}\n\nfunction popAnyEntry<K, V>(map: Map<K, V>): V | undefined {\n const iterator = map.keys().next()\n if (!iterator.done) {\n const key = iterator.value\n const value = map.get(key)!\n map.delete(key)\n return value\n }\n return undefined\n}\n\n/**\n * Virtualization at row level. Great for long lists.\n *\n * Can be used to implement table components with few columns.\n */\nexport const Ui89VirtualList = React.memo(\n <T,>(props: Ui89VirtualListProps<T>) => {\n const keyCounter = useRef<number>(0)\n const scrollContainer = useRef<HTMLDivElement>(null)\n const scrollAreaContainer = useRef<HTMLDivElement>(null)\n\n const { size } = useResizeObserver(scrollContainer)\n const scrollY = useScrollYPosition(scrollContainer)\n\n const rowHeight = props.rowHeight ?? 50\n\n const totalHeight = rowHeight * props.rows.length\n\n const [visibleRows, setVisibleRows] = useState<Map<string, VisibleRow<T>>>(\n new Map(),\n )\n\n useEffect(() => {\n if (size.height === 0) {\n setVisibleRows(new Map())\n return\n }\n\n const firstIndex = Math.max(0, Math.floor(scrollY / rowHeight) - 1)\n const length = Math.min(\n props.rows.length - firstIndex,\n Math.ceil(size.height / rowHeight) + 2,\n )\n\n const deletedRows = new Map(visibleRows)\n\n // Must find the ones that are no longer visible.\n for (let index = firstIndex; index < firstIndex + length; index++) {\n let row = props.rows[index]\n let key = props.getRowKey ? props.getRowKey(row) : String(index)\n deletedRows.delete(key)\n }\n\n const newVisibleRows = new Map<string, VisibleRow<T>>()\n\n for (let index = firstIndex; index < firstIndex + length; index++) {\n let row = props.rows[index]\n let key = props.getRowKey ? props.getRowKey(row) : String(index)\n\n let existingRow = visibleRows.get(key)\n\n if (existingRow !== undefined) {\n if (existingRow.row === row) {\n // Data has technically not changed so we can reuse.\n } else {\n // Data has changed, must update render.\n existingRow.render = props.renderRow({ index, row })\n }\n\n newVisibleRows.set(key, existingRow)\n\n continue\n }\n\n let oldRow = popAnyEntry(deletedRows)\n\n if (oldRow !== undefined) {\n oldRow.index = index\n oldRow.row = row\n oldRow.userKey = key\n oldRow.render = props.renderRow({ index, row })\n oldRow.style = {\n transform: `translateY(${index * rowHeight}px)`,\n height: `${rowHeight}px`,\n }\n newVisibleRows.set(key, oldRow)\n } else {\n // New row.\n newVisibleRows.set(key, {\n index,\n row,\n key: keyCounter.current++,\n userKey: key,\n render: props.renderRow({ index, row }),\n style: {\n transform: `translateY(${index * rowHeight}px)`,\n height: `${rowHeight}px`,\n },\n })\n }\n }\n\n setVisibleRows(newVisibleRows)\n }, [props.rows, scrollY, size.height])\n\n const orderedVisibleRows = useMemo(() => {\n return Array.from(visibleRows.values()).sort((a, b) => a.index - b.index)\n }, [visibleRows])\n\n return (\n <div\n ref={scrollContainer}\n className=\"ui89-virtual-list\"\n style={{ maxHeight: props.maxHeight }}\n >\n <div\n ref={scrollAreaContainer}\n className=\"ui89-virtual-list__scroll-area\"\n style={{ height: `${totalHeight}px` }}\n >\n {orderedVisibleRows.map((visibleRow) => (\n <div\n key={visibleRow.key}\n className=\"ui89-virtual-list__row\"\n style={visibleRow.style}\n >\n {visibleRow.render}\n </div>\n ))}\n </div>\n </div>\n )\n },\n) as <T>(props: Ui89VirtualListProps<T>) => JSX.Element\n","import React, { forwardRef, useCallback, useMemo } from \"react\"\nimport \"./Ui89VirtualTable.css\"\nimport \"../style/typo.css\"\nimport { Ui89TagBox } from \"./Ui89TagBox\"\nimport {\n Ui89VirtualList,\n Ui89VirtualListPropsRenderRowProps,\n} from \"./Ui89VirtualList\"\n\nexport enum Ui89VirtualTablePropsColumnAlign {\n left = \"left\",\n right = \"right\",\n center = \"center\",\n}\n\nexport interface Ui89VirtualTablePropsColumnRenderHeaderParams<T> {\n index: number\n column: Ui89VirtualTablePropsColumn<T>\n}\n\nexport interface Ui89VirtualTablePropsColumnRenderBodyParams<T> {\n index: number\n row: T\n}\n\nexport interface Ui89VirtualTablePropsColumn<T> {\n width?: number\n halign?: keyof typeof Ui89VirtualTablePropsColumnAlign\n renderHeader?: (\n props: Ui89VirtualTablePropsColumnRenderHeaderParams<T>,\n ) => React.ReactNode\n renderBody: (\n props: Ui89VirtualTablePropsColumnRenderBodyParams<T>,\n ) => React.ReactNode\n}\n\nexport interface Ui89VirtualTableProps<T> {\n maxHeight?: string\n rows?: T[]\n columns?: Ui89VirtualTablePropsColumn<T>[]\n rowHeight?: number\n}\n\nexport const Ui89VirtualTable = React.memo(\n <T,>(props: Ui89VirtualTableProps<T>) => {\n const rows = useMemo<(T | undefined)[]>(() => {\n let rows: any[] = props.rows !== undefined ? props.rows.slice() : []\n\n rows.unshift(undefined)\n\n return rows\n }, [props.rows])\n\n const columns = useMemo(() => {\n return props.columns !== undefined ? props.columns : []\n }, [props.columns])\n\n const rowHeight = props.rowHeight ?? 20\n\n function getColumnWidth(index: number): number {\n return columns[index].width ?? 100\n }\n\n function getColumnHorizontalOffset(columnIndex: number) {\n let offset = 0\n\n for (let i = 0; i < columnIndex; i++) {\n offset += getColumnWidth(i)\n }\n\n return offset\n }\n\n function isLastColumn(columnIndex: number): boolean {\n return columnIndex === columns.length - 1\n }\n\n function getRowClass(rowIndex: number): string {\n const classes = [\"ui89-virtual-table__row\"]\n\n if (rowIndex === 0) {\n classes.push(\"ui89-virtual-table__row--first\")\n classes.push(\"ui89-typo-normal-bold\")\n }\n\n if (rowIndex === rows.length) {\n classes.push(\"ui89-virtual-table__row--last\")\n }\n\n return classes.join(\" \")\n }\n\n function getColumnClass(columnIndex: number): string {\n const halign = columns[columnIndex].halign ?? \"left\"\n\n const classes = [\n \"ui89-virtual-table__cell\",\n `ui89-virtual-table__cell--halign-${halign}`,\n ]\n\n if (columnIndex === 0) {\n classes.push(\"ui89-virtual-table__cell--column-first\")\n }\n\n if (isLastColumn(columnIndex)) {\n classes.push(\"ui89-virtual-table__cell--column-last\")\n }\n\n return classes.join(\" \")\n }\n\n /**\n * The width of an entire row.\n */\n function rowWidth() {\n return getColumnHorizontalOffset(columns.length)\n }\n\n const renderRow = useCallback(\n ({ index, row }: Ui89VirtualListPropsRenderRowProps<T>) => {\n return (\n <div\n className={getRowClass(index)}\n style={{ minWidth: rowWidth() + \"px\", height: \"100%\" }}\n >\n {columns.map((column, columnIndex) => {\n return (\n <div\n key={columnIndex}\n className={getColumnClass(columnIndex)}\n style={{\n top: 0,\n height: \"100%\",\n width: getColumnWidth(columnIndex) + \"px\",\n left: getColumnHorizontalOffset(columnIndex) + \"px\",\n }}\n >\n {index === 0\n ? columns[columnIndex].renderHeader\n ? columns[columnIndex].renderHeader({\n index: columnIndex,\n column: column,\n })\n : \"\"\n : columns[columnIndex].renderBody({\n index: index,\n row: row,\n })}\n </div>\n )\n })}\n </div>\n )\n },\n [columns, rowHeight],\n )\n\n return (\n <>\n {rows.length > 1 ? (\n <Ui89VirtualList\n maxHeight={props.maxHeight}\n rows={rows as T[]}\n rowHeight={rowHeight}\n renderRow={renderRow}\n />\n ) : (\n <div className=\"ui89-virtual-table__empty\">\n <Ui89TagBox theme=\"warning\">Empty</Ui89TagBox>\n </div>\n )}\n </>\n )\n },\n) as <T>(props: Ui89VirtualTableProps<T>) => JSX.Element\n"],"names":["React","ShortcutSvg"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-ui89",
|
|
3
3
|
"description": "A collection of React components that mimic a common style of user interfaces from the late 80s and early 90s.",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.38.0",
|
|
5
5
|
"author": "Daniel Araujo",
|
|
6
6
|
"module": "dist/esm/index.js",
|
|
7
7
|
"files": [
|