@helpwave/hightide 0.0.15 → 0.0.16
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/index.d.mts +86 -2
- package/dist/index.d.ts +86 -2
- package/dist/index.js +5714 -0
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +5541 -0
- package/dist/index.mjs.map +1 -1
- package/dist/util/news.d.mts +9 -9
- package/dist/util/news.d.ts +9 -9
- package/package.json +11 -7
- package/dist/components/Span.d.mts +0 -2
- package/dist/components/Span.d.ts +0 -2
- package/dist/components/Span.js +0 -2
- package/dist/components/Span.js.map +0 -1
- package/dist/components/Span.mjs +0 -1
- package/dist/components/Span.mjs.map +0 -1
- package/dist/components/examples/InputGroupExample.d.mts +0 -11
- package/dist/components/examples/InputGroupExample.d.ts +0 -11
- package/dist/components/examples/InputGroupExample.js +0 -466
- package/dist/components/examples/InputGroupExample.js.map +0 -1
- package/dist/components/examples/InputGroupExample.mjs +0 -436
- package/dist/components/examples/InputGroupExample.mjs.map +0 -1
- package/dist/components/examples/MultiSelectExample.d.mts +0 -14
- package/dist/components/examples/MultiSelectExample.d.ts +0 -14
- package/dist/components/examples/MultiSelectExample.js +0 -661
- package/dist/components/examples/MultiSelectExample.js.map +0 -1
- package/dist/components/examples/MultiSelectExample.mjs +0 -631
- package/dist/components/examples/MultiSelectExample.mjs.map +0 -1
- package/dist/components/examples/SearchableSelectExample.d.mts +0 -13
- package/dist/components/examples/SearchableSelectExample.d.ts +0 -13
- package/dist/components/examples/SearchableSelectExample.js +0 -365
- package/dist/components/examples/SearchableSelectExample.js.map +0 -1
- package/dist/components/examples/SearchableSelectExample.mjs +0 -335
- package/dist/components/examples/SearchableSelectExample.mjs.map +0 -1
- package/dist/components/examples/SelectExample.d.mts +0 -9
- package/dist/components/examples/SelectExample.d.ts +0 -9
- package/dist/components/examples/SelectExample.js +0 -180
- package/dist/components/examples/SelectExample.js.map +0 -1
- package/dist/components/examples/SelectExample.mjs +0 -145
- package/dist/components/examples/SelectExample.mjs.map +0 -1
- package/dist/components/examples/StackingModals.d.mts +0 -8
- package/dist/components/examples/StackingModals.d.ts +0 -8
- package/dist/components/examples/StackingModals.js +0 -498
- package/dist/components/examples/StackingModals.js.map +0 -1
- package/dist/components/examples/StackingModals.mjs +0 -463
- package/dist/components/examples/StackingModals.mjs.map +0 -1
- package/dist/components/examples/TableExample.d.mts +0 -13
- package/dist/components/examples/TableExample.d.ts +0 -13
- package/dist/components/examples/TableExample.js +0 -853
- package/dist/components/examples/TableExample.js.map +0 -1
- package/dist/components/examples/TableExample.mjs +0 -823
- package/dist/components/examples/TableExample.mjs.map +0 -1
- package/dist/components/examples/TextareaExample.d.mts +0 -12
- package/dist/components/examples/TextareaExample.d.ts +0 -12
- package/dist/components/examples/TextareaExample.js +0 -176
- package/dist/components/examples/TextareaExample.js.map +0 -1
- package/dist/components/examples/TextareaExample.mjs +0 -141
- package/dist/components/examples/TextareaExample.mjs.map +0 -1
- package/dist/components/examples/TileExample.d.mts +0 -14
- package/dist/components/examples/TileExample.d.ts +0 -14
- package/dist/components/examples/TileExample.js +0 -79
- package/dist/components/examples/TileExample.js.map +0 -1
- package/dist/components/examples/TileExample.mjs +0 -44
- package/dist/components/examples/TileExample.mjs.map +0 -1
- package/dist/components/examples/Title.d.mts +0 -2
- package/dist/components/examples/Title.d.ts +0 -2
- package/dist/components/examples/Title.js +0 -2
- package/dist/components/examples/Title.js.map +0 -1
- package/dist/components/examples/Title.mjs +0 -1
- package/dist/components/examples/Title.mjs.map +0 -1
- package/dist/components/examples/date/DateTimePickerExample.d.mts +0 -18
- package/dist/components/examples/date/DateTimePickerExample.d.ts +0 -18
- package/dist/components/examples/date/DateTimePickerExample.js +0 -879
- package/dist/components/examples/date/DateTimePickerExample.js.map +0 -1
- package/dist/components/examples/date/DateTimePickerExample.mjs +0 -844
- package/dist/components/examples/date/DateTimePickerExample.mjs.map +0 -1
- package/dist/components/examples/properties/CheckboxPropertyExample.d.mts +0 -16
- package/dist/components/examples/properties/CheckboxPropertyExample.d.ts +0 -16
- package/dist/components/examples/properties/CheckboxPropertyExample.js +0 -349
- package/dist/components/examples/properties/CheckboxPropertyExample.js.map +0 -1
- package/dist/components/examples/properties/CheckboxPropertyExample.mjs +0 -314
- package/dist/components/examples/properties/CheckboxPropertyExample.mjs.map +0 -1
- package/dist/components/examples/properties/DatePropertyExample.d.mts +0 -16
- package/dist/components/examples/properties/DatePropertyExample.d.ts +0 -16
- package/dist/components/examples/properties/DatePropertyExample.js +0 -460
- package/dist/components/examples/properties/DatePropertyExample.js.map +0 -1
- package/dist/components/examples/properties/DatePropertyExample.mjs +0 -430
- package/dist/components/examples/properties/DatePropertyExample.mjs.map +0 -1
- package/dist/components/examples/properties/MultiSelectPropertyExample.d.mts +0 -18
- package/dist/components/examples/properties/MultiSelectPropertyExample.d.ts +0 -18
- package/dist/components/examples/properties/MultiSelectPropertyExample.js +0 -848
- package/dist/components/examples/properties/MultiSelectPropertyExample.js.map +0 -1
- package/dist/components/examples/properties/MultiSelectPropertyExample.mjs +0 -818
- package/dist/components/examples/properties/MultiSelectPropertyExample.mjs.map +0 -1
- package/dist/components/examples/properties/NumberPropertyExample.d.mts +0 -14
- package/dist/components/examples/properties/NumberPropertyExample.d.ts +0 -14
- package/dist/components/examples/properties/NumberPropertyExample.js +0 -456
- package/dist/components/examples/properties/NumberPropertyExample.js.map +0 -1
- package/dist/components/examples/properties/NumberPropertyExample.mjs +0 -426
- package/dist/components/examples/properties/NumberPropertyExample.mjs.map +0 -1
- package/dist/components/examples/properties/SelectPropertyExample.d.mts +0 -17
- package/dist/components/examples/properties/SelectPropertyExample.d.ts +0 -17
- package/dist/components/examples/properties/SelectPropertyExample.js +0 -584
- package/dist/components/examples/properties/SelectPropertyExample.js.map +0 -1
- package/dist/components/examples/properties/SelectPropertyExample.mjs +0 -554
- package/dist/components/examples/properties/SelectPropertyExample.mjs.map +0 -1
- package/dist/components/examples/properties/TextPropertyExample.d.mts +0 -16
- package/dist/components/examples/properties/TextPropertyExample.d.ts +0 -16
- package/dist/components/examples/properties/TextPropertyExample.js +0 -405
- package/dist/components/examples/properties/TextPropertyExample.js.map +0 -1
- package/dist/components/examples/properties/TextPropertyExample.mjs +0 -370
- package/dist/components/examples/properties/TextPropertyExample.mjs.map +0 -1
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
// src/components/examples/SelectExample.tsx
|
|
2
|
-
import { useEffect, useState } from "react";
|
|
3
|
-
|
|
4
|
-
// src/components/user-input/Select.tsx
|
|
5
|
-
import { Menu } from "@headlessui/react";
|
|
6
|
-
import { ChevronDown, ChevronUp } from "lucide-react";
|
|
7
|
-
import clsx from "clsx";
|
|
8
|
-
|
|
9
|
-
// src/components/user-input/Label.tsx
|
|
10
|
-
import { jsx } from "react/jsx-runtime";
|
|
11
|
-
var styleMapping = {
|
|
12
|
-
labelSmall: "textstyle-label-sm",
|
|
13
|
-
labelMedium: "textstyle-label-md",
|
|
14
|
-
labelBig: "textstyle-label-lg"
|
|
15
|
-
};
|
|
16
|
-
var Label = ({
|
|
17
|
-
children,
|
|
18
|
-
name,
|
|
19
|
-
labelType = "labelSmall",
|
|
20
|
-
...props
|
|
21
|
-
}) => {
|
|
22
|
-
return /* @__PURE__ */ jsx("label", { ...props, children: children ? children : /* @__PURE__ */ jsx("span", { className: styleMapping[labelType], children: name }) });
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
// src/components/user-input/Select.tsx
|
|
26
|
-
import { Fragment, jsx as jsx2, jsxs } from "react/jsx-runtime";
|
|
27
|
-
var Select = ({
|
|
28
|
-
value,
|
|
29
|
-
label,
|
|
30
|
-
options,
|
|
31
|
-
onChange,
|
|
32
|
-
isHidingCurrentValue = true,
|
|
33
|
-
hintText = "",
|
|
34
|
-
showDisabledOptions = true,
|
|
35
|
-
isDisabled,
|
|
36
|
-
className,
|
|
37
|
-
textColor = "text-menu-text",
|
|
38
|
-
hoverColor = "hover:brightness-90",
|
|
39
|
-
additionalItems,
|
|
40
|
-
selectedDisplayOverwrite
|
|
41
|
-
}) => {
|
|
42
|
-
let filteredOptions = isHidingCurrentValue ? options.filter((option) => option.value !== value) : options;
|
|
43
|
-
if (!showDisabledOptions) {
|
|
44
|
-
filteredOptions = filteredOptions.filter((value2) => !value2.disabled);
|
|
45
|
-
}
|
|
46
|
-
const selectedOption = options.find((option) => option.value === value);
|
|
47
|
-
if (value !== void 0 && selectedOption === void 0 && selectedDisplayOverwrite === void 0) {
|
|
48
|
-
console.warn("The selected value is not found in the options list. This might be an error on your part or default behavior if it is complex data type on which === does not work. In case of the latter use selectedDisplayOverwrite to set your selected text or component");
|
|
49
|
-
}
|
|
50
|
-
const borderColor = "border-menu-border";
|
|
51
|
-
return /* @__PURE__ */ jsxs("div", { className: clsx(className), children: [
|
|
52
|
-
label && /* @__PURE__ */ jsx2(Label, { ...label, labelType: label.labelType ?? "labelBig", className: clsx("mb-1", label.className) }),
|
|
53
|
-
/* @__PURE__ */ jsx2(Menu, { as: "div", className: "relative text-menu-text", children: ({ open }) => /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
54
|
-
/* @__PURE__ */ jsxs(
|
|
55
|
-
Menu.Button,
|
|
56
|
-
{
|
|
57
|
-
className: clsx(
|
|
58
|
-
"inline-flex w-full justify-between items-center rounded-t-lg border-2 px-4 py-2 font-medium bg-menu-background text-menu-text",
|
|
59
|
-
textColor,
|
|
60
|
-
borderColor,
|
|
61
|
-
{
|
|
62
|
-
"rounded-b-lg": !open,
|
|
63
|
-
[hoverColor]: !isDisabled,
|
|
64
|
-
"bg-disabled-background cursor-not-allowed text-disabled": isDisabled
|
|
65
|
-
}
|
|
66
|
-
),
|
|
67
|
-
disabled: isDisabled,
|
|
68
|
-
children: [
|
|
69
|
-
/* @__PURE__ */ jsx2("span", { children: selectedDisplayOverwrite ?? selectedOption?.label ?? hintText }),
|
|
70
|
-
open ? /* @__PURE__ */ jsx2(ChevronUp, {}) : /* @__PURE__ */ jsx2(ChevronDown, {})
|
|
71
|
-
]
|
|
72
|
-
}
|
|
73
|
-
),
|
|
74
|
-
/* @__PURE__ */ jsxs(
|
|
75
|
-
Menu.Items,
|
|
76
|
-
{
|
|
77
|
-
className: "absolute w-full z-10 rounded-b-lg bg-menu-background text-menu-text shadow-lg max-h-[500px] overflow-y-auto",
|
|
78
|
-
children: [
|
|
79
|
-
(additionalItems ?? []).map((item, index) => /* @__PURE__ */ jsx2(
|
|
80
|
-
"div",
|
|
81
|
-
{
|
|
82
|
-
className: clsx(borderColor, "px-4 py-2 overflow-hidden whitespace-nowrap text-ellipsis border-2 border-t-0", {
|
|
83
|
-
"border-b-0 rounded-b-lg": filteredOptions.length === 0 && index === (additionalItems?.length ?? 1) - 1
|
|
84
|
-
}),
|
|
85
|
-
children: item
|
|
86
|
-
},
|
|
87
|
-
`additionalItems${index}`
|
|
88
|
-
)),
|
|
89
|
-
filteredOptions.map((option, index) => /* @__PURE__ */ jsx2(Menu.Item, { children: /* @__PURE__ */ jsx2(
|
|
90
|
-
"div",
|
|
91
|
-
{
|
|
92
|
-
className: clsx(
|
|
93
|
-
"px-4 py-2 overflow-hidden whitespace-nowrap text-ellipsis border-2 border-t-0 cursor-pointer",
|
|
94
|
-
option.className,
|
|
95
|
-
borderColor,
|
|
96
|
-
{
|
|
97
|
-
"brightness-90": option.value === value,
|
|
98
|
-
"brightness-95": index % 2 === 1,
|
|
99
|
-
"text-disabled bg-disabled-background cursor-not-allowed": !!option.disabled,
|
|
100
|
-
"bg-menu-background text-menu-text hover:brightness-90 cursor-pointer": !option.disabled,
|
|
101
|
-
"rounded-b-lg": index === filteredOptions.length - 1
|
|
102
|
-
}
|
|
103
|
-
),
|
|
104
|
-
onClick: () => {
|
|
105
|
-
if (!option.disabled) {
|
|
106
|
-
onChange(option.value);
|
|
107
|
-
}
|
|
108
|
-
},
|
|
109
|
-
children: option.label
|
|
110
|
-
}
|
|
111
|
-
) }, `item${index}`))
|
|
112
|
-
]
|
|
113
|
-
}
|
|
114
|
-
)
|
|
115
|
-
] }) })
|
|
116
|
-
] });
|
|
117
|
-
};
|
|
118
|
-
|
|
119
|
-
// src/components/examples/SelectExample.tsx
|
|
120
|
-
import { jsx as jsx3 } from "react/jsx-runtime";
|
|
121
|
-
var SelectExample = ({ options, value, hintText, ...props }) => {
|
|
122
|
-
const [selected, setSelected] = useState(value);
|
|
123
|
-
useEffect(() => {
|
|
124
|
-
if (options.find((options2) => options2.value === value)) {
|
|
125
|
-
setSelected(value);
|
|
126
|
-
}
|
|
127
|
-
}, [options, value]);
|
|
128
|
-
useEffect(() => {
|
|
129
|
-
setSelected(void 0);
|
|
130
|
-
}, [hintText]);
|
|
131
|
-
return /* @__PURE__ */ jsx3(
|
|
132
|
-
Select,
|
|
133
|
-
{
|
|
134
|
-
value: selected,
|
|
135
|
-
options,
|
|
136
|
-
onChange: (value2) => setSelected(value2),
|
|
137
|
-
hintText,
|
|
138
|
-
...props
|
|
139
|
-
}
|
|
140
|
-
);
|
|
141
|
-
};
|
|
142
|
-
export {
|
|
143
|
-
SelectExample
|
|
144
|
-
};
|
|
145
|
-
//# sourceMappingURL=SelectExample.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/examples/SelectExample.tsx","../../../src/components/user-input/Select.tsx","../../../src/components/user-input/Label.tsx"],"sourcesContent":["import { useEffect, useState } from 'react'\nimport { Select, type SelectProps } from '../user-input/Select'\n\ntype SelectExampleProps<T> = Omit<SelectProps<T>, 'onChange' | 'additionalItems' | 'selectedDisplayOverwrite'>\n\nexport const SelectExample = <T, >({ options, value, hintText, ...props }: SelectExampleProps<T>) => {\n const [selected, setSelected] = useState(value)\n\n useEffect(() => {\n if (options.find(options => options.value === value)) {\n setSelected(value)\n }\n }, [options, value])\n\n useEffect(() => {\n setSelected(undefined)\n }, [hintText])\n\n return (\n <Select\n value={selected}\n options={options}\n onChange={value => setSelected(value)}\n hintText={hintText}\n {...props}\n />\n )\n}\n","import { Menu } from '@headlessui/react'\nimport { ChevronDown, ChevronUp } from 'lucide-react'\nimport type { ReactNode } from 'react'\nimport clsx from 'clsx'\nimport type { LabelProps } from './Label'\nimport { Label } from './Label'\n\nexport type SelectOption<T> = {\n label: ReactNode,\n value: T,\n disabled?: boolean,\n className?: string,\n}\n\nexport type SelectProps<T> = {\n value?: T,\n label?: LabelProps,\n options: SelectOption<T>[],\n onChange: (value: T) => void,\n isHidingCurrentValue?: boolean,\n hintText?: string,\n showDisabledOptions?: boolean,\n className?: string,\n isDisabled?: boolean,\n textColor?: string,\n hoverColor?: string,\n /**\n * The items will be at the start of the select and aren't selectable\n */\n additionalItems?: ReactNode[],\n selectedDisplayOverwrite?: ReactNode,\n};\n\n/**\n * A Select Component for selecting form a list of options\n *\n * The State is managed by the parent\n */\nexport const Select = <T, >({\n value,\n label,\n options,\n onChange,\n isHidingCurrentValue = true,\n hintText = '',\n showDisabledOptions = true,\n isDisabled,\n className,\n textColor = 'text-menu-text',\n hoverColor = 'hover:brightness-90',\n additionalItems,\n selectedDisplayOverwrite,\n }: SelectProps<T>) => {\n // Notice: for more complex types this check here might need an additional compare method\n let filteredOptions = isHidingCurrentValue ? options.filter(option => option.value !== value) : options\n if (!showDisabledOptions) {\n filteredOptions = filteredOptions.filter(value => !value.disabled)\n }\n const selectedOption = options.find(option => option.value === value)\n if (value !== undefined && selectedOption === undefined && selectedDisplayOverwrite === undefined) {\n console.warn('The selected value is not found in the options list. This might be an error on your part or' +\n ' default behavior if it is complex data type on which === does not work. In case of the latter' +\n ' use selectedDisplayOverwrite to set your selected text or component')\n }\n\n const borderColor = 'border-menu-border'\n\n return (\n <div className={clsx(className)}>\n {label && (\n <Label {...label} labelType={label.labelType ?? 'labelBig'} className={clsx('mb-1', label.className)}/>\n )}\n <Menu as=\"div\" className=\"relative text-menu-text\">\n {({ open }) => (\n <>\n <Menu.Button\n className={clsx(\n 'inline-flex w-full justify-between items-center rounded-t-lg border-2 px-4 py-2 font-medium bg-menu-background text-menu-text',\n textColor, borderColor,\n {\n 'rounded-b-lg': !open,\n [hoverColor]: !isDisabled,\n 'bg-disabled-background cursor-not-allowed text-disabled': isDisabled\n }\n )}\n disabled={isDisabled}\n >\n <span>{selectedDisplayOverwrite ?? selectedOption?.label ?? hintText}</span>\n {open ? <ChevronUp/> : <ChevronDown/>}\n </Menu.Button>\n <Menu.Items\n className=\"absolute w-full z-10 rounded-b-lg bg-menu-background text-menu-text shadow-lg max-h-[500px] overflow-y-auto\"\n >\n {(additionalItems ?? []).map((item, index) => (\n <div key={`additionalItems${index}`}\n className={clsx(borderColor, 'px-4 py-2 overflow-hidden whitespace-nowrap text-ellipsis border-2 border-t-0', {\n 'border-b-0 rounded-b-lg': filteredOptions.length === 0 && index === (additionalItems?.length ?? 1) - 1,\n })}\n >\n {item}\n </div>\n ))}\n {filteredOptions.map((option, index) => (\n <Menu.Item key={`item${index}`}>\n {\n <div\n className={clsx('px-4 py-2 overflow-hidden whitespace-nowrap text-ellipsis border-2 border-t-0 cursor-pointer',\n option.className, borderColor, {\n 'brightness-90': option.value === value,\n 'brightness-95': index % 2 === 1,\n 'text-disabled bg-disabled-background cursor-not-allowed': !!option.disabled,\n 'bg-menu-background text-menu-text hover:brightness-90 cursor-pointer': !option.disabled,\n 'rounded-b-lg': index === filteredOptions.length - 1,\n })}\n onClick={() => {\n if (!option.disabled) {\n onChange(option.value)\n }\n }}\n >\n {option.label}\n </div>\n }\n </Menu.Item>\n ))}\n </Menu.Items>\n </>\n )}\n </Menu>\n </div>\n )\n}\n","import type { LabelHTMLAttributes } from 'react'\n\nexport type LabelType = 'labelSmall' | 'labelMedium' | 'labelBig'\nconst styleMapping: Record<LabelType, string> = {\n labelSmall: 'textstyle-label-sm',\n labelMedium: 'textstyle-label-md',\n labelBig: 'textstyle-label-lg',\n}\n\n\nexport type LabelProps = {\n /** The text for the label */\n name?: string,\n /** The styling for the label */\n labelType?: LabelType,\n} & LabelHTMLAttributes<HTMLLabelElement>\n\n/**\n * A Label component\n */\nexport const Label = ({\n children,\n name,\n labelType = 'labelSmall',\n ...props\n}: LabelProps) => {\n return (\n <label {...props}>\n {children ? children : (<span className={styleMapping[labelType]}>{name}</span>)}\n </label>\n )\n}\n"],"mappings":"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","names":["jsx","value","jsx","options","value"]}
|
|
@@ -1,498 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
|
|
30
|
-
// src/components/examples/StackingModals.tsx
|
|
31
|
-
var StackingModals_exports = {};
|
|
32
|
-
__export(StackingModals_exports, {
|
|
33
|
-
StackingModals: () => StackingModals
|
|
34
|
-
});
|
|
35
|
-
module.exports = __toCommonJS(StackingModals_exports);
|
|
36
|
-
var import_react6 = require("react");
|
|
37
|
-
|
|
38
|
-
// src/components/modals/ModalRegister.tsx
|
|
39
|
-
var import_react = require("react");
|
|
40
|
-
|
|
41
|
-
// src/util/noop.ts
|
|
42
|
-
var noop = () => void 0;
|
|
43
|
-
|
|
44
|
-
// src/components/modals/ModalRegister.tsx
|
|
45
|
-
var import_jsx_runtime = require("react/jsx-runtime");
|
|
46
|
-
var ModalContext = (0, import_react.createContext)({
|
|
47
|
-
register: [],
|
|
48
|
-
addToRegister: noop,
|
|
49
|
-
removeFromRegister: noop
|
|
50
|
-
});
|
|
51
|
-
var ModalRegister = ({
|
|
52
|
-
children
|
|
53
|
-
}) => {
|
|
54
|
-
const [register, setRegister] = (0, import_react.useState)([]);
|
|
55
|
-
const inRegister = (id) => {
|
|
56
|
-
return !!register.find((value) => value === id);
|
|
57
|
-
};
|
|
58
|
-
const addToRegister = (id) => {
|
|
59
|
-
if (!inRegister(id)) {
|
|
60
|
-
setRegister([...register, id]);
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
const removeFromRegister = (id) => {
|
|
64
|
-
if (inRegister(id)) {
|
|
65
|
-
setRegister(register.filter((value) => value !== id));
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
|
-
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(ModalContext.Provider, { value: { register, addToRegister, removeFromRegister }, children });
|
|
69
|
-
};
|
|
70
|
-
|
|
71
|
-
// src/components/Button.tsx
|
|
72
|
-
var import_clsx = __toESM(require("clsx"));
|
|
73
|
-
var import_jsx_runtime2 = require("react/jsx-runtime");
|
|
74
|
-
var ButtonSizePaddings = {
|
|
75
|
-
small: "btn-sm",
|
|
76
|
-
medium: "btn-md",
|
|
77
|
-
large: "btn-lg"
|
|
78
|
-
};
|
|
79
|
-
var SolidButton = ({
|
|
80
|
-
children,
|
|
81
|
-
disabled = false,
|
|
82
|
-
color = "primary",
|
|
83
|
-
size = "medium",
|
|
84
|
-
startIcon,
|
|
85
|
-
endIcon,
|
|
86
|
-
onClick,
|
|
87
|
-
className,
|
|
88
|
-
...restProps
|
|
89
|
-
}) => {
|
|
90
|
-
const colorClasses = {
|
|
91
|
-
primary: "bg-button-solid-primary-background text-button-solid-primary-text",
|
|
92
|
-
secondary: "bg-button-solid-secondary-background text-button-solid-secondary-text",
|
|
93
|
-
tertiary: "bg-button-solid-tertiary-background text-button-solid-tertiary-text",
|
|
94
|
-
positive: "bg-button-solid-positive-background text-button-solid-positive-text",
|
|
95
|
-
warning: "bg-button-solid-warning-background text-button-solid-warning-text",
|
|
96
|
-
negative: "bg-button-solid-negative-background text-button-solid-negative-text"
|
|
97
|
-
}[color];
|
|
98
|
-
const iconColorClasses = {
|
|
99
|
-
primary: "text-button-solid-primary-icon",
|
|
100
|
-
secondary: "text-button-solid-secondary-icon",
|
|
101
|
-
tertiary: "text-button-solid-tertiary-icon",
|
|
102
|
-
positive: "text-button-solid-positive-icon",
|
|
103
|
-
warning: "text-button-solid-warning-icon",
|
|
104
|
-
negative: "text-button-solid-negative-icon"
|
|
105
|
-
}[color];
|
|
106
|
-
return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
|
|
107
|
-
"button",
|
|
108
|
-
{
|
|
109
|
-
onClick: disabled ? void 0 : onClick,
|
|
110
|
-
disabled: disabled || onClick === void 0,
|
|
111
|
-
className: (0, import_clsx.default)(
|
|
112
|
-
className,
|
|
113
|
-
{
|
|
114
|
-
"text-disabled-text bg-disabled-background": disabled,
|
|
115
|
-
[(0, import_clsx.default)(colorClasses, "hover:brightness-90")]: !disabled
|
|
116
|
-
},
|
|
117
|
-
ButtonSizePaddings[size]
|
|
118
|
-
),
|
|
119
|
-
...restProps,
|
|
120
|
-
children: [
|
|
121
|
-
startIcon && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
|
|
122
|
-
"span",
|
|
123
|
-
{
|
|
124
|
-
className: (0, import_clsx.default)({
|
|
125
|
-
[iconColorClasses]: !disabled,
|
|
126
|
-
[`text-disabled-icon`]: disabled
|
|
127
|
-
}),
|
|
128
|
-
children: startIcon
|
|
129
|
-
}
|
|
130
|
-
),
|
|
131
|
-
children,
|
|
132
|
-
endIcon && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
|
|
133
|
-
"span",
|
|
134
|
-
{
|
|
135
|
-
className: (0, import_clsx.default)({
|
|
136
|
-
[iconColorClasses]: !disabled,
|
|
137
|
-
[`text-disabled-icon`]: disabled
|
|
138
|
-
}),
|
|
139
|
-
children: endIcon
|
|
140
|
-
}
|
|
141
|
-
)
|
|
142
|
-
]
|
|
143
|
-
}
|
|
144
|
-
);
|
|
145
|
-
};
|
|
146
|
-
|
|
147
|
-
// src/hooks/useLanguage.tsx
|
|
148
|
-
var import_react3 = require("react");
|
|
149
|
-
|
|
150
|
-
// src/hooks/useLocalStorage.tsx
|
|
151
|
-
var import_react2 = require("react");
|
|
152
|
-
|
|
153
|
-
// src/hooks/useLanguage.tsx
|
|
154
|
-
var import_jsx_runtime3 = require("react/jsx-runtime");
|
|
155
|
-
var DEFAULT_LANGUAGE = "en";
|
|
156
|
-
var LanguageContext = (0, import_react3.createContext)({ language: DEFAULT_LANGUAGE, setLanguage: (v) => v });
|
|
157
|
-
var useLanguage = () => (0, import_react3.useContext)(LanguageContext);
|
|
158
|
-
|
|
159
|
-
// src/hooks/useTranslation.ts
|
|
160
|
-
var useTranslation = (defaults, translationOverwrite = {}) => {
|
|
161
|
-
const { language: languageProp, translation: overwrite } = translationOverwrite;
|
|
162
|
-
const { language: inferredLanguage } = useLanguage();
|
|
163
|
-
const usedLanguage = languageProp ?? inferredLanguage;
|
|
164
|
-
let defaultValues = defaults[usedLanguage];
|
|
165
|
-
if (overwrite && overwrite[usedLanguage]) {
|
|
166
|
-
defaultValues = { ...defaultValues, ...overwrite[usedLanguage] };
|
|
167
|
-
}
|
|
168
|
-
return defaultValues;
|
|
169
|
-
};
|
|
170
|
-
|
|
171
|
-
// src/components/modals/Modal.tsx
|
|
172
|
-
var import_react5 = require("react");
|
|
173
|
-
var import_react_dom = __toESM(require("react-dom"));
|
|
174
|
-
var import_lucide_react = require("lucide-react");
|
|
175
|
-
var import_clsx3 = __toESM(require("clsx"));
|
|
176
|
-
|
|
177
|
-
// src/hooks/useHoverState.ts
|
|
178
|
-
var import_react4 = require("react");
|
|
179
|
-
var defaultUseHoverStateProps = {
|
|
180
|
-
closingDelay: 200,
|
|
181
|
-
isDisabled: false
|
|
182
|
-
};
|
|
183
|
-
var useHoverState = (props = void 0) => {
|
|
184
|
-
const { closingDelay, isDisabled } = { ...defaultUseHoverStateProps, ...props };
|
|
185
|
-
const [isHovered, setIsHovered] = (0, import_react4.useState)(false);
|
|
186
|
-
const [timer, setTimer] = (0, import_react4.useState)();
|
|
187
|
-
const onMouseEnter = () => {
|
|
188
|
-
if (isDisabled) {
|
|
189
|
-
return;
|
|
190
|
-
}
|
|
191
|
-
clearTimeout(timer);
|
|
192
|
-
setIsHovered(true);
|
|
193
|
-
};
|
|
194
|
-
const onMouseLeave = () => {
|
|
195
|
-
if (isDisabled) {
|
|
196
|
-
return;
|
|
197
|
-
}
|
|
198
|
-
setTimer(setTimeout(() => {
|
|
199
|
-
setIsHovered(false);
|
|
200
|
-
}, closingDelay));
|
|
201
|
-
};
|
|
202
|
-
(0, import_react4.useEffect)(() => {
|
|
203
|
-
if (timer) {
|
|
204
|
-
return () => {
|
|
205
|
-
clearTimeout(timer);
|
|
206
|
-
};
|
|
207
|
-
}
|
|
208
|
-
});
|
|
209
|
-
(0, import_react4.useEffect)(() => {
|
|
210
|
-
if (timer) {
|
|
211
|
-
clearTimeout(timer);
|
|
212
|
-
}
|
|
213
|
-
}, [isDisabled]);
|
|
214
|
-
return {
|
|
215
|
-
isHovered,
|
|
216
|
-
setIsHovered,
|
|
217
|
-
handlers: { onMouseEnter, onMouseLeave }
|
|
218
|
-
};
|
|
219
|
-
};
|
|
220
|
-
|
|
221
|
-
// src/components/Tooltip.tsx
|
|
222
|
-
var import_clsx2 = require("clsx");
|
|
223
|
-
var import_jsx_runtime4 = require("react/jsx-runtime");
|
|
224
|
-
var Tooltip = ({
|
|
225
|
-
tooltip,
|
|
226
|
-
children,
|
|
227
|
-
animationDelay = 650,
|
|
228
|
-
tooltipClassName = "",
|
|
229
|
-
containerClassName = "",
|
|
230
|
-
position = "bottom",
|
|
231
|
-
zIndex = 10
|
|
232
|
-
}) => {
|
|
233
|
-
const { isHovered, handlers } = useHoverState();
|
|
234
|
-
const positionClasses = {
|
|
235
|
-
top: `bottom-full left-1/2 -translate-x-1/2 mb-[6px]`,
|
|
236
|
-
bottom: `top-full left-1/2 -translate-x-1/2 mt-[6px]`,
|
|
237
|
-
left: `right-full top-1/2 -translate-y-1/2 mr-[6px]`,
|
|
238
|
-
right: `left-full top-1/2 -translate-y-1/2 ml-[6px]`
|
|
239
|
-
};
|
|
240
|
-
const triangleSize = 6;
|
|
241
|
-
const triangleClasses = {
|
|
242
|
-
top: `top-full left-1/2 -translate-x-1/2 border-t-gray-600 border-l-transparent border-r-transparent`,
|
|
243
|
-
bottom: `bottom-full left-1/2 -translate-x-1/2 border-b-gray-600 border-l-transparent border-r-transparent`,
|
|
244
|
-
left: `left-full top-1/2 -translate-y-1/2 border-l-gray-600 border-t-transparent border-b-transparent`,
|
|
245
|
-
right: `right-full top-1/2 -translate-y-1/2 border-r-gray-600 border-t-transparent border-b-transparent`
|
|
246
|
-
};
|
|
247
|
-
const triangleStyle = {
|
|
248
|
-
top: { borderWidth: `${triangleSize}px ${triangleSize}px 0 ${triangleSize}px` },
|
|
249
|
-
bottom: { borderWidth: `0 ${triangleSize}px ${triangleSize}px ${triangleSize}px` },
|
|
250
|
-
left: { borderWidth: `${triangleSize}px 0 ${triangleSize}px ${triangleSize}px` },
|
|
251
|
-
right: { borderWidth: `${triangleSize}px ${triangleSize}px ${triangleSize}px 0` }
|
|
252
|
-
};
|
|
253
|
-
return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(
|
|
254
|
-
"div",
|
|
255
|
-
{
|
|
256
|
-
className: (0, import_clsx2.clsx)("relative inline-block", containerClassName),
|
|
257
|
-
...handlers,
|
|
258
|
-
children: [
|
|
259
|
-
children,
|
|
260
|
-
isHovered && /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(
|
|
261
|
-
"div",
|
|
262
|
-
{
|
|
263
|
-
className: (0, import_clsx2.clsx)(`opacity-0 absolute text-black text-xs font-semibold text-gray-600 px-2 py-1 rounded whitespace-nowrap border-2 border-gray-600
|
|
264
|
-
animate-tooltip-fade-in shadow-lg bg-gray-100`, positionClasses[position], tooltipClassName),
|
|
265
|
-
style: { zIndex, animationDelay: animationDelay + "ms" },
|
|
266
|
-
children: [
|
|
267
|
-
tooltip,
|
|
268
|
-
/* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
|
|
269
|
-
"div",
|
|
270
|
-
{
|
|
271
|
-
className: (0, import_clsx2.clsx)(`absolute w-0 h-0`, triangleClasses[position]),
|
|
272
|
-
style: { ...triangleStyle[position], zIndex }
|
|
273
|
-
}
|
|
274
|
-
)
|
|
275
|
-
]
|
|
276
|
-
}
|
|
277
|
-
)
|
|
278
|
-
]
|
|
279
|
-
}
|
|
280
|
-
);
|
|
281
|
-
};
|
|
282
|
-
|
|
283
|
-
// src/components/modals/Modal.tsx
|
|
284
|
-
var import_jsx_runtime5 = require("react/jsx-runtime");
|
|
285
|
-
var defaultModalHeaderTranslation = {
|
|
286
|
-
en: {
|
|
287
|
-
close: "Close"
|
|
288
|
-
},
|
|
289
|
-
de: {
|
|
290
|
-
close: "Schlie\xDFen"
|
|
291
|
-
}
|
|
292
|
-
};
|
|
293
|
-
var ModalHeader = ({
|
|
294
|
-
overwriteTranslation,
|
|
295
|
-
onCloseClick,
|
|
296
|
-
title,
|
|
297
|
-
titleText = "",
|
|
298
|
-
description,
|
|
299
|
-
descriptionText = ""
|
|
300
|
-
}) => {
|
|
301
|
-
const translation = useTranslation(defaultModalHeaderTranslation, overwriteTranslation);
|
|
302
|
-
return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "col", children: [
|
|
303
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "row justify-between items-start gap-x-8", children: [
|
|
304
|
-
title ?? /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { className: (0, import_clsx3.default)("textstyle-title-lg", {
|
|
305
|
-
"mb-1": description || descriptionText
|
|
306
|
-
}), children: titleText }),
|
|
307
|
-
!!onCloseClick && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(Tooltip, { tooltip: translation.close, children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("button", { className: "row bg-gray-200 hover:bg-gray-300 rounded-md p-1", onClick: onCloseClick, children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_lucide_react.X, {}) }) })
|
|
308
|
-
] }),
|
|
309
|
-
description ?? /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { className: "textstyle-description", children: descriptionText })
|
|
310
|
-
] });
|
|
311
|
-
};
|
|
312
|
-
var modalRootName = "modal-root";
|
|
313
|
-
var Modal = ({
|
|
314
|
-
children,
|
|
315
|
-
id,
|
|
316
|
-
isOpen,
|
|
317
|
-
onBackgroundClick,
|
|
318
|
-
backgroundClassName = "",
|
|
319
|
-
modalClassName = "",
|
|
320
|
-
containerClassName = "",
|
|
321
|
-
...modalHeaderProps
|
|
322
|
-
}) => {
|
|
323
|
-
const modalRoot = typeof window !== "undefined" ? document.getElementById(modalRootName) : null;
|
|
324
|
-
const {
|
|
325
|
-
register,
|
|
326
|
-
addToRegister,
|
|
327
|
-
removeFromRegister
|
|
328
|
-
} = (0, import_react5.useContext)(ModalContext);
|
|
329
|
-
if (!id) {
|
|
330
|
-
console.error("the id cannot be empty");
|
|
331
|
-
}
|
|
332
|
-
(0, import_react5.useEffect)(() => {
|
|
333
|
-
if (isOpen) {
|
|
334
|
-
addToRegister(id);
|
|
335
|
-
} else {
|
|
336
|
-
removeFromRegister(id);
|
|
337
|
-
}
|
|
338
|
-
}, [addToRegister, id, removeFromRegister, isOpen]);
|
|
339
|
-
if (modalRoot === null || !isOpen) return null;
|
|
340
|
-
const isLast = register.length < 1 || register[register.length - 1] === id;
|
|
341
|
-
const isSecondLast = register.length < 2 || register[register.length - 2] === id;
|
|
342
|
-
return import_react_dom.default.createPortal(
|
|
343
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: (0, import_clsx3.default)("fixed inset-0 overflow-y-auto z-[99]", containerClassName), id, children: [
|
|
344
|
-
isLast && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
|
|
345
|
-
"div",
|
|
346
|
-
{
|
|
347
|
-
className: (0, import_clsx3.default)("fixed inset-0 h-screen w-screen", backgroundClassName, {
|
|
348
|
-
"bg-black/70": isLast && register.length === 1
|
|
349
|
-
}),
|
|
350
|
-
onClick: onBackgroundClick
|
|
351
|
-
}
|
|
352
|
-
),
|
|
353
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
|
|
354
|
-
"div",
|
|
355
|
-
{
|
|
356
|
-
className: (0, import_clsx3.default)("fixed left-1/2 top-1/2 -translate-y-1/2 -translate-x-1/2 col p-4 bg-white text-black rounded-xl shadow-xl", modalClassName),
|
|
357
|
-
children: [
|
|
358
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsx)(ModalHeader, { ...modalHeaderProps }),
|
|
359
|
-
children
|
|
360
|
-
]
|
|
361
|
-
}
|
|
362
|
-
),
|
|
363
|
-
!isLast && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
|
|
364
|
-
"div",
|
|
365
|
-
{
|
|
366
|
-
className: (0, import_clsx3.default)("fixed inset-0 h-screen w-screen", backgroundClassName, {
|
|
367
|
-
"bg-black/70": isSecondLast && register.length > 1
|
|
368
|
-
})
|
|
369
|
-
}
|
|
370
|
-
)
|
|
371
|
-
] }),
|
|
372
|
-
modalRoot,
|
|
373
|
-
id
|
|
374
|
-
);
|
|
375
|
-
};
|
|
376
|
-
|
|
377
|
-
// src/components/modals/ConfirmDialog.tsx
|
|
378
|
-
var import_jsx_runtime6 = require("react/jsx-runtime");
|
|
379
|
-
var defaultConfirmDialogTranslation = {
|
|
380
|
-
en: {
|
|
381
|
-
confirm: "Confirm",
|
|
382
|
-
cancel: "Cancel",
|
|
383
|
-
decline: "Decline"
|
|
384
|
-
},
|
|
385
|
-
de: {
|
|
386
|
-
confirm: "Best\xE4tigen",
|
|
387
|
-
cancel: "Abbrechen",
|
|
388
|
-
decline: "Ablehnen"
|
|
389
|
-
}
|
|
390
|
-
};
|
|
391
|
-
var ConfirmDialog = ({
|
|
392
|
-
overwriteTranslation,
|
|
393
|
-
children,
|
|
394
|
-
onCancel,
|
|
395
|
-
onConfirm,
|
|
396
|
-
onDecline,
|
|
397
|
-
confirmType = "positive",
|
|
398
|
-
buttonOverwrites,
|
|
399
|
-
...restProps
|
|
400
|
-
}) => {
|
|
401
|
-
const translation = useTranslation(defaultConfirmDialogTranslation, overwriteTranslation);
|
|
402
|
-
const mapping = {
|
|
403
|
-
neutral: "primary",
|
|
404
|
-
negative: "negative",
|
|
405
|
-
positive: "positive"
|
|
406
|
-
};
|
|
407
|
-
return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(Modal, { ...restProps, children: [
|
|
408
|
-
children,
|
|
409
|
-
/* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { className: "row mt-3 gap-x-4 justify-end", children: [
|
|
410
|
-
onCancel && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
411
|
-
SolidButton,
|
|
412
|
-
{
|
|
413
|
-
color: buttonOverwrites?.[0].color ?? "primary",
|
|
414
|
-
onClick: onCancel,
|
|
415
|
-
disabled: buttonOverwrites?.[0].disabled ?? false,
|
|
416
|
-
children: buttonOverwrites?.[0].text ?? translation.cancel
|
|
417
|
-
}
|
|
418
|
-
),
|
|
419
|
-
onDecline && /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
420
|
-
SolidButton,
|
|
421
|
-
{
|
|
422
|
-
color: buttonOverwrites?.[1].color ?? "negative",
|
|
423
|
-
onClick: onDecline,
|
|
424
|
-
disabled: buttonOverwrites?.[1].disabled ?? false,
|
|
425
|
-
children: buttonOverwrites?.[1].text ?? translation.decline
|
|
426
|
-
}
|
|
427
|
-
),
|
|
428
|
-
/* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
429
|
-
SolidButton,
|
|
430
|
-
{
|
|
431
|
-
autoFocus: true,
|
|
432
|
-
color: buttonOverwrites?.[2].color ?? mapping[confirmType],
|
|
433
|
-
onClick: onConfirm,
|
|
434
|
-
disabled: buttonOverwrites?.[2].disabled ?? false,
|
|
435
|
-
children: buttonOverwrites?.[2].text ?? translation.confirm
|
|
436
|
-
}
|
|
437
|
-
)
|
|
438
|
-
] })
|
|
439
|
-
] });
|
|
440
|
-
};
|
|
441
|
-
|
|
442
|
-
// src/components/examples/StackingModals.tsx
|
|
443
|
-
var import_jsx_runtime7 = require("react/jsx-runtime");
|
|
444
|
-
var StackingModals = () => {
|
|
445
|
-
const [modal1, setModal1] = (0, import_react6.useState)(false);
|
|
446
|
-
const [modal2, setModal2] = (0, import_react6.useState)(false);
|
|
447
|
-
const [modal3, setModal3] = (0, import_react6.useState)(false);
|
|
448
|
-
return /* @__PURE__ */ (0, import_jsx_runtime7.jsxs)(ModalRegister, { children: [
|
|
449
|
-
/* @__PURE__ */ (0, import_jsx_runtime7.jsxs)(
|
|
450
|
-
ConfirmDialog,
|
|
451
|
-
{
|
|
452
|
-
id: "1",
|
|
453
|
-
isOpen: modal1,
|
|
454
|
-
onConfirm: () => setModal1(false),
|
|
455
|
-
onBackgroundClick: () => setModal1(false),
|
|
456
|
-
onCloseClick: () => setModal1(false),
|
|
457
|
-
modalClassName: "!bg-yellow-200 min-h-[300px]",
|
|
458
|
-
children: [
|
|
459
|
-
"I'm Modal 1",
|
|
460
|
-
/* @__PURE__ */ (0, import_jsx_runtime7.jsx)(SolidButton, { onClick: () => setModal2(true), children: "Open Modal 2" })
|
|
461
|
-
]
|
|
462
|
-
}
|
|
463
|
-
),
|
|
464
|
-
/* @__PURE__ */ (0, import_jsx_runtime7.jsxs)(
|
|
465
|
-
ConfirmDialog,
|
|
466
|
-
{
|
|
467
|
-
id: "2",
|
|
468
|
-
isOpen: modal2,
|
|
469
|
-
onConfirm: () => setModal2(false),
|
|
470
|
-
onBackgroundClick: () => setModal2(false),
|
|
471
|
-
onCloseClick: () => setModal2(false),
|
|
472
|
-
modalClassName: "!bg-green-200 min-w-[300px]",
|
|
473
|
-
children: [
|
|
474
|
-
"The next layer of Modals!",
|
|
475
|
-
"This is Modal 2",
|
|
476
|
-
/* @__PURE__ */ (0, import_jsx_runtime7.jsx)(SolidButton, { onClick: () => setModal3(true), children: "Open Modal 3" })
|
|
477
|
-
]
|
|
478
|
-
}
|
|
479
|
-
),
|
|
480
|
-
/* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
|
|
481
|
-
ConfirmDialog,
|
|
482
|
-
{
|
|
483
|
-
id: "3",
|
|
484
|
-
isOpen: modal3,
|
|
485
|
-
onConfirm: () => setModal3(false),
|
|
486
|
-
onBackgroundClick: () => setModal3(false),
|
|
487
|
-
onCloseClick: () => setModal3(false),
|
|
488
|
-
children: "This is Modal 3!"
|
|
489
|
-
}
|
|
490
|
-
),
|
|
491
|
-
/* @__PURE__ */ (0, import_jsx_runtime7.jsx)("div", { className: "row items-center justify-center min-h-[400px]", id: modalRootName, children: /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(SolidButton, { onClick: () => setModal1(true), children: "Open Modal 1" }) })
|
|
492
|
-
] });
|
|
493
|
-
};
|
|
494
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
495
|
-
0 && (module.exports = {
|
|
496
|
-
StackingModals
|
|
497
|
-
});
|
|
498
|
-
//# sourceMappingURL=StackingModals.js.map
|