@positronic/cli 0.0.38 → 0.0.40
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/src/cli.js +41 -77
- package/dist/src/commands/brain.js +52 -410
- package/dist/src/commands/schedule.js +10 -4
- package/dist/src/components/brain-list.js +57 -21
- package/dist/src/components/brain-resolver.js +405 -0
- package/dist/src/components/brain-run.js +529 -0
- package/dist/src/components/brain-watch.js +356 -0
- package/dist/types/cli.d.ts.map +1 -1
- package/dist/types/commands/brain.d.ts +8 -8
- package/dist/types/commands/brain.d.ts.map +1 -1
- package/dist/types/commands/schedule.d.ts +2 -2
- package/dist/types/commands/schedule.d.ts.map +1 -1
- package/dist/types/components/brain-list.d.ts.map +1 -1
- package/dist/types/components/brain-resolver.d.ts +16 -0
- package/dist/types/components/brain-resolver.d.ts.map +1 -0
- package/dist/types/components/brain-run.d.ts +8 -0
- package/dist/types/components/brain-run.d.ts.map +1 -0
- package/dist/types/components/brain-watch.d.ts +12 -0
- package/dist/types/components/brain-watch.d.ts.map +1 -0
- package/package.json +5 -4
|
@@ -0,0 +1,529 @@
|
|
|
1
|
+
function _array_like_to_array(arr, len) {
|
|
2
|
+
if (len == null || len > arr.length) len = arr.length;
|
|
3
|
+
for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
|
|
4
|
+
return arr2;
|
|
5
|
+
}
|
|
6
|
+
function _array_with_holes(arr) {
|
|
7
|
+
if (Array.isArray(arr)) return arr;
|
|
8
|
+
}
|
|
9
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
10
|
+
try {
|
|
11
|
+
var info = gen[key](arg);
|
|
12
|
+
var value = info.value;
|
|
13
|
+
} catch (error) {
|
|
14
|
+
reject(error);
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
if (info.done) {
|
|
18
|
+
resolve(value);
|
|
19
|
+
} else {
|
|
20
|
+
Promise.resolve(value).then(_next, _throw);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function _async_to_generator(fn) {
|
|
24
|
+
return function() {
|
|
25
|
+
var self = this, args = arguments;
|
|
26
|
+
return new Promise(function(resolve, reject) {
|
|
27
|
+
var gen = fn.apply(self, args);
|
|
28
|
+
function _next(value) {
|
|
29
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
30
|
+
}
|
|
31
|
+
function _throw(err) {
|
|
32
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
33
|
+
}
|
|
34
|
+
_next(undefined);
|
|
35
|
+
});
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
function _define_property(obj, key, value) {
|
|
39
|
+
if (key in obj) {
|
|
40
|
+
Object.defineProperty(obj, key, {
|
|
41
|
+
value: value,
|
|
42
|
+
enumerable: true,
|
|
43
|
+
configurable: true,
|
|
44
|
+
writable: true
|
|
45
|
+
});
|
|
46
|
+
} else {
|
|
47
|
+
obj[key] = value;
|
|
48
|
+
}
|
|
49
|
+
return obj;
|
|
50
|
+
}
|
|
51
|
+
function _iterable_to_array_limit(arr, i) {
|
|
52
|
+
var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
|
|
53
|
+
if (_i == null) return;
|
|
54
|
+
var _arr = [];
|
|
55
|
+
var _n = true;
|
|
56
|
+
var _d = false;
|
|
57
|
+
var _s, _e;
|
|
58
|
+
try {
|
|
59
|
+
for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
|
|
60
|
+
_arr.push(_s.value);
|
|
61
|
+
if (i && _arr.length === i) break;
|
|
62
|
+
}
|
|
63
|
+
} catch (err) {
|
|
64
|
+
_d = true;
|
|
65
|
+
_e = err;
|
|
66
|
+
} finally{
|
|
67
|
+
try {
|
|
68
|
+
if (!_n && _i["return"] != null) _i["return"]();
|
|
69
|
+
} finally{
|
|
70
|
+
if (_d) throw _e;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return _arr;
|
|
74
|
+
}
|
|
75
|
+
function _non_iterable_rest() {
|
|
76
|
+
throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
77
|
+
}
|
|
78
|
+
function _object_spread(target) {
|
|
79
|
+
for(var i = 1; i < arguments.length; i++){
|
|
80
|
+
var source = arguments[i] != null ? arguments[i] : {};
|
|
81
|
+
var ownKeys = Object.keys(source);
|
|
82
|
+
if (typeof Object.getOwnPropertySymbols === "function") {
|
|
83
|
+
ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
84
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
85
|
+
}));
|
|
86
|
+
}
|
|
87
|
+
ownKeys.forEach(function(key) {
|
|
88
|
+
_define_property(target, key, source[key]);
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
return target;
|
|
92
|
+
}
|
|
93
|
+
function ownKeys(object, enumerableOnly) {
|
|
94
|
+
var keys = Object.keys(object);
|
|
95
|
+
if (Object.getOwnPropertySymbols) {
|
|
96
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
97
|
+
if (enumerableOnly) {
|
|
98
|
+
symbols = symbols.filter(function(sym) {
|
|
99
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
keys.push.apply(keys, symbols);
|
|
103
|
+
}
|
|
104
|
+
return keys;
|
|
105
|
+
}
|
|
106
|
+
function _object_spread_props(target, source) {
|
|
107
|
+
source = source != null ? source : {};
|
|
108
|
+
if (Object.getOwnPropertyDescriptors) {
|
|
109
|
+
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
110
|
+
} else {
|
|
111
|
+
ownKeys(Object(source)).forEach(function(key) {
|
|
112
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
return target;
|
|
116
|
+
}
|
|
117
|
+
function _sliced_to_array(arr, i) {
|
|
118
|
+
return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
|
|
119
|
+
}
|
|
120
|
+
function _unsupported_iterable_to_array(o, minLen) {
|
|
121
|
+
if (!o) return;
|
|
122
|
+
if (typeof o === "string") return _array_like_to_array(o, minLen);
|
|
123
|
+
var n = Object.prototype.toString.call(o).slice(8, -1);
|
|
124
|
+
if (n === "Object" && o.constructor) n = o.constructor.name;
|
|
125
|
+
if (n === "Map" || n === "Set") return Array.from(n);
|
|
126
|
+
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
|
|
127
|
+
}
|
|
128
|
+
function _ts_generator(thisArg, body) {
|
|
129
|
+
var f, y, t, _ = {
|
|
130
|
+
label: 0,
|
|
131
|
+
sent: function() {
|
|
132
|
+
if (t[0] & 1) throw t[1];
|
|
133
|
+
return t[1];
|
|
134
|
+
},
|
|
135
|
+
trys: [],
|
|
136
|
+
ops: []
|
|
137
|
+
}, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
|
|
138
|
+
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
|
|
139
|
+
return this;
|
|
140
|
+
}), g;
|
|
141
|
+
function verb(n) {
|
|
142
|
+
return function(v) {
|
|
143
|
+
return step([
|
|
144
|
+
n,
|
|
145
|
+
v
|
|
146
|
+
]);
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
function step(op) {
|
|
150
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
151
|
+
while(g && (g = 0, op[0] && (_ = 0)), _)try {
|
|
152
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
153
|
+
if (y = 0, t) op = [
|
|
154
|
+
op[0] & 2,
|
|
155
|
+
t.value
|
|
156
|
+
];
|
|
157
|
+
switch(op[0]){
|
|
158
|
+
case 0:
|
|
159
|
+
case 1:
|
|
160
|
+
t = op;
|
|
161
|
+
break;
|
|
162
|
+
case 4:
|
|
163
|
+
_.label++;
|
|
164
|
+
return {
|
|
165
|
+
value: op[1],
|
|
166
|
+
done: false
|
|
167
|
+
};
|
|
168
|
+
case 5:
|
|
169
|
+
_.label++;
|
|
170
|
+
y = op[1];
|
|
171
|
+
op = [
|
|
172
|
+
0
|
|
173
|
+
];
|
|
174
|
+
continue;
|
|
175
|
+
case 7:
|
|
176
|
+
op = _.ops.pop();
|
|
177
|
+
_.trys.pop();
|
|
178
|
+
continue;
|
|
179
|
+
default:
|
|
180
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
|
|
181
|
+
_ = 0;
|
|
182
|
+
continue;
|
|
183
|
+
}
|
|
184
|
+
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
|
|
185
|
+
_.label = op[1];
|
|
186
|
+
break;
|
|
187
|
+
}
|
|
188
|
+
if (op[0] === 6 && _.label < t[1]) {
|
|
189
|
+
_.label = t[1];
|
|
190
|
+
t = op;
|
|
191
|
+
break;
|
|
192
|
+
}
|
|
193
|
+
if (t && _.label < t[2]) {
|
|
194
|
+
_.label = t[2];
|
|
195
|
+
_.ops.push(op);
|
|
196
|
+
break;
|
|
197
|
+
}
|
|
198
|
+
if (t[2]) _.ops.pop();
|
|
199
|
+
_.trys.pop();
|
|
200
|
+
continue;
|
|
201
|
+
}
|
|
202
|
+
op = body.call(thisArg, _);
|
|
203
|
+
} catch (e) {
|
|
204
|
+
op = [
|
|
205
|
+
6,
|
|
206
|
+
e
|
|
207
|
+
];
|
|
208
|
+
y = 0;
|
|
209
|
+
} finally{
|
|
210
|
+
f = t = 0;
|
|
211
|
+
}
|
|
212
|
+
if (op[0] & 5) throw op[1];
|
|
213
|
+
return {
|
|
214
|
+
value: op[0] ? op[1] : void 0,
|
|
215
|
+
done: true
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
import React, { useState, useEffect, useCallback } from 'react';
|
|
220
|
+
import { Box, Text, useInput, useApp } from 'ink';
|
|
221
|
+
import { ErrorComponent } from './error.js';
|
|
222
|
+
import { Watch } from './watch.js';
|
|
223
|
+
import { apiClient, isApiLocalDevMode } from '../commands/helpers.js';
|
|
224
|
+
export var BrainRun = function(param) {
|
|
225
|
+
var identifier = param.identifier, watch = param.watch, options = param.options;
|
|
226
|
+
var _useState = _sliced_to_array(useState('searching'), 2), phase = _useState[0], setPhase = _useState[1];
|
|
227
|
+
var _useState1 = _sliced_to_array(useState([]), 2), brains = _useState1[0], setBrains = _useState1[1];
|
|
228
|
+
var _useState2 = _sliced_to_array(useState(0), 2), selectedIndex = _useState2[0], setSelectedIndex = _useState2[1];
|
|
229
|
+
var _useState3 = _sliced_to_array(useState(null), 2), runId = _useState3[0], setRunId = _useState3[1];
|
|
230
|
+
var _useState4 = _sliced_to_array(useState(null), 2), error = _useState4[0], setError = _useState4[1];
|
|
231
|
+
var exit = useApp().exit;
|
|
232
|
+
var getConnectionError = useCallback(function() {
|
|
233
|
+
if (isApiLocalDevMode()) {
|
|
234
|
+
return {
|
|
235
|
+
title: 'Connection Error',
|
|
236
|
+
message: 'Error connecting to the local development server.',
|
|
237
|
+
details: "Please ensure the server is running ('positronic server' or 'px s')."
|
|
238
|
+
};
|
|
239
|
+
} else {
|
|
240
|
+
return {
|
|
241
|
+
title: 'Connection Error',
|
|
242
|
+
message: 'Error connecting to the remote project server.',
|
|
243
|
+
details: 'Please check your network connection and verify the project URL is correct.'
|
|
244
|
+
};
|
|
245
|
+
}
|
|
246
|
+
}, []);
|
|
247
|
+
var runBrain = useCallback(function(brainTitle) {
|
|
248
|
+
return _async_to_generator(function() {
|
|
249
|
+
var response, result, errorText, err, baseError;
|
|
250
|
+
return _ts_generator(this, function(_state) {
|
|
251
|
+
switch(_state.label){
|
|
252
|
+
case 0:
|
|
253
|
+
setPhase('running');
|
|
254
|
+
_state.label = 1;
|
|
255
|
+
case 1:
|
|
256
|
+
_state.trys.push([
|
|
257
|
+
1,
|
|
258
|
+
8,
|
|
259
|
+
,
|
|
260
|
+
9
|
|
261
|
+
]);
|
|
262
|
+
return [
|
|
263
|
+
4,
|
|
264
|
+
apiClient.fetch('/brains/runs', {
|
|
265
|
+
method: 'POST',
|
|
266
|
+
headers: {
|
|
267
|
+
'Content-Type': 'application/json'
|
|
268
|
+
},
|
|
269
|
+
body: JSON.stringify({
|
|
270
|
+
identifier: brainTitle,
|
|
271
|
+
options: options
|
|
272
|
+
})
|
|
273
|
+
})
|
|
274
|
+
];
|
|
275
|
+
case 2:
|
|
276
|
+
response = _state.sent();
|
|
277
|
+
if (!(response.status === 201)) return [
|
|
278
|
+
3,
|
|
279
|
+
4
|
|
280
|
+
];
|
|
281
|
+
return [
|
|
282
|
+
4,
|
|
283
|
+
response.json()
|
|
284
|
+
];
|
|
285
|
+
case 3:
|
|
286
|
+
result = _state.sent();
|
|
287
|
+
setRunId(result.brainRunId);
|
|
288
|
+
setPhase('complete');
|
|
289
|
+
return [
|
|
290
|
+
3,
|
|
291
|
+
7
|
|
292
|
+
];
|
|
293
|
+
case 4:
|
|
294
|
+
if (!(response.status === 404)) return [
|
|
295
|
+
3,
|
|
296
|
+
5
|
|
297
|
+
];
|
|
298
|
+
setError({
|
|
299
|
+
title: 'Brain Not Found',
|
|
300
|
+
message: "Brain '".concat(brainTitle, "' not found."),
|
|
301
|
+
details: 'The brain may have been removed or renamed since the search.'
|
|
302
|
+
});
|
|
303
|
+
setPhase('error');
|
|
304
|
+
return [
|
|
305
|
+
3,
|
|
306
|
+
7
|
|
307
|
+
];
|
|
308
|
+
case 5:
|
|
309
|
+
return [
|
|
310
|
+
4,
|
|
311
|
+
response.text()
|
|
312
|
+
];
|
|
313
|
+
case 6:
|
|
314
|
+
errorText = _state.sent();
|
|
315
|
+
setError({
|
|
316
|
+
title: 'Server Error',
|
|
317
|
+
message: "Error starting brain run: ".concat(response.status, " ").concat(response.statusText),
|
|
318
|
+
details: errorText
|
|
319
|
+
});
|
|
320
|
+
setPhase('error');
|
|
321
|
+
_state.label = 7;
|
|
322
|
+
case 7:
|
|
323
|
+
return [
|
|
324
|
+
3,
|
|
325
|
+
9
|
|
326
|
+
];
|
|
327
|
+
case 8:
|
|
328
|
+
err = _state.sent();
|
|
329
|
+
baseError = getConnectionError();
|
|
330
|
+
setError(_object_spread_props(_object_spread({}, baseError), {
|
|
331
|
+
details: "".concat(baseError.details, " ").concat(err.message)
|
|
332
|
+
}));
|
|
333
|
+
setPhase('error');
|
|
334
|
+
return [
|
|
335
|
+
3,
|
|
336
|
+
9
|
|
337
|
+
];
|
|
338
|
+
case 9:
|
|
339
|
+
return [
|
|
340
|
+
2
|
|
341
|
+
];
|
|
342
|
+
}
|
|
343
|
+
});
|
|
344
|
+
})();
|
|
345
|
+
}, [
|
|
346
|
+
options,
|
|
347
|
+
getConnectionError
|
|
348
|
+
]);
|
|
349
|
+
// Initial search
|
|
350
|
+
useEffect(function() {
|
|
351
|
+
var searchBrains = function() {
|
|
352
|
+
return _async_to_generator(function() {
|
|
353
|
+
var url, response, errorText, data, err, baseError;
|
|
354
|
+
return _ts_generator(this, function(_state) {
|
|
355
|
+
switch(_state.label){
|
|
356
|
+
case 0:
|
|
357
|
+
_state.trys.push([
|
|
358
|
+
0,
|
|
359
|
+
9,
|
|
360
|
+
,
|
|
361
|
+
10
|
|
362
|
+
]);
|
|
363
|
+
url = "/brains?q=".concat(encodeURIComponent(identifier));
|
|
364
|
+
return [
|
|
365
|
+
4,
|
|
366
|
+
apiClient.fetch(url, {
|
|
367
|
+
method: 'GET'
|
|
368
|
+
})
|
|
369
|
+
];
|
|
370
|
+
case 1:
|
|
371
|
+
response = _state.sent();
|
|
372
|
+
if (!!response.ok) return [
|
|
373
|
+
3,
|
|
374
|
+
3
|
|
375
|
+
];
|
|
376
|
+
return [
|
|
377
|
+
4,
|
|
378
|
+
response.text()
|
|
379
|
+
];
|
|
380
|
+
case 2:
|
|
381
|
+
errorText = _state.sent();
|
|
382
|
+
setError({
|
|
383
|
+
title: 'Server Error',
|
|
384
|
+
message: "Error searching for brains: ".concat(response.status, " ").concat(response.statusText),
|
|
385
|
+
details: errorText
|
|
386
|
+
});
|
|
387
|
+
setPhase('error');
|
|
388
|
+
return [
|
|
389
|
+
2
|
|
390
|
+
];
|
|
391
|
+
case 3:
|
|
392
|
+
return [
|
|
393
|
+
4,
|
|
394
|
+
response.json()
|
|
395
|
+
];
|
|
396
|
+
case 4:
|
|
397
|
+
data = _state.sent();
|
|
398
|
+
if (!(data.count === 0)) return [
|
|
399
|
+
3,
|
|
400
|
+
5
|
|
401
|
+
];
|
|
402
|
+
setError({
|
|
403
|
+
title: 'Brain Not Found',
|
|
404
|
+
message: "No brains found matching '".concat(identifier, "'."),
|
|
405
|
+
details: 'Please check that:\n 1. The brain name is spelled correctly\n 2. The brain exists in your project\n 3. The brain has been properly defined and exported\n\nYou can list available brains with: positronic list'
|
|
406
|
+
});
|
|
407
|
+
setPhase('error');
|
|
408
|
+
return [
|
|
409
|
+
3,
|
|
410
|
+
8
|
|
411
|
+
];
|
|
412
|
+
case 5:
|
|
413
|
+
if (!(data.count === 1)) return [
|
|
414
|
+
3,
|
|
415
|
+
7
|
|
416
|
+
];
|
|
417
|
+
// Exactly one match - run it directly
|
|
418
|
+
return [
|
|
419
|
+
4,
|
|
420
|
+
runBrain(data.brains[0].title)
|
|
421
|
+
];
|
|
422
|
+
case 6:
|
|
423
|
+
_state.sent();
|
|
424
|
+
return [
|
|
425
|
+
3,
|
|
426
|
+
8
|
|
427
|
+
];
|
|
428
|
+
case 7:
|
|
429
|
+
// Multiple matches - show disambiguation UI
|
|
430
|
+
setBrains(data.brains);
|
|
431
|
+
setPhase('disambiguating');
|
|
432
|
+
_state.label = 8;
|
|
433
|
+
case 8:
|
|
434
|
+
return [
|
|
435
|
+
3,
|
|
436
|
+
10
|
|
437
|
+
];
|
|
438
|
+
case 9:
|
|
439
|
+
err = _state.sent();
|
|
440
|
+
baseError = getConnectionError();
|
|
441
|
+
setError(_object_spread_props(_object_spread({}, baseError), {
|
|
442
|
+
details: "".concat(baseError.details, " ").concat(err.message)
|
|
443
|
+
}));
|
|
444
|
+
setPhase('error');
|
|
445
|
+
return [
|
|
446
|
+
3,
|
|
447
|
+
10
|
|
448
|
+
];
|
|
449
|
+
case 10:
|
|
450
|
+
return [
|
|
451
|
+
2
|
|
452
|
+
];
|
|
453
|
+
}
|
|
454
|
+
});
|
|
455
|
+
})();
|
|
456
|
+
};
|
|
457
|
+
searchBrains();
|
|
458
|
+
}, [
|
|
459
|
+
identifier,
|
|
460
|
+
runBrain,
|
|
461
|
+
getConnectionError
|
|
462
|
+
]);
|
|
463
|
+
// Handle keyboard input for disambiguation
|
|
464
|
+
useInput(function(input, key) {
|
|
465
|
+
if (phase !== 'disambiguating') return;
|
|
466
|
+
if (key.upArrow) {
|
|
467
|
+
setSelectedIndex(function(prev) {
|
|
468
|
+
return (prev - 1 + brains.length) % brains.length;
|
|
469
|
+
});
|
|
470
|
+
} else if (key.downArrow) {
|
|
471
|
+
setSelectedIndex(function(prev) {
|
|
472
|
+
return (prev + 1) % brains.length;
|
|
473
|
+
});
|
|
474
|
+
} else if (key.return) {
|
|
475
|
+
var selectedBrain = brains[selectedIndex];
|
|
476
|
+
runBrain(selectedBrain.title);
|
|
477
|
+
} else if (input === 'q' || key.escape) {
|
|
478
|
+
exit();
|
|
479
|
+
}
|
|
480
|
+
});
|
|
481
|
+
// Render based on phase
|
|
482
|
+
if (phase === 'searching') {
|
|
483
|
+
return /*#__PURE__*/ React.createElement(Box, null, /*#__PURE__*/ React.createElement(Text, null, "Searching for brain '", identifier, "'..."));
|
|
484
|
+
}
|
|
485
|
+
if (phase === 'error' && error) {
|
|
486
|
+
return /*#__PURE__*/ React.createElement(ErrorComponent, {
|
|
487
|
+
error: error
|
|
488
|
+
});
|
|
489
|
+
}
|
|
490
|
+
if (phase === 'disambiguating') {
|
|
491
|
+
return /*#__PURE__*/ React.createElement(Box, {
|
|
492
|
+
flexDirection: "column"
|
|
493
|
+
}, /*#__PURE__*/ React.createElement(Text, {
|
|
494
|
+
bold: true
|
|
495
|
+
}, "Multiple brains match '", identifier, "':"), /*#__PURE__*/ React.createElement(Box, {
|
|
496
|
+
marginTop: 1,
|
|
497
|
+
flexDirection: "column"
|
|
498
|
+
}, brains.map(function(brain, index) {
|
|
499
|
+
var isSelected = index === selectedIndex;
|
|
500
|
+
return /*#__PURE__*/ React.createElement(Box, {
|
|
501
|
+
key: brain.title,
|
|
502
|
+
flexDirection: "column",
|
|
503
|
+
marginBottom: 1
|
|
504
|
+
}, /*#__PURE__*/ React.createElement(Text, {
|
|
505
|
+
color: isSelected ? 'cyan' : undefined
|
|
506
|
+
}, isSelected ? '▶ ' : ' ', /*#__PURE__*/ React.createElement(Text, {
|
|
507
|
+
bold: true
|
|
508
|
+
}, brain.title)), /*#__PURE__*/ React.createElement(Text, {
|
|
509
|
+
dimColor: true
|
|
510
|
+
}, ' ', brain.description));
|
|
511
|
+
})), /*#__PURE__*/ React.createElement(Box, {
|
|
512
|
+
marginTop: 1
|
|
513
|
+
}, /*#__PURE__*/ React.createElement(Text, {
|
|
514
|
+
dimColor: true
|
|
515
|
+
}, "Use arrow keys to navigate, Enter to select, q to quit")));
|
|
516
|
+
}
|
|
517
|
+
if (phase === 'running') {
|
|
518
|
+
return /*#__PURE__*/ React.createElement(Box, null, /*#__PURE__*/ React.createElement(Text, null, "Starting brain run..."));
|
|
519
|
+
}
|
|
520
|
+
if (phase === 'complete' && runId) {
|
|
521
|
+
if (watch) {
|
|
522
|
+
return /*#__PURE__*/ React.createElement(Watch, {
|
|
523
|
+
runId: runId
|
|
524
|
+
});
|
|
525
|
+
}
|
|
526
|
+
return /*#__PURE__*/ React.createElement(Text, null, "Run ID: ", runId);
|
|
527
|
+
}
|
|
528
|
+
return null;
|
|
529
|
+
};
|