genassist-chat-react 1.0.8 → 1.0.9
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/components/ChatMessage.d.ts +2 -8
- package/dist/components/ChatMessage.js +6 -60
- package/dist/components/GenAgentChat.js +26 -12
- package/dist/components/GenAgentConfigPanel.d.ts +24 -0
- package/dist/components/GenAgentConfigPanel.js +360 -0
- package/dist/components/Spinner.d.ts +7 -0
- package/dist/components/Spinner.js +8 -0
- package/dist/components/VoiceInput.js +6 -9
- package/dist/hooks/useChat.js +47 -20
- package/dist/index.d.ts +2 -0
- package/dist/index.js +2 -1
- package/dist/services/chatService.d.ts +3 -1
- package/dist/services/chatService.js +19 -10
- package/dist/types/index.d.ts +13 -8
- package/dist/types/index.js +1 -1
- package/dist/utils/fileIcons.d.ts +4 -0
- package/dist/utils/fileIcons.js +15 -0
- package/dist/utils/time.d.ts +4 -0
- package/dist/utils/time.js +36 -0
- package/package.json +1 -1
|
@@ -0,0 +1,360 @@
|
|
|
1
|
+
var __assign = (this && this.__assign) || function () {
|
|
2
|
+
__assign = Object.assign || function(t) {
|
|
3
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
4
|
+
s = arguments[i];
|
|
5
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
6
|
+
t[p] = s[p];
|
|
7
|
+
}
|
|
8
|
+
return t;
|
|
9
|
+
};
|
|
10
|
+
return __assign.apply(this, arguments);
|
|
11
|
+
};
|
|
12
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
13
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
14
|
+
if (ar || !(i in from)) {
|
|
15
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
16
|
+
ar[i] = from[i];
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
20
|
+
};
|
|
21
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
22
|
+
import { useEffect, useMemo, useState } from 'react';
|
|
23
|
+
import { ChevronDown, ChevronUp, Plus, Trash2, Pencil } from 'lucide-react';
|
|
24
|
+
var defaultTheme = {
|
|
25
|
+
primaryColor: '#4F46E5',
|
|
26
|
+
secondaryColor: '#f5f5f5',
|
|
27
|
+
backgroundColor: '#ffffff',
|
|
28
|
+
textColor: '#000000',
|
|
29
|
+
fontFamily: 'Inter, sans-serif',
|
|
30
|
+
fontSize: '15px',
|
|
31
|
+
};
|
|
32
|
+
var defaultSettings = {
|
|
33
|
+
name: 'Genassist',
|
|
34
|
+
description: 'Support',
|
|
35
|
+
};
|
|
36
|
+
function objectToParams(obj) {
|
|
37
|
+
if (!obj)
|
|
38
|
+
return [];
|
|
39
|
+
return Object.keys(obj).map(function (k) {
|
|
40
|
+
var v = obj[k];
|
|
41
|
+
var type = 'string';
|
|
42
|
+
if (typeof v === 'number')
|
|
43
|
+
type = 'number';
|
|
44
|
+
else if (typeof v === 'boolean')
|
|
45
|
+
type = 'boolean';
|
|
46
|
+
return { name: k, type: type, required: false, value: v };
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
function paramsToObject(params) {
|
|
50
|
+
var o = {};
|
|
51
|
+
params.forEach(function (p) {
|
|
52
|
+
if (typeof p.value !== 'undefined') {
|
|
53
|
+
o[p.name] = p.value;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
return o;
|
|
57
|
+
}
|
|
58
|
+
export var GenAgentConfigPanel = function (_a) {
|
|
59
|
+
var _b, _c;
|
|
60
|
+
var themeProp = _a.theme, onThemeChange = _a.onThemeChange, chatSettingsProp = _a.chatSettings, onChatSettingsChange = _a.onChatSettingsChange, metadataProp = _a.metadata, onMetadataChange = _a.onMetadataChange, defaultOpen = _a.defaultOpen, onSave = _a.onSave, onCancel = _a.onCancel, style = _a.style;
|
|
61
|
+
// Controlled or internal state fallbacks
|
|
62
|
+
var _d = useState(themeProp || defaultTheme), theme = _d[0], setTheme = _d[1];
|
|
63
|
+
var _e = useState(chatSettingsProp || defaultSettings), chatSettings = _e[0], setChatSettings = _e[1];
|
|
64
|
+
var _f = useState(objectToParams(metadataProp)), params = _f[0], setParams = _f[1];
|
|
65
|
+
useEffect(function () {
|
|
66
|
+
if (themeProp)
|
|
67
|
+
setTheme(themeProp);
|
|
68
|
+
}, [themeProp]);
|
|
69
|
+
useEffect(function () {
|
|
70
|
+
if (chatSettingsProp)
|
|
71
|
+
setChatSettings(chatSettingsProp);
|
|
72
|
+
}, [chatSettingsProp]);
|
|
73
|
+
useEffect(function () {
|
|
74
|
+
if (metadataProp)
|
|
75
|
+
setParams(objectToParams(metadataProp));
|
|
76
|
+
}, [metadataProp]);
|
|
77
|
+
var _g = useState(typeof (defaultOpen === null || defaultOpen === void 0 ? void 0 : defaultOpen.appearance) === 'boolean' ? !!(defaultOpen === null || defaultOpen === void 0 ? void 0 : defaultOpen.appearance) : true), showAppearance = _g[0], setShowAppearance = _g[1];
|
|
78
|
+
var _h = useState(typeof (defaultOpen === null || defaultOpen === void 0 ? void 0 : defaultOpen.settings) === 'boolean' ? !!(defaultOpen === null || defaultOpen === void 0 ? void 0 : defaultOpen.settings) : false), showSettings = _h[0], setShowSettings = _h[1];
|
|
79
|
+
var _j = useState(typeof (defaultOpen === null || defaultOpen === void 0 ? void 0 : defaultOpen.metadata) === 'boolean' ? !!(defaultOpen === null || defaultOpen === void 0 ? void 0 : defaultOpen.metadata) : false), showMetadata = _j[0], setShowMetadata = _j[1];
|
|
80
|
+
var _k = useState(false), showAddParam = _k[0], setShowAddParam = _k[1];
|
|
81
|
+
var _l = useState({
|
|
82
|
+
name: 'param_1',
|
|
83
|
+
type: 'string',
|
|
84
|
+
required: false,
|
|
85
|
+
value: '',
|
|
86
|
+
}), draftParam = _l[0], setDraftParam = _l[1];
|
|
87
|
+
var _m = useState(false), showEditParam = _m[0], setShowEditParam = _m[1];
|
|
88
|
+
var _o = useState(null), editIndex = _o[0], setEditIndex = _o[1];
|
|
89
|
+
var _p = useState({ name: '', type: 'string', required: false, value: '' }), editDraft = _p[0], setEditDraft = _p[1];
|
|
90
|
+
var metadata = useMemo(function () { return paramsToObject(params); }, [params]);
|
|
91
|
+
var handleThemeChange = function (key, value) {
|
|
92
|
+
var _a;
|
|
93
|
+
var next = __assign(__assign({}, theme), (_a = {}, _a[key] = value, _a));
|
|
94
|
+
if (!themeProp)
|
|
95
|
+
setTheme(next);
|
|
96
|
+
onThemeChange === null || onThemeChange === void 0 ? void 0 : onThemeChange(next);
|
|
97
|
+
};
|
|
98
|
+
var handleSettingChange = function (key, value) {
|
|
99
|
+
var _a;
|
|
100
|
+
var next = __assign(__assign({}, chatSettings), (_a = {}, _a[key] = value, _a));
|
|
101
|
+
if (!chatSettingsProp)
|
|
102
|
+
setChatSettings(next);
|
|
103
|
+
onChatSettingsChange === null || onChatSettingsChange === void 0 ? void 0 : onChatSettingsChange(next);
|
|
104
|
+
};
|
|
105
|
+
var handleAddParam = function () {
|
|
106
|
+
var name = draftParam.name.trim();
|
|
107
|
+
if (!name)
|
|
108
|
+
return;
|
|
109
|
+
if (params.some(function (p) { return p.name === name; }))
|
|
110
|
+
return;
|
|
111
|
+
var normalized = __assign(__assign({}, draftParam), { name: name, value: typeof draftParam.value !== 'undefined'
|
|
112
|
+
? draftParam.value
|
|
113
|
+
: draftParam.type === 'number'
|
|
114
|
+
? 0
|
|
115
|
+
: draftParam.type === 'boolean'
|
|
116
|
+
? false
|
|
117
|
+
: '' });
|
|
118
|
+
var next = __spreadArray(__spreadArray([], params, true), [normalized], false);
|
|
119
|
+
setParams(next);
|
|
120
|
+
onMetadataChange === null || onMetadataChange === void 0 ? void 0 : onMetadataChange(paramsToObject(next));
|
|
121
|
+
setDraftParam({ name: 'param_1', type: 'string', required: false, value: '' });
|
|
122
|
+
setShowAddParam(false);
|
|
123
|
+
};
|
|
124
|
+
var coerceForType = function (val, type) {
|
|
125
|
+
if (type === 'number') {
|
|
126
|
+
var n = Number(val);
|
|
127
|
+
return isNaN(n) ? 0 : n;
|
|
128
|
+
}
|
|
129
|
+
if (type === 'boolean') {
|
|
130
|
+
if (typeof val === 'boolean')
|
|
131
|
+
return val;
|
|
132
|
+
var s = String(val).toLowerCase();
|
|
133
|
+
return s === 'true' || s === '1' || s === 'yes';
|
|
134
|
+
}
|
|
135
|
+
return String(val !== null && val !== void 0 ? val : '');
|
|
136
|
+
};
|
|
137
|
+
var handleEditSave = function () {
|
|
138
|
+
if (editIndex === null)
|
|
139
|
+
return;
|
|
140
|
+
var newName = editDraft.name.trim();
|
|
141
|
+
if (!newName)
|
|
142
|
+
return;
|
|
143
|
+
if (params.some(function (p, i) { return i !== editIndex && p.name === newName; }))
|
|
144
|
+
return;
|
|
145
|
+
var next = __spreadArray([], params, true);
|
|
146
|
+
var old = next[editIndex];
|
|
147
|
+
var updated = __assign(__assign({}, old), editDraft);
|
|
148
|
+
updated.value = coerceForType(old.value, editDraft.type);
|
|
149
|
+
next[editIndex] = updated;
|
|
150
|
+
setParams(next);
|
|
151
|
+
onMetadataChange === null || onMetadataChange === void 0 ? void 0 : onMetadataChange(paramsToObject(next));
|
|
152
|
+
setShowEditParam(false);
|
|
153
|
+
setEditIndex(null);
|
|
154
|
+
};
|
|
155
|
+
var handleRemoveParam = function (index) {
|
|
156
|
+
var next = params.filter(function (_, i) { return i !== index; });
|
|
157
|
+
setParams(next);
|
|
158
|
+
onMetadataChange === null || onMetadataChange === void 0 ? void 0 : onMetadataChange(paramsToObject(next));
|
|
159
|
+
};
|
|
160
|
+
var containerStyle = __assign({ flex: '1', maxWidth: 300, backgroundColor: '#ffffff', borderRadius: 8, boxShadow: '0 2px 10px rgba(0,0,0,0.1)', overflow: 'hidden', display: 'flex', flexDirection: 'column' }, style);
|
|
161
|
+
var sectionHeaderStyle = {
|
|
162
|
+
padding: 16,
|
|
163
|
+
borderBottom: '1px solid #e0e0e0',
|
|
164
|
+
display: 'flex',
|
|
165
|
+
justifyContent: 'space-between',
|
|
166
|
+
alignItems: 'center',
|
|
167
|
+
cursor: 'pointer',
|
|
168
|
+
backgroundColor: '#f9f9f9',
|
|
169
|
+
};
|
|
170
|
+
var sectionTitleStyle = {
|
|
171
|
+
margin: 0,
|
|
172
|
+
fontSize: 12,
|
|
173
|
+
fontWeight: 'bold',
|
|
174
|
+
color: '#666',
|
|
175
|
+
letterSpacing: 1,
|
|
176
|
+
};
|
|
177
|
+
var formGroupStyle = {
|
|
178
|
+
padding: '16px 16px 12px',
|
|
179
|
+
display: 'flex',
|
|
180
|
+
flexDirection: 'row',
|
|
181
|
+
justifyContent: 'space-between',
|
|
182
|
+
alignItems: 'center',
|
|
183
|
+
borderBottom: 'none',
|
|
184
|
+
};
|
|
185
|
+
var labelStyle = { fontSize: 14, color: '#333' };
|
|
186
|
+
var colorPickerStyle = {
|
|
187
|
+
appearance: 'none',
|
|
188
|
+
width: 120,
|
|
189
|
+
height: 32,
|
|
190
|
+
padding: 0,
|
|
191
|
+
border: '1px solid #e0e0e0',
|
|
192
|
+
borderRadius: 4,
|
|
193
|
+
cursor: 'pointer',
|
|
194
|
+
};
|
|
195
|
+
var selectStyle = {
|
|
196
|
+
width: 140,
|
|
197
|
+
height: 32,
|
|
198
|
+
padding: '0 8px',
|
|
199
|
+
border: '1px solid #e0e0e0',
|
|
200
|
+
borderRadius: 4,
|
|
201
|
+
backgroundColor: '#fff',
|
|
202
|
+
fontSize: 14,
|
|
203
|
+
};
|
|
204
|
+
var inputStyle = {
|
|
205
|
+
width: '100%',
|
|
206
|
+
height: 32,
|
|
207
|
+
padding: '0 8px',
|
|
208
|
+
border: '1px solid #e0e0e0',
|
|
209
|
+
borderRadius: 4,
|
|
210
|
+
fontSize: 14,
|
|
211
|
+
};
|
|
212
|
+
var actionBarStyle = {
|
|
213
|
+
padding: 12,
|
|
214
|
+
display: 'flex',
|
|
215
|
+
justifyContent: 'flex-end',
|
|
216
|
+
gap: 8,
|
|
217
|
+
borderTop: '1px solid #e0e0e0',
|
|
218
|
+
backgroundColor: '#fafafa',
|
|
219
|
+
};
|
|
220
|
+
var cancelButtonStyle = {
|
|
221
|
+
padding: '8px 12px',
|
|
222
|
+
backgroundColor: '#fff',
|
|
223
|
+
border: '1px solid #e0e0e0',
|
|
224
|
+
borderRadius: 6,
|
|
225
|
+
cursor: 'pointer',
|
|
226
|
+
};
|
|
227
|
+
var saveButtonStyle = {
|
|
228
|
+
padding: '8px 12px',
|
|
229
|
+
backgroundColor: '#111827',
|
|
230
|
+
color: '#fff',
|
|
231
|
+
border: '1px solid #0b1220',
|
|
232
|
+
borderRadius: 6,
|
|
233
|
+
cursor: 'pointer',
|
|
234
|
+
};
|
|
235
|
+
var fullWidthActionButton = {
|
|
236
|
+
display: 'flex',
|
|
237
|
+
alignItems: 'center',
|
|
238
|
+
gap: 8,
|
|
239
|
+
width: '100%',
|
|
240
|
+
padding: '10px 12px',
|
|
241
|
+
border: '1px solid #e0e0e0',
|
|
242
|
+
borderRadius: 8,
|
|
243
|
+
backgroundColor: '#fff',
|
|
244
|
+
cursor: 'pointer',
|
|
245
|
+
fontSize: 14,
|
|
246
|
+
color: '#111',
|
|
247
|
+
};
|
|
248
|
+
var smallIconButton = {
|
|
249
|
+
border: '1px solid #e0e0e0',
|
|
250
|
+
borderRadius: 8,
|
|
251
|
+
width: 28,
|
|
252
|
+
height: 28,
|
|
253
|
+
display: 'inline-flex',
|
|
254
|
+
alignItems: 'center',
|
|
255
|
+
justifyContent: 'center',
|
|
256
|
+
backgroundColor: '#fff',
|
|
257
|
+
cursor: 'pointer',
|
|
258
|
+
};
|
|
259
|
+
var metaRowStyle = {
|
|
260
|
+
display: 'grid',
|
|
261
|
+
gridTemplateColumns: '1fr minmax(90px, 150px) 28px 28px',
|
|
262
|
+
alignItems: 'center',
|
|
263
|
+
gap: 8,
|
|
264
|
+
padding: '6px 0',
|
|
265
|
+
};
|
|
266
|
+
var metaNameStyle = {
|
|
267
|
+
fontSize: 13,
|
|
268
|
+
color: '#222',
|
|
269
|
+
fontWeight: 500,
|
|
270
|
+
overflow: 'hidden',
|
|
271
|
+
textOverflow: 'ellipsis',
|
|
272
|
+
whiteSpace: 'nowrap',
|
|
273
|
+
};
|
|
274
|
+
var metaValueStyle = {
|
|
275
|
+
maxWidth: 150,
|
|
276
|
+
overflow: 'hidden',
|
|
277
|
+
textOverflow: 'ellipsis',
|
|
278
|
+
whiteSpace: 'nowrap',
|
|
279
|
+
fontSize: 13,
|
|
280
|
+
color: '#111',
|
|
281
|
+
border: '1px solid #e6e6e6',
|
|
282
|
+
borderRadius: 12,
|
|
283
|
+
padding: '6px 10px',
|
|
284
|
+
backgroundColor: '#fafafa',
|
|
285
|
+
};
|
|
286
|
+
var handleSave = function () {
|
|
287
|
+
onSave === null || onSave === void 0 ? void 0 : onSave({ theme: theme, chatSettings: chatSettings, metadata: metadata });
|
|
288
|
+
};
|
|
289
|
+
return (_jsxs("div", { style: containerStyle, children: [_jsxs("div", { style: { borderBottom: '1px solid #e0e0e0' }, children: [_jsxs("div", { style: sectionHeaderStyle, onClick: function () { return setShowAppearance(!showAppearance); }, children: [_jsx("h3", { style: sectionTitleStyle, children: "APPEARANCE" }), showAppearance ? _jsx(ChevronUp, { size: 16 }) : _jsx(ChevronDown, { size: 16 })] }), showAppearance && (_jsxs(_Fragment, { children: [_jsxs("div", { style: formGroupStyle, children: [_jsx("label", { style: labelStyle, children: "Primary Color" }), _jsx("input", { type: "color", value: theme.primaryColor, onChange: function (e) { return handleThemeChange('primaryColor', e.target.value); }, style: colorPickerStyle })] }), _jsxs("div", { style: formGroupStyle, children: [_jsx("label", { style: labelStyle, children: "Secondary Color" }), _jsx("input", { type: "color", value: theme.secondaryColor, onChange: function (e) { return handleThemeChange('secondaryColor', e.target.value); }, style: colorPickerStyle })] }), _jsxs("div", { style: formGroupStyle, children: [_jsx("label", { style: labelStyle, children: "Background Color" }), _jsx("input", { type: "color", value: theme.backgroundColor, onChange: function (e) { return handleThemeChange('backgroundColor', e.target.value); }, style: colorPickerStyle })] }), _jsxs("div", { style: formGroupStyle, children: [_jsx("label", { style: labelStyle, children: "Text Color" }), _jsx("input", { type: "color", value: theme.textColor, onChange: function (e) { return handleThemeChange('textColor', e.target.value); }, style: colorPickerStyle })] }), _jsxs("div", { style: formGroupStyle, children: [_jsx("label", { style: labelStyle, children: "Font Size" }), _jsxs("select", { style: selectStyle, value: theme.fontSize, onChange: function (e) { return handleThemeChange('fontSize', e.target.value); }, children: [_jsx("option", { value: "12px", children: "Small (12px)" }), _jsx("option", { value: "15px", children: "Medium (15px)" }), _jsx("option", { value: "18px", children: "Large (18px)" })] })] }), _jsxs("div", { style: formGroupStyle, children: [_jsx("label", { style: labelStyle, children: "Font Family" }), _jsxs("select", { style: selectStyle, value: theme.fontFamily.split(',')[0].trim(), onChange: function (e) {
|
|
290
|
+
var v = e.target.value;
|
|
291
|
+
var ff = v === 'Inter'
|
|
292
|
+
? 'Inter, sans-serif'
|
|
293
|
+
: v === 'Arial'
|
|
294
|
+
? 'Arial, sans-serif'
|
|
295
|
+
: v === 'Times New Roman'
|
|
296
|
+
? "'Times New Roman', serif"
|
|
297
|
+
: 'monospace';
|
|
298
|
+
handleThemeChange('fontFamily', ff);
|
|
299
|
+
}, children: [_jsx("option", { value: "Inter", children: "Inter" }), _jsx("option", { value: "Arial", children: "Arial" }), _jsx("option", { value: "Times New Roman", children: "Times New Roman" }), _jsx("option", { value: "monospace", children: "Monospace" })] })] })] }))] }), _jsxs("div", { children: [_jsxs("div", { style: sectionHeaderStyle, onClick: function () { return setShowSettings(!showSettings); }, children: [_jsx("h3", { style: sectionTitleStyle, children: "SETTINGS" }), showSettings ? _jsx(ChevronUp, { size: 16 }) : _jsx(ChevronDown, { size: 16 })] }), showSettings && (_jsxs(_Fragment, { children: [_jsxs("div", { style: { padding: '16px 16px 12px' }, children: [_jsx("label", { style: __assign(__assign({}, labelStyle), { display: 'block', marginBottom: 8 }), children: "Name" }), _jsx("input", { type: "text", style: __assign(__assign({}, inputStyle), { height: 40, padding: '0 12px', boxSizing: 'border-box' }), value: chatSettings.name, onChange: function (e) { return handleSettingChange('name', e.target.value); } })] }), _jsxs("div", { style: { padding: '0 16px 16px' }, children: [_jsx("label", { style: __assign(__assign({}, labelStyle), { display: 'block', marginBottom: 8 }), children: "Description" }), _jsx("input", { type: "text", style: __assign(__assign({}, inputStyle), { height: 40, padding: '0 12px', boxSizing: 'border-box' }), value: chatSettings.description, onChange: function (e) { return handleSettingChange('description', e.target.value); } })] })] }))] }), _jsxs("div", { children: [_jsxs("div", { style: sectionHeaderStyle, onClick: function () { return setShowMetadata(!showMetadata); }, children: [_jsx("h3", { style: sectionTitleStyle, children: "METADATA" }), showMetadata ? _jsx(ChevronUp, { size: 16 }) : _jsx(ChevronDown, { size: 16 })] }), showMetadata && (_jsxs(_Fragment, { children: [_jsxs("div", { style: { padding: '12px 16px' }, children: [_jsx("div", { style: { fontSize: 13, color: '#555', marginBottom: 10 }, children: "Define key/value parameters sent as chat metadata." }), _jsxs("button", { style: fullWidthActionButton, onClick: function () { return setShowAddParam(true); }, children: [_jsx(Plus, { size: 18 }), _jsx("span", { children: "Add Parameter" })] })] }), params.length > 0 && (_jsx("div", { style: { padding: '2px 16px 12px', display: 'flex', flexDirection: 'column', gap: 6 }, children: params.map(function (p, idx) {
|
|
300
|
+
var _a;
|
|
301
|
+
var displayVal = p.type === 'boolean' ? (p.value ? 'True' : 'False') : String((_a = p.value) !== null && _a !== void 0 ? _a : '');
|
|
302
|
+
return (_jsxs("div", { style: metaRowStyle, children: [_jsx("div", { style: metaNameStyle, children: p.name }), _jsx("div", { style: metaValueStyle, title: displayVal, children: displayVal }), _jsx("button", { title: "Edit", style: smallIconButton, onClick: function () {
|
|
303
|
+
setEditIndex(idx);
|
|
304
|
+
setEditDraft(__assign({}, p));
|
|
305
|
+
setShowEditParam(true);
|
|
306
|
+
}, "aria-label": "Edit ".concat(p.name), children: _jsx(Pencil, { size: 16 }) }), _jsx("button", { title: "Remove", style: smallIconButton, onClick: function () { return handleRemoveParam(idx); }, "aria-label": "Remove ".concat(p.name), children: _jsx(Trash2, { size: 16 }) })] }, p.name));
|
|
307
|
+
}) }))] }))] }), _jsxs("div", { style: actionBarStyle, children: [_jsx("button", { style: cancelButtonStyle, onClick: function () { return onCancel === null || onCancel === void 0 ? void 0 : onCancel(); }, children: "Cancel" }), _jsx("button", { style: saveButtonStyle, onClick: handleSave, children: "Save Changes" })] }), showAddParam && (_jsx("div", { style: modalOverlayStyle, children: _jsxs("div", { style: modalStyle, children: [_jsx("div", { style: modalHeaderStyle, children: "Add Parameter" }), _jsxs("div", { style: modalBodyStyle, children: [_jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: 6 }, children: [_jsx("label", { style: { fontSize: 12, color: '#777' }, children: "Parameter Name" }), _jsx("input", { type: "text", style: inputStyle, value: draftParam.name, onChange: function (e) { return setDraftParam(function (d) { return (__assign(__assign({}, d), { name: e.target.value })); }); }, placeholder: "param_1" })] }), _jsxs("div", { style: { display: 'flex', gap: 12 }, children: [_jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: 6, flex: 1 }, children: [_jsx("label", { style: { fontSize: 12, color: '#777' }, children: "Type" }), _jsxs("select", { style: selectStyle, value: draftParam.type, onChange: function (e) {
|
|
308
|
+
return setDraftParam(function (d) { return (__assign(__assign({}, d), { type: e.target.value, value: e.target.value === 'boolean' ? false : e.target.value === 'number' ? 0 : '' })); });
|
|
309
|
+
}, children: [_jsx("option", { value: "string", children: "String" }), _jsx("option", { value: "number", children: "Number" }), _jsx("option", { value: "boolean", children: "Boolean" })] })] }), _jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: 6, flex: 1 }, children: [_jsx("label", { style: { fontSize: 12, color: '#777' }, children: "Required" }), _jsxs("select", { style: selectStyle, value: draftParam.required ? 'yes' : 'no', onChange: function (e) { return setDraftParam(function (d) { return (__assign(__assign({}, d), { required: e.target.value === 'yes' })); }); }, children: [_jsx("option", { value: "no", children: "No" }), _jsx("option", { value: "yes", children: "Yes" })] })] })] }), _jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: 6 }, children: [_jsx("label", { style: { fontSize: 12, color: '#777' }, children: "Default / Value" }), draftParam.type === 'boolean' ? (_jsxs("select", { style: selectStyle, value: draftParam.value ? 'true' : 'false', onChange: function (e) { return setDraftParam(function (d) { return (__assign(__assign({}, d), { value: e.target.value === 'true' })); }); }, children: [_jsx("option", { value: "false", children: "False" }), _jsx("option", { value: "true", children: "True" })] })) : (_jsx("input", { type: draftParam.type === 'number' ? 'number' : 'text', style: inputStyle, value: String((_b = draftParam.value) !== null && _b !== void 0 ? _b : ''), onChange: function (e) {
|
|
310
|
+
return setDraftParam(function (d) { return (__assign(__assign({}, d), { value: draftParam.type === 'number' ? Number(e.target.value) : e.target.value })); });
|
|
311
|
+
} }))] })] }), _jsxs("div", { style: modalFooterStyle, children: [_jsx("button", { style: cancelButtonStyle, onClick: function () { return setShowAddParam(false); }, children: "Cancel" }), _jsx("button", { style: saveButtonStyle, onClick: handleAddParam, children: "Add" })] })] }) })), showEditParam && (_jsx("div", { style: modalOverlayStyle, children: _jsxs("div", { style: modalStyle, children: [_jsx("div", { style: modalHeaderStyle, children: "Edit Parameter" }), _jsxs("div", { style: modalBodyStyle, children: [_jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: 6 }, children: [_jsx("label", { style: { fontSize: 12, color: '#777' }, children: "Parameter Name" }), _jsx("input", { type: "text", style: inputStyle, value: editDraft.name, onChange: function (e) { return setEditDraft(function (d) { return (__assign(__assign({}, d), { name: e.target.value })); }); } })] }), _jsxs("div", { style: { display: 'flex', gap: 12 }, children: [_jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: 6, flex: 1 }, children: [_jsx("label", { style: { fontSize: 12, color: '#777' }, children: "Type" }), _jsxs("select", { style: selectStyle, value: editDraft.type, onChange: function (e) {
|
|
312
|
+
return setEditDraft(function (d) { return (__assign(__assign({}, d), { type: e.target.value, value: e.target.value === 'boolean'
|
|
313
|
+
? false
|
|
314
|
+
: e.target.value === 'number'
|
|
315
|
+
? 0
|
|
316
|
+
: typeof d.value === 'string'
|
|
317
|
+
? d.value
|
|
318
|
+
: '' })); });
|
|
319
|
+
}, children: [_jsx("option", { value: "string", children: "String" }), _jsx("option", { value: "number", children: "Number" }), _jsx("option", { value: "boolean", children: "Boolean" })] })] }), _jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: 6, flex: 1 }, children: [_jsx("label", { style: { fontSize: 12, color: '#777' }, children: "Required" }), _jsxs("select", { style: selectStyle, value: editDraft.required ? 'yes' : 'no', onChange: function (e) { return setEditDraft(function (d) { return (__assign(__assign({}, d), { required: e.target.value === 'yes' })); }); }, children: [_jsx("option", { value: "no", children: "No" }), _jsx("option", { value: "yes", children: "Yes" })] })] })] }), _jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: 6 }, children: [_jsx("label", { style: { fontSize: 12, color: '#777' }, children: "Value" }), editDraft.type === 'boolean' ? (_jsxs("select", { style: selectStyle, value: editDraft.value ? 'true' : 'false', onChange: function (e) { return setEditDraft(function (d) { return (__assign(__assign({}, d), { value: e.target.value === 'true' })); }); }, children: [_jsx("option", { value: "false", children: "False" }), _jsx("option", { value: "true", children: "True" })] })) : (_jsx("input", { type: editDraft.type === 'number' ? 'number' : 'text', style: inputStyle, value: String((_c = editDraft.value) !== null && _c !== void 0 ? _c : ''), onChange: function (e) {
|
|
320
|
+
return setEditDraft(function (d) { return (__assign(__assign({}, d), { value: editDraft.type === 'number' ? Number(e.target.value) : e.target.value })); });
|
|
321
|
+
} }))] })] }), _jsxs("div", { style: modalFooterStyle, children: [_jsx("button", { style: cancelButtonStyle, onClick: function () { return setShowEditParam(false); }, children: "Cancel" }), _jsx("button", { style: saveButtonStyle, onClick: handleEditSave, children: "Save" })] })] }) }))] }));
|
|
322
|
+
};
|
|
323
|
+
// Modal styles (shared)
|
|
324
|
+
var modalOverlayStyle = {
|
|
325
|
+
position: 'fixed',
|
|
326
|
+
inset: 0,
|
|
327
|
+
backgroundColor: 'rgba(0,0,0,0.25)',
|
|
328
|
+
display: 'flex',
|
|
329
|
+
alignItems: 'center',
|
|
330
|
+
justifyContent: 'center',
|
|
331
|
+
zIndex: 9999,
|
|
332
|
+
};
|
|
333
|
+
var modalStyle = {
|
|
334
|
+
width: 420,
|
|
335
|
+
maxWidth: '92vw',
|
|
336
|
+
backgroundColor: '#fff',
|
|
337
|
+
borderRadius: 12,
|
|
338
|
+
boxShadow: '0 8px 24px rgba(0,0,0,0.18)',
|
|
339
|
+
overflow: 'hidden',
|
|
340
|
+
};
|
|
341
|
+
var modalHeaderStyle = {
|
|
342
|
+
padding: '12px 16px',
|
|
343
|
+
fontWeight: 600,
|
|
344
|
+
borderBottom: '1px solid #eee',
|
|
345
|
+
};
|
|
346
|
+
var modalBodyStyle = {
|
|
347
|
+
padding: 16,
|
|
348
|
+
display: 'flex',
|
|
349
|
+
flexDirection: 'column',
|
|
350
|
+
gap: 12,
|
|
351
|
+
};
|
|
352
|
+
var modalFooterStyle = {
|
|
353
|
+
padding: 12,
|
|
354
|
+
display: 'flex',
|
|
355
|
+
justifyContent: 'flex-end',
|
|
356
|
+
gap: 8,
|
|
357
|
+
borderTop: '1px solid #eee',
|
|
358
|
+
backgroundColor: '#fafafa',
|
|
359
|
+
};
|
|
360
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GenAgentConfigPanel.js","sourceRoot":"","sources":["../../src/components/GenAgentConfigPanel.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA,OAAc,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5D,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAe,MAAM,cAAc,CAAC;AA8BzF,IAAM,YAAY,GAAc;IAC9B,YAAY,EAAE,SAAS;IACvB,cAAc,EAAE,SAAS;IACzB,eAAe,EAAE,SAAS;IAC1B,SAAS,EAAE,SAAS;IACpB,UAAU,EAAE,mBAAmB;IAC/B,QAAQ,EAAE,MAAM;CACjB,CAAC;AAEF,IAAM,eAAe,GAAuB;IAC1C,IAAI,EAAE,WAAW;IACjB,WAAW,EAAE,SAAS;CACvB,CAAC;AAEF,SAAS,cAAc,CAAC,GAAoC;IAC1D,IAAI,CAAC,GAAG;QAAE,OAAO,EAAE,CAAC;IACpB,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,UAAC,CAAC;QAC5B,IAAM,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QACjB,IAAI,IAAI,GAAc,QAAQ,CAAC;QAC/B,IAAI,OAAO,CAAC,KAAK,QAAQ;YAAE,IAAI,GAAG,QAAQ,CAAC;aACtC,IAAI,OAAO,CAAC,KAAK,SAAS;YAAE,IAAI,GAAG,SAAS,CAAC;QAClD,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,MAAA,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;IACtD,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,cAAc,CAAC,MAAuB;IAC7C,IAAM,CAAC,GAAwB,EAAE,CAAC;IAClC,MAAM,CAAC,OAAO,CAAC,UAAC,CAAC;QACf,IAAI,OAAO,CAAC,CAAC,KAAK,KAAK,WAAW,EAAE,CAAC;YACnC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;QACtB,CAAC;IACH,CAAC,CAAC,CAAC;IACH,OAAO,CAAC,CAAC;AACX,CAAC;AAED,MAAM,CAAC,IAAM,mBAAmB,GAAuC,UAAC,EAWvE;;QAVQ,SAAS,WAAA,EAChB,aAAa,mBAAA,EACC,gBAAgB,kBAAA,EAC9B,oBAAoB,0BAAA,EACV,YAAY,cAAA,EACtB,gBAAgB,sBAAA,EAChB,WAAW,iBAAA,EACX,MAAM,YAAA,EACN,QAAQ,cAAA,EACR,KAAK,WAAA;IAEL,yCAAyC;IACnC,IAAA,KAAoB,QAAQ,CAAY,SAAS,IAAI,YAAY,CAAC,EAAjE,KAAK,QAAA,EAAE,QAAQ,QAAkD,CAAC;IACnE,IAAA,KAAkC,QAAQ,CAAqB,gBAAgB,IAAI,eAAe,CAAC,EAAlG,YAAY,QAAA,EAAE,eAAe,QAAqE,CAAC;IACpG,IAAA,KAAsB,QAAQ,CAAkB,cAAc,CAAC,YAAY,CAAC,CAAC,EAA5E,MAAM,QAAA,EAAE,SAAS,QAA2D,CAAC;IAEpF,SAAS,CAAC;QACR,IAAI,SAAS;YAAE,QAAQ,CAAC,SAAS,CAAC,CAAC;IACrC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,SAAS,CAAC;QACR,IAAI,gBAAgB;YAAE,eAAe,CAAC,gBAAgB,CAAC,CAAC;IAC1D,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAEvB,SAAS,CAAC;QACR,IAAI,YAAY;YAAE,SAAS,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,CAAC;IAC5D,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAEb,IAAA,KAAsC,QAAQ,CAClD,OAAO,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,UAAU,CAAA,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,UAAU,CAAA,CAAC,CAAC,CAAC,IAAI,CAChF,EAFM,cAAc,QAAA,EAAE,iBAAiB,QAEvC,CAAC;IACI,IAAA,KAAkC,QAAQ,CAC9C,OAAO,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,CAAA,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,CAAA,CAAC,CAAC,CAAC,KAAK,CAC7E,EAFM,YAAY,QAAA,EAAE,eAAe,QAEnC,CAAC;IACI,IAAA,KAAkC,QAAQ,CAC9C,OAAO,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,CAAA,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,CAAA,CAAC,CAAC,CAAC,KAAK,CAC7E,EAFM,YAAY,QAAA,EAAE,eAAe,QAEnC,CAAC;IAEI,IAAA,KAAkC,QAAQ,CAAC,KAAK,CAAC,EAAhD,YAAY,QAAA,EAAE,eAAe,QAAmB,CAAC;IAClD,IAAA,KAA8B,QAAQ,CAAgB;QAC1D,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,KAAK;QACf,KAAK,EAAE,EAAE;KACZ,CAAC,EALO,UAAU,QAAA,EAAE,aAAa,QAKhC,CAAC;IAEK,IAAA,KAAoC,QAAQ,CAAC,KAAK,CAAC,EAAlD,aAAa,QAAA,EAAE,gBAAgB,QAAmB,CAAC;IACpD,IAAA,KAA4B,QAAQ,CAAgB,IAAI,CAAC,EAAxD,SAAS,QAAA,EAAE,YAAY,QAAiC,CAAC;IAC1D,IAAA,KAA4B,QAAQ,CAAgB,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAA5G,SAAS,QAAA,EAAE,YAAY,QAAqF,CAAC;IAEpH,IAAM,QAAQ,GAAG,OAAO,CAAC,cAAM,OAAA,cAAc,CAAC,MAAM,CAAC,EAAtB,CAAsB,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAEjE,IAAM,iBAAiB,GAAG,UAAC,GAAoB,EAAE,KAAa;;QAC5D,IAAM,IAAI,GAAG,sBAAK,KAAK,gBAAG,GAAG,IAAG,KAAK,MAAe,CAAC;QACrD,IAAI,CAAC,SAAS;YAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC/B,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAG,IAAI,CAAC,CAAC;IACxB,CAAC,CAAC;IAEF,IAAM,mBAAmB,GAAG,UAAC,GAA6B,EAAE,KAAa;;QACvE,IAAM,IAAI,GAAG,sBAAK,YAAY,gBAAG,GAAG,IAAG,KAAK,MAAwB,CAAC;QACrE,IAAI,CAAC,gBAAgB;YAAE,eAAe,CAAC,IAAI,CAAC,CAAC;QAC7C,oBAAoB,aAApB,oBAAoB,uBAApB,oBAAoB,CAAG,IAAI,CAAC,CAAC;IAC/B,CAAC,CAAC;IAEF,IAAM,cAAc,GAAG;QACrB,IAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QACpC,IAAI,CAAC,IAAI;YAAE,OAAO;QAClB,IAAI,MAAM,CAAC,IAAI,CAAC,UAAC,CAAC,IAAK,OAAA,CAAC,CAAC,IAAI,KAAK,IAAI,EAAf,CAAe,CAAC;YAAE,OAAO;QAChD,IAAM,UAAU,yBACX,UAAU,KACb,IAAI,MAAA,EACJ,KAAK,EACH,OAAO,UAAU,CAAC,KAAK,KAAK,WAAW;gBACrC,CAAC,CAAC,UAAU,CAAC,KAAK;gBAClB,CAAC,CAAC,UAAU,CAAC,IAAI,KAAK,QAAQ;oBAC9B,CAAC,CAAC,CAAC;oBACH,CAAC,CAAC,UAAU,CAAC,IAAI,KAAK,SAAS;wBAC/B,CAAC,CAAC,KAAK;wBACP,CAAC,CAAC,EAAE,GACT,CAAC;QACF,IAAM,IAAI,mCAAO,MAAM,UAAE,UAAU,SAAC,CAAC;QACrC,SAAS,CAAC,IAAI,CAAC,CAAC;QAChB,gBAAgB,aAAhB,gBAAgB,uBAAhB,gBAAgB,CAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC;QACzC,aAAa,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QAC/E,eAAe,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC,CAAC;IAEF,IAAM,aAAa,GAAG,UAAC,GAAQ,EAAE,IAAe;QAC9C,IAAI,IAAI,KAAK,QAAQ,EAAE,CAAC;YACtB,IAAM,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;YACtB,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1B,CAAC;QACD,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;YACvB,IAAI,OAAO,GAAG,KAAK,SAAS;gBAAE,OAAO,GAAG,CAAC;YACzC,IAAM,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;YACpC,OAAO,CAAC,KAAK,MAAM,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,KAAK,CAAC;QAClD,CAAC;QACD,OAAO,MAAM,CAAC,GAAG,aAAH,GAAG,cAAH,GAAG,GAAI,EAAE,CAAC,CAAC;IAC3B,CAAC,CAAC;IAEF,IAAM,cAAc,GAAG;QACrB,IAAI,SAAS,KAAK,IAAI;YAAE,OAAO;QAC/B,IAAM,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QACtC,IAAI,CAAC,OAAO;YAAE,OAAO;QACrB,IAAI,MAAM,CAAC,IAAI,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,KAAK,SAAS,IAAI,CAAC,CAAC,IAAI,KAAK,OAAO,EAArC,CAAqC,CAAC;YAAE,OAAO;QACzE,IAAM,IAAI,qBAAO,MAAM,OAAC,CAAC;QACzB,IAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;QAC5B,IAAM,OAAO,yBAAuB,GAAG,GAAK,SAAS,CAAE,CAAC;QACxD,OAAO,CAAC,KAAK,GAAG,aAAa,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;QACzD,IAAI,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC;QAC1B,SAAS,CAAC,IAAI,CAAC,CAAC;QAChB,gBAAgB,aAAhB,gBAAgB,uBAAhB,gBAAgB,CAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC;QACzC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QACxB,YAAY,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC,CAAC;IAEF,IAAM,iBAAiB,GAAG,UAAC,KAAa;QACtC,IAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,KAAK,KAAK,EAAX,CAAW,CAAC,CAAC;QAClD,SAAS,CAAC,IAAI,CAAC,CAAC;QAChB,gBAAgB,aAAhB,gBAAgB,uBAAhB,gBAAgB,CAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC;IAEF,IAAM,cAAc,cAClB,IAAI,EAAE,GAAG,EACT,QAAQ,EAAE,GAAG,EACb,eAAe,EAAE,SAAS,EAC1B,YAAY,EAAE,CAAC,EACf,SAAS,EAAE,4BAA4B,EACvC,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,QAAQ,IACpB,KAAK,CACT,CAAC;IAEF,IAAM,kBAAkB,GAAwB;QAC9C,OAAO,EAAE,EAAE;QACX,YAAY,EAAE,mBAAmB;QACjC,OAAO,EAAE,MAAM;QACf,cAAc,EAAE,eAAe;QAC/B,UAAU,EAAE,QAAQ;QACpB,MAAM,EAAE,SAAS;QACjB,eAAe,EAAE,SAAS;KAC3B,CAAC;IAEF,IAAM,iBAAiB,GAAwB;QAC7C,MAAM,EAAE,CAAC;QACT,QAAQ,EAAE,EAAE;QACZ,UAAU,EAAE,MAAM;QAClB,KAAK,EAAE,MAAM;QACb,aAAa,EAAE,CAAC;KACM,CAAC;IAEzB,IAAM,cAAc,GAAwB;QAC1C,OAAO,EAAE,gBAAgB;QACzB,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,KAAK;QACpB,cAAc,EAAE,eAAe;QAC/B,UAAU,EAAE,QAAQ;QACpB,YAAY,EAAE,MAAM;KACrB,CAAC;IAEF,IAAM,UAAU,GAAwB,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;IACxE,IAAM,gBAAgB,GAAwB;QAC5C,UAAU,EAAE,MAAM;QAClB,KAAK,EAAE,GAAG;QACV,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,CAAC;QACV,MAAM,EAAE,mBAAmB;QAC3B,YAAY,EAAE,CAAC;QACf,MAAM,EAAE,SAAS;KACK,CAAC;IAEzB,IAAM,WAAW,GAAwB;QACvC,KAAK,EAAE,GAAG;QACV,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,OAAO;QAChB,MAAM,EAAE,mBAAmB;QAC3B,YAAY,EAAE,CAAC;QACf,eAAe,EAAE,MAAM;QACvB,QAAQ,EAAE,EAAE;KACU,CAAC;IAEzB,IAAM,UAAU,GAAwB;QACtC,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,OAAO;QAChB,MAAM,EAAE,mBAAmB;QAC3B,YAAY,EAAE,CAAC;QACf,QAAQ,EAAE,EAAE;KACb,CAAC;IAEF,IAAM,cAAc,GAAwB;QAC1C,OAAO,EAAE,EAAE;QACX,OAAO,EAAE,MAAM;QACf,cAAc,EAAE,UAAU;QAC1B,GAAG,EAAE,CAAC;QACN,SAAS,EAAE,mBAAmB;QAC9B,eAAe,EAAE,SAAS;KAC3B,CAAC;IAEF,IAAM,iBAAiB,GAAwB;QAC7C,OAAO,EAAE,UAAU;QACnB,eAAe,EAAE,MAAM;QACvB,MAAM,EAAE,mBAAmB;QAC3B,YAAY,EAAE,CAAC;QACf,MAAM,EAAE,SAAS;KAClB,CAAC;IACF,IAAM,eAAe,GAAwB;QAC3C,OAAO,EAAE,UAAU;QACnB,eAAe,EAAE,SAAS;QAC1B,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,mBAAmB;QAC3B,YAAY,EAAE,CAAC;QACf,MAAM,EAAE,SAAS;KAClB,CAAC;IAEF,IAAM,qBAAqB,GAAwB;QACjD,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,GAAG,EAAE,CAAC;QACN,KAAK,EAAE,MAAM;QACb,OAAO,EAAE,WAAW;QACpB,MAAM,EAAE,mBAAmB;QAC3B,YAAY,EAAE,CAAC;QACf,eAAe,EAAE,MAAM;QACvB,MAAM,EAAE,SAAS;QACjB,QAAQ,EAAE,EAAE;QACZ,KAAK,EAAE,MAAM;KACd,CAAC;IAEF,IAAM,eAAe,GAAwB;QAC3C,MAAM,EAAE,mBAAmB;QAC3B,YAAY,EAAE,CAAC;QACf,KAAK,EAAE,EAAE;QACT,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,aAAa;QACtB,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,eAAe,EAAE,MAAM;QACvB,MAAM,EAAE,SAAS;KAClB,CAAC;IAEF,IAAM,YAAY,GAAwB;QACxC,OAAO,EAAE,MAAM;QACf,mBAAmB,EAAE,mCAAmC;QACxD,UAAU,EAAE,QAAQ;QACpB,GAAG,EAAE,CAAC;QACN,OAAO,EAAE,OAAO;KACjB,CAAC;IACF,IAAM,aAAa,GAAwB;QACzC,QAAQ,EAAE,EAAE;QACZ,KAAK,EAAE,MAAM;QACb,UAAU,EAAE,GAAG;QACf,QAAQ,EAAE,QAAQ;QAClB,YAAY,EAAE,UAAU;QACxB,UAAU,EAAE,QAAQ;KACrB,CAAC;IACF,IAAM,cAAc,GAAwB;QAC1C,QAAQ,EAAE,GAAG;QACb,QAAQ,EAAE,QAAQ;QAClB,YAAY,EAAE,UAAU;QACxB,UAAU,EAAE,QAAQ;QACpB,QAAQ,EAAE,EAAE;QACZ,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,mBAAmB;QAC3B,YAAY,EAAE,EAAE;QAChB,OAAO,EAAE,UAAU;QACnB,eAAe,EAAE,SAAS;KAC3B,CAAC;IAEF,IAAM,UAAU,GAAG;QACjB,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,EAAE,KAAK,OAAA,EAAE,YAAY,cAAA,EAAE,QAAQ,UAAA,EAAE,CAAC,CAAC;IAC9C,CAAC,CAAC;IAEF,OAAO,CACL,eAAK,KAAK,EAAE,cAAc,aAExB,eAAK,KAAK,EAAE,EAAE,YAAY,EAAE,mBAAmB,EAAE,aAC/C,eAAK,KAAK,EAAE,kBAAkB,EAAE,OAAO,EAAE,cAAM,OAAA,iBAAiB,CAAC,CAAC,cAAc,CAAC,EAAlC,CAAkC,aAC/E,aAAI,KAAK,EAAE,iBAAiB,2BAAiB,EAC5C,cAAc,CAAC,CAAC,CAAC,KAAC,SAAS,IAAC,IAAI,EAAE,EAAE,GAAI,CAAC,CAAC,CAAC,KAAC,WAAW,IAAC,IAAI,EAAE,EAAE,GAAI,IACjE,EACL,cAAc,IAAI,CACjB,8BACE,eAAK,KAAK,EAAE,cAAc,aACxB,gBAAO,KAAK,EAAE,UAAU,8BAAuB,EAC/C,gBACE,IAAI,EAAC,OAAO,EACZ,KAAK,EAAE,KAAK,CAAC,YAAY,EACzB,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,iBAAiB,CAAC,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAjD,CAAiD,EAClE,KAAK,EAAE,gBAAgB,GACvB,IACE,EACN,eAAK,KAAK,EAAE,cAAc,aACxB,gBAAO,KAAK,EAAE,UAAU,gCAAyB,EACjD,gBACE,IAAI,EAAC,OAAO,EACZ,KAAK,EAAE,KAAK,CAAC,cAAc,EAC3B,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,iBAAiB,CAAC,gBAAgB,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAnD,CAAmD,EACpE,KAAK,EAAE,gBAAgB,GACvB,IACE,EACN,eAAK,KAAK,EAAE,cAAc,aACxB,gBAAO,KAAK,EAAE,UAAU,iCAA0B,EAClD,gBACE,IAAI,EAAC,OAAO,EACZ,KAAK,EAAE,KAAK,CAAC,eAAe,EAC5B,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,iBAAiB,CAAC,iBAAiB,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAApD,CAAoD,EACrE,KAAK,EAAE,gBAAgB,GACvB,IACE,EACN,eAAK,KAAK,EAAE,cAAc,aACxB,gBAAO,KAAK,EAAE,UAAU,2BAAoB,EAC5C,gBACE,IAAI,EAAC,OAAO,EACZ,KAAK,EAAE,KAAK,CAAC,SAAS,EACtB,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,iBAAiB,CAAC,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAA9C,CAA8C,EAC/D,KAAK,EAAE,gBAAgB,GACvB,IACE,EACN,eAAK,KAAK,EAAE,cAAc,aACxB,gBAAO,KAAK,EAAE,UAAU,0BAAmB,EAC3C,kBACE,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,KAAK,CAAC,QAAQ,EACrB,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,iBAAiB,CAAC,UAAU,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAA7C,CAA6C,aAE9D,iBAAQ,KAAK,EAAC,MAAM,6BAAsB,EAC1C,iBAAQ,KAAK,EAAC,MAAM,8BAAuB,EAC3C,iBAAQ,KAAK,EAAC,MAAM,6BAAsB,IACnC,IACL,EACN,eAAK,KAAK,EAAE,cAAc,aACxB,gBAAO,KAAK,EAAE,UAAU,4BAAqB,EAC7C,kBACE,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAC5C,QAAQ,EAAE,UAAC,CAAC;4CACV,IAAM,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;4CACzB,IAAM,EAAE,GACN,CAAC,KAAK,OAAO;gDACX,CAAC,CAAC,mBAAmB;gDACrB,CAAC,CAAC,CAAC,KAAK,OAAO;oDACf,CAAC,CAAC,mBAAmB;oDACrB,CAAC,CAAC,CAAC,KAAK,iBAAiB;wDACzB,CAAC,CAAC,0BAA0B;wDAC5B,CAAC,CAAC,WAAW,CAAC;4CAClB,iBAAiB,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;wCACtC,CAAC,aAED,iBAAQ,KAAK,EAAC,OAAO,sBAAe,EACpC,iBAAQ,KAAK,EAAC,OAAO,sBAAe,EACpC,iBAAQ,KAAK,EAAC,iBAAiB,gCAAyB,EACxD,iBAAQ,KAAK,EAAC,WAAW,0BAAmB,IACrC,IACL,IACL,CACJ,IACG,EAGN,0BACE,eAAK,KAAK,EAAE,kBAAkB,EAAE,OAAO,EAAE,cAAM,OAAA,eAAe,CAAC,CAAC,YAAY,CAAC,EAA9B,CAA8B,aAC3E,aAAI,KAAK,EAAE,iBAAiB,yBAAe,EAC1C,YAAY,CAAC,CAAC,CAAC,KAAC,SAAS,IAAC,IAAI,EAAE,EAAE,GAAI,CAAC,CAAC,CAAC,KAAC,WAAW,IAAC,IAAI,EAAE,EAAE,GAAI,IAC/D,EACL,YAAY,IAAI,CACf,8BACE,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,gBAAgB,EAAE,aACvC,gBAAO,KAAK,wBAAO,UAAU,KAAE,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,wBAAgB,EAChF,gBACE,IAAI,EAAC,MAAM,EACX,KAAK,wBAAO,UAAU,KAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,YAAY,KAC9E,KAAK,EAAE,YAAY,CAAC,IAAI,EACxB,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,mBAAmB,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAA3C,CAA2C,GAC5D,IACE,EACN,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,aAAa,EAAE,aACpC,gBAAO,KAAK,wBAAO,UAAU,KAAE,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,+BAAuB,EACvF,gBACE,IAAI,EAAC,MAAM,EACX,KAAK,wBAAO,UAAU,KAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,YAAY,KAC9E,KAAK,EAAE,YAAY,CAAC,WAAW,EAC/B,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,mBAAmB,CAAC,aAAa,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAlD,CAAkD,GACnE,IACE,IACL,CACJ,IACG,EAGN,0BACE,eAAK,KAAK,EAAE,kBAAkB,EAAE,OAAO,EAAE,cAAM,OAAA,eAAe,CAAC,CAAC,YAAY,CAAC,EAA9B,CAA8B,aAC3E,aAAI,KAAK,EAAE,iBAAiB,yBAAe,EAC1C,YAAY,CAAC,CAAC,CAAC,KAAC,SAAS,IAAC,IAAI,EAAE,EAAE,GAAI,CAAC,CAAC,CAAC,KAAC,WAAW,IAAC,IAAI,EAAE,EAAE,GAAI,IAC/D,EACL,YAAY,IAAI,CACf,8BACE,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,aAClC,cAAK,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,EAAE,mEAEvD,EACN,kBAAQ,KAAK,EAAE,qBAAqB,EAAE,OAAO,EAAE,cAAM,OAAA,eAAe,CAAC,IAAI,CAAC,EAArB,CAAqB,aACxE,KAAC,IAAI,IAAC,IAAI,EAAE,EAAE,GAAI,EAClB,2CAA0B,IACnB,IACL,EACL,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,CACpB,cAAK,KAAK,EAAE,EAAE,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,YACvF,MAAM,CAAC,GAAG,CAAC,UAAC,CAAC,EAAE,GAAG;;oCACjB,IAAM,UAAU,GAAG,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAA,CAAC,CAAC,KAAK,mCAAI,EAAE,CAAC,CAAC;oCAC/F,OAAO,CACL,eAAkB,KAAK,EAAE,YAAY,aACnC,cAAK,KAAK,EAAE,aAAa,YAAG,CAAC,CAAC,IAAI,GAAO,EACzC,cAAK,KAAK,EAAE,cAAc,EAAE,KAAK,EAAE,UAAU,YAC1C,UAAU,GACP,EACN,iBACE,KAAK,EAAC,MAAM,EACZ,KAAK,EAAE,eAAe,EACtB,OAAO,EAAE;oDACP,YAAY,CAAC,GAAG,CAAC,CAAC;oDAClB,YAAY,cAAM,CAAC,EAAG,CAAC;oDACvB,gBAAgB,CAAC,IAAI,CAAC,CAAC;gDACzB,CAAC,gBACW,eAAQ,CAAC,CAAC,IAAI,CAAE,YAE5B,KAAC,MAAM,IAAC,IAAI,EAAE,EAAE,GAAI,GACb,EACT,iBACE,KAAK,EAAC,QAAQ,EACd,KAAK,EAAE,eAAe,EACtB,OAAO,EAAE,cAAM,OAAA,iBAAiB,CAAC,GAAG,CAAC,EAAtB,CAAsB,gBACzB,iBAAU,CAAC,CAAC,IAAI,CAAE,YAE9B,KAAC,MAAM,IAAC,IAAI,EAAE,EAAE,GAAI,GACb,KAxBD,CAAC,CAAC,IAAI,CAyBV,CACP,CAAC;gCACJ,CAAC,CAAC,GACE,CACP,IACA,CACJ,IACG,EAGN,eAAK,KAAK,EAAE,cAAc,aACxB,iBAAQ,KAAK,EAAE,iBAAiB,EAAE,OAAO,EAAE,cAAM,OAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,EAAI,EAAZ,CAAY,uBAAiB,EAC9E,iBAAQ,KAAK,EAAE,eAAe,EAAE,OAAO,EAAE,UAAU,6BAAuB,IACtE,EAGL,YAAY,IAAI,CACf,cAAK,KAAK,EAAE,iBAAiB,YAC3B,eAAK,KAAK,EAAE,UAAU,aACpB,cAAK,KAAK,EAAE,gBAAgB,8BAAqB,EACjD,eAAK,KAAK,EAAE,cAAc,aACxB,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,aAC9D,gBAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,+BAAwB,EACrE,gBACE,IAAI,EAAC,MAAM,EACX,KAAK,EAAE,UAAU,EACjB,KAAK,EAAE,UAAU,CAAC,IAAI,EACtB,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,aAAa,CAAC,UAAC,CAAC,IAAK,OAAA,uBAAM,CAAC,KAAE,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,IAAG,EAAhC,CAAgC,CAAC,EAAtD,CAAsD,EACvE,WAAW,EAAC,SAAS,GACrB,IACE,EAEN,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,EAAE,aACtC,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,aACvE,gBAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,qBAAc,EAC3D,kBACE,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,UAAU,CAAC,IAAI,EACtB,QAAQ,EAAE,UAAC,CAAC;wDACV,OAAA,aAAa,CAAC,UAAC,CAAC,IAAK,OAAA,uBAChB,CAAC,KACJ,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAkB,EACjC,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,IAClF,EAJmB,CAInB,CAAC;oDAJH,CAIG,aAGL,iBAAQ,KAAK,EAAC,QAAQ,uBAAgB,EACtC,iBAAQ,KAAK,EAAC,QAAQ,uBAAgB,EACtC,iBAAQ,KAAK,EAAC,SAAS,wBAAiB,IACjC,IACL,EAEN,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,aACvE,gBAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,yBAAkB,EAC/D,kBACE,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,EACzC,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,aAAa,CAAC,UAAC,CAAC,IAAK,OAAA,uBAAM,CAAC,KAAE,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,KAAK,KAAK,IAAG,EAA9C,CAA8C,CAAC,EAApE,CAAoE,aAErF,iBAAQ,KAAK,EAAC,IAAI,mBAAY,EAC9B,iBAAQ,KAAK,EAAC,KAAK,oBAAa,IACzB,IACL,IACF,EAEN,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,aAC9D,gBAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,gCAAyB,EACrE,UAAU,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAC/B,kBACE,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EAC1C,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,aAAa,CAAC,UAAC,CAAC,IAAK,OAAA,uBAAM,CAAC,KAAE,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,KAAK,MAAM,IAAG,EAA5C,CAA4C,CAAC,EAAlE,CAAkE,aAEnF,iBAAQ,KAAK,EAAC,OAAO,sBAAe,EACpC,iBAAQ,KAAK,EAAC,MAAM,qBAAc,IAC3B,CACV,CAAC,CAAC,CAAC,CACF,gBACE,IAAI,EAAE,UAAU,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EACtD,KAAK,EAAE,UAAU,EACjB,KAAK,EAAE,MAAM,CAAC,MAAA,UAAU,CAAC,KAAK,mCAAI,EAAE,CAAC,EACrC,QAAQ,EAAE,UAAC,CAAC;gDACV,OAAA,aAAa,CAAC,UAAC,CAAC,IAAK,OAAA,uBAChB,CAAC,KACJ,KAAK,EAAE,UAAU,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,IAC7E,EAHmB,CAGnB,CAAC;4CAHH,CAGG,GAEL,CACH,IACG,IACF,EAEN,eAAK,KAAK,EAAE,gBAAgB,aAC1B,iBAAQ,KAAK,EAAE,iBAAiB,EAAE,OAAO,EAAE,cAAM,OAAA,eAAe,CAAC,KAAK,CAAC,EAAtB,CAAsB,uBAE9D,EACT,iBAAQ,KAAK,EAAE,eAAe,EAAE,OAAO,EAAE,cAAc,oBAE9C,IACL,IACF,GACF,CACP,EAEA,aAAa,IAAI,CAChB,cAAK,KAAK,EAAE,iBAAiB,YAC3B,eAAK,KAAK,EAAE,UAAU,aACpB,cAAK,KAAK,EAAE,gBAAgB,+BAAsB,EAClD,eAAK,KAAK,EAAE,cAAc,aACxB,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,aAC9D,gBAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,+BAAwB,EACrE,gBACE,IAAI,EAAC,MAAM,EACX,KAAK,EAAE,UAAU,EACjB,KAAK,EAAE,SAAS,CAAC,IAAI,EACrB,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,YAAY,CAAC,UAAC,CAAC,IAAK,OAAA,uBAAM,CAAC,KAAE,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,IAAG,EAAhC,CAAgC,CAAC,EAArD,CAAqD,GACtE,IACE,EAEN,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,EAAE,aACtC,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,aACvE,gBAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,qBAAc,EAC3D,kBACE,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,SAAS,CAAC,IAAI,EACrB,QAAQ,EAAE,UAAC,CAAC;wDACV,OAAA,YAAY,CAAC,UAAC,CAAC,IAAK,OAAA,uBACf,CAAC,KACJ,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAkB,EACjC,KAAK,EACH,CAAC,CAAC,MAAM,CAAC,KAAK,KAAK,SAAS;gEAC1B,CAAC,CAAC,KAAK;gEACP,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,KAAK,QAAQ;oEAC7B,CAAC,CAAC,CAAC;oEACH,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,KAAK,QAAQ;wEAC7B,CAAC,CAAC,CAAC,CAAC,KAAK;wEACT,CAAC,CAAC,EAAE,IACR,EAXkB,CAWlB,CAAC;oDAXH,CAWG,aAGL,iBAAQ,KAAK,EAAC,QAAQ,uBAAgB,EACtC,iBAAQ,KAAK,EAAC,QAAQ,uBAAgB,EACtC,iBAAQ,KAAK,EAAC,SAAS,wBAAiB,IACjC,IACL,EAEN,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,aACvE,gBAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,yBAAkB,EAC/D,kBACE,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,EACxC,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,YAAY,CAAC,UAAC,CAAC,IAAK,OAAA,uBAAM,CAAC,KAAE,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,KAAK,KAAK,IAAG,EAA9C,CAA8C,CAAC,EAAnE,CAAmE,aAEpF,iBAAQ,KAAK,EAAC,IAAI,mBAAY,EAC9B,iBAAQ,KAAK,EAAC,KAAK,oBAAa,IACzB,IACL,IACF,EAEN,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,aAC9D,gBAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,sBAAe,EAC3D,SAAS,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAC9B,kBACE,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EACzC,QAAQ,EAAE,UAAC,CAAC,IAAK,OAAA,YAAY,CAAC,UAAC,CAAC,IAAK,OAAA,uBAAM,CAAC,KAAE,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,KAAK,MAAM,IAAG,EAA5C,CAA4C,CAAC,EAAjE,CAAiE,aAElF,iBAAQ,KAAK,EAAC,OAAO,sBAAe,EACpC,iBAAQ,KAAK,EAAC,MAAM,qBAAc,IAC3B,CACV,CAAC,CAAC,CAAC,CACF,gBACE,IAAI,EAAE,SAAS,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EACrD,KAAK,EAAE,UAAU,EACjB,KAAK,EAAE,MAAM,CAAC,MAAA,SAAS,CAAC,KAAK,mCAAI,EAAE,CAAC,EACpC,QAAQ,EAAE,UAAC,CAAC;gDACV,OAAA,YAAY,CAAC,UAAC,CAAC,IAAK,OAAA,uBACf,CAAC,KACJ,KAAK,EAAE,SAAS,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,IAC5E,EAHkB,CAGlB,CAAC;4CAHH,CAGG,GAEL,CACH,IACG,IACF,EAEN,eAAK,KAAK,EAAE,gBAAgB,aAC1B,iBAAQ,KAAK,EAAE,iBAAiB,EAAE,OAAO,EAAE,cAAM,OAAA,gBAAgB,CAAC,KAAK,CAAC,EAAvB,CAAuB,uBAE/D,EACT,iBAAQ,KAAK,EAAE,eAAe,EAAE,OAAO,EAAE,cAAc,qBAE9C,IACL,IACF,GACF,CACP,IACG,CACP,CAAC;AACJ,CAAC,CAAC;AAKF,wBAAwB;AACxB,IAAM,iBAAiB,GAAwB;IAC7C,QAAQ,EAAE,OAAO;IACjB,KAAK,EAAE,CAAC;IACR,eAAe,EAAE,kBAAkB;IACnC,OAAO,EAAE,MAAM;IACf,UAAU,EAAE,QAAQ;IACpB,cAAc,EAAE,QAAQ;IACxB,MAAM,EAAE,IAAI;CACb,CAAC;AAEF,IAAM,UAAU,GAAwB;IACtC,KAAK,EAAE,GAAG;IACV,QAAQ,EAAE,MAAM;IAChB,eAAe,EAAE,MAAM;IACvB,YAAY,EAAE,EAAE;IAChB,SAAS,EAAE,6BAA6B;IACxC,QAAQ,EAAE,QAAQ;CACnB,CAAC;AAEF,IAAM,gBAAgB,GAAwB;IAC5C,OAAO,EAAE,WAAW;IACpB,UAAU,EAAE,GAAG;IACf,YAAY,EAAE,gBAAgB;CAC/B,CAAC;AAEF,IAAM,cAAc,GAAwB;IAC1C,OAAO,EAAE,EAAE;IACX,OAAO,EAAE,MAAM;IACf,aAAa,EAAE,QAAQ;IACvB,GAAG,EAAE,EAAE;CACR,CAAC;AAEF,IAAM,gBAAgB,GAAwB;IAC5C,OAAO,EAAE,EAAE;IACX,OAAO,EAAE,MAAM;IACf,cAAc,EAAE,UAAU;IAC1B,GAAG,EAAE,CAAC;IACN,SAAS,EAAE,gBAAgB;IAC3B,eAAe,EAAE,SAAS;CAC3B,CAAC","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { ChevronDown, ChevronUp, Plus, Trash2, Pencil, X, Sparkles } from 'lucide-react';\nimport type { ChatTheme, ChatSettingsConfig } from '../types';\n\ntype ParamType = 'string' | 'number' | 'boolean';\n\ninterface MetadataParam {\n  name: string;\n  type: ParamType;\n  description?: string;\n  required: boolean;\n  value?: string | number | boolean;\n}\n\nexport interface GenAgentConfigPanelProps {\n  theme?: ChatTheme;\n  onThemeChange?: (next: ChatTheme) => void;\n\n  chatSettings?: ChatSettingsConfig;\n  onChatSettingsChange?: (next: ChatSettingsConfig) => void;\n\n  metadata?: Record<string, any>;\n  onMetadataChange?: (next: Record<string, any>) => void;\n\n  defaultOpen?: { appearance?: boolean; settings?: boolean; metadata?: boolean };\n  onSave?: (payload: { theme: ChatTheme; chatSettings: ChatSettingsConfig; metadata: Record<string, any> }) => void;\n  onCancel?: () => void;\n\n  style?: React.CSSProperties;\n}\n\nconst defaultTheme: ChatTheme = {\n  primaryColor: '#4F46E5',\n  secondaryColor: '#f5f5f5',\n  backgroundColor: '#ffffff',\n  textColor: '#000000',\n  fontFamily: 'Inter, sans-serif',\n  fontSize: '15px',\n};\n\nconst defaultSettings: ChatSettingsConfig = {\n  name: 'Genassist',\n  description: 'Support',\n};\n\nfunction objectToParams(obj: Record<string, any> | undefined): MetadataParam[] {\n  if (!obj) return [];\n  return Object.keys(obj).map((k) => {\n    const v = obj[k];\n    let type: ParamType = 'string';\n    if (typeof v === 'number') type = 'number';\n    else if (typeof v === 'boolean') type = 'boolean';\n    return { name: k, type, required: false, value: v };\n  });\n}\n\nfunction paramsToObject(params: MetadataParam[]): Record<string, any> {\n  const o: Record<string, any> = {};\n  params.forEach((p) => {\n    if (typeof p.value !== 'undefined') {\n      o[p.name] = p.value;\n    }\n  });\n  return o;\n}\n\nexport const GenAgentConfigPanel: React.FC<GenAgentConfigPanelProps> = ({\n  theme: themeProp,\n  onThemeChange,\n  chatSettings: chatSettingsProp,\n  onChatSettingsChange,\n  metadata: metadataProp,\n  onMetadataChange,\n  defaultOpen,\n  onSave,\n  onCancel,\n  style,\n}) => {\n  // Controlled or internal state fallbacks\n  const [theme, setTheme] = useState<ChatTheme>(themeProp || defaultTheme);\n  const [chatSettings, setChatSettings] = useState<ChatSettingsConfig>(chatSettingsProp || defaultSettings);\n  const [params, setParams] = useState<MetadataParam[]>(objectToParams(metadataProp));\n\n  useEffect(() => {\n    if (themeProp) setTheme(themeProp);\n  }, [themeProp]);\n\n  useEffect(() => {\n    if (chatSettingsProp) setChatSettings(chatSettingsProp);\n  }, [chatSettingsProp]);\n\n  useEffect(() => {\n    if (metadataProp) setParams(objectToParams(metadataProp));\n  }, [metadataProp]);\n\n  const [showAppearance, setShowAppearance] = useState(\n    typeof defaultOpen?.appearance === 'boolean' ? !!defaultOpen?.appearance : true\n  );\n  const [showSettings, setShowSettings] = useState(\n    typeof defaultOpen?.settings === 'boolean' ? !!defaultOpen?.settings : false\n  );\n  const [showMetadata, setShowMetadata] = useState(\n    typeof defaultOpen?.metadata === 'boolean' ? !!defaultOpen?.metadata : false\n  );\n\n  const [showAddParam, setShowAddParam] = useState(false);\n  const [draftParam, setDraftParam] = useState<MetadataParam>({\n    name: 'param_1',\n    type: 'string',\n    required: false,\n    value: '',\n});\n\n  const [showEditParam, setShowEditParam] = useState(false);\n  const [editIndex, setEditIndex] = useState<number | null>(null);\n  const [editDraft, setEditDraft] = useState<MetadataParam>({ name: '', type: 'string', required: false, value: '' });\n\n  const metadata = useMemo(() => paramsToObject(params), [params]);\n\n  const handleThemeChange = (key: keyof ChatTheme, value: string) => {\n    const next = { ...theme, [key]: value } as ChatTheme;\n    if (!themeProp) setTheme(next);\n    onThemeChange?.(next);\n  };\n\n  const handleSettingChange = (key: keyof ChatSettingsConfig, value: string) => {\n    const next = { ...chatSettings, [key]: value } as ChatSettingsConfig;\n    if (!chatSettingsProp) setChatSettings(next);\n    onChatSettingsChange?.(next);\n  };\n\n  const handleAddParam = () => {\n    const name = draftParam.name.trim();\n    if (!name) return;\n    if (params.some((p) => p.name === name)) return;\n    const normalized: MetadataParam = {\n      ...draftParam,\n      name,\n      value:\n        typeof draftParam.value !== 'undefined'\n          ? draftParam.value\n          : draftParam.type === 'number'\n          ? 0\n          : draftParam.type === 'boolean'\n          ? false\n          : '',\n    };\n    const next = [...params, normalized];\n    setParams(next);\n    onMetadataChange?.(paramsToObject(next));\n    setDraftParam({ name: 'param_1', type: 'string', required: false, value: '' });\n    setShowAddParam(false);\n  };\n\n  const coerceForType = (val: any, type: ParamType) => {\n    if (type === 'number') {\n      const n = Number(val);\n      return isNaN(n) ? 0 : n;\n    }\n    if (type === 'boolean') {\n      if (typeof val === 'boolean') return val;\n      const s = String(val).toLowerCase();\n      return s === 'true' || s === '1' || s === 'yes';\n    }\n    return String(val ?? '');\n  };\n\n  const handleEditSave = () => {\n    if (editIndex === null) return;\n    const newName = editDraft.name.trim();\n    if (!newName) return;\n    if (params.some((p, i) => i !== editIndex && p.name === newName)) return;\n    const next = [...params];\n    const old = next[editIndex];\n    const updated: MetadataParam = { ...old, ...editDraft };\n    updated.value = coerceForType(old.value, editDraft.type);\n    next[editIndex] = updated;\n    setParams(next);\n    onMetadataChange?.(paramsToObject(next));\n    setShowEditParam(false);\n    setEditIndex(null);\n  };\n\n  const handleRemoveParam = (index: number) => {\n    const next = params.filter((_, i) => i !== index);\n    setParams(next);\n    onMetadataChange?.(paramsToObject(next));\n  };\n\n  const containerStyle: React.CSSProperties = {\n    flex: '1',\n    maxWidth: 300,\n    backgroundColor: '#ffffff',\n    borderRadius: 8,\n    boxShadow: '0 2px 10px rgba(0,0,0,0.1)',\n    overflow: 'hidden',\n    display: 'flex',\n    flexDirection: 'column',\n    ...style,\n  };\n\n  const sectionHeaderStyle: React.CSSProperties = {\n    padding: 16,\n    borderBottom: '1px solid #e0e0e0',\n    display: 'flex',\n    justifyContent: 'space-between',\n    alignItems: 'center',\n    cursor: 'pointer',\n    backgroundColor: '#f9f9f9',\n  };\n\n  const sectionTitleStyle: React.CSSProperties = {\n    margin: 0,\n    fontSize: 12,\n    fontWeight: 'bold',\n    color: '#666',\n    letterSpacing: 1,\n  } as React.CSSProperties;\n\n  const formGroupStyle: React.CSSProperties = {\n    padding: '16px 16px 12px',\n    display: 'flex',\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'center',\n    borderBottom: 'none',\n  };\n\n  const labelStyle: React.CSSProperties = { fontSize: 14, color: '#333' };\n  const colorPickerStyle: React.CSSProperties = {\n    appearance: 'none',\n    width: 120,\n    height: 32,\n    padding: 0,\n    border: '1px solid #e0e0e0',\n    borderRadius: 4,\n    cursor: 'pointer',\n  } as React.CSSProperties;\n\n  const selectStyle: React.CSSProperties = {\n    width: 140,\n    height: 32,\n    padding: '0 8px',\n    border: '1px solid #e0e0e0',\n    borderRadius: 4,\n    backgroundColor: '#fff',\n    fontSize: 14,\n  } as React.CSSProperties;\n\n  const inputStyle: React.CSSProperties = {\n    width: '100%',\n    height: 32,\n    padding: '0 8px',\n    border: '1px solid #e0e0e0',\n    borderRadius: 4,\n    fontSize: 14,\n  };\n\n  const actionBarStyle: React.CSSProperties = {\n    padding: 12,\n    display: 'flex',\n    justifyContent: 'flex-end',\n    gap: 8,\n    borderTop: '1px solid #e0e0e0',\n    backgroundColor: '#fafafa',\n  };\n\n  const cancelButtonStyle: React.CSSProperties = {\n    padding: '8px 12px',\n    backgroundColor: '#fff',\n    border: '1px solid #e0e0e0',\n    borderRadius: 6,\n    cursor: 'pointer',\n  };\n  const saveButtonStyle: React.CSSProperties = {\n    padding: '8px 12px',\n    backgroundColor: '#111827',\n    color: '#fff',\n    border: '1px solid #0b1220',\n    borderRadius: 6,\n    cursor: 'pointer',\n  };\n\n  const fullWidthActionButton: React.CSSProperties = {\n    display: 'flex',\n    alignItems: 'center',\n    gap: 8,\n    width: '100%',\n    padding: '10px 12px',\n    border: '1px solid #e0e0e0',\n    borderRadius: 8,\n    backgroundColor: '#fff',\n    cursor: 'pointer',\n    fontSize: 14,\n    color: '#111',\n  };\n\n  const smallIconButton: React.CSSProperties = {\n    border: '1px solid #e0e0e0',\n    borderRadius: 8,\n    width: 28,\n    height: 28,\n    display: 'inline-flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    backgroundColor: '#fff',\n    cursor: 'pointer',\n  };\n\n  const metaRowStyle: React.CSSProperties = {\n    display: 'grid',\n    gridTemplateColumns: '1fr minmax(90px, 150px) 28px 28px',\n    alignItems: 'center',\n    gap: 8,\n    padding: '6px 0',\n  };\n  const metaNameStyle: React.CSSProperties = {\n    fontSize: 13,\n    color: '#222',\n    fontWeight: 500,\n    overflow: 'hidden',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n  };\n  const metaValueStyle: React.CSSProperties = {\n    maxWidth: 150,\n    overflow: 'hidden',\n    textOverflow: 'ellipsis',\n    whiteSpace: 'nowrap',\n    fontSize: 13,\n    color: '#111',\n    border: '1px solid #e6e6e6',\n    borderRadius: 12,\n    padding: '6px 10px',\n    backgroundColor: '#fafafa',\n  };\n\n  const handleSave = () => {\n    onSave?.({ theme, chatSettings, metadata });\n  };\n\n  return (\n    <div style={containerStyle}>\n      {/* Appearance Section */}\n      <div style={{ borderBottom: '1px solid #e0e0e0' }}>\n        <div style={sectionHeaderStyle} onClick={() => setShowAppearance(!showAppearance)}>\n          <h3 style={sectionTitleStyle}>APPEARANCE</h3>\n          {showAppearance ? <ChevronUp size={16} /> : <ChevronDown size={16} />}\n        </div>\n        {showAppearance && (\n          <>\n            <div style={formGroupStyle}>\n              <label style={labelStyle}>Primary Color</label>\n              <input\n                type=\"color\"\n                value={theme.primaryColor}\n                onChange={(e) => handleThemeChange('primaryColor', e.target.value)}\n                style={colorPickerStyle}\n              />\n            </div>\n            <div style={formGroupStyle}>\n              <label style={labelStyle}>Secondary Color</label>\n              <input\n                type=\"color\"\n                value={theme.secondaryColor}\n                onChange={(e) => handleThemeChange('secondaryColor', e.target.value)}\n                style={colorPickerStyle}\n              />\n            </div>\n            <div style={formGroupStyle}>\n              <label style={labelStyle}>Background Color</label>\n              <input\n                type=\"color\"\n                value={theme.backgroundColor}\n                onChange={(e) => handleThemeChange('backgroundColor', e.target.value)}\n                style={colorPickerStyle}\n              />\n            </div>\n            <div style={formGroupStyle}>\n              <label style={labelStyle}>Text Color</label>\n              <input\n                type=\"color\"\n                value={theme.textColor}\n                onChange={(e) => handleThemeChange('textColor', e.target.value)}\n                style={colorPickerStyle}\n              />\n            </div>\n            <div style={formGroupStyle}>\n              <label style={labelStyle}>Font Size</label>\n              <select\n                style={selectStyle}\n                value={theme.fontSize}\n                onChange={(e) => handleThemeChange('fontSize', e.target.value)}\n              >\n                <option value=\"12px\">Small (12px)</option>\n                <option value=\"15px\">Medium (15px)</option>\n                <option value=\"18px\">Large (18px)</option>\n              </select>\n            </div>\n            <div style={formGroupStyle}>\n              <label style={labelStyle}>Font Family</label>\n              <select\n                style={selectStyle}\n                value={theme.fontFamily.split(',')[0].trim()}\n                onChange={(e) => {\n                  const v = e.target.value;\n                  const ff =\n                    v === 'Inter'\n                      ? 'Inter, sans-serif'\n                      : v === 'Arial'\n                      ? 'Arial, sans-serif'\n                      : v === 'Times New Roman'\n                      ? \"'Times New Roman', serif\"\n                      : 'monospace';\n                  handleThemeChange('fontFamily', ff);\n                }}\n              >\n                <option value=\"Inter\">Inter</option>\n                <option value=\"Arial\">Arial</option>\n                <option value=\"Times New Roman\">Times New Roman</option>\n                <option value=\"monospace\">Monospace</option>\n              </select>\n            </div>\n          </>\n        )}\n      </div>\n\n      {/* Settings Section */}\n      <div>\n        <div style={sectionHeaderStyle} onClick={() => setShowSettings(!showSettings)}>\n          <h3 style={sectionTitleStyle}>SETTINGS</h3>\n          {showSettings ? <ChevronUp size={16} /> : <ChevronDown size={16} />}\n        </div>\n        {showSettings && (\n          <>\n            <div style={{ padding: '16px 16px 12px' }}>\n              <label style={{ ...labelStyle, display: 'block', marginBottom: 8 }}>Name</label>\n              <input\n                type=\"text\"\n                style={{ ...inputStyle, height: 40, padding: '0 12px', boxSizing: 'border-box' }}\n                value={chatSettings.name}\n                onChange={(e) => handleSettingChange('name', e.target.value)}\n              />\n            </div>\n            <div style={{ padding: '0 16px 16px' }}>\n              <label style={{ ...labelStyle, display: 'block', marginBottom: 8 }}>Description</label>\n              <input\n                type=\"text\"\n                style={{ ...inputStyle, height: 40, padding: '0 12px', boxSizing: 'border-box' }}\n                value={chatSettings.description}\n                onChange={(e) => handleSettingChange('description', e.target.value)}\n              />\n            </div>\n          </>\n        )}\n      </div>\n\n      {/* Metadata Section */}\n      <div>\n        <div style={sectionHeaderStyle} onClick={() => setShowMetadata(!showMetadata)}>\n          <h3 style={sectionTitleStyle}>METADATA</h3>\n          {showMetadata ? <ChevronUp size={16} /> : <ChevronDown size={16} />}\n        </div>\n        {showMetadata && (\n          <>\n            <div style={{ padding: '12px 16px' }}>\n              <div style={{ fontSize: 13, color: '#555', marginBottom: 10 }}>\n                Define key/value parameters sent as chat metadata.\n              </div>\n              <button style={fullWidthActionButton} onClick={() => setShowAddParam(true)}>\n                <Plus size={18} />\n                <span>Add Parameter</span>\n              </button>\n            </div>\n            {params.length > 0 && (\n              <div style={{ padding: '2px 16px 12px', display: 'flex', flexDirection: 'column', gap: 6 }}>\n                {params.map((p, idx) => {\n                  const displayVal = p.type === 'boolean' ? (p.value ? 'True' : 'False') : String(p.value ?? '');\n                  return (\n                    <div key={p.name} style={metaRowStyle}>\n                      <div style={metaNameStyle}>{p.name}</div>\n                      <div style={metaValueStyle} title={displayVal}>\n                        {displayVal}\n                      </div>\n                      <button\n                        title=\"Edit\"\n                        style={smallIconButton}\n                        onClick={() => {\n                          setEditIndex(idx);\n                          setEditDraft({ ...p });\n                          setShowEditParam(true);\n                        }}\n                        aria-label={`Edit ${p.name}`}\n                      >\n                        <Pencil size={16} />\n                      </button>\n                      <button\n                        title=\"Remove\"\n                        style={smallIconButton}\n                        onClick={() => handleRemoveParam(idx)}\n                        aria-label={`Remove ${p.name}`}\n                      >\n                        <Trash2 size={16} />\n                      </button>\n                    </div>\n                  );\n                })}\n              </div>\n            )}\n          </>\n        )}\n      </div>\n\n      {/* Action Buttons */}\n      <div style={actionBarStyle}>\n        <button style={cancelButtonStyle} onClick={() => onCancel?.()}>Cancel</button>\n        <button style={saveButtonStyle} onClick={handleSave}>Save Changes</button>\n      </div>\n\n      {/* Simple Parameter Modals */}\n      {showAddParam && (\n        <div style={modalOverlayStyle}>\n          <div style={modalStyle}>\n            <div style={modalHeaderStyle}>Add Parameter</div>\n            <div style={modalBodyStyle}>\n              <div style={{ display: 'flex', flexDirection: 'column', gap: 6 }}>\n                <label style={{ fontSize: 12, color: '#777' }}>Parameter Name</label>\n                <input\n                  type=\"text\"\n                  style={inputStyle}\n                  value={draftParam.name}\n                  onChange={(e) => setDraftParam((d) => ({ ...d, name: e.target.value }))}\n                  placeholder=\"param_1\"\n                />\n              </div>\n\n              <div style={{ display: 'flex', gap: 12 }}>\n                <div style={{ display: 'flex', flexDirection: 'column', gap: 6, flex: 1 }}>\n                  <label style={{ fontSize: 12, color: '#777' }}>Type</label>\n                  <select\n                    style={selectStyle}\n                    value={draftParam.type}\n                    onChange={(e) =>\n                      setDraftParam((d) => ({\n                        ...d,\n                        type: e.target.value as ParamType,\n                        value: e.target.value === 'boolean' ? false : e.target.value === 'number' ? 0 : '',\n                      }))\n                    }\n                  >\n                    <option value=\"string\">String</option>\n                    <option value=\"number\">Number</option>\n                    <option value=\"boolean\">Boolean</option>\n                  </select>\n                </div>\n\n                <div style={{ display: 'flex', flexDirection: 'column', gap: 6, flex: 1 }}>\n                  <label style={{ fontSize: 12, color: '#777' }}>Required</label>\n                  <select\n                    style={selectStyle}\n                    value={draftParam.required ? 'yes' : 'no'}\n                    onChange={(e) => setDraftParam((d) => ({ ...d, required: e.target.value === 'yes' }))}\n                  >\n                    <option value=\"no\">No</option>\n                    <option value=\"yes\">Yes</option>\n                  </select>\n                </div>\n              </div>\n\n              <div style={{ display: 'flex', flexDirection: 'column', gap: 6 }}>\n                <label style={{ fontSize: 12, color: '#777' }}>Default / Value</label>\n                {draftParam.type === 'boolean' ? (\n                  <select\n                    style={selectStyle}\n                    value={draftParam.value ? 'true' : 'false'}\n                    onChange={(e) => setDraftParam((d) => ({ ...d, value: e.target.value === 'true' }))}\n                  >\n                    <option value=\"false\">False</option>\n                    <option value=\"true\">True</option>\n                  </select>\n                ) : (\n                  <input\n                    type={draftParam.type === 'number' ? 'number' : 'text'}\n                    style={inputStyle}\n                    value={String(draftParam.value ?? '')}\n                    onChange={(e) =>\n                      setDraftParam((d) => ({\n                        ...d,\n                        value: draftParam.type === 'number' ? Number(e.target.value) : e.target.value,\n                      }))\n                    }\n                  />\n                )}\n              </div>\n            </div>\n\n            <div style={modalFooterStyle}>\n              <button style={cancelButtonStyle} onClick={() => setShowAddParam(false)}>\n                Cancel\n              </button>\n              <button style={saveButtonStyle} onClick={handleAddParam}>\n                Add\n              </button>\n            </div>\n          </div>\n        </div>\n      )}\n\n      {showEditParam && (\n        <div style={modalOverlayStyle}>\n          <div style={modalStyle}>\n            <div style={modalHeaderStyle}>Edit Parameter</div>\n            <div style={modalBodyStyle}>\n              <div style={{ display: 'flex', flexDirection: 'column', gap: 6 }}>\n                <label style={{ fontSize: 12, color: '#777' }}>Parameter Name</label>\n                <input\n                  type=\"text\"\n                  style={inputStyle}\n                  value={editDraft.name}\n                  onChange={(e) => setEditDraft((d) => ({ ...d, name: e.target.value }))}\n                />\n              </div>\n\n              <div style={{ display: 'flex', gap: 12 }}>\n                <div style={{ display: 'flex', flexDirection: 'column', gap: 6, flex: 1 }}>\n                  <label style={{ fontSize: 12, color: '#777' }}>Type</label>\n                  <select\n                    style={selectStyle}\n                    value={editDraft.type}\n                    onChange={(e) =>\n                      setEditDraft((d) => ({\n                        ...d,\n                        type: e.target.value as ParamType,\n                        value:\n                          e.target.value === 'boolean'\n                            ? false\n                            : e.target.value === 'number'\n                            ? 0\n                            : typeof d.value === 'string'\n                            ? d.value\n                            : '',\n                      }))\n                    }\n                  >\n                    <option value=\"string\">String</option>\n                    <option value=\"number\">Number</option>\n                    <option value=\"boolean\">Boolean</option>\n                  </select>\n                </div>\n\n                <div style={{ display: 'flex', flexDirection: 'column', gap: 6, flex: 1 }}>\n                  <label style={{ fontSize: 12, color: '#777' }}>Required</label>\n                  <select\n                    style={selectStyle}\n                    value={editDraft.required ? 'yes' : 'no'}\n                    onChange={(e) => setEditDraft((d) => ({ ...d, required: e.target.value === 'yes' }))}\n                  >\n                    <option value=\"no\">No</option>\n                    <option value=\"yes\">Yes</option>\n                  </select>\n                </div>\n              </div>\n\n              <div style={{ display: 'flex', flexDirection: 'column', gap: 6 }}>\n                <label style={{ fontSize: 12, color: '#777' }}>Value</label>\n                {editDraft.type === 'boolean' ? (\n                  <select\n                    style={selectStyle}\n                    value={editDraft.value ? 'true' : 'false'}\n                    onChange={(e) => setEditDraft((d) => ({ ...d, value: e.target.value === 'true' }))}\n                  >\n                    <option value=\"false\">False</option>\n                    <option value=\"true\">True</option>\n                  </select>\n                ) : (\n                  <input\n                    type={editDraft.type === 'number' ? 'number' : 'text'}\n                    style={inputStyle}\n                    value={String(editDraft.value ?? '')}\n                    onChange={(e) =>\n                      setEditDraft((d) => ({\n                        ...d,\n                        value: editDraft.type === 'number' ? Number(e.target.value) : e.target.value,\n                      }))\n                    }\n                  />\n                )}\n              </div>\n            </div>\n\n            <div style={modalFooterStyle}>\n              <button style={cancelButtonStyle} onClick={() => setShowEditParam(false)}>\n                Cancel\n              </button>\n              <button style={saveButtonStyle} onClick={handleEditSave}>\n                Save\n              </button>\n            </div>\n          </div>\n        </div>\n      )}\n    </div>\n  );\n};\n\n// Re-export types for backward compatibility with existing imports\nexport type { ChatTheme, ChatSettingsConfig };\n\n// Modal styles (shared)\nconst modalOverlayStyle: React.CSSProperties = {\n  position: 'fixed',\n  inset: 0,\n  backgroundColor: 'rgba(0,0,0,0.25)',\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'center',\n  zIndex: 9999,\n};\n\nconst modalStyle: React.CSSProperties = {\n  width: 420,\n  maxWidth: '92vw',\n  backgroundColor: '#fff',\n  borderRadius: 12,\n  boxShadow: '0 8px 24px rgba(0,0,0,0.18)',\n  overflow: 'hidden',\n};\n\nconst modalHeaderStyle: React.CSSProperties = {\n  padding: '12px 16px',\n  fontWeight: 600,\n  borderBottom: '1px solid #eee',\n};\n\nconst modalBodyStyle: React.CSSProperties = {\n  padding: 16,\n  display: 'flex',\n  flexDirection: 'column',\n  gap: 12,\n};\n\nconst modalFooterStyle: React.CSSProperties = {\n  padding: 12,\n  display: 'flex',\n  justifyContent: 'flex-end',\n  gap: 8,\n  borderTop: '1px solid #eee',\n  backgroundColor: '#fafafa',\n};\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Loader2 } from 'lucide-react';
|
|
3
|
+
export var Spinner = function (_a) {
|
|
4
|
+
var _b = _a.size, size = _b === void 0 ? 24 : _b, _c = _a.color, color = _c === void 0 ? '#000' : _c;
|
|
5
|
+
var style = { animation: 'genassist-spin 1s linear infinite' };
|
|
6
|
+
return (_jsxs(_Fragment, { children: [_jsx("style", { children: "\n @keyframes genassist-spin {\n 0% { transform: rotate(0deg); }\n 100% { transform: rotate(360deg); }\n }\n " }), _jsx(Loader2, { size: size, color: color, style: style })] }));
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3Bpbm5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL1NwaW5uZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBT3ZDLE1BQU0sQ0FBQyxJQUFNLE9BQU8sR0FBMkIsVUFBQyxFQUE2QjtRQUEzQixZQUFTLEVBQVQsSUFBSSxtQkFBRyxFQUFFLEtBQUEsRUFBRSxhQUFjLEVBQWQsS0FBSyxtQkFBRyxNQUFNLEtBQUE7SUFDekUsSUFBTSxLQUFLLEdBQXdCLEVBQUUsU0FBUyxFQUFFLG1DQUFtQyxFQUFFLENBQUM7SUFDdEYsT0FBTyxDQUNMLDhCQUNFLDBCQUFRLG9KQUtQLEdBQVMsRUFDVixLQUFDLE9BQU8sSUFBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssR0FBSSxJQUNsRCxDQUNKLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgTG9hZGVyMiB9IGZyb20gJ2x1Y2lkZS1yZWFjdCc7XG5cbmludGVyZmFjZSBTcGlubmVyUHJvcHMge1xuICBzaXplPzogbnVtYmVyO1xuICBjb2xvcj86IHN0cmluZztcbn1cblxuZXhwb3J0IGNvbnN0IFNwaW5uZXI6IFJlYWN0LkZDPFNwaW5uZXJQcm9wcz4gPSAoeyBzaXplID0gMjQsIGNvbG9yID0gJyMwMDAnIH0pID0+IHtcbiAgY29uc3Qgc3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7IGFuaW1hdGlvbjogJ2dlbmFzc2lzdC1zcGluIDFzIGxpbmVhciBpbmZpbml0ZScgfTtcbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPHN0eWxlPntgXG4gICAgICAgIEBrZXlmcmFtZXMgZ2VuYXNzaXN0LXNwaW4ge1xuICAgICAgICAgIDAlIHsgdHJhbnNmb3JtOiByb3RhdGUoMGRlZyk7IH1cbiAgICAgICAgICAxMDAlIHsgdHJhbnNmb3JtOiByb3RhdGUoMzYwZGVnKTsgfVxuICAgICAgICB9XG4gICAgICBgfTwvc3R5bGU+XG4gICAgICA8TG9hZGVyMiBzaXplPXtzaXplfSBjb2xvcj17Y29sb3J9IHN0eWxlPXtzdHlsZX0gLz5cbiAgICA8Lz5cbiAgKTtcbn07XG5cbiJdfQ==
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { jsx as _jsx, Fragment as _Fragment
|
|
2
|
-
import { Mic
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { Mic } from 'lucide-react';
|
|
3
3
|
import { useVoiceInput } from '../hooks/useVoiceInput';
|
|
4
|
+
import { Spinner } from './Spinner';
|
|
4
5
|
export var VoiceInput = function (_a) {
|
|
5
6
|
var onTranscription = _a.onTranscription, onError = _a.onError, baseUrl = _a.baseUrl, apiKey = _a.apiKey, theme = _a.theme;
|
|
6
7
|
var _b = useVoiceInput({
|
|
@@ -16,9 +17,7 @@ export var VoiceInput = function (_a) {
|
|
|
16
17
|
};
|
|
17
18
|
var getButtonContent = function () {
|
|
18
19
|
if (isLoading) {
|
|
19
|
-
return
|
|
20
|
-
animation: 'spin 1s linear infinite',
|
|
21
|
-
} }));
|
|
20
|
+
return _jsx(Spinner, { size: 18, color: "#ffffff" });
|
|
22
21
|
}
|
|
23
22
|
return _jsx(Mic, { size: 18, color: "#ffffff" });
|
|
24
23
|
};
|
|
@@ -46,8 +45,6 @@ export var VoiceInput = function (_a) {
|
|
|
46
45
|
boxShadow: '0 1px 3px rgba(0, 0, 0, 0.08)',
|
|
47
46
|
opacity: isLoading ? 0.9 : 1,
|
|
48
47
|
};
|
|
49
|
-
|
|
50
|
-
var spinKeyframes = "\n @keyframes spin {\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(360deg);\n }\n }\n ";
|
|
51
|
-
return (_jsxs(_Fragment, { children: [_jsx("style", { children: spinKeyframes }), _jsx("button", { type: "button", style: buttonStyle, onClick: handleClick, title: getTitle(), disabled: isLoading, children: getButtonContent() })] }));
|
|
48
|
+
return (_jsx(_Fragment, { children: _jsx("button", { type: "button", style: buttonStyle, onClick: handleClick, title: getTitle(), disabled: isLoading, children: getButtonContent() }) }));
|
|
52
49
|
};
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVm9pY2VJbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL1ZvaWNlSW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ25DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBY3BDLE1BQU0sQ0FBQyxJQUFNLFVBQVUsR0FBOEIsVUFBQyxFQU1yRDtRQUxDLGVBQWUscUJBQUEsRUFDZixPQUFPLGFBQUEsRUFDUCxPQUFPLGFBQUEsRUFDUCxNQUFNLFlBQUEsRUFDTixLQUFLLFdBQUE7SUFFQyxJQUFBLEtBQThDLGFBQWEsQ0FBQztRQUNoRSxPQUFPLFNBQUE7UUFDUCxNQUFNLFFBQUE7UUFDTixlQUFlLGlCQUFBO1FBQ2YsT0FBTyxTQUFBO0tBQ1IsQ0FBQyxFQUxNLFdBQVcsaUJBQUEsRUFBRSxTQUFTLGVBQUEsRUFBRSxlQUFlLHFCQUs3QyxDQUFDO0lBRUgsSUFBTSxXQUFXLEdBQUcsVUFBQyxDQUFtQjtRQUN0QyxDQUFDLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDbkIsQ0FBQyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3BCLGVBQWUsRUFBRSxDQUFDO0lBQ3BCLENBQUMsQ0FBQztJQUVGLElBQU0sZ0JBQWdCLEdBQUc7UUFDdkIsSUFBSSxTQUFTLEVBQUUsQ0FBQztZQUNkLE9BQU8sS0FBQyxPQUFPLElBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUMsU0FBUyxHQUFHLENBQUM7UUFDL0MsQ0FBQztRQUNELE9BQU8sS0FBQyxHQUFHLElBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUMsU0FBUyxHQUFHLENBQUM7SUFDM0MsQ0FBQyxDQUFDO0lBRUYsSUFBTSxRQUFRLEdBQUc7UUFDZixJQUFJLFNBQVM7WUFBRSxPQUFPLGVBQWUsQ0FBQztRQUN0QyxPQUFPLFdBQVcsQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixDQUFDO0lBQzVELENBQUMsQ0FBQztJQUVGLElBQU0sTUFBTSxHQUFHLENBQUEsS0FBSyxhQUFMLEtBQUssdUJBQUwsS0FBSyxDQUFFLFlBQVksS0FBSSxTQUFTLENBQUM7SUFDaEQsSUFBTSxRQUFRLEdBQUcsU0FBUyxDQUFDLENBQUMscUJBQXFCO0lBQ2pELElBQU0sV0FBVyxHQUF3QjtRQUN2QyxlQUFlLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU07UUFDaEQsS0FBSyxFQUFFLFNBQVM7UUFDaEIsTUFBTSxFQUFFLE1BQU07UUFDZCxZQUFZLEVBQUUsS0FBSztRQUNuQixLQUFLLEVBQUUsTUFBTTtRQUNiLE1BQU0sRUFBRSxNQUFNO1FBQ2QsT0FBTyxFQUFFLE1BQU07UUFDZixVQUFVLEVBQUUsUUFBUTtRQUNwQixjQUFjLEVBQUUsUUFBUTtRQUN4QixNQUFNLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLFNBQVM7UUFDN0MsT0FBTyxFQUFFLE1BQU07UUFDZixVQUFVLEVBQUUsZUFBZTtRQUMzQixVQUFVLEVBQUUsQ0FBQztRQUNiLFNBQVMsRUFBRSwrQkFBK0I7UUFDMUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQzdCLENBQUM7SUFFRixPQUFPLENBQ0wsNEJBQ0UsaUJBQ0UsSUFBSSxFQUFDLFFBQVEsRUFDYixLQUFLLEVBQUUsV0FBVyxFQUNsQixPQUFPLEVBQUUsV0FBVyxFQUNwQixLQUFLLEVBQUUsUUFBUSxFQUFFLEVBQ2pCLFFBQVEsRUFBRSxTQUFTLFlBRWxCLGdCQUFnQixFQUFFLEdBQ1osR0FDUixDQUNKLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgTWljIH0gZnJvbSAnbHVjaWRlLXJlYWN0JztcbmltcG9ydCB7IHVzZVZvaWNlSW5wdXQgfSBmcm9tICcuLi9ob29rcy91c2VWb2ljZUlucHV0JztcbmltcG9ydCB7IFNwaW5uZXIgfSBmcm9tICcuL1NwaW5uZXInO1xuXG5pbnRlcmZhY2UgVm9pY2VJbnB1dFByb3BzIHtcbiAgb25UcmFuc2NyaXB0aW9uOiAodGV4dDogc3RyaW5nKSA9PiB2b2lkO1xuICBvbkVycm9yOiAoZXJyb3I6IEVycm9yKSA9PiB2b2lkO1xuICBiYXNlVXJsOiBzdHJpbmc7XG4gIGFwaUtleTogc3RyaW5nO1xuICB0aGVtZT86IHtcbiAgICBwcmltYXJ5Q29sb3I/OiBzdHJpbmc7XG4gICAgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xuICAgIGZvbnRGYW1pbHk/OiBzdHJpbmc7XG4gIH07XG59XG5cbmV4cG9ydCBjb25zdCBWb2ljZUlucHV0OiBSZWFjdC5GQzxWb2ljZUlucHV0UHJvcHM+ID0gKHtcbiAgb25UcmFuc2NyaXB0aW9uLFxuICBvbkVycm9yLFxuICBiYXNlVXJsLFxuICBhcGlLZXksXG4gIHRoZW1lXG59KSA9PiB7XG4gIGNvbnN0IHsgaXNSZWNvcmRpbmcsIGlzTG9hZGluZywgdG9nZ2xlUmVjb3JkaW5nIH0gPSB1c2VWb2ljZUlucHV0KHtcbiAgICBiYXNlVXJsLFxuICAgIGFwaUtleSxcbiAgICBvblRyYW5zY3JpcHRpb24sXG4gICAgb25FcnJvcixcbiAgfSk7XG5cbiAgY29uc3QgaGFuZGxlQ2xpY2sgPSAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4ge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIHRvZ2dsZVJlY29yZGluZygpO1xuICB9O1xuXG4gIGNvbnN0IGdldEJ1dHRvbkNvbnRlbnQgPSAoKSA9PiB7XG4gICAgaWYgKGlzTG9hZGluZykge1xuICAgICAgcmV0dXJuIDxTcGlubmVyIHNpemU9ezE4fSBjb2xvcj1cIiNmZmZmZmZcIiAvPjtcbiAgICB9XG4gICAgcmV0dXJuIDxNaWMgc2l6ZT17MTh9IGNvbG9yPVwiI2ZmZmZmZlwiIC8+O1xuICB9O1xuXG4gIGNvbnN0IGdldFRpdGxlID0gKCkgPT4ge1xuICAgIGlmIChpc0xvYWRpbmcpIHJldHVybiAnQ29ubmVjdGluZy4uLic7XG4gICAgcmV0dXJuIGlzUmVjb3JkaW5nID8gJ1N0b3AgUmVjb3JkaW5nJyA6ICdTdGFydCBSZWNvcmRpbmcnO1xuICB9O1xuXG4gIGNvbnN0IGlkbGVCZyA9IHRoZW1lPy5wcmltYXJ5Q29sb3IgfHwgJyMyOTYyRkYnO1xuICBjb25zdCBhY3RpdmVCZyA9ICcjRkYzQjMwJzsgLy8gcmVkIHdoZW4gcmVjb3JkaW5nXG4gIGNvbnN0IGJ1dHRvblN0eWxlOiBSZWFjdC5DU1NQcm9wZXJ0aWVzID0ge1xuICAgIGJhY2tncm91bmRDb2xvcjogaXNSZWNvcmRpbmcgPyBhY3RpdmVCZyA6IGlkbGVCZyxcbiAgICBjb2xvcjogJyNmZmZmZmYnLFxuICAgIGJvcmRlcjogJ25vbmUnLFxuICAgIGJvcmRlclJhZGl1czogJzUwJScsXG4gICAgd2lkdGg6ICczNnB4JyxcbiAgICBoZWlnaHQ6ICczNnB4JyxcbiAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAganVzdGlmeUNvbnRlbnQ6ICdjZW50ZXInLFxuICAgIGN1cnNvcjogaXNMb2FkaW5nID8gJ25vdC1hbGxvd2VkJyA6ICdwb2ludGVyJyxcbiAgICBvdXRsaW5lOiAnbm9uZScsXG4gICAgdHJhbnNpdGlvbjogJ2FsbCAwLjJzIGVhc2UnLFxuICAgIGZsZXhTaHJpbms6IDAsXG4gICAgYm94U2hhZG93OiAnMCAxcHggM3B4IHJnYmEoMCwgMCwgMCwgMC4wOCknLFxuICAgIG9wYWNpdHk6IGlzTG9hZGluZyA/IDAuOSA6IDEsXG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgc3R5bGU9e2J1dHRvblN0eWxlfVxuICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbGlja31cbiAgICAgICAgdGl0bGU9e2dldFRpdGxlKCl9XG4gICAgICAgIGRpc2FibGVkPXtpc0xvYWRpbmd9XG4gICAgICA+XG4gICAgICAgIHtnZXRCdXR0b25Db250ZW50KCl9XG4gICAgICA8L2J1dHRvbj5cbiAgICA8Lz5cbiAgKTtcbn07XG4iXX0=
|