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.
@@ -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":"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","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,7 @@
1
+ import React from 'react';
2
+ interface SpinnerProps {
3
+ size?: number;
4
+ color?: string;
5
+ }
6
+ export declare const Spinner: React.FC<SpinnerProps>;
7
+ export {};
@@ -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, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Mic, Loader2 } from 'lucide-react';
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 (_jsx(Loader2, { size: 18, color: "#ffffff", style: {
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
- // Keyframe animation for the spinner
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVm9pY2VJbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL1ZvaWNlSW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM1QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFjdkQsTUFBTSxDQUFDLElBQU0sVUFBVSxHQUE4QixVQUFDLEVBTXJEO1FBTEMsZUFBZSxxQkFBQSxFQUNmLE9BQU8sYUFBQSxFQUNQLE9BQU8sYUFBQSxFQUNQLE1BQU0sWUFBQSxFQUNOLEtBQUssV0FBQTtJQUVDLElBQUEsS0FBOEMsYUFBYSxDQUFDO1FBQ2hFLE9BQU8sU0FBQTtRQUNQLE1BQU0sUUFBQTtRQUNOLGVBQWUsaUJBQUE7UUFDZixPQUFPLFNBQUE7S0FDUixDQUFDLEVBTE0sV0FBVyxpQkFBQSxFQUFFLFNBQVMsZUFBQSxFQUFFLGVBQWUscUJBSzdDLENBQUM7SUFFSCxJQUFNLFdBQVcsR0FBRyxVQUFDLENBQW1CO1FBQ3RDLENBQUMsQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUNuQixDQUFDLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDcEIsZUFBZSxFQUFFLENBQUM7SUFDcEIsQ0FBQyxDQUFDO0lBRUYsSUFBTSxnQkFBZ0IsR0FBRztRQUN2QixJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQ2QsT0FBTyxDQUNMLEtBQUMsT0FBTyxJQUNOLElBQUksRUFBRSxFQUFFLEVBQ1IsS0FBSyxFQUFDLFNBQVMsRUFDZixLQUFLLEVBQUU7b0JBQ0wsU0FBUyxFQUFFLHlCQUF5QjtpQkFDckMsR0FDRCxDQUNILENBQUM7UUFDSixDQUFDO1FBQ0QsT0FBTyxLQUFDLEdBQUcsSUFBQyxJQUFJLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBQyxTQUFTLEdBQUcsQ0FBQztJQUMzQyxDQUFDLENBQUM7SUFFRixJQUFNLFFBQVEsR0FBRztRQUNmLElBQUksU0FBUztZQUFFLE9BQU8sZUFBZSxDQUFDO1FBQ3RDLE9BQU8sV0FBVyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsaUJBQWlCLENBQUM7SUFDNUQsQ0FBQyxDQUFDO0lBRUYsSUFBTSxNQUFNLEdBQUcsQ0FBQSxLQUFLLGFBQUwsS0FBSyx1QkFBTCxLQUFLLENBQUUsWUFBWSxLQUFJLFNBQVMsQ0FBQztJQUNoRCxJQUFNLFFBQVEsR0FBRyxTQUFTLENBQUMsQ0FBQyxxQkFBcUI7SUFDakQsSUFBTSxXQUFXLEdBQXdCO1FBQ3ZDLGVBQWUsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsTUFBTTtRQUNoRCxLQUFLLEVBQUUsU0FBUztRQUNoQixNQUFNLEVBQUUsTUFBTTtRQUNkLFlBQVksRUFBRSxLQUFLO1FBQ25CLEtBQUssRUFBRSxNQUFNO1FBQ2IsTUFBTSxFQUFFLE1BQU07UUFDZCxPQUFPLEVBQUUsTUFBTTtRQUNmLFVBQVUsRUFBRSxRQUFRO1FBQ3BCLGNBQWMsRUFBRSxRQUFRO1FBQ3hCLE1BQU0sRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsU0FBUztRQUM3QyxPQUFPLEVBQUUsTUFBTTtRQUNmLFVBQVUsRUFBRSxlQUFlO1FBQzNCLFVBQVUsRUFBRSxDQUFDO1FBQ2IsU0FBUyxFQUFFLCtCQUErQjtRQUMxQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDN0IsQ0FBQztJQUVGLHFDQUFxQztJQUNyQyxJQUFNLGFBQWEsR0FBRyxzSkFTckIsQ0FBQztJQUVGLE9BQU8sQ0FDTCw4QkFDRSwwQkFBUSxhQUFhLEdBQVMsRUFDOUIsaUJBQ0UsSUFBSSxFQUFDLFFBQVEsRUFDYixLQUFLLEVBQUUsV0FBVyxFQUNsQixPQUFPLEVBQUUsV0FBVyxFQUNwQixLQUFLLEVBQUUsUUFBUSxFQUFFLEVBQ2pCLFFBQVEsRUFBRSxTQUFTLFlBRWxCLGdCQUFnQixFQUFFLEdBQ1osSUFDUixDQUNKLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgTWljLCBMb2FkZXIyIH0gZnJvbSAnbHVjaWRlLXJlYWN0JztcbmltcG9ydCB7IHVzZVZvaWNlSW5wdXQgfSBmcm9tICcuLi9ob29rcy91c2VWb2ljZUlucHV0JztcblxuaW50ZXJmYWNlIFZvaWNlSW5wdXRQcm9wcyB7XG4gIG9uVHJhbnNjcmlwdGlvbjogKHRleHQ6IHN0cmluZykgPT4gdm9pZDtcbiAgb25FcnJvcjogKGVycm9yOiBFcnJvcikgPT4gdm9pZDtcbiAgYmFzZVVybDogc3RyaW5nO1xuICBhcGlLZXk6IHN0cmluZztcbiAgdGhlbWU/OiB7XG4gICAgcHJpbWFyeUNvbG9yPzogc3RyaW5nO1xuICAgIGJhY2tncm91bmRDb2xvcj86IHN0cmluZztcbiAgICBmb250RmFtaWx5Pzogc3RyaW5nO1xuICB9O1xufVxuXG5leHBvcnQgY29uc3QgVm9pY2VJbnB1dDogUmVhY3QuRkM8Vm9pY2VJbnB1dFByb3BzPiA9ICh7XG4gIG9uVHJhbnNjcmlwdGlvbixcbiAgb25FcnJvcixcbiAgYmFzZVVybCxcbiAgYXBpS2V5LFxuICB0aGVtZVxufSkgPT4ge1xuICBjb25zdCB7IGlzUmVjb3JkaW5nLCBpc0xvYWRpbmcsIHRvZ2dsZVJlY29yZGluZyB9ID0gdXNlVm9pY2VJbnB1dCh7XG4gICAgYmFzZVVybCxcbiAgICBhcGlLZXksXG4gICAgb25UcmFuc2NyaXB0aW9uLFxuICAgIG9uRXJyb3IsXG4gIH0pO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrID0gKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHtcbiAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgZS5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICB0b2dnbGVSZWNvcmRpbmcoKTtcbiAgfTtcblxuICBjb25zdCBnZXRCdXR0b25Db250ZW50ID0gKCkgPT4ge1xuICAgIGlmIChpc0xvYWRpbmcpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxMb2FkZXIyIFxuICAgICAgICAgIHNpemU9ezE4fSBcbiAgICAgICAgICBjb2xvcj1cIiNmZmZmZmZcIiBcbiAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgYW5pbWF0aW9uOiAnc3BpbiAxcyBsaW5lYXIgaW5maW5pdGUnLFxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gPE1pYyBzaXplPXsxOH0gY29sb3I9XCIjZmZmZmZmXCIgLz47XG4gIH07XG5cbiAgY29uc3QgZ2V0VGl0bGUgPSAoKSA9PiB7XG4gICAgaWYgKGlzTG9hZGluZykgcmV0dXJuICdDb25uZWN0aW5nLi4uJztcbiAgICByZXR1cm4gaXNSZWNvcmRpbmcgPyAnU3RvcCBSZWNvcmRpbmcnIDogJ1N0YXJ0IFJlY29yZGluZyc7XG4gIH07XG5cbiAgY29uc3QgaWRsZUJnID0gdGhlbWU/LnByaW1hcnlDb2xvciB8fCAnIzI5NjJGRic7XG4gIGNvbnN0IGFjdGl2ZUJnID0gJyNGRjNCMzAnOyAvLyByZWQgd2hlbiByZWNvcmRpbmdcbiAgY29uc3QgYnV0dG9uU3R5bGU6IFJlYWN0LkNTU1Byb3BlcnRpZXMgPSB7XG4gICAgYmFja2dyb3VuZENvbG9yOiBpc1JlY29yZGluZyA/IGFjdGl2ZUJnIDogaWRsZUJnLFxuICAgIGNvbG9yOiAnI2ZmZmZmZicsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgYm9yZGVyUmFkaXVzOiAnNTAlJyxcbiAgICB3aWR0aDogJzM2cHgnLFxuICAgIGhlaWdodDogJzM2cHgnLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICBqdXN0aWZ5Q29udGVudDogJ2NlbnRlcicsXG4gICAgY3Vyc29yOiBpc0xvYWRpbmcgPyAnbm90LWFsbG93ZWQnIDogJ3BvaW50ZXInLFxuICAgIG91dGxpbmU6ICdub25lJyxcbiAgICB0cmFuc2l0aW9uOiAnYWxsIDAuMnMgZWFzZScsXG4gICAgZmxleFNocmluazogMCxcbiAgICBib3hTaGFkb3c6ICcwIDFweCAzcHggcmdiYSgwLCAwLCAwLCAwLjA4KScsXG4gICAgb3BhY2l0eTogaXNMb2FkaW5nID8gMC45IDogMSxcbiAgfTtcblxuICAvLyBLZXlmcmFtZSBhbmltYXRpb24gZm9yIHRoZSBzcGlubmVyXG4gIGNvbnN0IHNwaW5LZXlmcmFtZXMgPSBgXG4gICAgQGtleWZyYW1lcyBzcGluIHtcbiAgICAgIGZyb20ge1xuICAgICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgwZGVnKTtcbiAgICAgIH1cbiAgICAgIHRvIHtcbiAgICAgICAgdHJhbnNmb3JtOiByb3RhdGUoMzYwZGVnKTtcbiAgICAgIH1cbiAgICB9XG4gIGA7XG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPHN0eWxlPntzcGluS2V5ZnJhbWVzfTwvc3R5bGU+XG4gICAgICA8YnV0dG9uXG4gICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICBzdHlsZT17YnV0dG9uU3R5bGV9XG4gICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsaWNrfVxuICAgICAgICB0aXRsZT17Z2V0VGl0bGUoKX1cbiAgICAgICAgZGlzYWJsZWQ9e2lzTG9hZGluZ31cbiAgICAgID5cbiAgICAgICAge2dldEJ1dHRvbkNvbnRlbnQoKX1cbiAgICAgIDwvYnV0dG9uPlxuICAgIDwvPlxuICApO1xufTsgXG4iXX0=
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVm9pY2VJbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL1ZvaWNlSW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ25DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBY3BDLE1BQU0sQ0FBQyxJQUFNLFVBQVUsR0FBOEIsVUFBQyxFQU1yRDtRQUxDLGVBQWUscUJBQUEsRUFDZixPQUFPLGFBQUEsRUFDUCxPQUFPLGFBQUEsRUFDUCxNQUFNLFlBQUEsRUFDTixLQUFLLFdBQUE7SUFFQyxJQUFBLEtBQThDLGFBQWEsQ0FBQztRQUNoRSxPQUFPLFNBQUE7UUFDUCxNQUFNLFFBQUE7UUFDTixlQUFlLGlCQUFBO1FBQ2YsT0FBTyxTQUFBO0tBQ1IsQ0FBQyxFQUxNLFdBQVcsaUJBQUEsRUFBRSxTQUFTLGVBQUEsRUFBRSxlQUFlLHFCQUs3QyxDQUFDO0lBRUgsSUFBTSxXQUFXLEdBQUcsVUFBQyxDQUFtQjtRQUN0QyxDQUFDLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDbkIsQ0FBQyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3BCLGVBQWUsRUFBRSxDQUFDO0lBQ3BCLENBQUMsQ0FBQztJQUVGLElBQU0sZ0JBQWdCLEdBQUc7UUFDdkIsSUFBSSxTQUFTLEVBQUUsQ0FBQztZQUNkLE9BQU8sS0FBQyxPQUFPLElBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUMsU0FBUyxHQUFHLENBQUM7UUFDL0MsQ0FBQztRQUNELE9BQU8sS0FBQyxHQUFHLElBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUMsU0FBUyxHQUFHLENBQUM7SUFDM0MsQ0FBQyxDQUFDO0lBRUYsSUFBTSxRQUFRLEdBQUc7UUFDZixJQUFJLFNBQVM7WUFBRSxPQUFPLGVBQWUsQ0FBQztRQUN0QyxPQUFPLFdBQVcsQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixDQUFDO0lBQzVELENBQUMsQ0FBQztJQUVGLElBQU0sTUFBTSxHQUFHLENBQUEsS0FBSyxhQUFMLEtBQUssdUJBQUwsS0FBSyxDQUFFLFlBQVksS0FBSSxTQUFTLENBQUM7SUFDaEQsSUFBTSxRQUFRLEdBQUcsU0FBUyxDQUFDLENBQUMscUJBQXFCO0lBQ2pELElBQU0sV0FBVyxHQUF3QjtRQUN2QyxlQUFlLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU07UUFDaEQsS0FBSyxFQUFFLFNBQVM7UUFDaEIsTUFBTSxFQUFFLE1BQU07UUFDZCxZQUFZLEVBQUUsS0FBSztRQUNuQixLQUFLLEVBQUUsTUFBTTtRQUNiLE1BQU0sRUFBRSxNQUFNO1FBQ2QsT0FBTyxFQUFFLE1BQU07UUFDZixVQUFVLEVBQUUsUUFBUTtRQUNwQixjQUFjLEVBQUUsUUFBUTtRQUN4QixNQUFNLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLFNBQVM7UUFDN0MsT0FBTyxFQUFFLE1BQU07UUFDZixVQUFVLEVBQUUsZUFBZTtRQUMzQixVQUFVLEVBQUUsQ0FBQztRQUNiLFNBQVMsRUFBRSwrQkFBK0I7UUFDMUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQzdCLENBQUM7SUFFRixPQUFPLENBQ0wsNEJBQ0UsaUJBQ0UsSUFBSSxFQUFDLFFBQVEsRUFDYixLQUFLLEVBQUUsV0FBVyxFQUNsQixPQUFPLEVBQUUsV0FBVyxFQUNwQixLQUFLLEVBQUUsUUFBUSxFQUFFLEVBQ2pCLFFBQVEsRUFBRSxTQUFTLFlBRWxCLGdCQUFnQixFQUFFLEdBQ1osR0FDUixDQUNKLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgTWljIH0gZnJvbSAnbHVjaWRlLXJlYWN0JztcbmltcG9ydCB7IHVzZVZvaWNlSW5wdXQgfSBmcm9tICcuLi9ob29rcy91c2VWb2ljZUlucHV0JztcbmltcG9ydCB7IFNwaW5uZXIgfSBmcm9tICcuL1NwaW5uZXInO1xuXG5pbnRlcmZhY2UgVm9pY2VJbnB1dFByb3BzIHtcbiAgb25UcmFuc2NyaXB0aW9uOiAodGV4dDogc3RyaW5nKSA9PiB2b2lkO1xuICBvbkVycm9yOiAoZXJyb3I6IEVycm9yKSA9PiB2b2lkO1xuICBiYXNlVXJsOiBzdHJpbmc7XG4gIGFwaUtleTogc3RyaW5nO1xuICB0aGVtZT86IHtcbiAgICBwcmltYXJ5Q29sb3I/OiBzdHJpbmc7XG4gICAgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xuICAgIGZvbnRGYW1pbHk/OiBzdHJpbmc7XG4gIH07XG59XG5cbmV4cG9ydCBjb25zdCBWb2ljZUlucHV0OiBSZWFjdC5GQzxWb2ljZUlucHV0UHJvcHM+ID0gKHtcbiAgb25UcmFuc2NyaXB0aW9uLFxuICBvbkVycm9yLFxuICBiYXNlVXJsLFxuICBhcGlLZXksXG4gIHRoZW1lXG59KSA9PiB7XG4gIGNvbnN0IHsgaXNSZWNvcmRpbmcsIGlzTG9hZGluZywgdG9nZ2xlUmVjb3JkaW5nIH0gPSB1c2VWb2ljZUlucHV0KHtcbiAgICBiYXNlVXJsLFxuICAgIGFwaUtleSxcbiAgICBvblRyYW5zY3JpcHRpb24sXG4gICAgb25FcnJvcixcbiAgfSk7XG5cbiAgY29uc3QgaGFuZGxlQ2xpY2sgPSAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4ge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIHRvZ2dsZVJlY29yZGluZygpO1xuICB9O1xuXG4gIGNvbnN0IGdldEJ1dHRvbkNvbnRlbnQgPSAoKSA9PiB7XG4gICAgaWYgKGlzTG9hZGluZykge1xuICAgICAgcmV0dXJuIDxTcGlubmVyIHNpemU9ezE4fSBjb2xvcj1cIiNmZmZmZmZcIiAvPjtcbiAgICB9XG4gICAgcmV0dXJuIDxNaWMgc2l6ZT17MTh9IGNvbG9yPVwiI2ZmZmZmZlwiIC8+O1xuICB9O1xuXG4gIGNvbnN0IGdldFRpdGxlID0gKCkgPT4ge1xuICAgIGlmIChpc0xvYWRpbmcpIHJldHVybiAnQ29ubmVjdGluZy4uLic7XG4gICAgcmV0dXJuIGlzUmVjb3JkaW5nID8gJ1N0b3AgUmVjb3JkaW5nJyA6ICdTdGFydCBSZWNvcmRpbmcnO1xuICB9O1xuXG4gIGNvbnN0IGlkbGVCZyA9IHRoZW1lPy5wcmltYXJ5Q29sb3IgfHwgJyMyOTYyRkYnO1xuICBjb25zdCBhY3RpdmVCZyA9ICcjRkYzQjMwJzsgLy8gcmVkIHdoZW4gcmVjb3JkaW5nXG4gIGNvbnN0IGJ1dHRvblN0eWxlOiBSZWFjdC5DU1NQcm9wZXJ0aWVzID0ge1xuICAgIGJhY2tncm91bmRDb2xvcjogaXNSZWNvcmRpbmcgPyBhY3RpdmVCZyA6IGlkbGVCZyxcbiAgICBjb2xvcjogJyNmZmZmZmYnLFxuICAgIGJvcmRlcjogJ25vbmUnLFxuICAgIGJvcmRlclJhZGl1czogJzUwJScsXG4gICAgd2lkdGg6ICczNnB4JyxcbiAgICBoZWlnaHQ6ICczNnB4JyxcbiAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAganVzdGlmeUNvbnRlbnQ6ICdjZW50ZXInLFxuICAgIGN1cnNvcjogaXNMb2FkaW5nID8gJ25vdC1hbGxvd2VkJyA6ICdwb2ludGVyJyxcbiAgICBvdXRsaW5lOiAnbm9uZScsXG4gICAgdHJhbnNpdGlvbjogJ2FsbCAwLjJzIGVhc2UnLFxuICAgIGZsZXhTaHJpbms6IDAsXG4gICAgYm94U2hhZG93OiAnMCAxcHggM3B4IHJnYmEoMCwgMCwgMCwgMC4wOCknLFxuICAgIG9wYWNpdHk6IGlzTG9hZGluZyA/IDAuOSA6IDEsXG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgc3R5bGU9e2J1dHRvblN0eWxlfVxuICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbGlja31cbiAgICAgICAgdGl0bGU9e2dldFRpdGxlKCl9XG4gICAgICAgIGRpc2FibGVkPXtpc0xvYWRpbmd9XG4gICAgICA+XG4gICAgICAgIHtnZXRCdXR0b25Db250ZW50KCl9XG4gICAgICA8L2J1dHRvbj5cbiAgICA8Lz5cbiAgKTtcbn07XG4iXX0=