react-ui89 0.37.0 → 0.39.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/Ui89InputSelect.d.ts +4 -0
- package/dist/esm/components/Ui89InputSelect.stories.d.ts +1 -0
- package/dist/esm/index.css +2 -2
- package/dist/esm/index.d.ts +1 -1
- package/dist/esm/index.js +198 -169
- package/dist/esm/index.js.map +1 -1
- package/package.json +2 -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;
|
package/dist/esm/index.css
CHANGED
|
@@ -15,7 +15,8 @@
|
|
|
15
15
|
.ui89-input-check-text{display:inline-block;cursor:pointer;user-select:none;}
|
|
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
|
-
.ui89-input-select{position:relative;}.ui89-input-select__menu{
|
|
18
|
+
.ui89-input-select{position:relative;}.ui89-input-select__menu{overflow:auto;background:var(--ui89-input-bg-color);color:var(--ui89-input-text-color);}.ui89-input-select:focus-within .ui89-input-select__menu{}@keyframes ui89-input-select__appear{from{transform:translateY(-5px);}to{transform:translateY(0%);}}.ui89-input-select__menu__item{display:inline-flex;flex-direction:column;justify-content:center;min-width:100%;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;box-sizing:border-box;}.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-virtual-list{position:relative;overflow:auto;}.ui89-virtual-list__row{position:absolute;width:100%;}
|
|
19
20
|
.ui89-link-stealth{color:currentColor;cursor:pointer;}.ui89-link-stealth:hover{color:currentColor;background:var(--ui89-scene-highlight-color);}
|
|
20
21
|
.ui89-link-underline{color:currentColor;text-decoration:underline;cursor:pointer;}.ui89-link-underline:hover{color:currentColor;}
|
|
21
22
|
.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);}
|
|
@@ -33,5 +34,4 @@
|
|
|
33
34
|
.ui89-title-box{display:flex;}.ui89-title-box__inside{min-width:0;color:var(--ui89-scene-bg-color);background-color:var(--ui89-scene-text-color);padding:0px var(--ui89-safe-space);}
|
|
34
35
|
.ui89-title-underline{display:flex;line-height:1;}.ui89-title-underline__inside{min-width:0;border-bottom:1px solid;position:relative;padding-bottom:calc(var(--ui89-safe-space) / 2);}.ui89-title-underline__inside:after{content:"";position:absolute;inset:0;transform:translateY(-2px);border-bottom:1px solid;z-index:0;}
|
|
35
36
|
.ui89-toaster::before{content:"";position:absolute;inset:0;border:var(--ui89-toaster-border-width) solid var(--ui89-chosen-theme-text-color);margin:var(--ui89-safe-space);}.ui89-toaster::after{content:"";display:block;position:absolute;top:0;left:50%;transform:translateX(-50%);background:var(--ui89-chosen-theme-bg-color);color:var(--ui89-chosen-theme-text-color);padding:0 var(--ui89-safe-space);}.ui89-toaster.Toastify__toast--default{--ui89-toaster-border-width:1px;display:block;min-height:auto;padding:calc(var(--ui89-safe-space) * 2 + var(--ui89-toaster-border-width));border-radius:0;box-shadow:var(--ui89-box-shadow);background:var(--ui89-chosen-theme-bg-color);color:var(--ui89-chosen-theme-text-color);}.ui89-toaster .Toastify__progress-bar--wrp{border-radius:0;}
|
|
36
|
-
.ui89-virtual-list{position:relative;overflow:auto;}.ui89-virtual-list__row{position:absolute;width:100%;}
|
|
37
37
|
.ui89-virtual-table__empty{display:flex;align-items:center;justify-content:center;text-align:center;}.ui89-virtual-table__row{position:relative;box-sizing:border-box;border-top:1px solid var(--ui89-scene-text-color);}.ui89-virtual-table__row--first{border-top:none;}.ui89-virtual-table__cell{position:absolute;display:flex;flex-direction:column;justify-content:center;padding:0 var(--ui89-safe-space);box-sizing:border-box;overflow:hidden;background:var(--ui89-scene-bg-color);}.ui89-virtual-table__cell--column-first{padding-left:var(--ui89-safe-space);}.ui89-virtual-table__cell--column-last{padding-right:var(--ui89-safe-space);}.ui89-virtual-table__cell--halign-left{align-items:flex-start;}.ui89-virtual-table__cell--halign-right{align-items:flex-end;}.ui89-virtual-table__cell--halign-center{align-items:center;}
|
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";
|
package/dist/esm/index.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import React__default, { createContext, useContext, useState, useEffect, useRef, useMemo, useCallback } from 'react';
|
|
3
3
|
import DatePicker from 'react-datepicker';
|
|
4
|
+
import { useFloating, size, autoUpdate, useClick, useDismiss, useRole, useInteractions, FloatingFocusManager } from '@floating-ui/react';
|
|
4
5
|
import Timeout from 'smart-timeout';
|
|
5
6
|
import { createPortal } from 'react-dom';
|
|
6
7
|
import { toast, ToastContainer } from 'react-toastify';
|
|
@@ -66,7 +67,12 @@ var Ui89ButtonPropsSize;
|
|
|
66
67
|
Ui89ButtonPropsSize["standard"] = "standard";
|
|
67
68
|
Ui89ButtonPropsSize["square"] = "square";
|
|
68
69
|
})(Ui89ButtonPropsSize || (Ui89ButtonPropsSize = {}));
|
|
69
|
-
|
|
70
|
+
var Ui89ButtonPropsType;
|
|
71
|
+
(function (Ui89ButtonPropsType) {
|
|
72
|
+
Ui89ButtonPropsType["submit"] = "submit";
|
|
73
|
+
Ui89ButtonPropsType["reset"] = "reset";
|
|
74
|
+
})(Ui89ButtonPropsType || (Ui89ButtonPropsType = {}));
|
|
75
|
+
function Ui89Button({ theme = Ui89Theme.primary, size = Ui89ButtonPropsSize.standard, type, block, onClick, href, children, autoDisableOnClick = true, disabled, activated, }) {
|
|
70
76
|
const overrides = useUi89Overrides();
|
|
71
77
|
const [clicking, setClicking] = useState(false);
|
|
72
78
|
let localDisabled = disabled || (autoDisableOnClick && clicking);
|
|
@@ -127,7 +133,7 @@ function Ui89Button({ theme = Ui89Theme.primary, size = Ui89ButtonPropsSize.stan
|
|
|
127
133
|
].join(" ");
|
|
128
134
|
return (React__default.createElement("div", { className: containerClass },
|
|
129
135
|
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 },
|
|
136
|
+
React__default.createElement("span", { className: buttonClass }, children))) : (React__default.createElement("button", { className: "ui-89-reset-button", type: type || "button", onClick: onButtonClick, disabled: localDisabled },
|
|
131
137
|
React__default.createElement("span", { className: buttonClass }, children))))));
|
|
132
138
|
}
|
|
133
139
|
|
|
@@ -265,11 +271,183 @@ function Ui89InputFileUpload({ value, onChange, }) {
|
|
|
265
271
|
React__default.createElement("span", { className: `ui89-input-file-upload__info ui89-text-single-line ui89-text-single-line--ellipsis-left`, title: value.name }, value.name))) : (React__default.createElement(Ui89Button, { onClick: onClick }, "Upload"))));
|
|
266
272
|
}
|
|
267
273
|
|
|
274
|
+
const useResizeObserver = (ref) => {
|
|
275
|
+
const [size, setSize] = useState({ width: 0, height: 0 });
|
|
276
|
+
useEffect(() => {
|
|
277
|
+
const observer = new ResizeObserver((entries) => {
|
|
278
|
+
for (let entry of entries) {
|
|
279
|
+
setSize({
|
|
280
|
+
width: entry.borderBoxSize?.[0]?.inlineSize ?? entry.contentRect.width,
|
|
281
|
+
height: entry.borderBoxSize?.[0]?.blockSize ?? entry.contentRect.height,
|
|
282
|
+
});
|
|
283
|
+
}
|
|
284
|
+
});
|
|
285
|
+
if (ref.current) {
|
|
286
|
+
observer.observe(ref.current);
|
|
287
|
+
}
|
|
288
|
+
return () => {
|
|
289
|
+
observer.disconnect();
|
|
290
|
+
};
|
|
291
|
+
}, [ref.current]);
|
|
292
|
+
return {
|
|
293
|
+
size,
|
|
294
|
+
};
|
|
295
|
+
};
|
|
296
|
+
|
|
297
|
+
const useScrollYPosition = (ref) => {
|
|
298
|
+
const [scrollY, setScrollY] = useState(0);
|
|
299
|
+
const ticking = useRef(false);
|
|
300
|
+
const observer = useRef(null);
|
|
301
|
+
useEffect(() => {
|
|
302
|
+
const element = ref.current;
|
|
303
|
+
if (!element)
|
|
304
|
+
return;
|
|
305
|
+
const handleScroll = () => {
|
|
306
|
+
if (!ticking.current) {
|
|
307
|
+
requestAnimationFrame(() => {
|
|
308
|
+
setScrollY(element.scrollTop);
|
|
309
|
+
ticking.current = false;
|
|
310
|
+
});
|
|
311
|
+
ticking.current = true;
|
|
312
|
+
}
|
|
313
|
+
};
|
|
314
|
+
element.addEventListener("scroll", handleScroll, { passive: true });
|
|
315
|
+
observer.current = new MutationObserver(() => {
|
|
316
|
+
if (ref.current !== element) {
|
|
317
|
+
element.removeEventListener("scroll", handleScroll);
|
|
318
|
+
ref.current?.addEventListener("scroll", handleScroll, { passive: true });
|
|
319
|
+
}
|
|
320
|
+
});
|
|
321
|
+
observer.current.observe(document.body, { childList: true, subtree: true });
|
|
322
|
+
return () => {
|
|
323
|
+
element.removeEventListener("scroll", handleScroll);
|
|
324
|
+
observer.current?.disconnect();
|
|
325
|
+
};
|
|
326
|
+
}, [ref]);
|
|
327
|
+
return scrollY;
|
|
328
|
+
};
|
|
329
|
+
|
|
330
|
+
function popAnyEntry(map) {
|
|
331
|
+
const iterator = map.keys().next();
|
|
332
|
+
if (!iterator.done) {
|
|
333
|
+
const key = iterator.value;
|
|
334
|
+
const value = map.get(key);
|
|
335
|
+
map.delete(key);
|
|
336
|
+
return value;
|
|
337
|
+
}
|
|
338
|
+
return undefined;
|
|
339
|
+
}
|
|
340
|
+
/**
|
|
341
|
+
* Virtualization at row level. Great for long lists.
|
|
342
|
+
*
|
|
343
|
+
* Can be used to implement table components with few columns.
|
|
344
|
+
*/
|
|
345
|
+
const Ui89VirtualList = React__default.memo((props) => {
|
|
346
|
+
const keyCounter = useRef(0);
|
|
347
|
+
const scrollContainer = useRef(null);
|
|
348
|
+
const scrollAreaContainer = useRef(null);
|
|
349
|
+
const { size } = useResizeObserver(scrollContainer);
|
|
350
|
+
const scrollY = useScrollYPosition(scrollContainer);
|
|
351
|
+
const rowHeight = props.rowHeight ?? 50;
|
|
352
|
+
const totalHeight = rowHeight * props.rows.length;
|
|
353
|
+
const [visibleRows, setVisibleRows] = useState(new Map());
|
|
354
|
+
useEffect(() => {
|
|
355
|
+
if (size.height === 0) {
|
|
356
|
+
setVisibleRows(new Map());
|
|
357
|
+
return;
|
|
358
|
+
}
|
|
359
|
+
const firstIndex = Math.max(0, Math.floor(scrollY / rowHeight) - 1);
|
|
360
|
+
const length = Math.min(props.rows.length - firstIndex, Math.ceil(size.height / rowHeight) + 2);
|
|
361
|
+
const deletedRows = new Map(visibleRows);
|
|
362
|
+
// Must find the ones that are no longer visible.
|
|
363
|
+
for (let index = firstIndex; index < firstIndex + length; index++) {
|
|
364
|
+
let row = props.rows[index];
|
|
365
|
+
let key = props.getRowKey ? props.getRowKey(row) : String(index);
|
|
366
|
+
deletedRows.delete(key);
|
|
367
|
+
}
|
|
368
|
+
const newVisibleRows = new Map();
|
|
369
|
+
for (let index = firstIndex; index < firstIndex + length; index++) {
|
|
370
|
+
let row = props.rows[index];
|
|
371
|
+
let key = props.getRowKey ? props.getRowKey(row) : String(index);
|
|
372
|
+
let existingRow = visibleRows.get(key);
|
|
373
|
+
if (existingRow !== undefined) {
|
|
374
|
+
if (existingRow.row === row) ;
|
|
375
|
+
else {
|
|
376
|
+
// Data has changed, must update render.
|
|
377
|
+
existingRow.render = props.renderRow({ index, row });
|
|
378
|
+
}
|
|
379
|
+
newVisibleRows.set(key, existingRow);
|
|
380
|
+
continue;
|
|
381
|
+
}
|
|
382
|
+
let oldRow = popAnyEntry(deletedRows);
|
|
383
|
+
if (oldRow !== undefined) {
|
|
384
|
+
oldRow.index = index;
|
|
385
|
+
oldRow.row = row;
|
|
386
|
+
oldRow.userKey = key;
|
|
387
|
+
oldRow.render = props.renderRow({ index, row });
|
|
388
|
+
oldRow.style = {
|
|
389
|
+
transform: `translateY(${index * rowHeight}px)`,
|
|
390
|
+
height: `${rowHeight}px`,
|
|
391
|
+
};
|
|
392
|
+
newVisibleRows.set(key, oldRow);
|
|
393
|
+
}
|
|
394
|
+
else {
|
|
395
|
+
// New row.
|
|
396
|
+
newVisibleRows.set(key, {
|
|
397
|
+
index,
|
|
398
|
+
row,
|
|
399
|
+
key: keyCounter.current++,
|
|
400
|
+
userKey: key,
|
|
401
|
+
render: props.renderRow({ index, row }),
|
|
402
|
+
style: {
|
|
403
|
+
transform: `translateY(${index * rowHeight}px)`,
|
|
404
|
+
height: `${rowHeight}px`,
|
|
405
|
+
},
|
|
406
|
+
});
|
|
407
|
+
}
|
|
408
|
+
}
|
|
409
|
+
setVisibleRows(newVisibleRows);
|
|
410
|
+
}, [props.rows, scrollY, size.height]);
|
|
411
|
+
const orderedVisibleRows = useMemo(() => {
|
|
412
|
+
return Array.from(visibleRows.values()).sort((a, b) => a.index - b.index);
|
|
413
|
+
}, [visibleRows]);
|
|
414
|
+
return (React__default.createElement("div", { ref: scrollContainer, className: "ui89-virtual-list", style: { maxHeight: props.maxHeight } },
|
|
415
|
+
React__default.createElement("div", { ref: scrollAreaContainer, className: "ui89-virtual-list__scroll-area", style: { height: `${totalHeight}px` } }, orderedVisibleRows.map((visibleRow) => (React__default.createElement("div", { key: visibleRow.key, className: "ui89-virtual-list__row", style: visibleRow.style }, visibleRow.render))))));
|
|
416
|
+
});
|
|
417
|
+
|
|
268
418
|
/**
|
|
269
419
|
* This is a very performant and customizable dropdown selector that
|
|
270
420
|
* allows you to choose from a list of options.
|
|
271
421
|
*/
|
|
272
422
|
function Ui89InputSelect(props) {
|
|
423
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
424
|
+
const { refs, floatingStyles, context } = useFloating({
|
|
425
|
+
open: isOpen,
|
|
426
|
+
onOpenChange: setIsOpen,
|
|
427
|
+
middleware: [
|
|
428
|
+
size({
|
|
429
|
+
apply({ availableWidth, availableHeight, elements }) {
|
|
430
|
+
let width = elements.reference.getBoundingClientRect().width;
|
|
431
|
+
// Change styles, e.g.
|
|
432
|
+
Object.assign(elements.floating.style, {
|
|
433
|
+
width: `${width}px`,
|
|
434
|
+
maxHeight: `${Math.max(0, availableHeight)}px`,
|
|
435
|
+
});
|
|
436
|
+
},
|
|
437
|
+
}),
|
|
438
|
+
],
|
|
439
|
+
whileElementsMounted: autoUpdate,
|
|
440
|
+
placement: "bottom-start",
|
|
441
|
+
strategy: "fixed",
|
|
442
|
+
});
|
|
443
|
+
const click = useClick(context);
|
|
444
|
+
const dismiss = useDismiss(context);
|
|
445
|
+
const role = useRole(context);
|
|
446
|
+
const { getReferenceProps, getFloatingProps } = useInteractions([
|
|
447
|
+
click,
|
|
448
|
+
dismiss,
|
|
449
|
+
role,
|
|
450
|
+
]);
|
|
273
451
|
const getOptionKey = useMemo(() => {
|
|
274
452
|
return props.getOptionKey ?? ((option) => option);
|
|
275
453
|
}, [props.getOptionKey]);
|
|
@@ -289,40 +467,36 @@ function Ui89InputSelect(props) {
|
|
|
289
467
|
}
|
|
290
468
|
return getOptionKey(option) === getOptionKey(props.value);
|
|
291
469
|
}
|
|
292
|
-
function selectOption(option) {
|
|
293
|
-
if (props.onChange !== undefined) {
|
|
294
|
-
props.onChange(option);
|
|
295
|
-
}
|
|
296
|
-
if (document.activeElement !== null) {
|
|
297
|
-
// @ts-expect-error
|
|
298
|
-
document.activeElement.blur();
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
470
|
function optionTitle(option) {
|
|
302
471
|
return String(option);
|
|
303
472
|
}
|
|
473
|
+
const selectOption = useCallback((option) => {
|
|
474
|
+
if (props.onChange !== undefined) {
|
|
475
|
+
props.onChange(option);
|
|
476
|
+
}
|
|
477
|
+
setIsOpen(false);
|
|
478
|
+
}, [props.onChange]);
|
|
479
|
+
const renderOption = useCallback(({ row }) => {
|
|
480
|
+
const isSelected = isOptionSelected(row);
|
|
481
|
+
return (React__default.createElement("div", { className: [
|
|
482
|
+
"ui89-input-select__menu__item",
|
|
483
|
+
isSelected ? "ui89-input-select__menu__item--selected" : null,
|
|
484
|
+
].join(" "), title: optionTitle(row), key: getOptionKey(row), onClick: () => selectOption(row) }, props.renderOption !== undefined ? props.renderOption(row) : row));
|
|
485
|
+
}, [options, selectOption]);
|
|
304
486
|
return (React__default.createElement("div", { className: "ui89-input-select" },
|
|
305
|
-
React__default.createElement("div", { className: [
|
|
487
|
+
React__default.createElement("div", { ref: refs.setReference, className: [
|
|
306
488
|
"ui89-input-box",
|
|
307
489
|
"ui89-input-box--unselectable",
|
|
308
490
|
"ui89-input-box--clickable",
|
|
309
491
|
"ui89-text-single-line",
|
|
310
|
-
].join(" "), tabIndex: 0, title: props.value !== undefined ? optionTitle(props.value) : undefined }, props.value !== undefined ? (React__default.createElement(React__default.Fragment, null, props.renderOption !== undefined
|
|
492
|
+
].join(" "), tabIndex: 0, title: props.value !== undefined ? optionTitle(props.value) : undefined, ...getReferenceProps() }, props.value !== undefined ? (React__default.createElement(React__default.Fragment, null, props.renderOption !== undefined
|
|
311
493
|
? props.renderOption(props.value)
|
|
312
494
|
: props.value)) : (React__default.createElement(React__default.Fragment, null, "Select..."))),
|
|
313
|
-
React__default.createElement(
|
|
314
|
-
React__default.createElement("div", { className: "ui89-input-
|
|
315
|
-
const isSelected = isOptionSelected(o);
|
|
316
|
-
return (React__default.createElement("div", { className: [
|
|
317
|
-
"ui89-input-select__menu__item",
|
|
318
|
-
isSelected
|
|
319
|
-
? "ui89-input-select__menu__item--selected"
|
|
320
|
-
: null,
|
|
321
|
-
].join(" "), title: optionTitle(o), key: getOptionKey(o), onClick: () => selectOption(o) }, props.renderOption !== undefined ? props.renderOption(o) : o));
|
|
322
|
-
})) : (React__default.createElement("div", { className: [
|
|
495
|
+
isOpen && (React__default.createElement(FloatingFocusManager, { context: context, modal: false },
|
|
496
|
+
React__default.createElement("div", { ref: refs.setFloating, className: "ui89-input-select__menu", tabIndex: 0, style: floatingStyles }, options.length > 0 ? (React__default.createElement(Ui89VirtualList, { maxHeight: "300px", rowHeight: props.optionHeight ?? 32, rows: options, renderRow: renderOption })) : (React__default.createElement("div", { className: [
|
|
323
497
|
"ui89-input-select__menu__item",
|
|
324
498
|
"ui89-input-select__menu__item--disabled",
|
|
325
|
-
].join(" ") }, "<empty>"))))));
|
|
499
|
+
].join(" ") }, "<empty>")))))));
|
|
326
500
|
}
|
|
327
501
|
|
|
328
502
|
let uniqueId = 0;
|
|
@@ -756,151 +930,6 @@ function Ui89Toaster() {
|
|
|
756
930
|
return React__default.createElement(ToastContainer, null);
|
|
757
931
|
}
|
|
758
932
|
|
|
759
|
-
const useResizeObserver = (ref) => {
|
|
760
|
-
const [size, setSize] = useState({ width: 0, height: 0 });
|
|
761
|
-
useEffect(() => {
|
|
762
|
-
const observer = new ResizeObserver((entries) => {
|
|
763
|
-
for (let entry of entries) {
|
|
764
|
-
setSize({
|
|
765
|
-
width: entry.borderBoxSize?.[0]?.inlineSize ?? entry.contentRect.width,
|
|
766
|
-
height: entry.borderBoxSize?.[0]?.blockSize ?? entry.contentRect.height,
|
|
767
|
-
});
|
|
768
|
-
}
|
|
769
|
-
});
|
|
770
|
-
if (ref.current) {
|
|
771
|
-
observer.observe(ref.current);
|
|
772
|
-
}
|
|
773
|
-
return () => {
|
|
774
|
-
observer.disconnect();
|
|
775
|
-
};
|
|
776
|
-
}, [ref.current]);
|
|
777
|
-
return {
|
|
778
|
-
size,
|
|
779
|
-
};
|
|
780
|
-
};
|
|
781
|
-
|
|
782
|
-
const useScrollYPosition = (ref) => {
|
|
783
|
-
const [scrollY, setScrollY] = useState(0);
|
|
784
|
-
const ticking = useRef(false);
|
|
785
|
-
const observer = useRef(null);
|
|
786
|
-
useEffect(() => {
|
|
787
|
-
const element = ref.current;
|
|
788
|
-
if (!element)
|
|
789
|
-
return;
|
|
790
|
-
const handleScroll = () => {
|
|
791
|
-
if (!ticking.current) {
|
|
792
|
-
requestAnimationFrame(() => {
|
|
793
|
-
setScrollY(element.scrollTop);
|
|
794
|
-
ticking.current = false;
|
|
795
|
-
});
|
|
796
|
-
ticking.current = true;
|
|
797
|
-
}
|
|
798
|
-
};
|
|
799
|
-
element.addEventListener("scroll", handleScroll, { passive: true });
|
|
800
|
-
observer.current = new MutationObserver(() => {
|
|
801
|
-
if (ref.current !== element) {
|
|
802
|
-
element.removeEventListener("scroll", handleScroll);
|
|
803
|
-
ref.current?.addEventListener("scroll", handleScroll, { passive: true });
|
|
804
|
-
}
|
|
805
|
-
});
|
|
806
|
-
observer.current.observe(document.body, { childList: true, subtree: true });
|
|
807
|
-
return () => {
|
|
808
|
-
element.removeEventListener("scroll", handleScroll);
|
|
809
|
-
observer.current?.disconnect();
|
|
810
|
-
};
|
|
811
|
-
}, [ref]);
|
|
812
|
-
return scrollY;
|
|
813
|
-
};
|
|
814
|
-
|
|
815
|
-
function popAnyEntry(map) {
|
|
816
|
-
const iterator = map.keys().next();
|
|
817
|
-
if (!iterator.done) {
|
|
818
|
-
const key = iterator.value;
|
|
819
|
-
const value = map.get(key);
|
|
820
|
-
map.delete(key);
|
|
821
|
-
return value;
|
|
822
|
-
}
|
|
823
|
-
return undefined;
|
|
824
|
-
}
|
|
825
|
-
/**
|
|
826
|
-
* Virtualization at row level. Great for long lists.
|
|
827
|
-
*
|
|
828
|
-
* Can be used to implement table components with few columns.
|
|
829
|
-
*/
|
|
830
|
-
const Ui89VirtualList = React__default.memo((props) => {
|
|
831
|
-
const keyCounter = useRef(0);
|
|
832
|
-
const scrollContainer = useRef(null);
|
|
833
|
-
const scrollAreaContainer = useRef(null);
|
|
834
|
-
const { size } = useResizeObserver(scrollContainer);
|
|
835
|
-
const scrollY = useScrollYPosition(scrollContainer);
|
|
836
|
-
const rowHeight = props.rowHeight ?? 50;
|
|
837
|
-
const totalHeight = rowHeight * props.rows.length;
|
|
838
|
-
const [visibleRows, setVisibleRows] = useState(new Map());
|
|
839
|
-
useEffect(() => {
|
|
840
|
-
if (size.height === 0) {
|
|
841
|
-
setVisibleRows(new Map());
|
|
842
|
-
return;
|
|
843
|
-
}
|
|
844
|
-
const firstIndex = Math.max(0, Math.floor(scrollY / rowHeight) - 1);
|
|
845
|
-
const length = Math.min(props.rows.length - firstIndex, Math.ceil(size.height / rowHeight) + 2);
|
|
846
|
-
const deletedRows = new Map(visibleRows);
|
|
847
|
-
// Must find the ones that are no longer visible.
|
|
848
|
-
for (let index = firstIndex; index < firstIndex + length; index++) {
|
|
849
|
-
let row = props.rows[index];
|
|
850
|
-
let key = props.getRowKey ? props.getRowKey(row) : String(index);
|
|
851
|
-
deletedRows.delete(key);
|
|
852
|
-
}
|
|
853
|
-
const newVisibleRows = new Map();
|
|
854
|
-
for (let index = firstIndex; index < firstIndex + length; index++) {
|
|
855
|
-
let row = props.rows[index];
|
|
856
|
-
let key = props.getRowKey ? props.getRowKey(row) : String(index);
|
|
857
|
-
let existingRow = visibleRows.get(key);
|
|
858
|
-
if (existingRow !== undefined) {
|
|
859
|
-
if (existingRow.row === row) ;
|
|
860
|
-
else {
|
|
861
|
-
// Data has changed, must update render.
|
|
862
|
-
existingRow.render = props.renderRow({ index, row });
|
|
863
|
-
}
|
|
864
|
-
newVisibleRows.set(key, existingRow);
|
|
865
|
-
continue;
|
|
866
|
-
}
|
|
867
|
-
let oldRow = popAnyEntry(deletedRows);
|
|
868
|
-
if (oldRow !== undefined) {
|
|
869
|
-
oldRow.index = index;
|
|
870
|
-
oldRow.row = row;
|
|
871
|
-
oldRow.userKey = key;
|
|
872
|
-
oldRow.render = props.renderRow({ index, row });
|
|
873
|
-
oldRow.style = {
|
|
874
|
-
transform: `translateY(${index * rowHeight}px)`,
|
|
875
|
-
height: `${rowHeight}px`,
|
|
876
|
-
};
|
|
877
|
-
newVisibleRows.set(key, oldRow);
|
|
878
|
-
}
|
|
879
|
-
else
|
|
880
|
-
[
|
|
881
|
-
// New row.
|
|
882
|
-
newVisibleRows.set(key, {
|
|
883
|
-
index,
|
|
884
|
-
row,
|
|
885
|
-
key: keyCounter.current++,
|
|
886
|
-
userKey: key,
|
|
887
|
-
render: props.renderRow({ index, row }),
|
|
888
|
-
style: {
|
|
889
|
-
transform: `translateY(${index * rowHeight}px)`,
|
|
890
|
-
height: `${rowHeight}px`,
|
|
891
|
-
},
|
|
892
|
-
})
|
|
893
|
-
];
|
|
894
|
-
}
|
|
895
|
-
setVisibleRows(newVisibleRows);
|
|
896
|
-
}, [props.rows, scrollY, size.height]);
|
|
897
|
-
const orderedVisibleRows = useMemo(() => {
|
|
898
|
-
return Array.from(visibleRows.values()).sort((a, b) => a.index - b.index);
|
|
899
|
-
}, [visibleRows]);
|
|
900
|
-
return (React__default.createElement("div", { ref: scrollContainer, className: "ui89-virtual-list", style: { maxHeight: props.maxHeight } },
|
|
901
|
-
React__default.createElement("div", { ref: scrollAreaContainer, className: "ui89-virtual-list__scroll-area", style: { height: `${totalHeight}px` } }, orderedVisibleRows.map((visibleRow) => (React__default.createElement("div", { key: visibleRow.key, className: "ui89-virtual-list__row", style: visibleRow.style }, visibleRow.render))))));
|
|
902
|
-
});
|
|
903
|
-
|
|
904
933
|
var Ui89VirtualTablePropsColumnAlign;
|
|
905
934
|
(function (Ui89VirtualTablePropsColumnAlign) {
|
|
906
935
|
Ui89VirtualTablePropsColumnAlign["left"] = "left";
|
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/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 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\"\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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"}
|
|
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/useResizeObserver.ts","../../src/useScrollYPosition.ts","../../src/components/Ui89VirtualList.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/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 { 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, { useCallback, useMemo, useState } from \"react\"\nimport {\n useFloating,\n autoUpdate,\n size,\n useClick,\n useDismiss,\n useRole,\n useInteractions,\n FloatingFocusManager,\n} from \"@floating-ui/react\"\n\nimport \"./Ui89InputSelect.css\"\nimport \"../style/input-box.css\"\nimport \"../style/text.css\"\nimport {\n Ui89VirtualList,\n Ui89VirtualListPropsRenderRowProps,\n} from \"./Ui89VirtualList\"\n\nexport interface Ui89InputSelectProps<T> {\n /**\n * Available options.\n */\n options?: T[]\n\n /**\n * Option height. Options list uses a technique called DOM virtualization.\n */\n optionHeight?: number\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 [isOpen, setIsOpen] = useState(false)\n const { refs, floatingStyles, context } = useFloating({\n open: isOpen,\n onOpenChange: setIsOpen,\n middleware: [\n size({\n apply({ availableWidth, availableHeight, elements }) {\n let width = elements.reference.getBoundingClientRect().width\n // Change styles, e.g.\n Object.assign(elements.floating.style, {\n width: `${width}px`,\n maxHeight: `${Math.max(0, availableHeight)}px`,\n })\n },\n }),\n ],\n whileElementsMounted: autoUpdate,\n placement: \"bottom-start\",\n strategy: \"fixed\",\n })\n\n const click = useClick(context)\n const dismiss = useDismiss(context)\n const role = useRole(context)\n\n const { getReferenceProps, getFloatingProps } = useInteractions([\n click,\n dismiss,\n role,\n ])\n\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 optionTitle(option: T) {\n return String(option)\n }\n\n const selectOption = useCallback(\n (option: T) => {\n if (props.onChange !== undefined) {\n props.onChange(option)\n }\n\n setIsOpen(false)\n },\n [props.onChange],\n )\n\n const renderOption = useCallback(\n ({ row }: Ui89VirtualListPropsRenderRowProps<T>) => {\n const isSelected = isOptionSelected(row)\n\n return (\n <div\n className={[\n \"ui89-input-select__menu__item\",\n isSelected ? \"ui89-input-select__menu__item--selected\" : null,\n ].join(\" \")}\n title={optionTitle(row)}\n key={getOptionKey(row)}\n onClick={() => selectOption(row)}\n >\n {props.renderOption !== undefined ? props.renderOption(row) : row}\n </div>\n )\n },\n [options, selectOption],\n )\n\n return (\n <div className=\"ui89-input-select\">\n <div\n ref={refs.setReference}\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 {...getReferenceProps()}\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 {isOpen && (\n <FloatingFocusManager context={context} modal={false}>\n <div\n ref={refs.setFloating}\n className=\"ui89-input-select__menu\"\n tabIndex={0}\n style={floatingStyles}\n >\n {options.length > 0 ? (\n <Ui89VirtualList\n maxHeight=\"300px\"\n rowHeight={props.optionHeight ?? 32}\n rows={options}\n renderRow={renderOption}\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 </FloatingFocusManager>\n )}\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 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.39.0",
|
|
5
5
|
"author": "Daniel Araujo",
|
|
6
6
|
"module": "dist/esm/index.js",
|
|
7
7
|
"files": [
|
|
@@ -73,6 +73,7 @@
|
|
|
73
73
|
"vite-plugin-svgr": "^4.3.0"
|
|
74
74
|
},
|
|
75
75
|
"dependencies": {
|
|
76
|
+
"@floating-ui/react": "^0.27.5",
|
|
76
77
|
"react-datepicker": "^7.6.0",
|
|
77
78
|
"react-toastify": "^11.0.2",
|
|
78
79
|
"smart-timeout": "^2.7.1"
|