sillytavern-utils-lib 1.0.60 → 1.0.62
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/character-utils.cjs +1 -0
- package/dist/character-utils.d.ts +1 -0
- package/dist/character-utils.js +48 -68
- package/dist/components/react/ConnectionProfileSelect.cjs +1 -0
- package/dist/components/{ConnectionProfileSelect.d.ts → react/ConnectionProfileSelect.d.ts} +2 -3
- package/dist/components/react/ConnectionProfileSelect.d.ts.map +1 -0
- package/dist/components/react/ConnectionProfileSelect.js +64 -0
- package/dist/components/react/Popup.cjs +1 -0
- package/dist/components/{Popup.d.ts → react/Popup.d.ts} +3 -2
- package/dist/components/react/Popup.d.ts.map +1 -0
- package/dist/components/react/Popup.js +180 -0
- package/dist/components/react/STButton.cjs +1 -0
- package/dist/components/{STButton.d.ts → react/STButton.d.ts} +1 -0
- package/dist/components/react/STButton.d.ts.map +1 -0
- package/dist/components/react/STButton.js +12 -0
- package/dist/components/react/STFancyDropdown.cjs +1 -0
- package/dist/components/{STFancyDropdown.d.ts → react/STFancyDropdown.d.ts} +1 -0
- package/dist/components/react/STFancyDropdown.d.ts.map +1 -0
- package/dist/components/react/STFancyDropdown.js +176 -0
- package/dist/components/react/STInput.cjs +1 -0
- package/dist/components/{STInput.d.ts → react/STInput.d.ts} +2 -1
- package/dist/components/react/STInput.d.ts.map +1 -0
- package/dist/components/react/STInput.js +19 -0
- package/dist/components/react/STPresetSelect.cjs +1 -0
- package/dist/components/{STPresetSelect.d.ts → react/STPresetSelect.d.ts} +1 -0
- package/dist/components/react/STPresetSelect.d.ts.map +1 -0
- package/dist/components/react/STPresetSelect.js +142 -0
- package/dist/components/react/STSelect.cjs +1 -0
- package/dist/components/{STSelect.d.ts → react/STSelect.d.ts} +1 -0
- package/dist/components/react/STSelect.d.ts.map +1 -0
- package/dist/components/react/STSelect.js +12 -0
- package/dist/components/react/STSortableList.cjs +1 -0
- package/dist/components/{STSortableList.d.ts → react/STSortableList.d.ts} +4 -3
- package/dist/components/react/STSortableList.d.ts.map +1 -0
- package/dist/components/react/STSortableList.js +148 -0
- package/dist/components/react/STTextarea.cjs +1 -0
- package/dist/components/{STTextarea.d.ts → react/STTextarea.d.ts} +1 -0
- package/dist/components/react/STTextarea.d.ts.map +1 -0
- package/dist/components/react/STTextarea.js +12 -0
- package/dist/components/react/index.cjs +1 -0
- package/dist/components/{index.d.ts → react/index.d.ts} +3 -2
- package/dist/components/react/index.d.ts.map +1 -0
- package/dist/components/react/index.js +22 -0
- package/dist/components/vue/STConnectionProfileSelect.vue.cjs +1 -0
- package/dist/components/vue/STConnectionProfileSelect.vue.d.ts +80 -0
- package/dist/components/vue/STConnectionProfileSelect.vue.d.ts.map +1 -0
- package/dist/components/vue/STConnectionProfileSelect.vue.js +83 -0
- package/dist/components/vue/STConnectionProfileSelect.vue2.cjs +1 -0
- package/dist/components/vue/STConnectionProfileSelect.vue2.js +4 -0
- package/dist/components/vue/index.cjs +1 -0
- package/dist/components/vue/index.d.ts +4 -0
- package/dist/components/vue/index.d.ts.map +1 -0
- package/dist/components/vue/index.js +4 -0
- package/dist/config.cjs +1 -0
- package/dist/config.d.ts +11 -1
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +238 -157
- package/dist/extension-settings-manager.cjs +1 -0
- package/dist/extension-settings-manager.js +118 -182
- package/dist/fancy-dropdown.cjs +1 -0
- package/dist/fancy-dropdown.js +244 -524
- package/dist/generate.cjs +1 -0
- package/dist/generate.d.ts +1 -0
- package/dist/generate.js +78 -93
- package/dist/index.cjs +1 -0
- package/dist/index.d.ts +2 -1
- package/dist/index.js +21 -10
- package/dist/preset-select.cjs +1 -0
- package/dist/preset-select.d.ts +1 -0
- package/dist/preset-select.js +124 -235
- package/dist/profile-utils.cjs +1 -0
- package/dist/profile-utils.d.ts +9 -0
- package/dist/profile-utils.d.ts.map +1 -0
- package/dist/profile-utils.js +17 -0
- package/dist/prompt-builder.cjs +6 -0
- package/dist/prompt-builder.d.ts +1 -0
- package/dist/prompt-builder.js +370 -516
- package/dist/sortable-list.cjs +1 -0
- package/dist/sortable-list.d.ts +2 -1
- package/dist/sortable-list.js +229 -405
- package/dist/tokenizer.cjs +1 -0
- package/dist/tokenizer.js +19 -18
- package/dist/types/chat-completion.cjs +1 -0
- package/dist/types/chat-completion.js +1 -2
- package/dist/types/context.cjs +1 -0
- package/dist/types/context.js +1 -2
- package/dist/types/index.cjs +1 -0
- package/dist/types/index.d.ts +6 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +4 -74
- package/dist/types/instruct.cjs +1 -0
- package/dist/types/instruct.js +1 -2
- package/dist/types/popup.cjs +1 -0
- package/dist/types/popup.js +5 -15
- package/dist/types/profiles.cjs +1 -0
- package/dist/types/profiles.js +1 -2
- package/dist/types/regex.cjs +1 -0
- package/dist/types/regex.js +1 -2
- package/dist/types/sysprompt.cjs +1 -0
- package/dist/types/sysprompt.js +1 -2
- package/dist/types/text-completion.cjs +1 -0
- package/dist/types/text-completion.js +1 -2
- package/dist/types/translate.cjs +1 -0
- package/dist/types/translate.js +4 -8
- package/dist/types/world-info.cjs +1 -0
- package/dist/types/world-info.js +1 -2
- package/dist/vue-shim.d.ts +5 -0
- package/dist/world-info-utils.cjs +1 -0
- package/dist/world-info-utils.d.ts +1 -0
- package/dist/world-info-utils.js +87 -136
- package/package.json +50 -23
- package/dist/character-utils.js.map +0 -1
- package/dist/chat-utils.d.ts +0 -6
- package/dist/chat-utils.d.ts.map +0 -1
- package/dist/chat-utils.js +0 -14
- package/dist/chat-utils.js.map +0 -1
- package/dist/components/ConnectionProfileSelect.d.ts.map +0 -1
- package/dist/components/ConnectionProfileSelect.js +0 -126
- package/dist/components/ConnectionProfileSelect.js.map +0 -1
- package/dist/components/MyFancyButton.d.ts +0 -6
- package/dist/components/MyFancyButton.d.ts.map +0 -1
- package/dist/components/MyFancyButton.js +0 -22
- package/dist/components/MyFancyButton.js.map +0 -1
- package/dist/components/Popup.d.ts.map +0 -1
- package/dist/components/Popup.js +0 -179
- package/dist/components/Popup.js.map +0 -1
- package/dist/components/STButton.d.ts.map +0 -1
- package/dist/components/STButton.js +0 -20
- package/dist/components/STButton.js.map +0 -1
- package/dist/components/STFancyDropdown.d.ts.map +0 -1
- package/dist/components/STFancyDropdown.js +0 -135
- package/dist/components/STFancyDropdown.js.map +0 -1
- package/dist/components/STInput.d.ts.map +0 -1
- package/dist/components/STInput.js +0 -26
- package/dist/components/STInput.js.map +0 -1
- package/dist/components/STPresetSelect.d.ts.map +0 -1
- package/dist/components/STPresetSelect.js +0 -104
- package/dist/components/STPresetSelect.js.map +0 -1
- package/dist/components/STSelect.d.ts.map +0 -1
- package/dist/components/STSelect.js +0 -18
- package/dist/components/STSelect.js.map +0 -1
- package/dist/components/STSortableList.d.ts.map +0 -1
- package/dist/components/STSortableList.js +0 -90
- package/dist/components/STSortableList.js.map +0 -1
- package/dist/components/STTextarea.d.ts.map +0 -1
- package/dist/components/STTextarea.js +0 -18
- package/dist/components/STTextarea.js.map +0 -1
- package/dist/components/index.d.ts.map +0 -1
- package/dist/components/index.js +0 -11
- package/dist/components/index.js.map +0 -1
- package/dist/config.js.map +0 -1
- package/dist/extension-settings-manager.js.map +0 -1
- package/dist/fancy-dropdown.js.map +0 -1
- package/dist/generate.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/macro-utils.d.ts +0 -2
- package/dist/macro-utils.d.ts.map +0 -1
- package/dist/macro-utils.js +0 -2
- package/dist/macro-utils.js.map +0 -1
- package/dist/preset-select.js.map +0 -1
- package/dist/prompt-builder.js.map +0 -1
- package/dist/sortable-list.js.map +0 -1
- package/dist/tokenizer.js.map +0 -1
- package/dist/types/chat-completion.js.map +0 -1
- package/dist/types/context.js.map +0 -1
- package/dist/types/index.js.map +0 -1
- package/dist/types/instruct.js.map +0 -1
- package/dist/types/popup.js.map +0 -1
- package/dist/types/profiles.js.map +0 -1
- package/dist/types/regex.js.map +0 -1
- package/dist/types/sysprompt.js.map +0 -1
- package/dist/types/text-completion.js.map +0 -1
- package/dist/types/translate.js.map +0 -1
- package/dist/types/world-info.js.map +0 -1
- package/dist/world-info-utils.js.map +0 -1
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import { jsxs as d, jsx as n } from "react/jsx-runtime";
|
|
2
|
+
import j, { useState as x, useRef as D, useEffect as k, useMemo as m } from "react";
|
|
3
|
+
import F from "fuse.js";
|
|
4
|
+
import { STInput as H } from "./STInput.js";
|
|
5
|
+
const z = ({
|
|
6
|
+
items: e,
|
|
7
|
+
value: o,
|
|
8
|
+
onChange: p,
|
|
9
|
+
placeholder: s = "Select items...",
|
|
10
|
+
closeOnSelect: l = !1,
|
|
11
|
+
multiple: I = !0,
|
|
12
|
+
disabled: f = !1,
|
|
13
|
+
onBeforeSelection: y,
|
|
14
|
+
enableSearch: a = !1,
|
|
15
|
+
searchPlaceholder: N = "Search...",
|
|
16
|
+
searchNoResultsText: T = "No results found",
|
|
17
|
+
searchFuseOptions: h,
|
|
18
|
+
inputClasses: E,
|
|
19
|
+
containerClasses: L
|
|
20
|
+
}) => {
|
|
21
|
+
const [i, u] = x(!1), [c, b] = x(""), v = D(null);
|
|
22
|
+
k(() => {
|
|
23
|
+
const r = (t) => {
|
|
24
|
+
v.current && !v.current.contains(t.target) && u(!1);
|
|
25
|
+
};
|
|
26
|
+
return document.addEventListener("mousedown", r), () => document.removeEventListener("mousedown", r);
|
|
27
|
+
}, []), k(() => {
|
|
28
|
+
i || b("");
|
|
29
|
+
}, [i]);
|
|
30
|
+
const g = m(() => {
|
|
31
|
+
if (!a) return null;
|
|
32
|
+
const r = {
|
|
33
|
+
includeScore: !1,
|
|
34
|
+
threshold: 0.4,
|
|
35
|
+
keys: ["label", "value"],
|
|
36
|
+
...h
|
|
37
|
+
};
|
|
38
|
+
return new F(e, r);
|
|
39
|
+
}, [e, a, h]), w = m(() => !a || !c.trim() || !g ? e : g.search(c.trim()).map((r) => r.item), [e, c, a, g]), R = async (r) => {
|
|
40
|
+
let t;
|
|
41
|
+
I ? t = o.includes(r) ? o.filter((C) => C !== r) : [...o, r] : t = o.includes(r) ? [] : [r], !(y && !await Promise.resolve(y(o, t))) && (p(t), l && u(!1));
|
|
42
|
+
}, S = m(() => {
|
|
43
|
+
var r;
|
|
44
|
+
return o.length === 0 ? s : o.length === 1 ? ((r = e.find((t) => t.value === o[0])) == null ? void 0 : r.label) ?? o[0] : `${o.length} items selected`;
|
|
45
|
+
}, [o, e, s]);
|
|
46
|
+
return /* @__PURE__ */ d(
|
|
47
|
+
"div",
|
|
48
|
+
{
|
|
49
|
+
ref: v,
|
|
50
|
+
className: `fancy-dropdown-container ${L ?? ""}`,
|
|
51
|
+
style: {
|
|
52
|
+
position: "relative",
|
|
53
|
+
userSelect: "none",
|
|
54
|
+
opacity: f ? 0.6 : 1,
|
|
55
|
+
pointerEvents: f ? "none" : "auto"
|
|
56
|
+
},
|
|
57
|
+
children: [
|
|
58
|
+
/* @__PURE__ */ d(
|
|
59
|
+
"div",
|
|
60
|
+
{
|
|
61
|
+
className: "fancy-dropdown-trigger",
|
|
62
|
+
onClick: () => !f && u(!i),
|
|
63
|
+
style: {
|
|
64
|
+
padding: "8px 12px",
|
|
65
|
+
border: "1px solid var(--border-color)",
|
|
66
|
+
backgroundColor: "var(--bg-color)",
|
|
67
|
+
color: "var(--text-color)",
|
|
68
|
+
borderRadius: "4px",
|
|
69
|
+
cursor: "pointer",
|
|
70
|
+
display: "flex",
|
|
71
|
+
alignItems: "center",
|
|
72
|
+
justifyContent: "space-between"
|
|
73
|
+
},
|
|
74
|
+
children: [
|
|
75
|
+
/* @__PURE__ */ n("span", { className: "fancy-dropdown-trigger-text", children: S }),
|
|
76
|
+
/* @__PURE__ */ n("i", { className: `fas ${i ? "fa-chevron-up" : "fa-chevron-down"}`, style: { marginLeft: "8px" } })
|
|
77
|
+
]
|
|
78
|
+
}
|
|
79
|
+
),
|
|
80
|
+
i && /* @__PURE__ */ d(
|
|
81
|
+
"div",
|
|
82
|
+
{
|
|
83
|
+
className: "fancy-dropdown-list",
|
|
84
|
+
style: {
|
|
85
|
+
position: "absolute",
|
|
86
|
+
top: "100%",
|
|
87
|
+
left: "0",
|
|
88
|
+
right: "0",
|
|
89
|
+
maxHeight: "300px",
|
|
90
|
+
zIndex: 1050,
|
|
91
|
+
border: "1px solid var(--border-color)",
|
|
92
|
+
borderTop: "none",
|
|
93
|
+
backgroundColor: "var(--bg-color-popup, var(--bg-color-secondary, var(--greyCAIbg, var(--grey30))))",
|
|
94
|
+
color: "var(--text-color)",
|
|
95
|
+
borderRadius: "0 0 4px 4px",
|
|
96
|
+
boxShadow: "0 4px 8px var(--black50a)",
|
|
97
|
+
overflowY: "auto",
|
|
98
|
+
display: "flex",
|
|
99
|
+
flexDirection: "column"
|
|
100
|
+
},
|
|
101
|
+
children: [
|
|
102
|
+
a && /* @__PURE__ */ n(
|
|
103
|
+
"div",
|
|
104
|
+
{
|
|
105
|
+
style: {
|
|
106
|
+
padding: "8px",
|
|
107
|
+
borderBottom: "1px solid var(--border-color)",
|
|
108
|
+
position: "sticky",
|
|
109
|
+
top: 0,
|
|
110
|
+
backgroundColor: "inherit"
|
|
111
|
+
},
|
|
112
|
+
children: /* @__PURE__ */ n(
|
|
113
|
+
H,
|
|
114
|
+
{
|
|
115
|
+
type: "text",
|
|
116
|
+
placeholder: N,
|
|
117
|
+
value: c,
|
|
118
|
+
onChange: (r) => b(r.target.value),
|
|
119
|
+
autoFocus: !0,
|
|
120
|
+
className: E
|
|
121
|
+
}
|
|
122
|
+
)
|
|
123
|
+
}
|
|
124
|
+
),
|
|
125
|
+
/* @__PURE__ */ n("ul", { style: { listStyle: "none", margin: 0, padding: 0 }, children: w.length > 0 ? w.map((r) => /* @__PURE__ */ n(
|
|
126
|
+
M,
|
|
127
|
+
{
|
|
128
|
+
item: r,
|
|
129
|
+
isSelected: o.includes(r.value),
|
|
130
|
+
onClick: R
|
|
131
|
+
},
|
|
132
|
+
r.value
|
|
133
|
+
)) : /* @__PURE__ */ n(
|
|
134
|
+
"div",
|
|
135
|
+
{
|
|
136
|
+
style: {
|
|
137
|
+
padding: "8px 12px",
|
|
138
|
+
textAlign: "center",
|
|
139
|
+
color: "var(--text-color-secondary, var(--grey50))"
|
|
140
|
+
},
|
|
141
|
+
children: T
|
|
142
|
+
}
|
|
143
|
+
) })
|
|
144
|
+
]
|
|
145
|
+
}
|
|
146
|
+
)
|
|
147
|
+
]
|
|
148
|
+
}
|
|
149
|
+
);
|
|
150
|
+
}, M = j.memo(({ item: e, isSelected: o, onClick: p }) => {
|
|
151
|
+
const [s, l] = x(!1);
|
|
152
|
+
return /* @__PURE__ */ d(
|
|
153
|
+
"li",
|
|
154
|
+
{
|
|
155
|
+
onClick: () => p(e.value),
|
|
156
|
+
onMouseEnter: () => l(!0),
|
|
157
|
+
onMouseLeave: () => l(!1),
|
|
158
|
+
style: {
|
|
159
|
+
padding: "8px 12px",
|
|
160
|
+
cursor: "pointer",
|
|
161
|
+
display: "flex",
|
|
162
|
+
alignItems: "center",
|
|
163
|
+
justifyContent: "space-between",
|
|
164
|
+
backgroundColor: o ? "var(--accent-color-bg, var(--link-color))" : s ? "var(--hover-color, var(--white20a))" : "transparent"
|
|
165
|
+
},
|
|
166
|
+
children: [
|
|
167
|
+
/* @__PURE__ */ n("span", { children: e.label }),
|
|
168
|
+
o && /* @__PURE__ */ n("i", { className: "checkmark fa-solid fa-check", style: { marginLeft: "8px" } })
|
|
169
|
+
]
|
|
170
|
+
}
|
|
171
|
+
);
|
|
172
|
+
});
|
|
173
|
+
export {
|
|
174
|
+
M as FancyDropdownItem,
|
|
175
|
+
z as STFancyDropdown
|
|
176
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("react/jsx-runtime"),l=require("react"),u=({label:i,className:n,overrideDefaults:c=!1,type:e="text",...o})=>{const r=l.useMemo(()=>{const s=[];return c||(e==="text"||e==="number"||e==="password"||e==="email"||e==="search")&&s.push("text_pole"),s.push(n),s.filter(Boolean).join(" ")},[c,n,e]);if(e==="checkbox"){const s=c?n:`checkbox_label ${n??""}`.trim();return t.jsxs("label",{className:s,children:[t.jsx("input",{type:"checkbox",...o}),i&&t.jsx("span",{children:i})]})}return t.jsx("input",{type:e,className:r,...o})};exports.STInput=u;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import React,
|
|
1
|
+
import { default as React, FC, InputHTMLAttributes } from 'react';
|
|
2
|
+
|
|
2
3
|
export interface STInputProps extends InputHTMLAttributes<HTMLInputElement> {
|
|
3
4
|
/**
|
|
4
5
|
* For checkboxes, this text will be displayed inside the associated label.
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"STInput.d.ts","sourceRoot":"","sources":["../../../src/components/react/STInput.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,EAAE,mBAAmB,EAAW,MAAM,OAAO,CAAC;AAEhE,MAAM,WAAW,YAAa,SAAQ,mBAAmB,CAAC,gBAAgB,CAAC;IACzE;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC;IACjC;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;;;;OAKG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED;;;;GAIG;AACH,eAAO,MAAM,OAAO,EAAE,EAAE,CAAC,YAAY,CA4BpC,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { jsxs as l, jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import { useMemo as a } from "react";
|
|
3
|
+
const h = ({ label: r, className: o, overrideDefaults: c = !1, type: n = "text", ...t }) => {
|
|
4
|
+
const i = a(() => {
|
|
5
|
+
const s = [];
|
|
6
|
+
return c || (n === "text" || n === "number" || n === "password" || n === "email" || n === "search") && s.push("text_pole"), s.push(o), s.filter(Boolean).join(" ");
|
|
7
|
+
}, [c, o, n]);
|
|
8
|
+
if (n === "checkbox") {
|
|
9
|
+
const s = c ? o : `checkbox_label ${o ?? ""}`.trim();
|
|
10
|
+
return /* @__PURE__ */ l("label", { className: s, children: [
|
|
11
|
+
/* @__PURE__ */ e("input", { type: "checkbox", ...t }),
|
|
12
|
+
r && /* @__PURE__ */ e("span", { children: r })
|
|
13
|
+
] });
|
|
14
|
+
}
|
|
15
|
+
return /* @__PURE__ */ e("input", { type: n, className: i, ...t });
|
|
16
|
+
};
|
|
17
|
+
export {
|
|
18
|
+
h as STInput
|
|
19
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("react/jsx-runtime"),g=require("react"),v=require("./STButton.cjs"),I=require("./STSelect.cjs");require("./Popup.cjs");require("./ConnectionProfileSelect.cjs");require("./STSortableList.cjs");require("./STFancyDropdown.cjs");const d=require("../../config.cjs"),h=SillyTavern.getContext(),R=({value:c,items:r,readOnlyValues:p=[],label:t,onChange:f,onItemsChange:m,enableCreate:P=!1,enableRename:T=!1,enableDelete:j=!1,onCreate:$,onRename:x,onDelete:y,buttons:w})=>{const a=g.useMemo(()=>r.find(e=>e.value===c),[r,c]),S=g.useCallback(e=>e?p.includes(e):!1,[p]),q=async()=>{const e=await h.Popup.show.input(`Create a new ${t}`,`Please enter a name for the new ${t}:`,"");if(!e||e.trim()==="")return;const s=e.trim();if(r.some(n=>n.value===s)){await d.st_echo("warning",`A ${t} with this name already exists.`);return}let i={value:s,label:s};if($){const n=await Promise.resolve($(s));if(!n.confirmed)return;n.value&&(typeof n.value=="string"?i={value:n.value,label:n.value}:i=n.value)}m([...r,i]),f(i.value,c)},k=async()=>{if(!a){await d.st_echo("warning",`Please select a ${t} to rename.`);return}if(S(a.value)){await d.st_echo("warning",`This ${t} cannot be renamed as it is read-only.`);return}const e=await h.Popup.show.input(`Rename ${t}`,`Please enter a new name for "${a.label}":`,a.label);if(!e||e.trim()===""||e.trim()===a.value)return;const s=e.trim();if(r.some(l=>l.value===s)){await d.st_echo("warning",`A ${t} with this name already exists.`);return}let i={value:s,label:s};if(x){const l=await Promise.resolve(x(a.value,s));if(!l.confirmed)return;l.value&&(typeof l.value=="string"?i={value:l.value,label:l.value}:i=l.value)}const n=r.map(l=>l.value===a.value?i:l);m(n),f(i.value,c)},C=async()=>{var l;if(!a){await d.st_echo("warning",`Please select a ${t} to delete.`);return}if(S(a.value)){await d.st_echo("warning",`This ${t} cannot be deleted as it is read-only.`);return}if(!await h.Popup.show.confirm(`Delete ${t}`,`Are you sure you want to delete "${a.label}"?`)||y&&!await Promise.resolve(y(a.value)))return;const s=r.findIndex(u=>u.value===a.value),i=r.filter(u=>u.value!==a.value);m(i);let n;if(i.length>0){const u=Math.min(s,i.length-1);n=(l=i[u])==null?void 0:l.value}f(n,c)};return o.jsxs("div",{className:"preset-select-container",style:{display:"flex",alignItems:"center"},children:[o.jsx(I.STSelect,{value:c??"",onChange:e=>f(e.target.value,c),children:r.map(e=>o.jsx("option",{value:e.value,children:e.label},e.value))}),P&&o.jsx(v.STButton,{className:"fa-solid fa-file-circle-plus",title:`Create a new ${t}`,onClick:q,"data-i18n":`[title]Create a new ${t}`}),T&&o.jsx(v.STButton,{className:"fa-solid fa-pencil",title:`Rename selected ${t}`,onClick:k,disabled:!a,"data-i18n":`[title]Rename selected ${t}`}),j&&o.jsx(v.STButton,{className:"fa-solid fa-trash-can",title:`Delete selected ${t}`,onClick:C,disabled:!a,"data-i18n":`[title]Delete selected ${t}`}),w==null?void 0:w.map(e=>o.jsx(v.STButton,{className:e.icon,title:e.title,onClick:e.onClick,disabled:e.disabled,"data-i18n":e.i18n?`[title]${e.i18n}`:void 0},e.key))]})};exports.STPresetSelect=R;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"STPresetSelect.d.ts","sourceRoot":"","sources":["../../../src/components/react/STPresetSelect.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,EAAE,EAAwB,MAAM,OAAO,CAAC;AAMxD,MAAM,WAAW,UAAU;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,eAAe;IAC9B,oCAAoC;IACpC,GAAG,EAAE,MAAM,CAAC;IACZ,iDAAiD;IACjD,IAAI,EAAE,MAAM,CAAC;IACb,wCAAwC;IACxC,KAAK,EAAE,MAAM,CAAC;IACd,mDAAmD;IACnD,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,kEAAkE;IAClE,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,iCAAiC;IACjC,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,mBAAmB;IAClC,oCAAoC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,oDAAoD;IACpD,KAAK,EAAE,UAAU,EAAE,CAAC;IACpB,0DAA0D;IAC1D,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,wFAAwF;IACxF,KAAK,EAAE,MAAM,CAAC;IACd,uDAAuD;IACvD,QAAQ,EAAE,CAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;IACzD,+GAA+G;IAC/G,aAAa,EAAE,CAAC,QAAQ,EAAE,UAAU,EAAE,KAAK,IAAI,CAAC;IAChD,+CAA+C;IAC/C,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,+CAA+C;IAC/C,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,+CAA+C;IAC/C,YAAY,CAAC,EAAE,OAAO,CAAC;IAEvB;;;;OAIG;IACH,QAAQ,CAAC,EAAE,CACT,QAAQ,EAAE,MAAM,KAEd,OAAO,CAAC;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU,CAAA;KAAE,CAAC,GAC5D;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU,CAAA;KAAE,CAAC;IACxD;;;OAGG;IACH,QAAQ,CAAC,EAAE,CACT,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,KAEd,OAAO,CAAC;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU,CAAA;KAAE,CAAC,GAC5D;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU,CAAA;KAAE,CAAC;IACxD;;;OAGG;IACH,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IACzD,yEAAyE;IACzE,OAAO,CAAC,EAAE,eAAe,EAAE,CAAC;CAC7B;AAED;;;GAGG;AACH,eAAO,MAAM,cAAc,EAAE,EAAE,CAAC,mBAAmB,CA6KlD,CAAC"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import { jsxs as D, jsx as u } from "react/jsx-runtime";
|
|
2
|
+
import { useMemo as N, useCallback as R } from "react";
|
|
3
|
+
import { STButton as m } from "./STButton.js";
|
|
4
|
+
import { STSelect as V } from "./STSelect.js";
|
|
5
|
+
import "./Popup.js";
|
|
6
|
+
import "./ConnectionProfileSelect.js";
|
|
7
|
+
import "./STSortableList.js";
|
|
8
|
+
import "./STFancyDropdown.js";
|
|
9
|
+
import { st_echo as d } from "../../config.js";
|
|
10
|
+
const p = SillyTavern.getContext(), G = ({
|
|
11
|
+
value: o,
|
|
12
|
+
items: s,
|
|
13
|
+
readOnlyValues: h = [],
|
|
14
|
+
label: a,
|
|
15
|
+
onChange: f,
|
|
16
|
+
onItemsChange: v,
|
|
17
|
+
enableCreate: g = !1,
|
|
18
|
+
enableRename: k = !1,
|
|
19
|
+
enableDelete: C = !1,
|
|
20
|
+
onCreate: $,
|
|
21
|
+
onRename: y,
|
|
22
|
+
onDelete: x,
|
|
23
|
+
buttons: w
|
|
24
|
+
}) => {
|
|
25
|
+
const t = N(() => s.find((e) => e.value === o), [s, o]), P = R((e) => e ? h.includes(e) : !1, [h]), I = async () => {
|
|
26
|
+
const e = await p.Popup.show.input(
|
|
27
|
+
`Create a new ${a}`,
|
|
28
|
+
`Please enter a name for the new ${a}:`,
|
|
29
|
+
""
|
|
30
|
+
);
|
|
31
|
+
if (!e || e.trim() === "") return;
|
|
32
|
+
const r = e.trim();
|
|
33
|
+
if (s.some((n) => n.value === r)) {
|
|
34
|
+
await d("warning", `A ${a} with this name already exists.`);
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
let i = { value: r, label: r };
|
|
38
|
+
if ($) {
|
|
39
|
+
const n = await Promise.resolve($(r));
|
|
40
|
+
if (!n.confirmed) return;
|
|
41
|
+
n.value && (typeof n.value == "string" ? i = { value: n.value, label: n.value } : i = n.value);
|
|
42
|
+
}
|
|
43
|
+
v([...s, i]), f(i.value, o);
|
|
44
|
+
}, S = async () => {
|
|
45
|
+
if (!t) {
|
|
46
|
+
await d("warning", `Please select a ${a} to rename.`);
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
if (P(t.value)) {
|
|
50
|
+
await d("warning", `This ${a} cannot be renamed as it is read-only.`);
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
const e = await p.Popup.show.input(
|
|
54
|
+
`Rename ${a}`,
|
|
55
|
+
`Please enter a new name for "${t.label}":`,
|
|
56
|
+
t.label
|
|
57
|
+
);
|
|
58
|
+
if (!e || e.trim() === "" || e.trim() === t.value) return;
|
|
59
|
+
const r = e.trim();
|
|
60
|
+
if (s.some((l) => l.value === r)) {
|
|
61
|
+
await d("warning", `A ${a} with this name already exists.`);
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
let i = { value: r, label: r };
|
|
65
|
+
if (y) {
|
|
66
|
+
const l = await Promise.resolve(y(t.value, r));
|
|
67
|
+
if (!l.confirmed) return;
|
|
68
|
+
l.value && (typeof l.value == "string" ? i = { value: l.value, label: l.value } : i = l.value);
|
|
69
|
+
}
|
|
70
|
+
const n = s.map((l) => l.value === t.value ? i : l);
|
|
71
|
+
v(n), f(i.value, o);
|
|
72
|
+
}, T = async () => {
|
|
73
|
+
var l;
|
|
74
|
+
if (!t) {
|
|
75
|
+
await d("warning", `Please select a ${a} to delete.`);
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
if (P(t.value)) {
|
|
79
|
+
await d("warning", `This ${a} cannot be deleted as it is read-only.`);
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
if (!await p.Popup.show.confirm(
|
|
83
|
+
`Delete ${a}`,
|
|
84
|
+
`Are you sure you want to delete "${t.label}"?`
|
|
85
|
+
) || x && !await Promise.resolve(x(t.value)))
|
|
86
|
+
return;
|
|
87
|
+
const r = s.findIndex((c) => c.value === t.value), i = s.filter((c) => c.value !== t.value);
|
|
88
|
+
v(i);
|
|
89
|
+
let n;
|
|
90
|
+
if (i.length > 0) {
|
|
91
|
+
const c = Math.min(r, i.length - 1);
|
|
92
|
+
n = (l = i[c]) == null ? void 0 : l.value;
|
|
93
|
+
}
|
|
94
|
+
f(n, o);
|
|
95
|
+
};
|
|
96
|
+
return /* @__PURE__ */ D("div", { className: "preset-select-container", style: { display: "flex", alignItems: "center" }, children: [
|
|
97
|
+
/* @__PURE__ */ u(V, { value: o ?? "", onChange: (e) => f(e.target.value, o), children: s.map((e) => /* @__PURE__ */ u("option", { value: e.value, children: e.label }, e.value)) }),
|
|
98
|
+
g && /* @__PURE__ */ u(
|
|
99
|
+
m,
|
|
100
|
+
{
|
|
101
|
+
className: "fa-solid fa-file-circle-plus",
|
|
102
|
+
title: `Create a new ${a}`,
|
|
103
|
+
onClick: I,
|
|
104
|
+
"data-i18n": `[title]Create a new ${a}`
|
|
105
|
+
}
|
|
106
|
+
),
|
|
107
|
+
k && /* @__PURE__ */ u(
|
|
108
|
+
m,
|
|
109
|
+
{
|
|
110
|
+
className: "fa-solid fa-pencil",
|
|
111
|
+
title: `Rename selected ${a}`,
|
|
112
|
+
onClick: S,
|
|
113
|
+
disabled: !t,
|
|
114
|
+
"data-i18n": `[title]Rename selected ${a}`
|
|
115
|
+
}
|
|
116
|
+
),
|
|
117
|
+
C && /* @__PURE__ */ u(
|
|
118
|
+
m,
|
|
119
|
+
{
|
|
120
|
+
className: "fa-solid fa-trash-can",
|
|
121
|
+
title: `Delete selected ${a}`,
|
|
122
|
+
onClick: T,
|
|
123
|
+
disabled: !t,
|
|
124
|
+
"data-i18n": `[title]Delete selected ${a}`
|
|
125
|
+
}
|
|
126
|
+
),
|
|
127
|
+
w == null ? void 0 : w.map((e) => /* @__PURE__ */ u(
|
|
128
|
+
m,
|
|
129
|
+
{
|
|
130
|
+
className: e.icon,
|
|
131
|
+
title: e.title,
|
|
132
|
+
onClick: e.onClick,
|
|
133
|
+
disabled: e.disabled,
|
|
134
|
+
"data-i18n": e.i18n ? `[title]${e.i18n}` : void 0
|
|
135
|
+
},
|
|
136
|
+
e.key
|
|
137
|
+
))
|
|
138
|
+
] });
|
|
139
|
+
};
|
|
140
|
+
export {
|
|
141
|
+
G as STPresetSelect
|
|
142
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("react/jsx-runtime"),r=require("react"),u=({children:n,className:t,overrideDefaults:s=!1,...o})=>{const c=r.useMemo(()=>{const e=[];return s||e.push("text_pole"),e.push(t),e.filter(Boolean).join(" ")},[s,t]);return l.jsx("select",{className:c,...o,children:n})};exports.STSelect=u;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"STSelect.d.ts","sourceRoot":"","sources":["../../../src/components/react/STSelect.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,oBAAoB,EAAW,MAAM,OAAO,CAAC;AAE1D,MAAM,WAAW,aAAc,SAAQ,oBAAoB,CAAC,iBAAiB,CAAC;IAC5E;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;;OAGG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED;;;GAGG;AACH,eAAO,MAAM,QAAQ,EAAE,EAAE,CAAC,aAAa,CAkBtC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx as r } from "react/jsx-runtime";
|
|
2
|
+
import { useMemo as c } from "react";
|
|
3
|
+
const a = ({ children: t, className: s, overrideDefaults: o = !1, ...l }) => {
|
|
4
|
+
const n = c(() => {
|
|
5
|
+
const e = [];
|
|
6
|
+
return o || e.push("text_pole"), e.push(s), e.filter(Boolean).join(" ");
|
|
7
|
+
}, [o, s]);
|
|
8
|
+
return /* @__PURE__ */ r("select", { className: n, ...l, children: t });
|
|
9
|
+
};
|
|
10
|
+
export {
|
|
11
|
+
a as STSelect
|
|
12
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("react/jsx-runtime"),b=require("react"),C=require("sortablejs"),R=require("./STSelect.cjs"),v=require("./STButton.cjs"),j=b.memo(({item:n,showToggleButton:a,showDeleteButton:u,showSelectInput:g,onToggle:p,onDelete:f,onSelectChange:i})=>{const{id:o,label:h,enabled:s,canDelete:S=!0,canToggle:e=!0,showSelect:l=!0,canSelect:t=!0,selectOptions:c=[],selectValue:x}=n,T={display:"flex",alignItems:"center",padding:"8px 12px",border:"1px solid var(--SmartThemeBorderColor, #ccc)",color:"var(--SmartThemeBodyColor, #333)",marginBottom:"2px",opacity:a&&!s?.6:1},y={cursor:"pointer",flexShrink:0},m={display:"inline-block",flexShrink:0,marginRight:"10px"};return r.jsxs("li",{className:"sortable-list-item",style:T,"data-id":o,children:[r.jsx("span",{className:"drag-handle fas fa-bars",style:{cursor:"grab",marginRight:"10px",color:"var(--SmartThemeBodyColor, #555)",flexShrink:0}}),r.jsx("span",{className:"item-label",style:{flexGrow:1,marginRight:"10px",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:h}),g&&l&&t&&r.jsx(R.STSelect,{value:x,onChange:d=>i(o,d.target.value),disabled:!s,style:{marginRight:"10px",flexShrink:0,width:"unset"},children:c.length===0?r.jsx("option",{disabled:!0,children:"--"}):c.map(d=>r.jsx("option",{value:d.value,children:d.label},d.value))}),g&&(!l||!t)&&r.jsx("span",{style:m}),a&&e&&r.jsx(v.STButton,{overrideDefaults:!0,className:`toggle-button fas ${s?"fa-toggle-on":"fa-toggle-off"}`,style:{...y,marginRight:"10px",fontSize:"1.2em",color:s?"var(--success-color, #4CAF50)":"var(--SmartThemeBodyColor, #555)",backgroundColor:"transparent",border:"none"},onClick:()=>p(o)}),a&&!e&&r.jsx("span",{style:m}),u&&S&&r.jsx(v.STButton,{overrideDefaults:!0,className:"delete-button fas fa-trash-can",style:{...y,color:"var(--error-color, #f44336)",backgroundColor:"transparent",border:"none"},onClick:()=>f(o)}),u&&!S&&r.jsx("span",{style:{...m,marginRight:0}})]})}),k=({items:n,onItemsChange:a,showToggleButton:u=!1,showDeleteButton:g=!1,showSelectInput:p=!1,sortableJsOptions:f={}})=>{const i=b.useRef(null),o=b.useRef(null);b.useEffect(()=>(i.current&&(o.current=C.create(i.current,{handle:".drag-handle",animation:150,ghostClass:"sortable-ghost",chosenClass:"sortable-chosen",dragClass:"sortable-drag",filter:"select, button, .toggle-button, .delete-button",preventOnFilter:!1,...f,onEnd:e=>{const{oldIndex:l,newIndex:t}=e;if(l===void 0||t===void 0||l===t)return;const c=Array.from(n),[x]=c.splice(l,1);c.splice(t,0,x),a(c)}})),()=>{var e;(e=o.current)==null||e.destroy(),o.current=null}),[n,a,f]);const h=e=>{a(n.map(l=>l.id===e?{...l,enabled:!l.enabled}:l))},s=e=>{a(n.filter(l=>l.id!==e))},S=(e,l)=>{a(n.map(t=>t.id===e?{...t,selectValue:l}:t))};return r.jsx("ul",{ref:i,className:"sortable-list",style:{listStyle:"none",padding:0,margin:0},children:n.map(e=>r.jsx(j,{item:e,showToggleButton:u,showDeleteButton:g,showSelectInput:p,onToggle:h,onDelete:s,onSelectChange:S},e.id))})};exports.STSortableList=k;exports.STSortableListItem=j;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import React,
|
|
2
|
-
import Sortable from 'sortablejs';
|
|
3
|
-
import { DropdownItem } from '
|
|
1
|
+
import { default as React, FC } from 'react';
|
|
2
|
+
import { default as Sortable } from 'sortablejs';
|
|
3
|
+
import { DropdownItem } from '../../fancy-dropdown.js';
|
|
4
|
+
|
|
4
5
|
export interface SortableListItemData {
|
|
5
6
|
id: string;
|
|
6
7
|
label: string | React.ReactNode;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"STSortableList.d.ts","sourceRoot":"","sources":["../../../src/components/react/STSortableList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,EAAqB,MAAM,OAAO,CAAC;AACrD,OAAO,QAA2B,MAAM,YAAY,CAAC;AAErD,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAKvD,MAAM,WAAW,oBAAoB;IACnC,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC;IAChC,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,aAAa,CAAC,EAAE,YAAY,EAAE,CAAC;IAC/B,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,mBAAmB;IAClC,8CAA8C;IAC9C,KAAK,EAAE,oBAAoB,EAAE,CAAC;IAC9B,qGAAqG;IACrG,aAAa,EAAE,CAAC,QAAQ,EAAE,oBAAoB,EAAE,KAAK,IAAI,CAAC;IAE1D,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,eAAe,CAAC,EAAE,OAAO,CAAC;IAE1B;;;OAGG;IACH,iBAAiB,CAAC,EAAE,QAAQ,CAAC,OAAO,CAAC;CACtC;AAGD,MAAM,WAAW,uBAAuB;IACtC,IAAI,EAAE,oBAAoB,CAAC;IAC3B,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,QAAQ,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/B,QAAQ,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/B,cAAc,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;CACxD;AAED,eAAO,MAAM,kBAAkB,EAAE,EAAE,CAAC,uBAAuB,CAuG1D,CAAC;AAIF;;;GAGG;AACH,eAAO,MAAM,cAAc,EAAE,EAAE,CAAC,mBAAmB,CA0ElD,CAAC"}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
import { jsxs as k, jsx as r } from "react/jsx-runtime";
|
|
2
|
+
import R, { useRef as x, useEffect as T } from "react";
|
|
3
|
+
import N from "sortablejs";
|
|
4
|
+
import { STSelect as w } from "./STSelect.js";
|
|
5
|
+
import { STButton as v } from "./STButton.js";
|
|
6
|
+
const D = R.memo(
|
|
7
|
+
({ item: o, showToggleButton: a, showDeleteButton: f, showSelectInput: u, onToggle: m, onDelete: p, onSelectChange: i }) => {
|
|
8
|
+
const {
|
|
9
|
+
id: n,
|
|
10
|
+
label: h,
|
|
11
|
+
enabled: s,
|
|
12
|
+
canDelete: g = !0,
|
|
13
|
+
canToggle: e = !0,
|
|
14
|
+
showSelect: l = !0,
|
|
15
|
+
canSelect: t = !0,
|
|
16
|
+
selectOptions: c = [],
|
|
17
|
+
selectValue: b
|
|
18
|
+
} = o, C = {
|
|
19
|
+
display: "flex",
|
|
20
|
+
alignItems: "center",
|
|
21
|
+
padding: "8px 12px",
|
|
22
|
+
border: "1px solid var(--SmartThemeBorderColor, #ccc)",
|
|
23
|
+
color: "var(--SmartThemeBodyColor, #333)",
|
|
24
|
+
marginBottom: "2px",
|
|
25
|
+
opacity: a && !s ? 0.6 : 1
|
|
26
|
+
}, y = { cursor: "pointer", flexShrink: 0 }, S = { display: "inline-block", flexShrink: 0, marginRight: "10px" };
|
|
27
|
+
return /* @__PURE__ */ k("li", { className: "sortable-list-item", style: C, "data-id": n, children: [
|
|
28
|
+
/* @__PURE__ */ r(
|
|
29
|
+
"span",
|
|
30
|
+
{
|
|
31
|
+
className: "drag-handle fas fa-bars",
|
|
32
|
+
style: { cursor: "grab", marginRight: "10px", color: "var(--SmartThemeBodyColor, #555)", flexShrink: 0 }
|
|
33
|
+
}
|
|
34
|
+
),
|
|
35
|
+
/* @__PURE__ */ r(
|
|
36
|
+
"span",
|
|
37
|
+
{
|
|
38
|
+
className: "item-label",
|
|
39
|
+
style: {
|
|
40
|
+
flexGrow: 1,
|
|
41
|
+
marginRight: "10px",
|
|
42
|
+
overflow: "hidden",
|
|
43
|
+
textOverflow: "ellipsis",
|
|
44
|
+
whiteSpace: "nowrap"
|
|
45
|
+
},
|
|
46
|
+
children: h
|
|
47
|
+
}
|
|
48
|
+
),
|
|
49
|
+
u && l && t && /* @__PURE__ */ r(
|
|
50
|
+
w,
|
|
51
|
+
{
|
|
52
|
+
value: b,
|
|
53
|
+
onChange: (d) => i(n, d.target.value),
|
|
54
|
+
disabled: !s,
|
|
55
|
+
style: { marginRight: "10px", flexShrink: 0, width: "unset" },
|
|
56
|
+
children: c.length === 0 ? /* @__PURE__ */ r("option", { disabled: !0, children: "--" }) : c.map((d) => /* @__PURE__ */ r("option", { value: d.value, children: d.label }, d.value))
|
|
57
|
+
}
|
|
58
|
+
),
|
|
59
|
+
u && (!l || !t) && /* @__PURE__ */ r("span", { style: S }),
|
|
60
|
+
a && e && /* @__PURE__ */ r(
|
|
61
|
+
v,
|
|
62
|
+
{
|
|
63
|
+
overrideDefaults: !0,
|
|
64
|
+
className: `toggle-button fas ${s ? "fa-toggle-on" : "fa-toggle-off"}`,
|
|
65
|
+
style: {
|
|
66
|
+
...y,
|
|
67
|
+
marginRight: "10px",
|
|
68
|
+
fontSize: "1.2em",
|
|
69
|
+
color: s ? "var(--success-color, #4CAF50)" : "var(--SmartThemeBodyColor, #555)",
|
|
70
|
+
backgroundColor: "transparent",
|
|
71
|
+
border: "none"
|
|
72
|
+
},
|
|
73
|
+
onClick: () => m(n)
|
|
74
|
+
}
|
|
75
|
+
),
|
|
76
|
+
a && !e && /* @__PURE__ */ r("span", { style: S }),
|
|
77
|
+
f && g && /* @__PURE__ */ r(
|
|
78
|
+
v,
|
|
79
|
+
{
|
|
80
|
+
overrideDefaults: !0,
|
|
81
|
+
className: "delete-button fas fa-trash-can",
|
|
82
|
+
style: {
|
|
83
|
+
...y,
|
|
84
|
+
color: "var(--error-color, #f44336)",
|
|
85
|
+
backgroundColor: "transparent",
|
|
86
|
+
border: "none"
|
|
87
|
+
},
|
|
88
|
+
onClick: () => p(n)
|
|
89
|
+
}
|
|
90
|
+
),
|
|
91
|
+
f && !g && /* @__PURE__ */ r("span", { style: { ...S, marginRight: 0 } })
|
|
92
|
+
] });
|
|
93
|
+
}
|
|
94
|
+
), F = ({
|
|
95
|
+
items: o,
|
|
96
|
+
onItemsChange: a,
|
|
97
|
+
showToggleButton: f = !1,
|
|
98
|
+
showDeleteButton: u = !1,
|
|
99
|
+
showSelectInput: m = !1,
|
|
100
|
+
sortableJsOptions: p = {}
|
|
101
|
+
}) => {
|
|
102
|
+
const i = x(null), n = x(null);
|
|
103
|
+
T(() => (i.current && (n.current = N.create(i.current, {
|
|
104
|
+
handle: ".drag-handle",
|
|
105
|
+
animation: 150,
|
|
106
|
+
ghostClass: "sortable-ghost",
|
|
107
|
+
chosenClass: "sortable-chosen",
|
|
108
|
+
dragClass: "sortable-drag",
|
|
109
|
+
filter: "select, button, .toggle-button, .delete-button",
|
|
110
|
+
// Prevent drag on controls
|
|
111
|
+
preventOnFilter: !1,
|
|
112
|
+
...p,
|
|
113
|
+
onEnd: (e) => {
|
|
114
|
+
const { oldIndex: l, newIndex: t } = e;
|
|
115
|
+
if (l === void 0 || t === void 0 || l === t)
|
|
116
|
+
return;
|
|
117
|
+
const c = Array.from(o), [b] = c.splice(l, 1);
|
|
118
|
+
c.splice(t, 0, b), a(c);
|
|
119
|
+
}
|
|
120
|
+
})), () => {
|
|
121
|
+
var e;
|
|
122
|
+
(e = n.current) == null || e.destroy(), n.current = null;
|
|
123
|
+
}), [o, a, p]);
|
|
124
|
+
const h = (e) => {
|
|
125
|
+
a(o.map((l) => l.id === e ? { ...l, enabled: !l.enabled } : l));
|
|
126
|
+
}, s = (e) => {
|
|
127
|
+
a(o.filter((l) => l.id !== e));
|
|
128
|
+
}, g = (e, l) => {
|
|
129
|
+
a(o.map((t) => t.id === e ? { ...t, selectValue: l } : t));
|
|
130
|
+
};
|
|
131
|
+
return /* @__PURE__ */ r("ul", { ref: i, className: "sortable-list", style: { listStyle: "none", padding: 0, margin: 0 }, children: o.map((e) => /* @__PURE__ */ r(
|
|
132
|
+
D,
|
|
133
|
+
{
|
|
134
|
+
item: e,
|
|
135
|
+
showToggleButton: f,
|
|
136
|
+
showDeleteButton: u,
|
|
137
|
+
showSelectInput: m,
|
|
138
|
+
onToggle: h,
|
|
139
|
+
onDelete: s,
|
|
140
|
+
onSelectChange: g
|
|
141
|
+
},
|
|
142
|
+
e.id
|
|
143
|
+
)) });
|
|
144
|
+
};
|
|
145
|
+
export {
|
|
146
|
+
F as STSortableList,
|
|
147
|
+
D as STSortableListItem
|
|
148
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("react/jsx-runtime"),c=require("react"),u=({children:s,className:t,overrideDefaults:a=!1,...r})=>{const o=c.useMemo(()=>{const e=[];return a||e.push("text_pole","textarea_compact"),e.push(t),e.filter(Boolean).join(" ")},[a,t]);return n.jsx("textarea",{className:o,...r,children:s})};exports.STTextarea=u;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"STTextarea.d.ts","sourceRoot":"","sources":["../../../src/components/react/STTextarea.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,sBAAsB,EAAW,MAAM,OAAO,CAAC;AAE5D,MAAM,WAAW,eAAgB,SAAQ,sBAAsB,CAAC,mBAAmB,CAAC;IAClF;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;;OAGG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED;;;GAGG;AACH,eAAO,MAAM,UAAU,EAAE,EAAE,CAAC,eAAe,CAkB1C,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx as n } from "react/jsx-runtime";
|
|
2
|
+
import { useMemo as m } from "react";
|
|
3
|
+
const l = ({ children: a, className: e, overrideDefaults: o = !1, ...s }) => {
|
|
4
|
+
const r = m(() => {
|
|
5
|
+
const t = [];
|
|
6
|
+
return o || t.push("text_pole", "textarea_compact"), t.push(e), t.filter(Boolean).join(" ");
|
|
7
|
+
}, [o, e]);
|
|
8
|
+
return /* @__PURE__ */ n("textarea", { className: r, ...s, children: a });
|
|
9
|
+
};
|
|
10
|
+
export {
|
|
11
|
+
l as STTextarea
|
|
12
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("./STButton.cjs"),r=require("./STInput.cjs"),S=require("./STSelect.cjs"),n=require("./STTextarea.cjs"),T=require("./Popup.cjs"),c=require("./ConnectionProfileSelect.cjs"),i=require("./STPresetSelect.cjs"),e=require("./STSortableList.cjs"),t=require("./STFancyDropdown.cjs");exports.STButton=o.STButton;exports.STInput=r.STInput;exports.STSelect=S.STSelect;exports.STTextarea=n.STTextarea;exports.Popup=T.Popup;exports.STConnectionProfileSelect=c.STConnectionProfileSelect;exports.STPresetSelect=i.STPresetSelect;exports.STSortableList=e.STSortableList;exports.STSortableListItem=e.STSortableListItem;exports.FancyDropdownItem=t.FancyDropdownItem;exports.STFancyDropdown=t.STFancyDropdown;
|
|
@@ -3,10 +3,11 @@ import { STInput, STInputProps } from './STInput.js';
|
|
|
3
3
|
import { STSelect, STSelectProps } from './STSelect.js';
|
|
4
4
|
import { STTextarea, STTextareaProps } from './STTextarea.js';
|
|
5
5
|
import { Popup } from './Popup.js';
|
|
6
|
-
import { STConnectionProfileSelect, STConnectionProfileSelectProps
|
|
6
|
+
import { STConnectionProfileSelect, STConnectionProfileSelectProps } from './ConnectionProfileSelect.js';
|
|
7
7
|
import { PresetButtonDef, PresetItem, STPresetSelect, STPresetSelectProps } from './STPresetSelect.js';
|
|
8
8
|
import { SortableListItemData, STSortableList, STSortableListItem, STSortableListItemProps, STSortableListProps } from './STSortableList.js';
|
|
9
9
|
import { DropdownItem, FancyDropdownItem, STFancyDropdown, STFancyDropdownProps } from './STFancyDropdown.js';
|
|
10
|
-
|
|
10
|
+
|
|
11
|
+
export { STButton, STInput, STSelect, STTextarea, Popup, STConnectionProfileSelect, STPresetSelect, STSortableList, STSortableListItem, STFancyDropdown, FancyDropdownItem, };
|
|
11
12
|
export type { STButtonProps, STInputProps, STSelectProps, STTextareaProps, STConnectionProfileSelectProps, STPresetSelectProps, PresetItem, PresetButtonDef, STSortableListItemProps, STSortableListProps, SortableListItemData, STFancyDropdownProps, DropdownItem, };
|
|
12
13
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/react/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAE9D,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,yBAAyB,EAAE,8BAA8B,EAAE,MAAM,8BAA8B,CAAC;AACzG,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AACvG,OAAO,EACL,oBAAoB,EACpB,cAAc,EACd,kBAAkB,EAClB,uBAAuB,EACvB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAE9G,OAAO,EACL,QAAQ,EACR,OAAO,EACP,QAAQ,EACR,UAAU,EACV,KAAK,EACL,yBAAyB,EACzB,cAAc,EACd,cAAc,EACd,kBAAkB,EAClB,eAAe,EACf,iBAAiB,GAClB,CAAC;AACF,YAAY,EACV,aAAa,EACb,YAAY,EACZ,aAAa,EACb,eAAe,EACf,8BAA8B,EAC9B,mBAAmB,EACnB,UAAU,EACV,eAAe,EACf,uBAAuB,EACvB,mBAAmB,EACnB,oBAAoB,EACpB,oBAAoB,EACpB,YAAY,GACb,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { STButton as r } from "./STButton.js";
|
|
2
|
+
import { STInput as p } from "./STInput.js";
|
|
3
|
+
import { STSelect as m } from "./STSelect.js";
|
|
4
|
+
import { STTextarea as x } from "./STTextarea.js";
|
|
5
|
+
import { Popup as n } from "./Popup.js";
|
|
6
|
+
import { STConnectionProfileSelect as c } from "./ConnectionProfileSelect.js";
|
|
7
|
+
import { STPresetSelect as i } from "./STPresetSelect.js";
|
|
8
|
+
import { STSortableList as u, STSortableListItem as I } from "./STSortableList.js";
|
|
9
|
+
import { FancyDropdownItem as b, STFancyDropdown as d } from "./STFancyDropdown.js";
|
|
10
|
+
export {
|
|
11
|
+
b as FancyDropdownItem,
|
|
12
|
+
n as Popup,
|
|
13
|
+
r as STButton,
|
|
14
|
+
c as STConnectionProfileSelect,
|
|
15
|
+
d as STFancyDropdown,
|
|
16
|
+
p as STInput,
|
|
17
|
+
i as STPresetSelect,
|
|
18
|
+
m as STSelect,
|
|
19
|
+
u as STSortableList,
|
|
20
|
+
I as STSortableListItem,
|
|
21
|
+
x as STTextarea
|
|
22
|
+
};
|