@positronic/cli 0.0.38 → 0.0.39
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 +4 -4
|
@@ -0,0 +1,356 @@
|
|
|
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 _sliced_to_array(arr, i) {
|
|
94
|
+
return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
|
|
95
|
+
}
|
|
96
|
+
function _unsupported_iterable_to_array(o, minLen) {
|
|
97
|
+
if (!o) return;
|
|
98
|
+
if (typeof o === "string") return _array_like_to_array(o, minLen);
|
|
99
|
+
var n = Object.prototype.toString.call(o).slice(8, -1);
|
|
100
|
+
if (n === "Object" && o.constructor) n = o.constructor.name;
|
|
101
|
+
if (n === "Map" || n === "Set") return Array.from(n);
|
|
102
|
+
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
|
|
103
|
+
}
|
|
104
|
+
function _ts_generator(thisArg, body) {
|
|
105
|
+
var f, y, t, _ = {
|
|
106
|
+
label: 0,
|
|
107
|
+
sent: function() {
|
|
108
|
+
if (t[0] & 1) throw t[1];
|
|
109
|
+
return t[1];
|
|
110
|
+
},
|
|
111
|
+
trys: [],
|
|
112
|
+
ops: []
|
|
113
|
+
}, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
|
|
114
|
+
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
|
|
115
|
+
return this;
|
|
116
|
+
}), g;
|
|
117
|
+
function verb(n) {
|
|
118
|
+
return function(v) {
|
|
119
|
+
return step([
|
|
120
|
+
n,
|
|
121
|
+
v
|
|
122
|
+
]);
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
function step(op) {
|
|
126
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
127
|
+
while(g && (g = 0, op[0] && (_ = 0)), _)try {
|
|
128
|
+
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;
|
|
129
|
+
if (y = 0, t) op = [
|
|
130
|
+
op[0] & 2,
|
|
131
|
+
t.value
|
|
132
|
+
];
|
|
133
|
+
switch(op[0]){
|
|
134
|
+
case 0:
|
|
135
|
+
case 1:
|
|
136
|
+
t = op;
|
|
137
|
+
break;
|
|
138
|
+
case 4:
|
|
139
|
+
_.label++;
|
|
140
|
+
return {
|
|
141
|
+
value: op[1],
|
|
142
|
+
done: false
|
|
143
|
+
};
|
|
144
|
+
case 5:
|
|
145
|
+
_.label++;
|
|
146
|
+
y = op[1];
|
|
147
|
+
op = [
|
|
148
|
+
0
|
|
149
|
+
];
|
|
150
|
+
continue;
|
|
151
|
+
case 7:
|
|
152
|
+
op = _.ops.pop();
|
|
153
|
+
_.trys.pop();
|
|
154
|
+
continue;
|
|
155
|
+
default:
|
|
156
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
|
|
157
|
+
_ = 0;
|
|
158
|
+
continue;
|
|
159
|
+
}
|
|
160
|
+
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
|
|
161
|
+
_.label = op[1];
|
|
162
|
+
break;
|
|
163
|
+
}
|
|
164
|
+
if (op[0] === 6 && _.label < t[1]) {
|
|
165
|
+
_.label = t[1];
|
|
166
|
+
t = op;
|
|
167
|
+
break;
|
|
168
|
+
}
|
|
169
|
+
if (t && _.label < t[2]) {
|
|
170
|
+
_.label = t[2];
|
|
171
|
+
_.ops.push(op);
|
|
172
|
+
break;
|
|
173
|
+
}
|
|
174
|
+
if (t[2]) _.ops.pop();
|
|
175
|
+
_.trys.pop();
|
|
176
|
+
continue;
|
|
177
|
+
}
|
|
178
|
+
op = body.call(thisArg, _);
|
|
179
|
+
} catch (e) {
|
|
180
|
+
op = [
|
|
181
|
+
6,
|
|
182
|
+
e
|
|
183
|
+
];
|
|
184
|
+
y = 0;
|
|
185
|
+
} finally{
|
|
186
|
+
f = t = 0;
|
|
187
|
+
}
|
|
188
|
+
if (op[0] & 5) throw op[1];
|
|
189
|
+
return {
|
|
190
|
+
value: op[0] ? op[1] : void 0,
|
|
191
|
+
done: true
|
|
192
|
+
};
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
import React, { useState, useEffect } from 'react';
|
|
196
|
+
import { Box, Text } from 'ink';
|
|
197
|
+
import { Watch } from './watch.js';
|
|
198
|
+
import { BrainResolver } from './brain-resolver.js';
|
|
199
|
+
import { ErrorComponent } from './error.js';
|
|
200
|
+
import { apiClient, isApiLocalDevMode } from '../commands/helpers.js';
|
|
201
|
+
/**
|
|
202
|
+
* BrainWatchByTitle - Watches a brain's active run by its resolved title.
|
|
203
|
+
*
|
|
204
|
+
* Looks up active runs for the brain and:
|
|
205
|
+
* - If 0 active runs: shows a message
|
|
206
|
+
* - If 1 active run: starts watching it
|
|
207
|
+
* - If multiple: shows the list of run IDs to choose from
|
|
208
|
+
*/ var BrainWatchByTitle = function(param) {
|
|
209
|
+
var brainTitle = param.brainTitle;
|
|
210
|
+
var _useState = _sliced_to_array(useState('loading'), 2), phase = _useState[0], setPhase = _useState[1];
|
|
211
|
+
var _useState1 = _sliced_to_array(useState(null), 2), runId = _useState1[0], setRunId = _useState1[1];
|
|
212
|
+
var _useState2 = _sliced_to_array(useState([]), 2), runs = _useState2[0], setRuns = _useState2[1];
|
|
213
|
+
var _useState3 = _sliced_to_array(useState(null), 2), error = _useState3[0], setError = _useState3[1];
|
|
214
|
+
useEffect(function() {
|
|
215
|
+
var fetchActiveRuns = function() {
|
|
216
|
+
return _async_to_generator(function() {
|
|
217
|
+
var apiPath, response, result, errorText, err, connectionError;
|
|
218
|
+
return _ts_generator(this, function(_state) {
|
|
219
|
+
switch(_state.label){
|
|
220
|
+
case 0:
|
|
221
|
+
_state.trys.push([
|
|
222
|
+
0,
|
|
223
|
+
6,
|
|
224
|
+
,
|
|
225
|
+
7
|
|
226
|
+
]);
|
|
227
|
+
apiPath = "/brains/".concat(encodeURIComponent(brainTitle), "/active-runs");
|
|
228
|
+
return [
|
|
229
|
+
4,
|
|
230
|
+
apiClient.fetch(apiPath, {
|
|
231
|
+
method: 'GET'
|
|
232
|
+
})
|
|
233
|
+
];
|
|
234
|
+
case 1:
|
|
235
|
+
response = _state.sent();
|
|
236
|
+
if (!(response.status === 200)) return [
|
|
237
|
+
3,
|
|
238
|
+
3
|
|
239
|
+
];
|
|
240
|
+
return [
|
|
241
|
+
4,
|
|
242
|
+
response.json()
|
|
243
|
+
];
|
|
244
|
+
case 2:
|
|
245
|
+
result = _state.sent();
|
|
246
|
+
if (result.runs.length === 0) {
|
|
247
|
+
setPhase('no-runs');
|
|
248
|
+
} else if (result.runs.length === 1) {
|
|
249
|
+
setRunId(result.runs[0].brainRunId);
|
|
250
|
+
setPhase('watching');
|
|
251
|
+
} else {
|
|
252
|
+
setRuns(result.runs);
|
|
253
|
+
setPhase('multiple-runs');
|
|
254
|
+
}
|
|
255
|
+
return [
|
|
256
|
+
3,
|
|
257
|
+
5
|
|
258
|
+
];
|
|
259
|
+
case 3:
|
|
260
|
+
return [
|
|
261
|
+
4,
|
|
262
|
+
response.text()
|
|
263
|
+
];
|
|
264
|
+
case 4:
|
|
265
|
+
errorText = _state.sent();
|
|
266
|
+
setError({
|
|
267
|
+
title: 'API Error',
|
|
268
|
+
message: 'Failed to get active runs for brain "'.concat(brainTitle, '".'),
|
|
269
|
+
details: "Server returned ".concat(response.status, ": ").concat(errorText)
|
|
270
|
+
});
|
|
271
|
+
setPhase('error');
|
|
272
|
+
_state.label = 5;
|
|
273
|
+
case 5:
|
|
274
|
+
return [
|
|
275
|
+
3,
|
|
276
|
+
7
|
|
277
|
+
];
|
|
278
|
+
case 6:
|
|
279
|
+
err = _state.sent();
|
|
280
|
+
connectionError = isApiLocalDevMode() ? {
|
|
281
|
+
message: 'Error connecting to the local development server.',
|
|
282
|
+
details: "Please ensure the server is running ('positronic server' or 'px s').\n\nError details: ".concat(err.message)
|
|
283
|
+
} : {
|
|
284
|
+
message: 'Error connecting to the remote project server.',
|
|
285
|
+
details: "Please check your network connection and verify the project URL is correct.\n\nError details: ".concat(err.message)
|
|
286
|
+
};
|
|
287
|
+
setError(_object_spread({
|
|
288
|
+
title: 'Connection Error'
|
|
289
|
+
}, connectionError));
|
|
290
|
+
setPhase('error');
|
|
291
|
+
return [
|
|
292
|
+
3,
|
|
293
|
+
7
|
|
294
|
+
];
|
|
295
|
+
case 7:
|
|
296
|
+
return [
|
|
297
|
+
2
|
|
298
|
+
];
|
|
299
|
+
}
|
|
300
|
+
});
|
|
301
|
+
})();
|
|
302
|
+
};
|
|
303
|
+
fetchActiveRuns();
|
|
304
|
+
}, [
|
|
305
|
+
brainTitle
|
|
306
|
+
]);
|
|
307
|
+
if (phase === 'loading') {
|
|
308
|
+
return /*#__PURE__*/ React.createElement(Box, null, /*#__PURE__*/ React.createElement(Text, null, 'Looking for active runs for "', brainTitle, '"...'));
|
|
309
|
+
}
|
|
310
|
+
if (phase === 'error' && error) {
|
|
311
|
+
return /*#__PURE__*/ React.createElement(ErrorComponent, {
|
|
312
|
+
error: error
|
|
313
|
+
});
|
|
314
|
+
}
|
|
315
|
+
if (phase === 'no-runs') {
|
|
316
|
+
return /*#__PURE__*/ React.createElement(ErrorComponent, {
|
|
317
|
+
error: {
|
|
318
|
+
title: 'No Active Runs',
|
|
319
|
+
message: 'No currently running brain runs found for brain "'.concat(brainTitle, '".'),
|
|
320
|
+
details: "To start a new run, use: positronic run ".concat(brainTitle)
|
|
321
|
+
}
|
|
322
|
+
});
|
|
323
|
+
}
|
|
324
|
+
if (phase === 'multiple-runs') {
|
|
325
|
+
return /*#__PURE__*/ React.createElement(ErrorComponent, {
|
|
326
|
+
error: {
|
|
327
|
+
title: 'Multiple Active Runs',
|
|
328
|
+
message: "Found ".concat(runs.length, ' active runs for brain "').concat(brainTitle, '".'),
|
|
329
|
+
details: "Please specify a specific run ID with --run-id:\n".concat(runs.map(function(run) {
|
|
330
|
+
return " positronic watch --run-id ".concat(run.brainRunId);
|
|
331
|
+
}).join('\n'))
|
|
332
|
+
}
|
|
333
|
+
});
|
|
334
|
+
}
|
|
335
|
+
if (phase === 'watching' && runId) {
|
|
336
|
+
return /*#__PURE__*/ React.createElement(Watch, {
|
|
337
|
+
runId: runId
|
|
338
|
+
});
|
|
339
|
+
}
|
|
340
|
+
return null;
|
|
341
|
+
};
|
|
342
|
+
/**
|
|
343
|
+
* BrainWatchWithResolver - Resolves a brain identifier and watches its active run.
|
|
344
|
+
*
|
|
345
|
+
* Uses BrainResolver to handle fuzzy matching and disambiguation,
|
|
346
|
+
* then finds and watches the brain's active run.
|
|
347
|
+
*/ export var BrainWatchWithResolver = function(param) {
|
|
348
|
+
var identifier = param.identifier;
|
|
349
|
+
return /*#__PURE__*/ React.createElement(BrainResolver, {
|
|
350
|
+
identifier: identifier
|
|
351
|
+
}, function(resolvedBrainTitle) {
|
|
352
|
+
return /*#__PURE__*/ React.createElement(BrainWatchByTitle, {
|
|
353
|
+
brainTitle: resolvedBrainTitle
|
|
354
|
+
});
|
|
355
|
+
});
|
|
356
|
+
};
|
package/dist/types/cli.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../../src/cli.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAQ1B,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAK5D,MAAM,WAAW,UAAU;IACzB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,MAAM,CAAC,EAAE,mBAAmB,CAAC;IAC7B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,MAAM,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,YAAY,KAAK,GAAG,CAAC;CAC9C;AAoBD,wBAAgB,QAAQ,CAAC,OAAO,EAAE,UAAU,
|
|
1
|
+
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../../src/cli.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAQ1B,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAK5D,MAAM,WAAW,UAAU;IACzB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,MAAM,CAAC,EAAE,mBAAmB,CAAC;IAC7B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,MAAM,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,YAAY,KAAK,GAAG,CAAC;CAC9C;AAoBD,wBAAgB,QAAQ,CAAC,OAAO,EAAE,UAAU,4BA0jC3C"}
|
|
@@ -3,26 +3,26 @@ import React from 'react';
|
|
|
3
3
|
interface BrainListArgs {
|
|
4
4
|
}
|
|
5
5
|
interface BrainHistoryArgs {
|
|
6
|
-
|
|
6
|
+
brain: string;
|
|
7
7
|
limit: number;
|
|
8
8
|
}
|
|
9
9
|
interface BrainShowArgs {
|
|
10
10
|
runId: string;
|
|
11
11
|
}
|
|
12
12
|
interface BrainRerunArgs {
|
|
13
|
-
|
|
13
|
+
brain: string;
|
|
14
14
|
runId?: string;
|
|
15
15
|
startsAt?: number;
|
|
16
16
|
stopsAfter?: number;
|
|
17
17
|
}
|
|
18
18
|
interface BrainRunArgs {
|
|
19
|
-
|
|
19
|
+
brain: string;
|
|
20
20
|
watch?: boolean;
|
|
21
21
|
options?: Record<string, string>;
|
|
22
22
|
}
|
|
23
23
|
interface BrainWatchArgs {
|
|
24
24
|
runId?: string;
|
|
25
|
-
|
|
25
|
+
brain?: string;
|
|
26
26
|
}
|
|
27
27
|
interface BrainKillArgs {
|
|
28
28
|
runId: string;
|
|
@@ -30,11 +30,11 @@ interface BrainKillArgs {
|
|
|
30
30
|
}
|
|
31
31
|
export declare class BrainCommand {
|
|
32
32
|
list(argv: ArgumentsCamelCase<BrainListArgs>): React.ReactElement;
|
|
33
|
-
history({
|
|
33
|
+
history({ brain, limit, }: ArgumentsCamelCase<BrainHistoryArgs>): React.ReactElement;
|
|
34
34
|
show({ runId, }: ArgumentsCamelCase<BrainShowArgs>): React.ReactElement;
|
|
35
|
-
rerun({
|
|
36
|
-
run({
|
|
37
|
-
watch({ runId,
|
|
35
|
+
rerun({ brain, runId, startsAt, stopsAfter, }: ArgumentsCamelCase<BrainRerunArgs>): React.ReactElement;
|
|
36
|
+
run({ brain, watch, options }: ArgumentsCamelCase<BrainRunArgs>): React.ReactElement;
|
|
37
|
+
watch({ runId, brain, }: ArgumentsCamelCase<BrainWatchArgs>): React.ReactElement;
|
|
38
38
|
kill({ runId, force, }: ArgumentsCamelCase<BrainKillArgs>): React.ReactElement;
|
|
39
39
|
}
|
|
40
40
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"brain.d.ts","sourceRoot":"","sources":["../../../src/commands/brain.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"brain.d.ts","sourceRoot":"","sources":["../../../src/commands/brain.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAC;AAChD,OAAO,KAAK,MAAM,OAAO,CAAC;AAY1B,UAAU,aAAa;CAAG;AAC1B,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AACD,UAAU,aAAa;IACrB,KAAK,EAAE,MAAM,CAAC;CACf;AACD,UAAU,cAAc;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AACD,UAAU,YAAY;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAClC;AACD,UAAU,cAAc;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AACD,UAAU,aAAa;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,OAAO,CAAC;CAChB;AAED,qBAAa,YAAY;IACvB,IAAI,CAAC,IAAI,EAAE,kBAAkB,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC,YAAY;IAIjE,OAAO,CAAC,EACN,KAAK,EACL,KAAK,GACN,EAAE,kBAAkB,CAAC,gBAAgB,CAAC,GAAG,KAAK,CAAC,YAAY;IAQ5D,IAAI,CAAC,EACH,KAAK,GACN,EAAE,kBAAkB,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC,YAAY;IAIzD,KAAK,CAAC,EACJ,KAAK,EACL,KAAK,EACL,QAAQ,EACR,UAAU,GACX,EAAE,kBAAkB,CAAC,cAAc,CAAC,GAAG,KAAK,CAAC,YAAY;IAa1D,GAAG,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,kBAAkB,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC,YAAY;IAQpF,KAAK,CAAC,EACJ,KAAK,EACL,KAAK,GACN,EAAE,kBAAkB,CAAC,cAAc,CAAC,GAAG,KAAK,CAAC,YAAY;IAyB1D,IAAI,CAAC,EACH,KAAK,EACL,KAAK,GACN,EAAE,kBAAkB,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC,YAAY;CAI1D"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { ArgumentsCamelCase } from 'yargs';
|
|
2
2
|
import React from 'react';
|
|
3
3
|
interface ScheduleCreateArgs {
|
|
4
|
-
|
|
4
|
+
brain: string;
|
|
5
5
|
cronExpression: string;
|
|
6
6
|
}
|
|
7
7
|
interface ScheduleListArgs {
|
|
@@ -18,7 +18,7 @@ interface ScheduleRunsArgs {
|
|
|
18
18
|
}
|
|
19
19
|
export declare class ScheduleCommand {
|
|
20
20
|
constructor();
|
|
21
|
-
create({
|
|
21
|
+
create({ brain, cronExpression, }: ArgumentsCamelCase<ScheduleCreateArgs>): React.ReactElement;
|
|
22
22
|
list({ brain }: ArgumentsCamelCase<ScheduleListArgs>): React.ReactElement;
|
|
23
23
|
delete({ scheduleId, force }: ArgumentsCamelCase<ScheduleDeleteArgs>): React.ReactElement;
|
|
24
24
|
runs({ scheduleId, limit, status, }: ArgumentsCamelCase<ScheduleRunsArgs>): React.ReactElement;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schedule.d.ts","sourceRoot":"","sources":["../../../src/commands/schedule.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAC;AAChD,OAAO,KAAK,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"schedule.d.ts","sourceRoot":"","sources":["../../../src/commands/schedule.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAC;AAChD,OAAO,KAAK,MAAM,OAAO,CAAC;AAO1B,UAAU,kBAAkB;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,UAAU,gBAAgB;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,UAAU,kBAAkB;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,OAAO,CAAC;CAChB;AAED,UAAU,gBAAgB;IACxB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,WAAW,GAAG,QAAQ,GAAG,UAAU,CAAC;CAC9C;AAED,qBAAa,eAAe;;IAG1B,MAAM,CAAC,EACL,KAAK,EACL,cAAc,GACf,EAAE,kBAAkB,CAAC,kBAAkB,CAAC,GAAG,KAAK,CAAC,YAAY;IAW9D,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,kBAAkB,CAAC,gBAAgB,CAAC,GAAG,KAAK,CAAC,YAAY;IAMzE,MAAM,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,EAAE,kBAAkB,CAAC,kBAAkB,CAAC,GAAG,KAAK,CAAC,YAAY;IAOzF,IAAI,CAAC,EACH,UAAU,EACV,KAAK,EACL,MAAM,GACP,EAAE,kBAAkB,CAAC,gBAAgB,CAAC,GAAG,KAAK,CAAC,YAAY;CAO7D"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"brain-list.d.ts","sourceRoot":"","sources":["../../../src/components/brain-list.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"brain-list.d.ts","sourceRoot":"","sources":["../../../src/components/brain-list.tsx"],"names":[],"mappings":"AA2CA,eAAO,MAAM,SAAS,+CAkFrB,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface BrainResolverProps {
|
|
3
|
+
identifier: string;
|
|
4
|
+
children: (resolvedBrainTitle: string) => React.ReactNode;
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* BrainResolver - A reusable component that resolves a brain identifier to a title.
|
|
8
|
+
*
|
|
9
|
+
* It searches for brains matching the identifier and:
|
|
10
|
+
* - If 0 matches: shows an error
|
|
11
|
+
* - If 1 match: renders children with the resolved brain title
|
|
12
|
+
* - If multiple matches: shows a disambiguation UI
|
|
13
|
+
*/
|
|
14
|
+
export declare const BrainResolver: ({ identifier, children }: BrainResolverProps) => import("react/jsx-runtime").JSX.Element | null;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=brain-resolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"brain-resolver.d.ts","sourceRoot":"","sources":["../../../src/components/brain-resolver.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA2C,MAAM,OAAO,CAAC;AAehE,UAAU,kBAAkB;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,CAAC,kBAAkB,EAAE,MAAM,KAAK,KAAK,CAAC,SAAS,CAAC;CAC3D;AAID;;;;;;;GAOG;AACH,eAAO,MAAM,aAAa,GAAI,0BAA0B,kBAAkB,mDA8IzE,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
interface BrainRunProps {
|
|
2
|
+
identifier: string;
|
|
3
|
+
watch?: boolean;
|
|
4
|
+
options?: Record<string, string>;
|
|
5
|
+
}
|
|
6
|
+
export declare const BrainRun: ({ identifier, watch, options }: BrainRunProps) => import("react/jsx-runtime").JSX.Element | null;
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=brain-run.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"brain-run.d.ts","sourceRoot":"","sources":["../../../src/components/brain-run.tsx"],"names":[],"mappings":"AAgBA,UAAU,aAAa;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAClC;AAID,eAAO,MAAM,QAAQ,GAAI,gCAAgC,aAAa,mDA8LrE,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
interface BrainWatchWithResolverProps {
|
|
2
|
+
identifier: string;
|
|
3
|
+
}
|
|
4
|
+
/**
|
|
5
|
+
* BrainWatchWithResolver - Resolves a brain identifier and watches its active run.
|
|
6
|
+
*
|
|
7
|
+
* Uses BrainResolver to handle fuzzy matching and disambiguation,
|
|
8
|
+
* then finds and watches the brain's active run.
|
|
9
|
+
*/
|
|
10
|
+
export declare const BrainWatchWithResolver: ({ identifier }: BrainWatchWithResolverProps) => import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=brain-watch.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"brain-watch.d.ts","sourceRoot":"","sources":["../../../src/components/brain-watch.tsx"],"names":[],"mappings":"AAmIA,UAAU,2BAA2B;IACnC,UAAU,EAAE,MAAM,CAAC;CACpB;AAED;;;;;GAKG;AACH,eAAO,MAAM,sBAAsB,GAAI,gBAAgB,2BAA2B,4CAMjF,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@positronic/cli",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.39",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
@@ -23,9 +23,9 @@
|
|
|
23
23
|
"clean": "rm -rf tsconfig.tsbuildinfo dist node_modules"
|
|
24
24
|
},
|
|
25
25
|
"dependencies": {
|
|
26
|
-
"@positronic/core": "^0.0.
|
|
27
|
-
"@positronic/spec": "^0.0.
|
|
28
|
-
"@positronic/template-new-project": "^0.0.
|
|
26
|
+
"@positronic/core": "^0.0.39",
|
|
27
|
+
"@positronic/spec": "^0.0.39",
|
|
28
|
+
"@positronic/template-new-project": "^0.0.39",
|
|
29
29
|
"caz": "^2.0.0",
|
|
30
30
|
"chokidar": "^3.6.0",
|
|
31
31
|
"dotenv": "^16.4.7",
|