-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
-
34
-
35
-
36
-
37
-
38
-
39
-
40
-
41
-
42
-
43
-
44
-
45
-
46
-
47
-
48
-
49
-
50
-
51
-
52
-
53
-
54
-
55
-
56
-
57
-
58
-
59
-
60
-
61
-
62
-
63
-
64
-
65
-
66
-
67
-
68
-
69
-
70
-
71
-
72
-
73
-
74
-
75
-
76
-
77
-
78
-
79
-
80
-
81
-
82
-
83
-
84
-
85
-
86
-
87
-
88
-
89
-
90
-
91
-
92
-
93
-
94
-
95
-
96
-
97
-
98
-
99
-
100
-
101
-
102
-
103
-
104
-
105
-
106
-
107
-
108
-
109
-
110
-
111
-
112
-
113
-
114
-
115
-
116
-
117
-
118
-
119
-
120
-
121
-
122
-
123
-
124
-
125
-
126
---
// SPDX-FileCopyrightText: 2024 Shota FUJI <pockawoooh@gmail.com>
// SPDX-License-Identifier: AGPL-3.0-only
import DocsLayout from "../../layouts/DocsLayout.astro";
import Document from "../../components/Document.astro";
import Preview from "../../components/Preview.astro";
import ThemeMatrixPreview from "../../components/ThemeMatrixPreview.astro";
import { create, toJsonString } from "@bufbuild/protobuf";
import { ListResponseSchema } from "@yamori/proto/yamori/workspace/v1/list_response_pb.js";
const sampleAttr = toJsonString(
ListResponseSchema,
create(ListResponseSchema, {
result: {
case: "ok",
value: {
workspaces: [
{
id: { value: "ws-foo" },
displayName: "Foo",
},
{
id: { value: "ws-bar" },
displayName: "ばー",
},
],
},
},
}),
);
---
<script>
import { create } from "@bufbuild/protobuf";
import { ListResponseSchema } from "@yamori/proto/yamori/workspace/v1/list_response_pb.js";
import {
OpenEvent,
RetryEvent,
YamoriWorkspaceList,
} from "../../../widgets/workspace-list/workspace-list.ts";
customElements.whenDefined(YamoriWorkspaceList.tagName).then(() => {
for (const demo of document.querySelectorAll("[data-id=demo]")) {
demo.setListResponse(
create(ListResponseSchema, {
result: {
case: "ok",
value: {
workspaces: [
{
id: { value: "ws-foo" },
displayName: "Foo",
},
{
id: { value: "ws-bar" },
displayName: "ばー",
},
],
},
},
}),
);
}
for (const demo of document.querySelectorAll("[data-id=system_error]")) {
demo.setListResponse(
create(ListResponseSchema, {
result: {
case: "systemError",
value: {
code: "SAMPLE_ERR",
message: "サンプルエラー",
},
},
}),
);
demo.addEventListener("retry", (event) => {
if (event instanceof RetryEvent) {
console.groupCollapsed("yamori-workspace-list.retry");
console.dir(event);
console.groupEnd();
}
});
}
});
document.addEventListener("open", (event) => {
if (event instanceof OpenEvent) {
console.groupCollapsed("yamori-workspace-list.open (composed)");
console.dir(event);
console.groupEnd();
}
});
</script>
<DocsLayout title="Workspace List">
<Document>
<p>
<code>yamori.workspace.v1.ListResponse</code> を表示する UI 要素です。
</p>
<ThemeMatrixPreview>
<yamori-workspace-list data-id="demo"></yamori-workspace-list>
</ThemeMatrixPreview>
<h2>System Error</h2>
<p>
レスポンスが <code>system_error</code> の場合はエラー表示となります。
</p>
<Preview title="result=system_error">
<yamori-workspace-list data-id="system_error"></yamori-workspace-list>
</Preview>
<h2>Attribute Usage</h2>
<p>
<code>setListResponse</code> メソッドの代わりに <code>list-response</code>
属性に <code>toJsonString</code> の結果を値として指定することも可能です。
</p>
<Preview>
<yamori-workspace-list list-response={sampleAttr}></yamori-workspace-list>
</Preview>
</Document>
</DocsLayout>