@positronic/cli 0.0.50 → 0.0.52

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/dist/src/cli.js +37 -68
  2. package/dist/src/commands/brain.js +14 -23
  3. package/dist/src/commands/server.js +28 -41
  4. package/dist/src/components/brain-rerun.js +1 -1
  5. package/dist/src/components/brain-resolver.js +18 -49
  6. package/dist/src/components/brain-run.js +26 -43
  7. package/dist/src/components/brain-top-table.js +153 -0
  8. package/dist/src/components/brain-top.js +139 -0
  9. package/dist/src/components/project-select.js +32 -52
  10. package/dist/src/components/select-list.js +102 -0
  11. package/dist/src/components/top-navigator.js +259 -0
  12. package/dist/src/components/watch-resolver.js +592 -0
  13. package/dist/src/components/watch.js +114 -112
  14. package/dist/src/hooks/useBrainMachine.js +19 -0
  15. package/dist/types/cli.d.ts.map +1 -1
  16. package/dist/types/commands/brain.d.ts +6 -3
  17. package/dist/types/commands/brain.d.ts.map +1 -1
  18. package/dist/types/commands/server.d.ts.map +1 -1
  19. package/dist/types/components/brain-resolver.d.ts.map +1 -1
  20. package/dist/types/components/brain-run.d.ts.map +1 -1
  21. package/dist/types/components/brain-top-table.d.ts +22 -0
  22. package/dist/types/components/brain-top-table.d.ts.map +1 -0
  23. package/dist/types/components/brain-top.d.ts +6 -0
  24. package/dist/types/components/brain-top.d.ts.map +1 -0
  25. package/dist/types/components/project-select.d.ts.map +1 -1
  26. package/dist/types/components/select-list.d.ts +23 -0
  27. package/dist/types/components/select-list.d.ts.map +1 -0
  28. package/dist/types/components/top-navigator.d.ts +6 -0
  29. package/dist/types/components/top-navigator.d.ts.map +1 -0
  30. package/dist/types/components/watch-resolver.d.ts +15 -0
  31. package/dist/types/components/watch-resolver.d.ts.map +1 -0
  32. package/dist/types/components/watch.d.ts +3 -1
  33. package/dist/types/components/watch.d.ts.map +1 -1
  34. package/dist/types/hooks/useBrainMachine.d.ts +37 -0
  35. package/dist/types/hooks/useBrainMachine.d.ts.map +1 -0
  36. package/package.json +5 -4
@@ -0,0 +1,592 @@
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 _instanceof(left, right) {
52
+ if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
53
+ return !!right[Symbol.hasInstance](left);
54
+ } else {
55
+ return left instanceof right;
56
+ }
57
+ }
58
+ function _iterable_to_array_limit(arr, i) {
59
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
60
+ if (_i == null) return;
61
+ var _arr = [];
62
+ var _n = true;
63
+ var _d = false;
64
+ var _s, _e;
65
+ try {
66
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
67
+ _arr.push(_s.value);
68
+ if (i && _arr.length === i) break;
69
+ }
70
+ } catch (err) {
71
+ _d = true;
72
+ _e = err;
73
+ } finally{
74
+ try {
75
+ if (!_n && _i["return"] != null) _i["return"]();
76
+ } finally{
77
+ if (_d) throw _e;
78
+ }
79
+ }
80
+ return _arr;
81
+ }
82
+ function _non_iterable_rest() {
83
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
84
+ }
85
+ function _object_spread(target) {
86
+ for(var i = 1; i < arguments.length; i++){
87
+ var source = arguments[i] != null ? arguments[i] : {};
88
+ var ownKeys = Object.keys(source);
89
+ if (typeof Object.getOwnPropertySymbols === "function") {
90
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
91
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
92
+ }));
93
+ }
94
+ ownKeys.forEach(function(key) {
95
+ _define_property(target, key, source[key]);
96
+ });
97
+ }
98
+ return target;
99
+ }
100
+ function ownKeys(object, enumerableOnly) {
101
+ var keys = Object.keys(object);
102
+ if (Object.getOwnPropertySymbols) {
103
+ var symbols = Object.getOwnPropertySymbols(object);
104
+ if (enumerableOnly) {
105
+ symbols = symbols.filter(function(sym) {
106
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
107
+ });
108
+ }
109
+ keys.push.apply(keys, symbols);
110
+ }
111
+ return keys;
112
+ }
113
+ function _object_spread_props(target, source) {
114
+ source = source != null ? source : {};
115
+ if (Object.getOwnPropertyDescriptors) {
116
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
117
+ } else {
118
+ ownKeys(Object(source)).forEach(function(key) {
119
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
120
+ });
121
+ }
122
+ return target;
123
+ }
124
+ function _sliced_to_array(arr, i) {
125
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
126
+ }
127
+ function _type_of(obj) {
128
+ "@swc/helpers - typeof";
129
+ return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
130
+ }
131
+ function _unsupported_iterable_to_array(o, minLen) {
132
+ if (!o) return;
133
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
134
+ var n = Object.prototype.toString.call(o).slice(8, -1);
135
+ if (n === "Object" && o.constructor) n = o.constructor.name;
136
+ if (n === "Map" || n === "Set") return Array.from(n);
137
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
138
+ }
139
+ function _ts_generator(thisArg, body) {
140
+ var f, y, t, _ = {
141
+ label: 0,
142
+ sent: function() {
143
+ if (t[0] & 1) throw t[1];
144
+ return t[1];
145
+ },
146
+ trys: [],
147
+ ops: []
148
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
149
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
150
+ return this;
151
+ }), g;
152
+ function verb(n) {
153
+ return function(v) {
154
+ return step([
155
+ n,
156
+ v
157
+ ]);
158
+ };
159
+ }
160
+ function step(op) {
161
+ if (f) throw new TypeError("Generator is already executing.");
162
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
163
+ 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;
164
+ if (y = 0, t) op = [
165
+ op[0] & 2,
166
+ t.value
167
+ ];
168
+ switch(op[0]){
169
+ case 0:
170
+ case 1:
171
+ t = op;
172
+ break;
173
+ case 4:
174
+ _.label++;
175
+ return {
176
+ value: op[1],
177
+ done: false
178
+ };
179
+ case 5:
180
+ _.label++;
181
+ y = op[1];
182
+ op = [
183
+ 0
184
+ ];
185
+ continue;
186
+ case 7:
187
+ op = _.ops.pop();
188
+ _.trys.pop();
189
+ continue;
190
+ default:
191
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
192
+ _ = 0;
193
+ continue;
194
+ }
195
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
196
+ _.label = op[1];
197
+ break;
198
+ }
199
+ if (op[0] === 6 && _.label < t[1]) {
200
+ _.label = t[1];
201
+ t = op;
202
+ break;
203
+ }
204
+ if (t && _.label < t[2]) {
205
+ _.label = t[2];
206
+ _.ops.push(op);
207
+ break;
208
+ }
209
+ if (t[2]) _.ops.pop();
210
+ _.trys.pop();
211
+ continue;
212
+ }
213
+ op = body.call(thisArg, _);
214
+ } catch (e) {
215
+ op = [
216
+ 6,
217
+ e
218
+ ];
219
+ y = 0;
220
+ } finally{
221
+ f = t = 0;
222
+ }
223
+ if (op[0] & 5) throw op[1];
224
+ return {
225
+ value: op[0] ? op[1] : void 0,
226
+ done: true
227
+ };
228
+ }
229
+ }
230
+ import React, { useMemo } from 'react';
231
+ import { Box, Text } from 'ink';
232
+ import { createMachine, state, transition, reduce, invoke, immediate, guard } from 'robot3';
233
+ import { useMachine } from 'react-robot';
234
+ import { Watch } from './watch.js';
235
+ import { ErrorComponent } from './error.js';
236
+ import { SelectList } from './select-list.js';
237
+ import { apiClient, isApiLocalDevMode } from '../commands/helpers.js';
238
+ // Helper to get connection error message
239
+ var getConnectionError = function() {
240
+ if (isApiLocalDevMode()) {
241
+ return {
242
+ title: 'Connection Error',
243
+ message: 'Error connecting to the local development server.',
244
+ details: "Please ensure the server is running ('positronic server' or 'px s')."
245
+ };
246
+ }
247
+ return {
248
+ title: 'Connection Error',
249
+ message: 'Error connecting to the remote project server.',
250
+ details: 'Please check your network connection and verify the project URL is correct.'
251
+ };
252
+ };
253
+ // Async functions for invoke states
254
+ var searchBrains = function(ctx) {
255
+ return _async_to_generator(function() {
256
+ var url, response, errorText;
257
+ return _ts_generator(this, function(_state) {
258
+ switch(_state.label){
259
+ case 0:
260
+ url = "/brains?q=".concat(encodeURIComponent(ctx.identifier));
261
+ return [
262
+ 4,
263
+ apiClient.fetch(url, {
264
+ method: 'GET'
265
+ })
266
+ ];
267
+ case 1:
268
+ response = _state.sent();
269
+ if (!!response.ok) return [
270
+ 3,
271
+ 3
272
+ ];
273
+ return [
274
+ 4,
275
+ response.text()
276
+ ];
277
+ case 2:
278
+ errorText = _state.sent();
279
+ throw {
280
+ title: 'Server Error',
281
+ message: "Error searching for brains: ".concat(response.status, " ").concat(response.statusText),
282
+ details: errorText
283
+ };
284
+ case 3:
285
+ return [
286
+ 4,
287
+ response.json()
288
+ ];
289
+ case 4:
290
+ return [
291
+ 2,
292
+ _state.sent()
293
+ ];
294
+ }
295
+ });
296
+ })();
297
+ };
298
+ var searchRun = function(ctx) {
299
+ return _async_to_generator(function() {
300
+ var url, response, errorText;
301
+ return _ts_generator(this, function(_state) {
302
+ switch(_state.label){
303
+ case 0:
304
+ url = "/brains/runs/".concat(encodeURIComponent(ctx.identifier));
305
+ return [
306
+ 4,
307
+ apiClient.fetch(url, {
308
+ method: 'GET'
309
+ })
310
+ ];
311
+ case 1:
312
+ response = _state.sent();
313
+ if (!response.ok) return [
314
+ 3,
315
+ 3
316
+ ];
317
+ return [
318
+ 4,
319
+ response.json()
320
+ ];
321
+ case 2:
322
+ return [
323
+ 2,
324
+ _state.sent()
325
+ ];
326
+ case 3:
327
+ if (response.status === 404) {
328
+ throw {
329
+ title: 'Not Found',
330
+ message: "No brain or run found matching '".concat(ctx.identifier, "'."),
331
+ details: 'Please check that:\n' + ' 1. The brain name or run ID is correct\n' + ' 2. The brain exists in your project\n' + '\nYou can list available brains with: positronic list'
332
+ };
333
+ }
334
+ return [
335
+ 4,
336
+ response.text()
337
+ ];
338
+ case 4:
339
+ errorText = _state.sent();
340
+ throw {
341
+ title: 'Server Error',
342
+ message: "Error looking up run: ".concat(response.status, " ").concat(response.statusText),
343
+ details: errorText
344
+ };
345
+ }
346
+ });
347
+ })();
348
+ };
349
+ var fetchActiveRuns = function(ctx) {
350
+ return _async_to_generator(function() {
351
+ var apiPath, response, runs, errorText;
352
+ return _ts_generator(this, function(_state) {
353
+ switch(_state.label){
354
+ case 0:
355
+ apiPath = "/brains/".concat(encodeURIComponent(ctx.resolvedBrainTitle), "/active-runs");
356
+ return [
357
+ 4,
358
+ apiClient.fetch(apiPath, {
359
+ method: 'GET'
360
+ })
361
+ ];
362
+ case 1:
363
+ response = _state.sent();
364
+ if (!(response.status === 200)) return [
365
+ 3,
366
+ 3
367
+ ];
368
+ return [
369
+ 4,
370
+ response.json()
371
+ ];
372
+ case 2:
373
+ runs = _state.sent().runs;
374
+ return [
375
+ 2,
376
+ runs
377
+ ];
378
+ case 3:
379
+ return [
380
+ 4,
381
+ response.text()
382
+ ];
383
+ case 4:
384
+ errorText = _state.sent();
385
+ throw {
386
+ title: 'API Error',
387
+ message: 'Failed to get active runs for brain "'.concat(ctx.resolvedBrainTitle, '".'),
388
+ details: "Server returned ".concat(response.status, ": ").concat(errorText)
389
+ };
390
+ }
391
+ });
392
+ })();
393
+ };
394
+ // Error handler for network errors
395
+ var handleNetworkError = function(err) {
396
+ // If it's already an ErrorInfo object (thrown from our async functions)
397
+ if (err && (typeof err === "undefined" ? "undefined" : _type_of(err)) === 'object' && 'title' in err && 'message' in err) {
398
+ return err;
399
+ }
400
+ // Network/connection error
401
+ var baseError = getConnectionError();
402
+ var message = _instanceof(err, Error) ? err.message : String(err);
403
+ return _object_spread_props(_object_spread({}, baseError), {
404
+ details: "".concat(baseError.details, " ").concat(message)
405
+ });
406
+ };
407
+ // Reducers
408
+ var storeBrainSearchResult = reduce(function(ctx, ev) {
409
+ return _object_spread_props(_object_spread({}, ctx), {
410
+ brainSearchResult: ev.data
411
+ });
412
+ });
413
+ var storeRunAndResolve = reduce(function(ctx, ev) {
414
+ return _object_spread_props(_object_spread({}, ctx), {
415
+ runSearchResult: ev.data,
416
+ resolvedRunId: ev.data.brainRunId
417
+ });
418
+ });
419
+ var storeActiveRunsResult = reduce(function(ctx, ev) {
420
+ return _object_spread_props(_object_spread({}, ctx), {
421
+ activeRunsResult: ev.data
422
+ });
423
+ });
424
+ var setErrorFromEvent = reduce(function(ctx, ev) {
425
+ return _object_spread_props(_object_spread({}, ctx), {
426
+ error: handleNetworkError(ev.error)
427
+ });
428
+ });
429
+ var applyBrainFound = reduce(function(ctx) {
430
+ return _object_spread_props(_object_spread({}, ctx), {
431
+ resolvedBrainTitle: ctx.brainSearchResult.brains[0].title
432
+ });
433
+ });
434
+ var applyBrainsMultiple = reduce(function(ctx) {
435
+ return _object_spread_props(_object_spread({}, ctx), {
436
+ brains: ctx.brainSearchResult.brains
437
+ });
438
+ });
439
+ var applyActiveRunFound = reduce(function(ctx) {
440
+ return _object_spread_props(_object_spread({}, ctx), {
441
+ resolvedRunId: ctx.activeRunsResult[0].brainRunId
442
+ });
443
+ });
444
+ var applyMultipleActiveRuns = reduce(function(ctx) {
445
+ return _object_spread_props(_object_spread({}, ctx), {
446
+ activeRuns: ctx.activeRunsResult
447
+ });
448
+ });
449
+ var setBrainTitleFromSelection = reduce(function(ctx, ev) {
450
+ return _object_spread_props(_object_spread({}, ctx), {
451
+ resolvedBrainTitle: ev.brainTitle
452
+ });
453
+ });
454
+ // Guards for routing
455
+ var brainFoundGuard = guard(function(ctx) {
456
+ var _ctx_brainSearchResult;
457
+ return ((_ctx_brainSearchResult = ctx.brainSearchResult) === null || _ctx_brainSearchResult === void 0 ? void 0 : _ctx_brainSearchResult.count) === 1;
458
+ });
459
+ var brainNotFoundGuard = guard(function(ctx) {
460
+ var _ctx_brainSearchResult;
461
+ return ((_ctx_brainSearchResult = ctx.brainSearchResult) === null || _ctx_brainSearchResult === void 0 ? void 0 : _ctx_brainSearchResult.count) === 0;
462
+ });
463
+ var brainsMultipleGuard = guard(function(ctx) {
464
+ var _ctx_brainSearchResult;
465
+ var _ctx_brainSearchResult_count;
466
+ return ((_ctx_brainSearchResult_count = (_ctx_brainSearchResult = ctx.brainSearchResult) === null || _ctx_brainSearchResult === void 0 ? void 0 : _ctx_brainSearchResult.count) !== null && _ctx_brainSearchResult_count !== void 0 ? _ctx_brainSearchResult_count : 0) > 1;
467
+ });
468
+ var activeRunFoundGuard = guard(function(ctx) {
469
+ var _ctx_activeRunsResult;
470
+ return ((_ctx_activeRunsResult = ctx.activeRunsResult) === null || _ctx_activeRunsResult === void 0 ? void 0 : _ctx_activeRunsResult.length) === 1;
471
+ });
472
+ var noActiveRunsGuard = guard(function(ctx) {
473
+ var _ctx_activeRunsResult;
474
+ return ((_ctx_activeRunsResult = ctx.activeRunsResult) === null || _ctx_activeRunsResult === void 0 ? void 0 : _ctx_activeRunsResult.length) === 0;
475
+ });
476
+ var multipleActiveRunsGuard = guard(function(ctx) {
477
+ var _ctx_activeRunsResult;
478
+ var _ctx_activeRunsResult_length;
479
+ return ((_ctx_activeRunsResult_length = (_ctx_activeRunsResult = ctx.activeRunsResult) === null || _ctx_activeRunsResult === void 0 ? void 0 : _ctx_activeRunsResult.length) !== null && _ctx_activeRunsResult_length !== void 0 ? _ctx_activeRunsResult_length : 0) > 1;
480
+ });
481
+ // State machine definition
482
+ var createResolverMachine = function(identifier) {
483
+ return createMachine('searchingBrain', {
484
+ // Invoke state: search for brain by name
485
+ searchingBrain: invoke(searchBrains, transition('done', 'routeBrainSearch', storeBrainSearchResult), transition('error', 'error', setErrorFromEvent)),
486
+ // Route based on brain search result
487
+ routeBrainSearch: state(immediate('fetchingActiveRuns', brainFoundGuard, applyBrainFound), immediate('searchingRun', brainNotFoundGuard), immediate('disambiguating', brainsMultipleGuard, applyBrainsMultiple)),
488
+ // Invoke state: search for run by ID
489
+ searchingRun: invoke(searchRun, transition('done', 'resolved', storeRunAndResolve), transition('error', 'error', setErrorFromEvent)),
490
+ // User selects from multiple matching brains
491
+ disambiguating: state(transition('BRAIN_SELECTED', 'fetchingActiveRuns', setBrainTitleFromSelection)),
492
+ // Invoke state: fetch active runs for the brain
493
+ fetchingActiveRuns: invoke(fetchActiveRuns, transition('done', 'routeActiveRuns', storeActiveRunsResult), transition('error', 'error', setErrorFromEvent)),
494
+ // Route based on active runs result
495
+ routeActiveRuns: state(immediate('resolved', activeRunFoundGuard, applyActiveRunFound), immediate('noActiveRuns', noActiveRunsGuard), immediate('multipleActiveRuns', multipleActiveRunsGuard, applyMultipleActiveRuns)),
496
+ // Terminal states
497
+ resolved: state(),
498
+ noActiveRuns: state(),
499
+ multipleActiveRuns: state(),
500
+ error: state()
501
+ }, function() {
502
+ return {
503
+ identifier: identifier,
504
+ brains: [],
505
+ resolvedBrainTitle: null,
506
+ resolvedRunId: null,
507
+ activeRuns: [],
508
+ error: null,
509
+ brainSearchResult: null,
510
+ runSearchResult: null,
511
+ activeRunsResult: null
512
+ };
513
+ });
514
+ };
515
+ /**
516
+ * WatchResolver - Resolves an identifier to either a brain name or run ID and starts watching.
517
+ *
518
+ * State machine handles all async operations via invoke.
519
+ * Resolution order:
520
+ * 1. Try to resolve as a brain name (fuzzy search)
521
+ * 2. If no brain matches, try as a run ID
522
+ * 3. If neither works, show an error
523
+ */ export var WatchResolver = function(param) {
524
+ var identifier = param.identifier;
525
+ var machine = useMemo(function() {
526
+ return createResolverMachine(identifier);
527
+ }, [
528
+ identifier
529
+ ]);
530
+ var _useMachine = _sliced_to_array(useMachine(machine), 2), current = _useMachine[0], send = _useMachine[1];
531
+ var currentState = current.name;
532
+ var _current_context = current.context, brains = _current_context.brains, resolvedBrainTitle = _current_context.resolvedBrainTitle, resolvedRunId = _current_context.resolvedRunId, activeRuns = _current_context.activeRuns, error = _current_context.error;
533
+ // Render based on state
534
+ switch(currentState){
535
+ case 'searchingBrain':
536
+ return /*#__PURE__*/ React.createElement(Box, null, /*#__PURE__*/ React.createElement(Text, null, "Searching for '", identifier, "'..."));
537
+ case 'routeBrainSearch':
538
+ return /*#__PURE__*/ React.createElement(Box, null, /*#__PURE__*/ React.createElement(Text, null, "Searching for '", identifier, "'..."));
539
+ case 'searchingRun':
540
+ return /*#__PURE__*/ React.createElement(Box, null, /*#__PURE__*/ React.createElement(Text, null, "Checking if '", identifier, "' is a run ID..."));
541
+ case 'fetchingActiveRuns':
542
+ return /*#__PURE__*/ React.createElement(Box, null, /*#__PURE__*/ React.createElement(Text, null, 'Looking for active runs for "', resolvedBrainTitle, '"...'));
543
+ case 'routeActiveRuns':
544
+ return /*#__PURE__*/ React.createElement(Box, null, /*#__PURE__*/ React.createElement(Text, null, 'Looking for active runs for "', resolvedBrainTitle, '"...'));
545
+ case 'disambiguating':
546
+ return /*#__PURE__*/ React.createElement(SelectList, {
547
+ items: brains.map(function(b) {
548
+ return {
549
+ id: b.title,
550
+ label: b.title,
551
+ description: b.description
552
+ };
553
+ }),
554
+ header: "Multiple brains match '".concat(identifier, "':"),
555
+ onSelect: function(item) {
556
+ send({
557
+ type: 'BRAIN_SELECTED',
558
+ brainTitle: item.label
559
+ });
560
+ }
561
+ });
562
+ case 'noActiveRuns':
563
+ return /*#__PURE__*/ React.createElement(ErrorComponent, {
564
+ error: {
565
+ title: 'No Active Runs',
566
+ message: 'No currently running brain runs found for brain "'.concat(resolvedBrainTitle, '".'),
567
+ details: "To start a new run, use: positronic run ".concat(resolvedBrainTitle)
568
+ }
569
+ });
570
+ case 'multipleActiveRuns':
571
+ return /*#__PURE__*/ React.createElement(ErrorComponent, {
572
+ error: {
573
+ title: 'Multiple Active Runs',
574
+ message: "Found ".concat(activeRuns.length, ' active runs for brain "').concat(resolvedBrainTitle, '".'),
575
+ details: "Please specify a specific run ID:\n".concat(activeRuns.map(function(param) {
576
+ var brainRunId = param.brainRunId;
577
+ return " positronic watch ".concat(brainRunId);
578
+ }).join('\n'))
579
+ }
580
+ });
581
+ case 'error':
582
+ return error ? /*#__PURE__*/ React.createElement(ErrorComponent, {
583
+ error: error
584
+ }) : null;
585
+ case 'resolved':
586
+ return resolvedRunId ? /*#__PURE__*/ React.createElement(Watch, {
587
+ runId: resolvedRunId
588
+ }) : null;
589
+ default:
590
+ return null;
591
+ }
592
+ };