@sanity/workbench 0.1.0-alpha.7 → 0.1.0-alpha.9
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/_chunks-es/index.js +6 -1
- package/dist/_chunks-es/index.js.map +1 -1
- package/dist/_internal.js +3 -8
- package/dist/_internal.js.map +1 -1
- package/dist/core.d.ts +582 -24
- package/dist/core.js +207 -105
- package/dist/core.js.map +1 -1
- package/package.json +9 -3
- package/src/_internal/render.ts +4 -11
- package/src/core/applications/application-list.ts +1 -1
- package/src/core/applications/local-application.ts +6 -2
- package/src/core/canvases.ts +1 -1
- package/src/core/index.ts +1 -1
- package/src/core/log/index.ts +12 -0
- package/src/core/media-libraries.ts +1 -1
- package/src/core/user-applications/core-app.ts +66 -10
- package/src/core/user-applications/studios/index.ts +3 -0
- package/src/core/user-applications/studios/schemas.ts +106 -0
- package/src/core/user-applications/{studio.ts → studios/studio.ts} +56 -214
- package/src/core/user-applications/studios/workspace.ts +143 -0
- package/src/core/user-applications/user-application.ts +36 -5
- package/src/_internal/render.test.ts +0 -73
- package/src/core/__tests__/__fixtures__.ts +0 -248
- package/src/core/applications/application-list.test.ts +0 -222
- package/src/core/applications/local-application.test.ts +0 -93
- package/src/core/canvases.test.ts +0 -38
- package/src/core/log/index.test.ts +0 -133
- package/src/core/media-libraries.test.ts +0 -38
- package/src/core/organizations.test.ts +0 -134
- package/src/core/projects.test.ts +0 -248
- package/src/core/shared/urls.test.ts +0 -182
- package/src/core/user-applications/core-app.test.ts +0 -151
- package/src/core/user-applications/studio.test.ts +0 -928
- package/src/core/user-applications/user-application.test.ts +0 -126
|
@@ -1,182 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from "vitest";
|
|
2
|
-
|
|
3
|
-
import { createPath, joinUrlPaths, normalizePath, parsePath } from "./urls";
|
|
4
|
-
|
|
5
|
-
describe("joinUrlPaths", () => {
|
|
6
|
-
it("joins two simple segments", () => {
|
|
7
|
-
expect(joinUrlPaths("foo", "bar")).toBe("foo/bar");
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
it("handles trailing slash on first segment", () => {
|
|
11
|
-
expect(joinUrlPaths("foo/", "bar")).toBe("foo/bar");
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
it("handles leading slash on second segment", () => {
|
|
15
|
-
expect(joinUrlPaths("foo", "/bar")).toBe("foo/bar");
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
it("collapses double slashes at the join", () => {
|
|
19
|
-
expect(joinUrlPaths("foo/", "/bar")).toBe("foo/bar");
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
it("joins multiple segments", () => {
|
|
23
|
-
expect(joinUrlPaths("a", "b", "c")).toBe("a/b/c");
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
it("skips null and undefined values", () => {
|
|
27
|
-
expect(joinUrlPaths("a", null, undefined, "b")).toBe("a/b");
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
it("returns empty string for all nullish inputs", () => {
|
|
31
|
-
expect(joinUrlPaths(null, undefined)).toBe("");
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
it("returns empty string with no arguments", () => {
|
|
35
|
-
expect(joinUrlPaths()).toBe("");
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
it("returns single segment unchanged", () => {
|
|
39
|
-
expect(joinUrlPaths("foo")).toBe("foo");
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
it("extracts pathname from URL objects", () => {
|
|
43
|
-
const url = new URL("https://example.com/api");
|
|
44
|
-
expect(joinUrlPaths(url, "users")).toBe("/api/users");
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
it("handles URL object with trailing slash", () => {
|
|
48
|
-
const url = new URL("https://example.com/api/");
|
|
49
|
-
expect(joinUrlPaths(url, "users")).toBe("/api/users");
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
it("joins two URL objects", () => {
|
|
53
|
-
const a = new URL("https://example.com/api");
|
|
54
|
-
const b = new URL("https://example.com/v2");
|
|
55
|
-
expect(joinUrlPaths(a, b)).toBe("/api/v2");
|
|
56
|
-
});
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
describe("normalizePath", () => {
|
|
60
|
-
it("adds leading slash when missing", () => {
|
|
61
|
-
expect(normalizePath("foo")).toBe("/foo");
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
it("preserves existing leading slash", () => {
|
|
65
|
-
expect(normalizePath("/foo")).toBe("/foo");
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
it("removes trailing slash", () => {
|
|
69
|
-
expect(normalizePath("/foo/")).toBe("/foo");
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
it("preserves root path", () => {
|
|
73
|
-
expect(normalizePath("/")).toBe("/");
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
it("handles bare segment with trailing slash", () => {
|
|
77
|
-
expect(normalizePath("foo/")).toBe("/foo");
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
it("handles deeper paths", () => {
|
|
81
|
-
expect(normalizePath("/a/b/c/")).toBe("/a/b/c");
|
|
82
|
-
});
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
describe("parsePath", () => {
|
|
86
|
-
it("parses pathname only", () => {
|
|
87
|
-
expect(parsePath("/foo")).toEqual({ pathname: "/foo" });
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
it("parses pathname with search", () => {
|
|
91
|
-
expect(parsePath("/foo?bar=1")).toEqual({
|
|
92
|
-
pathname: "/foo",
|
|
93
|
-
search: "?bar=1",
|
|
94
|
-
});
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
it("parses pathname with hash", () => {
|
|
98
|
-
expect(parsePath("/foo#heading")).toEqual({
|
|
99
|
-
pathname: "/foo",
|
|
100
|
-
hash: "#heading",
|
|
101
|
-
});
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
it("parses pathname with search and hash", () => {
|
|
105
|
-
expect(parsePath("/foo?bar=1#heading")).toEqual({
|
|
106
|
-
pathname: "/foo",
|
|
107
|
-
search: "?bar=1",
|
|
108
|
-
hash: "#heading",
|
|
109
|
-
});
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
it("parses hash that appears before search in the string", () => {
|
|
113
|
-
expect(parsePath("/foo#heading?notSearch")).toEqual({
|
|
114
|
-
pathname: "/foo",
|
|
115
|
-
hash: "#heading?notSearch",
|
|
116
|
-
});
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
it("returns empty object for empty string", () => {
|
|
120
|
-
expect(parsePath("")).toEqual({});
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
it("parses search-only path", () => {
|
|
124
|
-
expect(parsePath("?q=1")).toEqual({ search: "?q=1" });
|
|
125
|
-
});
|
|
126
|
-
|
|
127
|
-
it("parses hash-only path", () => {
|
|
128
|
-
expect(parsePath("#top")).toEqual({ hash: "#top" });
|
|
129
|
-
});
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
describe("createPath", () => {
|
|
133
|
-
it("returns pathname only", () => {
|
|
134
|
-
expect(createPath({ pathname: "/foo" })).toBe("/foo");
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
it("appends search string", () => {
|
|
138
|
-
expect(createPath({ pathname: "/foo", search: "?bar=1" })).toBe(
|
|
139
|
-
"/foo?bar=1",
|
|
140
|
-
);
|
|
141
|
-
});
|
|
142
|
-
|
|
143
|
-
it("appends hash string", () => {
|
|
144
|
-
expect(createPath({ pathname: "/foo", hash: "#heading" })).toBe(
|
|
145
|
-
"/foo#heading",
|
|
146
|
-
);
|
|
147
|
-
});
|
|
148
|
-
|
|
149
|
-
it("appends both search and hash", () => {
|
|
150
|
-
expect(
|
|
151
|
-
createPath({
|
|
152
|
-
pathname: "/foo",
|
|
153
|
-
search: "?bar=1",
|
|
154
|
-
hash: "#heading",
|
|
155
|
-
}),
|
|
156
|
-
).toBe("/foo?bar=1#heading");
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
it("adds ? prefix when search is missing it", () => {
|
|
160
|
-
expect(createPath({ pathname: "/foo", search: "bar=1" })).toBe(
|
|
161
|
-
"/foo?bar=1",
|
|
162
|
-
);
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
it("adds # prefix when hash is missing it", () => {
|
|
166
|
-
expect(createPath({ pathname: "/foo", hash: "heading" })).toBe(
|
|
167
|
-
"/foo#heading",
|
|
168
|
-
);
|
|
169
|
-
});
|
|
170
|
-
|
|
171
|
-
it("defaults pathname to /", () => {
|
|
172
|
-
expect(createPath({})).toBe("/");
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
it("ignores bare ? search", () => {
|
|
176
|
-
expect(createPath({ pathname: "/foo", search: "?" })).toBe("/foo");
|
|
177
|
-
});
|
|
178
|
-
|
|
179
|
-
it("ignores bare # hash", () => {
|
|
180
|
-
expect(createPath({ pathname: "/foo", hash: "#" })).toBe("/foo");
|
|
181
|
-
});
|
|
182
|
-
});
|
|
@@ -1,151 +0,0 @@
|
|
|
1
|
-
import type { ApplicationResource as ProtocolApplicationResource } from "@sanity/message-protocol";
|
|
2
|
-
import { afterEach, describe, expect, expectTypeOf, it, vi } from "vitest";
|
|
3
|
-
|
|
4
|
-
import { APPLICATION_DATA } from "../__tests__/__fixtures__";
|
|
5
|
-
import { CoreAppApplication } from "./core-app";
|
|
6
|
-
|
|
7
|
-
const setup = () => new CoreAppApplication(APPLICATION_DATA);
|
|
8
|
-
|
|
9
|
-
describe("CoreAppApplication", () => {
|
|
10
|
-
afterEach(() => {
|
|
11
|
-
vi.unstubAllEnvs();
|
|
12
|
-
});
|
|
13
|
-
it("should have a type of coreApp", () => {
|
|
14
|
-
const application = setup();
|
|
15
|
-
expect(application.type).toBe("coreApp");
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
it("should have a href of <application>/<id>", () => {
|
|
19
|
-
const application = setup();
|
|
20
|
-
expect(application.href).toBe("/application/v27rvqtlp3lmdvcln6ey3lro");
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
it("should have a name of the application title", () => {
|
|
24
|
-
const application = setup();
|
|
25
|
-
expect(application.title).toBe("sdk-movie-list");
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
it("should have a updatedAt property", () => {
|
|
29
|
-
const application = setup();
|
|
30
|
-
expect(application.updatedAt).toBe("2025-03-27T19:00:32.792Z");
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
it("should have an activeDeployment property", () => {
|
|
34
|
-
const application = setup();
|
|
35
|
-
expect(application.activeDeployment).toMatchInlineSnapshot(`
|
|
36
|
-
{
|
|
37
|
-
"createdAt": "2025-03-27T19:07:21.038Z",
|
|
38
|
-
"deployedAt": "2025-03-27T19:07:21.082Z",
|
|
39
|
-
"deployedBy": "gwXueEBci",
|
|
40
|
-
"id": "dv3kz3fsl4aqha3parc8k391",
|
|
41
|
-
"isActiveDeployment": true,
|
|
42
|
-
"isAutoUpdating": false,
|
|
43
|
-
"manifest": null,
|
|
44
|
-
"size": 528292,
|
|
45
|
-
"updatedAt": "2025-03-27T19:07:21.082Z",
|
|
46
|
-
"userApplicationId": "v27rvqtlp3lmdvcln6ey3lro",
|
|
47
|
-
"version": "3.81.0",
|
|
48
|
-
}
|
|
49
|
-
`);
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
it("should implement the toProtocolResource method", () => {
|
|
53
|
-
vi.stubEnv("VITE_SANITY_ENV", "staging");
|
|
54
|
-
vi.stubEnv("VITE_SANITY_DOMAIN", "sanity.work");
|
|
55
|
-
const application = setup();
|
|
56
|
-
expect(application.toProtocolResource()).toMatchInlineSnapshot(`
|
|
57
|
-
{
|
|
58
|
-
"activeDeployment": {
|
|
59
|
-
"createdAt": "2025-03-27T19:07:21.038Z",
|
|
60
|
-
"deployedAt": "2025-03-27T19:07:21.082Z",
|
|
61
|
-
"deployedBy": "gwXueEBci",
|
|
62
|
-
"id": "dv3kz3fsl4aqha3parc8k391",
|
|
63
|
-
"isActiveDeployment": true,
|
|
64
|
-
"isAutoUpdating": false,
|
|
65
|
-
"manifest": null,
|
|
66
|
-
"size": 528292,
|
|
67
|
-
"updatedAt": "2025-03-27T19:07:21.082Z",
|
|
68
|
-
"userApplicationId": "v27rvqtlp3lmdvcln6ey3lro",
|
|
69
|
-
"version": "3.81.0",
|
|
70
|
-
},
|
|
71
|
-
"appHost": "x7apsmr6fxvc",
|
|
72
|
-
"createdAt": "2025-03-27T19:00:32.792Z",
|
|
73
|
-
"dashboardStatus": "default",
|
|
74
|
-
"id": "v27rvqtlp3lmdvcln6ey3lro",
|
|
75
|
-
"organizationId": "oSyH1iET5",
|
|
76
|
-
"projectId": null,
|
|
77
|
-
"title": "sdk-movie-list",
|
|
78
|
-
"type": "application",
|
|
79
|
-
"updatedAt": "2025-03-27T19:00:32.792Z",
|
|
80
|
-
"url": "https://x7apsmr6fxvc.studio.sanity.work/",
|
|
81
|
-
"urlType": "internal",
|
|
82
|
-
}
|
|
83
|
-
`);
|
|
84
|
-
|
|
85
|
-
expectTypeOf(
|
|
86
|
-
application.toProtocolResource(),
|
|
87
|
-
).toEqualTypeOf<ProtocolApplicationResource>();
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
it("should return undefined for subtitle", () => {
|
|
91
|
-
const application = setup();
|
|
92
|
-
expect(application.subtitle).toBeUndefined();
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
describe("get", () => {
|
|
96
|
-
it("should throw when accessing a non-existent attribute", () => {
|
|
97
|
-
const application = setup();
|
|
98
|
-
expect(() =>
|
|
99
|
-
// @ts-expect-error - testing invalid attribute
|
|
100
|
-
application.get("nonExistent"),
|
|
101
|
-
).toThrow(
|
|
102
|
-
"Attribute nonExistent does not exist on application v27rvqtlp3lmdvcln6ey3lro",
|
|
103
|
-
);
|
|
104
|
-
});
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
describe("manifest functionality", () => {
|
|
108
|
-
it("should use manifest from application when present", () => {
|
|
109
|
-
const applicationWithManifest = {
|
|
110
|
-
...APPLICATION_DATA,
|
|
111
|
-
activeDeployment: {
|
|
112
|
-
...APPLICATION_DATA.activeDeployment,
|
|
113
|
-
manifest: {
|
|
114
|
-
version: "1.0.0",
|
|
115
|
-
icon: "<svg>test-icon</svg>",
|
|
116
|
-
title: "Manifest Title",
|
|
117
|
-
},
|
|
118
|
-
},
|
|
119
|
-
};
|
|
120
|
-
const application = new CoreAppApplication(applicationWithManifest);
|
|
121
|
-
expect(application.title).toBe("Manifest Title");
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
it("should use manifest from activeDeployment when application manifest is not present", () => {
|
|
125
|
-
const applicationWithDeploymentManifest = {
|
|
126
|
-
...APPLICATION_DATA,
|
|
127
|
-
activeDeployment: {
|
|
128
|
-
...APPLICATION_DATA.activeDeployment,
|
|
129
|
-
manifest: {
|
|
130
|
-
version: "1.0.0",
|
|
131
|
-
icon: "<svg>deployment-icon</svg>",
|
|
132
|
-
title: "Deployment Title",
|
|
133
|
-
},
|
|
134
|
-
},
|
|
135
|
-
};
|
|
136
|
-
const application = new CoreAppApplication(
|
|
137
|
-
applicationWithDeploymentManifest,
|
|
138
|
-
);
|
|
139
|
-
expect(application.title).toBe("Deployment Title");
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
it("should allow you to get attributes from the application", () => {
|
|
143
|
-
const application = setup();
|
|
144
|
-
|
|
145
|
-
expect(application.get("title")).toBe("sdk-movie-list");
|
|
146
|
-
expect(application.get("urlType")).toBe("internal");
|
|
147
|
-
expect(application.get("appHost")).toBe("x7apsmr6fxvc");
|
|
148
|
-
expectTypeOf(application.get("appHost")).toEqualTypeOf<string>();
|
|
149
|
-
});
|
|
150
|
-
});
|
|
151
|
-
});
|