@promptbook/openai 0.81.0-5 → 0.81.0-6
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/esm/index.es.js +100 -2
- package/esm/index.es.js.map +1 -1
- package/esm/typings/books/index.d.ts +15 -0
- package/esm/typings/src/_packages/core.index.d.ts +2 -0
- package/esm/typings/src/_packages/templates.index.d.ts +1 -1
- package/esm/typings/src/_packages/utils.index.d.ts +8 -0
- package/esm/typings/src/config.d.ts +26 -0
- package/esm/typings/src/high-level-abstractions/index.d.ts +10 -0
- package/esm/typings/src/other/templates/getBookTemplate.d.ts +12 -0
- package/esm/typings/src/other/templates/getTemplatesPipelineCollection.d.ts +10 -0
- package/esm/typings/src/pipeline/PipelineJson/PipelineJson.d.ts +10 -0
- package/esm/typings/src/utils/editable/types/PipelineEditableSerialized.d.ts +0 -15
- package/esm/typings/src/utils/parameters/numberToString.d.ts +7 -0
- package/esm/typings/src/utils/parameters/templateParameters.d.ts +6 -2
- package/esm/typings/src/utils/parameters/valueToString.d.ts +17 -0
- package/esm/typings/src/utils/parameters/valueToString.test.d.ts +1 -0
- package/esm/typings/src/utils/serialization/asSerializable.d.ts +4 -0
- package/package.json +2 -2
- package/umd/index.umd.js +100 -2
- package/umd/index.umd.js.map +1 -1
- package/esm/typings/src/utils/formatNumber.d.ts +0 -6
- package/esm/typings/src/utils/getBookTemplate.d.ts +0 -12
- /package/esm/typings/src/utils/{formatNumber.test.d.ts → parameters/numberToString.test.d.ts} +0 -0
|
@@ -18,6 +18,11 @@ export declare const HIGH_LEVEL_ABSTRACTIONS: readonly [{
|
|
|
18
18
|
readonly knowledgePieces: import("../_packages/types.index").KnowledgePiecePreparedJson[];
|
|
19
19
|
readonly personas: (import("../_packages/types.index").PersonaJson | import("../_packages/types.index").PersonaPreparedJson)[];
|
|
20
20
|
readonly preparations: import("../_packages/types.index").PreparationJson[];
|
|
21
|
+
readonly sources: readonly {
|
|
22
|
+
type: "BOOK";
|
|
23
|
+
path: string | null;
|
|
24
|
+
content: import("../pipeline/PipelineString").PipelineString;
|
|
25
|
+
}[];
|
|
21
26
|
readonly formfactorName?: "CHATBOT" | "GENERATOR" | "GENERIC" | "EXPERIMENTAL_MATCHER" | "SHEETS" | "TRANSLATOR" | undefined;
|
|
22
27
|
}>): void;
|
|
23
28
|
}, {
|
|
@@ -35,6 +40,11 @@ export declare const HIGH_LEVEL_ABSTRACTIONS: readonly [{
|
|
|
35
40
|
readonly knowledgePieces: import("../_packages/types.index").KnowledgePiecePreparedJson[];
|
|
36
41
|
readonly personas: (import("../_packages/types.index").PersonaJson | import("../_packages/types.index").PersonaPreparedJson)[];
|
|
37
42
|
readonly preparations: import("../_packages/types.index").PreparationJson[];
|
|
43
|
+
readonly sources: readonly {
|
|
44
|
+
type: "BOOK";
|
|
45
|
+
path: string | null;
|
|
46
|
+
content: import("../pipeline/PipelineString").PipelineString;
|
|
47
|
+
}[];
|
|
38
48
|
readonly formfactorName?: "CHATBOT" | "GENERATOR" | "GENERIC" | "EXPERIMENTAL_MATCHER" | "SHEETS" | "TRANSLATOR" | undefined;
|
|
39
49
|
}>): void;
|
|
40
50
|
}];
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { string_formfactor_name } from '../../formfactors/_common/string_formfactor_name';
|
|
2
|
+
import type { PipelineJson } from '../../pipeline/PipelineJson/PipelineJson';
|
|
3
|
+
/**
|
|
4
|
+
* Get template for new book
|
|
5
|
+
*
|
|
6
|
+
* @public exported from `@promptbook/templates`
|
|
7
|
+
*/
|
|
8
|
+
export declare function getBookTemplate(formfactorName: string_formfactor_name): Promise<PipelineJson | null>;
|
|
9
|
+
/**
|
|
10
|
+
* TODO: [🧠] Which is the best place for this function
|
|
11
|
+
* TODO: !!!!!! `book string template notation
|
|
12
|
+
*/
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { PipelineCollection } from '../../collection/PipelineCollection';
|
|
2
|
+
/**
|
|
3
|
+
* Get pipeline collection for Untitled Promptbook project
|
|
4
|
+
*
|
|
5
|
+
* ⚠️ WARNING: This code has been generated by `@promptbook/cli` so that any manual changes will be overwritten
|
|
6
|
+
*
|
|
7
|
+
* @generated
|
|
8
|
+
* @returns {PipelineCollection} Library of promptbooks for Untitled Promptbook project
|
|
9
|
+
*/
|
|
10
|
+
export declare function getTemplatesPipelineCollection(): PipelineCollection;
|
|
@@ -3,7 +3,9 @@ import type { ModelRequirements } from '../../types/ModelRequirements';
|
|
|
3
3
|
import type { string_filename } from '../../types/typeAliases';
|
|
4
4
|
import type { string_markdown_text } from '../../types/typeAliases';
|
|
5
5
|
import type { string_pipeline_url } from '../../types/typeAliases';
|
|
6
|
+
import type { string_relative_filename } from '../../types/typeAliases';
|
|
6
7
|
import type { string_semantic_version } from '../../types/typeAliases';
|
|
8
|
+
import type { PipelineString } from '../PipelineString';
|
|
7
9
|
import type { KnowledgePiecePreparedJson } from './KnowledgePieceJson';
|
|
8
10
|
import type { KnowledgeSourceJson } from './KnowledgeSourceJson';
|
|
9
11
|
import type { KnowledgeSourcePreparedJson } from './KnowledgeSourceJson';
|
|
@@ -91,6 +93,14 @@ export type PipelineJson = {
|
|
|
91
93
|
* @see https://github.com/webgptorg/promptbook/discussions/78
|
|
92
94
|
*/
|
|
93
95
|
readonly preparations: Array<PreparationJson>;
|
|
96
|
+
/**
|
|
97
|
+
* Backup of the original book source
|
|
98
|
+
*/
|
|
99
|
+
readonly sources: ReadonlyArray<{
|
|
100
|
+
type: 'BOOK';
|
|
101
|
+
path: string_relative_filename | null;
|
|
102
|
+
content: PipelineString;
|
|
103
|
+
}>;
|
|
94
104
|
};
|
|
95
105
|
/**
|
|
96
106
|
* TODO: [🛳] Default PERSONA for the pipeline `defaultPersonaName` (same as `defaultModelRequirements`)
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
import type { ErrorJson } from '../../../errors/utils/ErrorJson';
|
|
2
2
|
import type { PipelineJson } from '../../../pipeline/PipelineJson/PipelineJson';
|
|
3
3
|
import type { string_date_iso8601 } from '../../../types/typeAliases';
|
|
4
|
-
import type { string_pipeline_url } from '../../../types/typeAliases';
|
|
5
|
-
import type { PipelineString } from '../../../pipeline/PipelineString';
|
|
6
4
|
/**
|
|
7
5
|
* Represents a single pipeline in PromptbookStudio
|
|
8
6
|
*
|
|
@@ -22,19 +20,6 @@ export type PipelineEditableSerialized = PipelineJson & {
|
|
|
22
20
|
* When was the pipeline last modified
|
|
23
21
|
*/
|
|
24
22
|
readonly updatedAt: string_date_iso8601 | null;
|
|
25
|
-
/**
|
|
26
|
-
* Unique identifier of the pipeline
|
|
27
|
-
*
|
|
28
|
-
* Note: In PromptbookStudio it is required
|
|
29
|
-
*/
|
|
30
|
-
readonly pipelineUrl: string_pipeline_url;
|
|
31
|
-
/**
|
|
32
|
-
* Backup of the pipeline string
|
|
33
|
-
*
|
|
34
|
-
* Note: This is present ONLY if pipelineString can not be automatically converted into json (i.e. compilePipeline throws an error)
|
|
35
|
-
* In other words, this is just a BACKUP of pipeline which will be deleted whener pipeline is valid again
|
|
36
|
-
*/
|
|
37
|
-
readonly pipelineString: PipelineString | string | null;
|
|
38
23
|
/**
|
|
39
24
|
* Known errors to transfer to new PipelineEditable
|
|
40
25
|
*/
|
|
@@ -1,12 +1,16 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { string_parameter_name } from '../../types/typeAliases';
|
|
2
2
|
import type { string_template } from '../../types/typeAliases';
|
|
3
|
+
import type { really_unknown } from '../organization/really_unknown';
|
|
3
4
|
/**
|
|
4
5
|
* Replaces parameters in template with values from parameters object
|
|
5
6
|
*
|
|
7
|
+
* Note: This function is not places strings into string,
|
|
8
|
+
* It's more complex and can handle this operation specifically for LLM models
|
|
9
|
+
*
|
|
6
10
|
* @param template the template with parameters in {curly} braces
|
|
7
11
|
* @param parameters the object with parameters
|
|
8
12
|
* @returns the template with replaced parameters
|
|
9
13
|
* @throws {PipelineExecutionError} if parameter is not defined, not closed, or not opened
|
|
10
14
|
* @public exported from `@promptbook/utils`
|
|
11
15
|
*/
|
|
12
|
-
export declare function templateParameters(template: string_template, parameters:
|
|
16
|
+
export declare function templateParameters(template: string_template, parameters: Record<string_parameter_name, really_unknown>): string;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { string_parameter_value } from '../../types/typeAliases';
|
|
2
|
+
import type { really_unknown } from '../organization/really_unknown';
|
|
3
|
+
/**
|
|
4
|
+
* Function `valueToString` will convert the given value to string
|
|
5
|
+
* This is useful and used in the `templateParameters` function
|
|
6
|
+
*
|
|
7
|
+
* Note: This function is not just calling `toString` method
|
|
8
|
+
* It's more complex and can handle this conversion specifically for LLM models
|
|
9
|
+
* See `VALUE_STRINGS`
|
|
10
|
+
*
|
|
11
|
+
* Note: There are 2 similar functions
|
|
12
|
+
* - `valueToString` converts value to string for LLM models as human-readable string
|
|
13
|
+
* - `asSerializable` converts value to string to preserve full information to be able to convert it back
|
|
14
|
+
*
|
|
15
|
+
* @public exported from `@promptbook/utils`
|
|
16
|
+
*/
|
|
17
|
+
export declare function valueToString(value: really_unknown): string_parameter_value;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -6,6 +6,10 @@ import type { really_any } from '../organization/really_any';
|
|
|
6
6
|
* For example:
|
|
7
7
|
* - `Date` objects will be converted to string
|
|
8
8
|
*
|
|
9
|
+
* Note: There are 2 similar functions
|
|
10
|
+
* - `valueToString` converts value to string for LLM models as human-readable string
|
|
11
|
+
* - `asSerializable` converts value to string to preserve full information to be able to convert it back
|
|
12
|
+
*
|
|
9
13
|
* @private Internal helper function
|
|
10
14
|
*/
|
|
11
15
|
export declare function asSerializable(value: really_any): really_any;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@promptbook/openai",
|
|
3
|
-
"version": "0.81.0-
|
|
3
|
+
"version": "0.81.0-6",
|
|
4
4
|
"description": "It's time for a paradigm shift. The future of software in plain English, French or Latin",
|
|
5
5
|
"--note-0": " <- [🐊]",
|
|
6
6
|
"private": false,
|
|
@@ -54,7 +54,7 @@
|
|
|
54
54
|
"module": "./esm/index.es.js",
|
|
55
55
|
"typings": "./esm/typings/src/_packages/openai.index.d.ts",
|
|
56
56
|
"peerDependencies": {
|
|
57
|
-
"@promptbook/core": "0.81.0-
|
|
57
|
+
"@promptbook/core": "0.81.0-6"
|
|
58
58
|
},
|
|
59
59
|
"dependencies": {
|
|
60
60
|
"colors": "1.4.0",
|
package/umd/index.umd.js
CHANGED
|
@@ -22,7 +22,7 @@
|
|
|
22
22
|
*
|
|
23
23
|
* @see https://github.com/webgptorg/promptbook
|
|
24
24
|
*/
|
|
25
|
-
var PROMPTBOOK_ENGINE_VERSION = '0.81.0-
|
|
25
|
+
var PROMPTBOOK_ENGINE_VERSION = '0.81.0-5';
|
|
26
26
|
/**
|
|
27
27
|
* TODO: string_promptbook_version should be constrained to the all versions of Promptbook engine
|
|
28
28
|
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
@@ -330,6 +330,26 @@
|
|
|
330
330
|
* @private within the repository - too low-level in comparison with other `MAX_...`
|
|
331
331
|
*/
|
|
332
332
|
var LOOP_LIMIT = 1000;
|
|
333
|
+
/**
|
|
334
|
+
* Strings to represent various values in the context of parameter values
|
|
335
|
+
*
|
|
336
|
+
* @public exported from `@promptbook/utils`
|
|
337
|
+
*/
|
|
338
|
+
var VALUE_STRINGS = {
|
|
339
|
+
empty: '(nothing; empty string)',
|
|
340
|
+
null: '(no value; null)',
|
|
341
|
+
undefined: '(unknown value; undefined)',
|
|
342
|
+
nan: '(not a number; NaN)',
|
|
343
|
+
infinity: '(infinity; ∞)',
|
|
344
|
+
negativeInfinity: '(negative infinity; -∞)',
|
|
345
|
+
unserializable: '(unserializable value)',
|
|
346
|
+
};
|
|
347
|
+
/**
|
|
348
|
+
* Small number limit
|
|
349
|
+
*
|
|
350
|
+
* @public exported from `@promptbook/utils`
|
|
351
|
+
*/
|
|
352
|
+
var SMALL_NUMBER = 0.001;
|
|
333
353
|
// <- TODO: [🧜♂️]
|
|
334
354
|
/**
|
|
335
355
|
* @@@
|
|
@@ -633,9 +653,87 @@
|
|
|
633
653
|
return LimitReachedError;
|
|
634
654
|
}(Error));
|
|
635
655
|
|
|
656
|
+
/**
|
|
657
|
+
* Format either small or big number
|
|
658
|
+
*
|
|
659
|
+
* @public exported from `@promptbook/utils`
|
|
660
|
+
*/
|
|
661
|
+
function numberToString(value) {
|
|
662
|
+
if (value === 0) {
|
|
663
|
+
return '0';
|
|
664
|
+
}
|
|
665
|
+
else if (Number.isNaN(value)) {
|
|
666
|
+
return VALUE_STRINGS.nan;
|
|
667
|
+
}
|
|
668
|
+
else if (value === Infinity) {
|
|
669
|
+
return VALUE_STRINGS.infinity;
|
|
670
|
+
}
|
|
671
|
+
else if (value === -Infinity) {
|
|
672
|
+
return VALUE_STRINGS.negativeInfinity;
|
|
673
|
+
}
|
|
674
|
+
for (var exponent = 0; exponent < 15; exponent++) {
|
|
675
|
+
var factor = Math.pow(10, exponent);
|
|
676
|
+
var valueRounded = Math.round(value * factor) / factor;
|
|
677
|
+
if (Math.abs(value - valueRounded) / value < SMALL_NUMBER) {
|
|
678
|
+
return valueRounded.toFixed(exponent);
|
|
679
|
+
}
|
|
680
|
+
}
|
|
681
|
+
return value.toString();
|
|
682
|
+
}
|
|
683
|
+
|
|
684
|
+
/**
|
|
685
|
+
* Function `valueToString` will convert the given value to string
|
|
686
|
+
* This is useful and used in the `templateParameters` function
|
|
687
|
+
*
|
|
688
|
+
* Note: This function is not just calling `toString` method
|
|
689
|
+
* It's more complex and can handle this conversion specifically for LLM models
|
|
690
|
+
* See `VALUE_STRINGS`
|
|
691
|
+
*
|
|
692
|
+
* Note: There are 2 similar functions
|
|
693
|
+
* - `valueToString` converts value to string for LLM models as human-readable string
|
|
694
|
+
* - `asSerializable` converts value to string to preserve full information to be able to convert it back
|
|
695
|
+
*
|
|
696
|
+
* @public exported from `@promptbook/utils`
|
|
697
|
+
*/
|
|
698
|
+
function valueToString(value) {
|
|
699
|
+
try {
|
|
700
|
+
if (value === '') {
|
|
701
|
+
return VALUE_STRINGS.empty;
|
|
702
|
+
}
|
|
703
|
+
else if (value === null) {
|
|
704
|
+
return VALUE_STRINGS.null;
|
|
705
|
+
}
|
|
706
|
+
else if (value === undefined) {
|
|
707
|
+
return VALUE_STRINGS.undefined;
|
|
708
|
+
}
|
|
709
|
+
else if (typeof value === 'string') {
|
|
710
|
+
return value;
|
|
711
|
+
}
|
|
712
|
+
else if (typeof value === 'number') {
|
|
713
|
+
return numberToString(value);
|
|
714
|
+
}
|
|
715
|
+
else if (value instanceof Date) {
|
|
716
|
+
return value.toISOString();
|
|
717
|
+
}
|
|
718
|
+
else {
|
|
719
|
+
return JSON.stringify(value);
|
|
720
|
+
}
|
|
721
|
+
}
|
|
722
|
+
catch (error) {
|
|
723
|
+
if (!(error instanceof Error)) {
|
|
724
|
+
throw error;
|
|
725
|
+
}
|
|
726
|
+
console.error(error);
|
|
727
|
+
return VALUE_STRINGS.unserializable;
|
|
728
|
+
}
|
|
729
|
+
}
|
|
730
|
+
|
|
636
731
|
/**
|
|
637
732
|
* Replaces parameters in template with values from parameters object
|
|
638
733
|
*
|
|
734
|
+
* Note: This function is not places strings into string,
|
|
735
|
+
* It's more complex and can handle this operation specifically for LLM models
|
|
736
|
+
*
|
|
639
737
|
* @param template the template with parameters in {curly} braces
|
|
640
738
|
* @param parameters the object with parameters
|
|
641
739
|
* @returns the template with replaced parameters
|
|
@@ -685,7 +783,7 @@
|
|
|
685
783
|
if (parameterValue === undefined) {
|
|
686
784
|
throw new PipelineExecutionError("Parameter `{".concat(parameterName, "}` is not defined"));
|
|
687
785
|
}
|
|
688
|
-
parameterValue = parameterValue
|
|
786
|
+
parameterValue = valueToString(parameterValue);
|
|
689
787
|
if (parameterValue.includes('\n') && /^\s*\W{0,3}\s*$/.test(precol)) {
|
|
690
788
|
parameterValue = parameterValue
|
|
691
789
|
.split('\n')
|