@arizeai/phoenix-client 5.4.0 → 5.5.0

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 (34) hide show
  1. package/dist/esm/__generated__/api/v1.d.ts +4 -0
  2. package/dist/esm/__generated__/api/v1.d.ts.map +1 -1
  3. package/dist/esm/datasets/appendDatasetExamples.d.ts.map +1 -1
  4. package/dist/esm/datasets/appendDatasetExamples.js +2 -0
  5. package/dist/esm/datasets/appendDatasetExamples.js.map +1 -1
  6. package/dist/esm/datasets/createDataset.d.ts.map +1 -1
  7. package/dist/esm/datasets/createDataset.js +2 -0
  8. package/dist/esm/datasets/createDataset.js.map +1 -1
  9. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
  10. package/dist/esm/types/datasets.d.ts +7 -0
  11. package/dist/esm/types/datasets.d.ts.map +1 -1
  12. package/dist/esm/utils/urlUtils.d.ts.map +1 -1
  13. package/dist/esm/utils/urlUtils.js +14 -4
  14. package/dist/esm/utils/urlUtils.js.map +1 -1
  15. package/dist/src/__generated__/api/v1.d.ts +4 -0
  16. package/dist/src/__generated__/api/v1.d.ts.map +1 -1
  17. package/dist/src/datasets/appendDatasetExamples.d.ts.map +1 -1
  18. package/dist/src/datasets/appendDatasetExamples.js +2 -0
  19. package/dist/src/datasets/appendDatasetExamples.js.map +1 -1
  20. package/dist/src/datasets/createDataset.d.ts.map +1 -1
  21. package/dist/src/datasets/createDataset.js +2 -0
  22. package/dist/src/datasets/createDataset.js.map +1 -1
  23. package/dist/src/types/datasets.d.ts +7 -0
  24. package/dist/src/types/datasets.d.ts.map +1 -1
  25. package/dist/src/utils/urlUtils.d.ts.map +1 -1
  26. package/dist/src/utils/urlUtils.js +14 -4
  27. package/dist/src/utils/urlUtils.js.map +1 -1
  28. package/dist/tsconfig.tsbuildinfo +1 -1
  29. package/package.json +2 -2
  30. package/src/__generated__/api/v1.ts +4 -0
  31. package/src/datasets/appendDatasetExamples.ts +4 -0
  32. package/src/datasets/createDataset.ts +4 -0
  33. package/src/types/datasets.ts +7 -0
  34. package/src/utils/urlUtils.ts +17 -4
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@arizeai/phoenix-client",
3
- "version": "5.4.0",
3
+ "version": "5.5.0",
4
4
  "description": "A client for the Phoenix API",
5
5
  "main": "dist/src/index.js",
6
6
  "module": "dist/esm/index.js",
@@ -67,7 +67,7 @@
67
67
  "tsx": "^4.19.3",
68
68
  "typescript": "^5.8.2",
69
69
  "vitest": "^4.0.10",
70
- "@arizeai/phoenix-evals": "0.4.0"
70
+ "@arizeai/phoenix-evals": "0.6.0"
71
71
  },
72
72
  "dependencies": {
73
73
  "@arizeai/openinference-semantic-conventions": "^1.1.0",
@@ -3527,6 +3527,8 @@ export interface operations {
3527
3527
  inputs: Record<string, unknown>[];
3528
3528
  outputs?: Record<string, unknown>[];
3529
3529
  metadata?: Record<string, unknown>[];
3530
+ /** @description Split per example: string, string array, or null */
3531
+ splits?: (string | string[] | null)[];
3530
3532
  };
3531
3533
  "multipart/form-data": {
3532
3534
  /** @enum {string} */
@@ -3536,6 +3538,8 @@ export interface operations {
3536
3538
  "input_keys[]": string[];
3537
3539
  "output_keys[]": string[];
3538
3540
  "metadata_keys[]"?: string[];
3541
+ /** @description Column names for auto-assigning examples to splits */
3542
+ "split_keys[]"?: string[];
3539
3543
  /** Format: binary */
3540
3544
  file: string;
3541
3545
  };
@@ -36,6 +36,9 @@ export async function appendDatasetExamples({
36
36
  const inputs = examples.map((example) => example.input);
37
37
  const outputs = examples.map((example) => example.output ?? {}); // Treat null as an empty object
38
38
  const metadata = examples.map((example) => example.metadata ?? {});
39
+ const splits = examples.map((example) =>
40
+ example.splits !== undefined ? example.splits : null
41
+ );
39
42
  let datasetName: string;
40
43
  if ("datasetName" in dataset) {
41
44
  datasetName = dataset.datasetName;
@@ -58,6 +61,7 @@ export async function appendDatasetExamples({
58
61
  inputs,
59
62
  outputs,
60
63
  metadata,
64
+ splits,
61
65
  },
62
66
  });
63
67
  invariant(appendResponse.data?.data, "Failed to append dataset examples");
@@ -37,6 +37,9 @@ export async function createDataset({
37
37
  const inputs = examples.map((example) => example.input);
38
38
  const outputs = examples.map((example) => example?.output ?? {}); // Treat null as an empty object
39
39
  const metadata = examples.map((example) => example?.metadata ?? {});
40
+ const splits = examples.map((example) =>
41
+ example?.splits !== undefined ? example.splits : null
42
+ );
40
43
  const createDatasetResponse = await client.POST("/v1/datasets/upload", {
41
44
  params: {
42
45
  query: {
@@ -51,6 +54,7 @@ export async function createDataset({
51
54
  inputs,
52
55
  outputs,
53
56
  metadata,
57
+ splits,
54
58
  },
55
59
  });
56
60
  invariant(createDatasetResponse.data?.data, "Failed to create dataset");
@@ -45,6 +45,13 @@ export interface Example {
45
45
  input: Record<string, unknown>;
46
46
  output?: Record<string, unknown> | null;
47
47
  metadata?: Record<string, unknown> | null;
48
+ /**
49
+ * Split assignment for this example. Can be:
50
+ * - A single string for one split: "train"
51
+ * - An array of strings for multiple splits: ["train", "easy"]
52
+ * - null for no split assignment
53
+ */
54
+ splits?: string | string[] | null;
48
55
  }
49
56
 
50
57
  /**
@@ -8,7 +8,13 @@
8
8
  * @returns The base URL for the Phoenix web UI
9
9
  */
10
10
  function getWebBaseUrl(baseUrl: string): string {
11
- return new URL(baseUrl).toString();
11
+ const url = new URL(baseUrl);
12
+ // Ensure the pathname ends with a trailing slash for proper path concatenation
13
+ // Without this, the URL constructor treats the last segment as a file and replaces it
14
+ if (!url.pathname.endsWith("/")) {
15
+ url.pathname += "/";
16
+ }
17
+ return url.toString();
12
18
  }
13
19
 
14
20
  /**
@@ -28,7 +34,9 @@ export function getExperimentUrl({
28
34
  datasetId: string;
29
35
  experimentId: string;
30
36
  }): string {
31
- return `${getWebBaseUrl(baseUrl)}datasets/${datasetId}/compare?experimentId=${experimentId}`;
37
+ const url = new URL(`datasets/${datasetId}/compare`, getWebBaseUrl(baseUrl));
38
+ url.searchParams.set("experimentId", experimentId);
39
+ return url.toString();
32
40
  }
33
41
 
34
42
  /**
@@ -45,7 +53,11 @@ export function getDatasetExperimentsUrl({
45
53
  baseUrl: string;
46
54
  datasetId: string;
47
55
  }): string {
48
- return `${getWebBaseUrl(baseUrl)}datasets/${datasetId}/experiments`;
56
+ const url = new URL(
57
+ `datasets/${datasetId}/experiments`,
58
+ getWebBaseUrl(baseUrl)
59
+ );
60
+ return url.toString();
49
61
  }
50
62
 
51
63
  /**
@@ -62,5 +74,6 @@ export function getDatasetUrl({
62
74
  baseUrl: string;
63
75
  datasetId: string;
64
76
  }): string {
65
- return `${getWebBaseUrl(baseUrl)}datasets/${datasetId}/examples`;
77
+ const url = new URL(`datasets/${datasetId}/examples`, getWebBaseUrl(baseUrl));
78
+ return url.toString();
66
79
  }