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.
Files changed (175) hide show
  1. package/dist/character-utils.cjs +1 -0
  2. package/dist/character-utils.d.ts +1 -0
  3. package/dist/character-utils.js +48 -68
  4. package/dist/components/react/ConnectionProfileSelect.cjs +1 -0
  5. package/dist/components/{ConnectionProfileSelect.d.ts → react/ConnectionProfileSelect.d.ts} +2 -3
  6. package/dist/components/react/ConnectionProfileSelect.d.ts.map +1 -0
  7. package/dist/components/react/ConnectionProfileSelect.js +64 -0
  8. package/dist/components/react/Popup.cjs +1 -0
  9. package/dist/components/{Popup.d.ts → react/Popup.d.ts} +3 -2
  10. package/dist/components/react/Popup.d.ts.map +1 -0
  11. package/dist/components/react/Popup.js +180 -0
  12. package/dist/components/react/STButton.cjs +1 -0
  13. package/dist/components/{STButton.d.ts → react/STButton.d.ts} +1 -0
  14. package/dist/components/react/STButton.d.ts.map +1 -0
  15. package/dist/components/react/STButton.js +12 -0
  16. package/dist/components/react/STFancyDropdown.cjs +1 -0
  17. package/dist/components/{STFancyDropdown.d.ts → react/STFancyDropdown.d.ts} +1 -0
  18. package/dist/components/react/STFancyDropdown.d.ts.map +1 -0
  19. package/dist/components/react/STFancyDropdown.js +176 -0
  20. package/dist/components/react/STInput.cjs +1 -0
  21. package/dist/components/{STInput.d.ts → react/STInput.d.ts} +2 -1
  22. package/dist/components/react/STInput.d.ts.map +1 -0
  23. package/dist/components/react/STInput.js +19 -0
  24. package/dist/components/react/STPresetSelect.cjs +1 -0
  25. package/dist/components/{STPresetSelect.d.ts → react/STPresetSelect.d.ts} +1 -0
  26. package/dist/components/react/STPresetSelect.d.ts.map +1 -0
  27. package/dist/components/react/STPresetSelect.js +142 -0
  28. package/dist/components/react/STSelect.cjs +1 -0
  29. package/dist/components/{STSelect.d.ts → react/STSelect.d.ts} +1 -0
  30. package/dist/components/react/STSelect.d.ts.map +1 -0
  31. package/dist/components/react/STSelect.js +12 -0
  32. package/dist/components/react/STSortableList.cjs +1 -0
  33. package/dist/components/{STSortableList.d.ts → react/STSortableList.d.ts} +4 -3
  34. package/dist/components/react/STSortableList.d.ts.map +1 -0
  35. package/dist/components/react/STSortableList.js +148 -0
  36. package/dist/components/react/STTextarea.cjs +1 -0
  37. package/dist/components/{STTextarea.d.ts → react/STTextarea.d.ts} +1 -0
  38. package/dist/components/react/STTextarea.d.ts.map +1 -0
  39. package/dist/components/react/STTextarea.js +12 -0
  40. package/dist/components/react/index.cjs +1 -0
  41. package/dist/components/{index.d.ts → react/index.d.ts} +3 -2
  42. package/dist/components/react/index.d.ts.map +1 -0
  43. package/dist/components/react/index.js +22 -0
  44. package/dist/components/vue/STConnectionProfileSelect.vue.cjs +1 -0
  45. package/dist/components/vue/STConnectionProfileSelect.vue.d.ts +80 -0
  46. package/dist/components/vue/STConnectionProfileSelect.vue.d.ts.map +1 -0
  47. package/dist/components/vue/STConnectionProfileSelect.vue.js +83 -0
  48. package/dist/components/vue/STConnectionProfileSelect.vue2.cjs +1 -0
  49. package/dist/components/vue/STConnectionProfileSelect.vue2.js +4 -0
  50. package/dist/components/vue/index.cjs +1 -0
  51. package/dist/components/vue/index.d.ts +4 -0
  52. package/dist/components/vue/index.d.ts.map +1 -0
  53. package/dist/components/vue/index.js +4 -0
  54. package/dist/config.cjs +1 -0
  55. package/dist/config.d.ts +11 -1
  56. package/dist/config.d.ts.map +1 -1
  57. package/dist/config.js +238 -157
  58. package/dist/extension-settings-manager.cjs +1 -0
  59. package/dist/extension-settings-manager.js +118 -182
  60. package/dist/fancy-dropdown.cjs +1 -0
  61. package/dist/fancy-dropdown.js +244 -524
  62. package/dist/generate.cjs +1 -0
  63. package/dist/generate.d.ts +1 -0
  64. package/dist/generate.js +78 -93
  65. package/dist/index.cjs +1 -0
  66. package/dist/index.d.ts +2 -1
  67. package/dist/index.js +21 -10
  68. package/dist/preset-select.cjs +1 -0
  69. package/dist/preset-select.d.ts +1 -0
  70. package/dist/preset-select.js +124 -235
  71. package/dist/profile-utils.cjs +1 -0
  72. package/dist/profile-utils.d.ts +9 -0
  73. package/dist/profile-utils.d.ts.map +1 -0
  74. package/dist/profile-utils.js +17 -0
  75. package/dist/prompt-builder.cjs +6 -0
  76. package/dist/prompt-builder.d.ts +1 -0
  77. package/dist/prompt-builder.js +370 -516
  78. package/dist/sortable-list.cjs +1 -0
  79. package/dist/sortable-list.d.ts +2 -1
  80. package/dist/sortable-list.js +229 -405
  81. package/dist/tokenizer.cjs +1 -0
  82. package/dist/tokenizer.js +19 -18
  83. package/dist/types/chat-completion.cjs +1 -0
  84. package/dist/types/chat-completion.js +1 -2
  85. package/dist/types/context.cjs +1 -0
  86. package/dist/types/context.js +1 -2
  87. package/dist/types/index.cjs +1 -0
  88. package/dist/types/index.d.ts +6 -0
  89. package/dist/types/index.d.ts.map +1 -1
  90. package/dist/types/index.js +4 -74
  91. package/dist/types/instruct.cjs +1 -0
  92. package/dist/types/instruct.js +1 -2
  93. package/dist/types/popup.cjs +1 -0
  94. package/dist/types/popup.js +5 -15
  95. package/dist/types/profiles.cjs +1 -0
  96. package/dist/types/profiles.js +1 -2
  97. package/dist/types/regex.cjs +1 -0
  98. package/dist/types/regex.js +1 -2
  99. package/dist/types/sysprompt.cjs +1 -0
  100. package/dist/types/sysprompt.js +1 -2
  101. package/dist/types/text-completion.cjs +1 -0
  102. package/dist/types/text-completion.js +1 -2
  103. package/dist/types/translate.cjs +1 -0
  104. package/dist/types/translate.js +4 -8
  105. package/dist/types/world-info.cjs +1 -0
  106. package/dist/types/world-info.js +1 -2
  107. package/dist/vue-shim.d.ts +5 -0
  108. package/dist/world-info-utils.cjs +1 -0
  109. package/dist/world-info-utils.d.ts +1 -0
  110. package/dist/world-info-utils.js +87 -136
  111. package/package.json +50 -23
  112. package/dist/character-utils.js.map +0 -1
  113. package/dist/chat-utils.d.ts +0 -6
  114. package/dist/chat-utils.d.ts.map +0 -1
  115. package/dist/chat-utils.js +0 -14
  116. package/dist/chat-utils.js.map +0 -1
  117. package/dist/components/ConnectionProfileSelect.d.ts.map +0 -1
  118. package/dist/components/ConnectionProfileSelect.js +0 -126
  119. package/dist/components/ConnectionProfileSelect.js.map +0 -1
  120. package/dist/components/MyFancyButton.d.ts +0 -6
  121. package/dist/components/MyFancyButton.d.ts.map +0 -1
  122. package/dist/components/MyFancyButton.js +0 -22
  123. package/dist/components/MyFancyButton.js.map +0 -1
  124. package/dist/components/Popup.d.ts.map +0 -1
  125. package/dist/components/Popup.js +0 -179
  126. package/dist/components/Popup.js.map +0 -1
  127. package/dist/components/STButton.d.ts.map +0 -1
  128. package/dist/components/STButton.js +0 -20
  129. package/dist/components/STButton.js.map +0 -1
  130. package/dist/components/STFancyDropdown.d.ts.map +0 -1
  131. package/dist/components/STFancyDropdown.js +0 -135
  132. package/dist/components/STFancyDropdown.js.map +0 -1
  133. package/dist/components/STInput.d.ts.map +0 -1
  134. package/dist/components/STInput.js +0 -26
  135. package/dist/components/STInput.js.map +0 -1
  136. package/dist/components/STPresetSelect.d.ts.map +0 -1
  137. package/dist/components/STPresetSelect.js +0 -104
  138. package/dist/components/STPresetSelect.js.map +0 -1
  139. package/dist/components/STSelect.d.ts.map +0 -1
  140. package/dist/components/STSelect.js +0 -18
  141. package/dist/components/STSelect.js.map +0 -1
  142. package/dist/components/STSortableList.d.ts.map +0 -1
  143. package/dist/components/STSortableList.js +0 -90
  144. package/dist/components/STSortableList.js.map +0 -1
  145. package/dist/components/STTextarea.d.ts.map +0 -1
  146. package/dist/components/STTextarea.js +0 -18
  147. package/dist/components/STTextarea.js.map +0 -1
  148. package/dist/components/index.d.ts.map +0 -1
  149. package/dist/components/index.js +0 -11
  150. package/dist/components/index.js.map +0 -1
  151. package/dist/config.js.map +0 -1
  152. package/dist/extension-settings-manager.js.map +0 -1
  153. package/dist/fancy-dropdown.js.map +0 -1
  154. package/dist/generate.js.map +0 -1
  155. package/dist/index.js.map +0 -1
  156. package/dist/macro-utils.d.ts +0 -2
  157. package/dist/macro-utils.d.ts.map +0 -1
  158. package/dist/macro-utils.js +0 -2
  159. package/dist/macro-utils.js.map +0 -1
  160. package/dist/preset-select.js.map +0 -1
  161. package/dist/prompt-builder.js.map +0 -1
  162. package/dist/sortable-list.js.map +0 -1
  163. package/dist/tokenizer.js.map +0 -1
  164. package/dist/types/chat-completion.js.map +0 -1
  165. package/dist/types/context.js.map +0 -1
  166. package/dist/types/index.js.map +0 -1
  167. package/dist/types/instruct.js.map +0 -1
  168. package/dist/types/popup.js.map +0 -1
  169. package/dist/types/profiles.js.map +0 -1
  170. package/dist/types/regex.js.map +0 -1
  171. package/dist/types/sysprompt.js.map +0 -1
  172. package/dist/types/text-completion.js.map +0 -1
  173. package/dist/types/translate.js.map +0 -1
  174. package/dist/types/world-info.js.map +0 -1
  175. 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, { FC, InputHTMLAttributes } from '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;
@@ -1,4 +1,5 @@
1
1
  import { FC } from 'react';
2
+
2
3
  export interface PresetItem {
3
4
  value: string;
4
5
  label: string;
@@ -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;
@@ -1,4 +1,5 @@
1
1
  import { FC, SelectHTMLAttributes } from 'react';
2
+
2
3
  export interface STSelectProps extends SelectHTMLAttributes<HTMLSelectElement> {
3
4
  /**
4
5
  * Custom class name(s) to append or replace the default 'text_pole' class.
@@ -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, { FC } from 'react';
2
- import Sortable from 'sortablejs';
3
- import { DropdownItem } from '../fancy-dropdown.js';
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;
@@ -1,4 +1,5 @@
1
1
  import { FC, TextareaHTMLAttributes } from 'react';
2
+
2
3
  export interface STTextareaProps extends TextareaHTMLAttributes<HTMLTextAreaElement> {
3
4
  /**
4
5
  * Custom class name(s) to append or replace the default SillyTavern classes.
@@ -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, isProfileSupported } from './ConnectionProfileSelect.js';
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
- export { STButton, STInput, STSelect, STTextarea, Popup, STConnectionProfileSelect, isProfileSupported, STPresetSelect, STSortableList, STSortableListItem, STFancyDropdown, FancyDropdownItem, };
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
+ };