@promptbook/legacy-documents 0.100.0-32 → 0.100.0-34

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.
@@ -1,5 +1,6 @@
1
1
  import type { Observable } from 'rxjs';
2
2
  import { PartialDeep } from 'type-fest';
3
+ import type { number_percent } from '../types/typeAliases';
3
4
  import type { task_id } from '../types/typeAliases';
4
5
  import type { string_SCREAMING_CASE } from '../utils/normalization/normalizeTo_SCREAMING_CASE';
5
6
  import type { string_promptbook_version } from '../version';
@@ -80,6 +81,19 @@ export type AbstractTask<TTaskResult extends AbstractTaskResult> = {
80
81
  * Status of the task
81
82
  */
82
83
  readonly status: task_status;
84
+ /**
85
+ * Short summary of the task status for quick overview in the UI
86
+ */
87
+ readonly tldr: {
88
+ /**
89
+ * Progress in percentage from 0 to 1 (100%) that can be used to display a progress bar
90
+ */
91
+ readonly percent: number_percent;
92
+ /**
93
+ * Short summary message of the task status that can be displayed in the UI
94
+ */
95
+ readonly message: string;
96
+ };
83
97
  /**
84
98
  * Date when the task was created
85
99
  */
@@ -15,7 +15,7 @@ export declare const BOOK_LANGUAGE_VERSION: string_semantic_version;
15
15
  export declare const PROMPTBOOK_ENGINE_VERSION: string_promptbook_version;
16
16
  /**
17
17
  * Represents the version string of the Promptbook engine.
18
- * It follows semantic versioning (e.g., `0.100.0-31`).
18
+ * It follows semantic versioning (e.g., `0.100.0-33`).
19
19
  *
20
20
  * @generated
21
21
  */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@promptbook/legacy-documents",
3
- "version": "0.100.0-32",
3
+ "version": "0.100.0-34",
4
4
  "description": "Promptbook: Run AI apps in plain human language across multiple models and platforms",
5
5
  "private": false,
6
6
  "sideEffects": false,
@@ -95,7 +95,7 @@
95
95
  "module": "./esm/index.es.js",
96
96
  "typings": "./esm/typings/src/_packages/legacy-documents.index.d.ts",
97
97
  "peerDependencies": {
98
- "@promptbook/core": "0.100.0-32"
98
+ "@promptbook/core": "0.100.0-34"
99
99
  },
100
100
  "dependencies": {
101
101
  "colors": "1.4.0",
package/umd/index.umd.js CHANGED
@@ -26,7 +26,7 @@
26
26
  * @generated
27
27
  * @see https://github.com/webgptorg/promptbook
28
28
  */
29
- const PROMPTBOOK_ENGINE_VERSION = '0.100.0-32';
29
+ const PROMPTBOOK_ENGINE_VERSION = '0.100.0-34';
30
30
  /**
31
31
  * TODO: string_promptbook_version should be constrained to the all versions of Promptbook engine
32
32
  * Note: [💞] Ignore a discrepancy between file name and entity name
@@ -2758,6 +2758,55 @@
2758
2758
  return status;
2759
2759
  // <- Note: [1] --||--
2760
2760
  },
2761
+ get tldr() {
2762
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
2763
+ // Derive a short progress summary from currentValue, status and any errors/warnings.
2764
+ const cv = currentValue;
2765
+ // Try several common places where a percent might be stored on the partial result
2766
+ let percentRaw = (_f = (_d = (_b = (_a = cv === null || cv === void 0 ? void 0 : cv.tldr) === null || _a === void 0 ? void 0 : _a.percent) !== null && _b !== void 0 ? _b : (_c = cv === null || cv === void 0 ? void 0 : cv.usage) === null || _c === void 0 ? void 0 : _c.percent) !== null && _d !== void 0 ? _d : (_e = cv === null || cv === void 0 ? void 0 : cv.progress) === null || _e === void 0 ? void 0 : _e.percent) !== null && _f !== void 0 ? _f : cv === null || cv === void 0 ? void 0 : cv.percent;
2767
+ // If we didn't find a numeric percent, infer from status
2768
+ if (typeof percentRaw !== 'number') {
2769
+ if (status === 'FINISHED') {
2770
+ percentRaw = 1;
2771
+ }
2772
+ else if (status === 'ERROR') {
2773
+ percentRaw = 0;
2774
+ }
2775
+ else {
2776
+ percentRaw = 0;
2777
+ }
2778
+ }
2779
+ // Clamp to [0,1]
2780
+ let percent = Number(percentRaw) || 0;
2781
+ if (percent < 0)
2782
+ percent = 0;
2783
+ if (percent > 1)
2784
+ percent = 1;
2785
+ // Build a short message: prefer explicit tldr.message, then common summary/message fields, then errors/warnings, then status
2786
+ const messageFromResult = (_k = (_j = (_h = (_g = cv === null || cv === void 0 ? void 0 : cv.tldr) === null || _g === void 0 ? void 0 : _g.message) !== null && _h !== void 0 ? _h : cv === null || cv === void 0 ? void 0 : cv.message) !== null && _j !== void 0 ? _j : cv === null || cv === void 0 ? void 0 : cv.summary) !== null && _k !== void 0 ? _k : cv === null || cv === void 0 ? void 0 : cv.statusMessage;
2787
+ let message = messageFromResult;
2788
+ if (!message) {
2789
+ if (errors.length) {
2790
+ message = errors[errors.length - 1].message || 'Error';
2791
+ }
2792
+ else if (warnings.length) {
2793
+ message = warnings[warnings.length - 1].message || 'Warning';
2794
+ }
2795
+ else if (status === 'FINISHED') {
2796
+ message = 'Finished';
2797
+ }
2798
+ else if (status === 'ERROR') {
2799
+ message = 'Error';
2800
+ }
2801
+ else {
2802
+ message = 'Running';
2803
+ }
2804
+ }
2805
+ return {
2806
+ percent: percent,
2807
+ message,
2808
+ };
2809
+ },
2761
2810
  get createdAt() {
2762
2811
  return createdAt;
2763
2812
  // <- Note: [1] --||--