@dxos/plugin-kanban 0.8.4-main.2e9d522 → 0.8.4-main.406dc2a

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 (75) hide show
  1. package/dist/lib/browser/blueprint-definition-UYVX622Q.mjs +28 -0
  2. package/dist/lib/browser/blueprint-definition-UYVX622Q.mjs.map +7 -0
  3. package/dist/lib/browser/{chunk-X44RHBZK.mjs → chunk-K7KYFJ3P.mjs} +6 -34
  4. package/dist/lib/browser/chunk-K7KYFJ3P.mjs.map +7 -0
  5. package/dist/lib/browser/index.mjs +14 -15
  6. package/dist/lib/browser/index.mjs.map +3 -3
  7. package/dist/lib/browser/{intent-resolver-E6O3LBAB.mjs → intent-resolver-LR3SDMKQ.mjs} +15 -15
  8. package/dist/lib/browser/intent-resolver-LR3SDMKQ.mjs.map +7 -0
  9. package/dist/lib/browser/meta.json +1 -1
  10. package/dist/lib/browser/{react-surface-MWNNZYMN.mjs → react-surface-R2ORFB43.mjs} +25 -26
  11. package/dist/lib/browser/react-surface-R2ORFB43.mjs.map +7 -0
  12. package/dist/lib/browser/types/index.mjs +3 -5
  13. package/dist/lib/node-esm/blueprint-definition-42P47FUY.mjs +30 -0
  14. package/dist/lib/node-esm/blueprint-definition-42P47FUY.mjs.map +7 -0
  15. package/dist/lib/node-esm/{chunk-6WK5CGYY.mjs → chunk-VDWYSHP4.mjs} +6 -34
  16. package/dist/lib/node-esm/chunk-VDWYSHP4.mjs.map +7 -0
  17. package/dist/lib/node-esm/index.mjs +14 -15
  18. package/dist/lib/node-esm/index.mjs.map +3 -3
  19. package/dist/lib/node-esm/{intent-resolver-LPASDELU.mjs → intent-resolver-CKDNVLND.mjs} +15 -15
  20. package/dist/lib/node-esm/intent-resolver-CKDNVLND.mjs.map +7 -0
  21. package/dist/lib/node-esm/meta.json +1 -1
  22. package/dist/lib/node-esm/{react-surface-T52BBG45.mjs → react-surface-RMRLHCOY.mjs} +25 -26
  23. package/dist/lib/node-esm/react-surface-RMRLHCOY.mjs.map +7 -0
  24. package/dist/lib/node-esm/types/index.mjs +3 -5
  25. package/dist/types/src/KanbanPlugin.d.ts +1 -1
  26. package/dist/types/src/KanbanPlugin.d.ts.map +1 -1
  27. package/dist/types/src/capabilities/artifact-definition.d.ts +1 -1
  28. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  29. package/dist/types/src/capabilities/blueprint-definition.d.ts +5 -0
  30. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  31. package/dist/types/src/capabilities/index.d.ts +3 -3
  32. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  33. package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
  34. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  35. package/dist/types/src/capabilities/react-surface.d.ts +1 -1
  36. package/dist/types/src/components/KanbanContainer.d.ts.map +1 -1
  37. package/dist/types/src/components/KanbanContainer.stories.d.ts +37 -6
  38. package/dist/types/src/components/KanbanContainer.stories.d.ts.map +1 -1
  39. package/dist/types/src/components/KanbanViewEditor.d.ts.map +1 -1
  40. package/dist/types/src/meta.d.ts +0 -1
  41. package/dist/types/src/meta.d.ts.map +1 -1
  42. package/dist/types/src/translations.d.ts +2 -2
  43. package/dist/types/src/translations.d.ts.map +1 -1
  44. package/dist/types/src/types/index.d.ts +0 -1
  45. package/dist/types/src/types/index.d.ts.map +1 -1
  46. package/dist/types/src/types/schema.d.ts +11 -54
  47. package/dist/types/src/types/schema.d.ts.map +1 -1
  48. package/dist/types/tsconfig.tsbuildinfo +1 -1
  49. package/package.json +42 -40
  50. package/src/KanbanPlugin.tsx +50 -50
  51. package/src/capabilities/artifact-definition.ts +10 -6
  52. package/src/capabilities/blueprint-definition.ts +30 -0
  53. package/src/capabilities/index.ts +1 -1
  54. package/src/capabilities/intent-resolver.ts +10 -9
  55. package/src/capabilities/react-surface.tsx +5 -5
  56. package/src/components/KanbanContainer.stories.tsx +34 -30
  57. package/src/components/KanbanContainer.tsx +6 -6
  58. package/src/components/KanbanViewEditor.tsx +15 -11
  59. package/src/meta.ts +1 -3
  60. package/src/translations.ts +2 -2
  61. package/src/types/index.ts +0 -1
  62. package/src/types/schema.ts +5 -5
  63. package/dist/lib/browser/artifact-definition-WMSZK3RW.mjs +0 -174
  64. package/dist/lib/browser/artifact-definition-WMSZK3RW.mjs.map +0 -7
  65. package/dist/lib/browser/chunk-X44RHBZK.mjs.map +0 -7
  66. package/dist/lib/browser/intent-resolver-E6O3LBAB.mjs.map +0 -7
  67. package/dist/lib/browser/react-surface-MWNNZYMN.mjs.map +0 -7
  68. package/dist/lib/node-esm/artifact-definition-QVZXPDXK.mjs +0 -175
  69. package/dist/lib/node-esm/artifact-definition-QVZXPDXK.mjs.map +0 -7
  70. package/dist/lib/node-esm/chunk-6WK5CGYY.mjs.map +0 -7
  71. package/dist/lib/node-esm/intent-resolver-LPASDELU.mjs.map +0 -7
  72. package/dist/lib/node-esm/react-surface-T52BBG45.mjs.map +0 -7
  73. package/dist/types/src/types/kanban.d.ts +0 -11
  74. package/dist/types/src/types/kanban.d.ts.map +0 -1
  75. package/src/types/kanban.ts +0 -29
@@ -5,26 +5,27 @@
5
5
  import React, { useCallback, useMemo } from 'react';
6
6
 
7
7
  import { Type } from '@dxos/echo';
8
- import { EchoSchema, FormatEnum } from '@dxos/echo-schema';
8
+ import { EchoSchema, FormatEnum } from '@dxos/echo/internal';
9
9
  import { useClient } from '@dxos/react-client';
10
10
  import { getSpace, useSchema } from '@dxos/react-client/echo';
11
- import { Form, SelectInput, type CustomInputMap } from '@dxos/react-ui-form';
12
- import { KanbanSettingsSchema, type KanbanView } from '@dxos/react-ui-kanban';
13
- import { type DataType, ProjectionModel } from '@dxos/schema';
11
+ import { type CustomInputMap, Form, SelectInput } from '@dxos/react-ui-form';
12
+ import { Kanban } from '@dxos/react-ui-kanban/types';
13
+ import { type DataType, ProjectionModel, getTypenameFromQuery } from '@dxos/schema';
14
14
 
15
15
  type KanbanViewEditorProps = { view: DataType.View };
16
16
 
17
17
  export const KanbanViewEditor = ({ view }: KanbanViewEditorProps) => {
18
18
  const client = useClient();
19
19
  const space = getSpace(view);
20
- const kanban = view.presentation.target as KanbanView;
21
- const currentTypename = useMemo(() => view.query.typename, [view.query.typename]);
20
+ const currentTypename = view.query ? getTypenameFromQuery(view.query.ast) : undefined;
22
21
  const schema = useSchema(client, space, currentTypename);
23
22
 
24
23
  const projection = useMemo(() => {
25
24
  if (schema) {
26
25
  const jsonSchema = schema instanceof EchoSchema ? schema.jsonSchema : Type.toJsonSchema(schema);
27
- return new ProjectionModel(jsonSchema, view.projection);
26
+ const projection = new ProjectionModel(jsonSchema, view.projection);
27
+ projection.normalizeView();
28
+ return projection;
28
29
  }
29
30
  }, [view.projection, JSON.stringify(schema)]);
30
31
 
@@ -35,12 +36,15 @@ export const KanbanViewEditor = ({ view }: KanbanViewEditorProps) => {
35
36
 
36
37
  const handleSave = useCallback(
37
38
  (values: Partial<{ columnFieldId: string }>) => {
38
- kanban.columnFieldId = values.columnFieldId;
39
+ view.projection.pivotFieldId = values.columnFieldId;
39
40
  },
40
- [kanban],
41
+ [view],
41
42
  );
42
43
 
43
- const initialValues = useMemo(() => ({ columnFieldId: kanban.columnFieldId }), [kanban.columnFieldId]);
44
+ const initialValues = useMemo(
45
+ () => ({ columnFieldId: view.projection.pivotFieldId }),
46
+ [view.projection.pivotFieldId],
47
+ );
44
48
  const custom: CustomInputMap = useMemo(
45
49
  () => ({ columnFieldId: (props) => <SelectInput {...props} options={selectFields} /> }),
46
50
  [selectFields],
@@ -49,7 +53,7 @@ export const KanbanViewEditor = ({ view }: KanbanViewEditorProps) => {
49
53
  return (
50
54
  <Form
51
55
  Custom={custom}
52
- schema={KanbanSettingsSchema}
56
+ schema={Kanban.SettingsSchema}
53
57
  values={initialValues}
54
58
  onSave={handleSave}
55
59
  autoSave
package/src/meta.ts CHANGED
@@ -4,10 +4,8 @@
4
4
 
5
5
  import { type PluginMeta } from '@dxos/app-framework';
6
6
 
7
- export const KANBAN_PLUGIN = 'dxos.org/plugin/kanban';
8
-
9
7
  export const meta: PluginMeta = {
10
- id: KANBAN_PLUGIN,
8
+ id: 'dxos.org/plugin/kanban',
11
9
  name: 'Kanban',
12
10
  description:
13
11
  'Kanban allows you to explore Table data in sorted columns defined by your custom schema. You can use Kanbans to track progress or trigger custom automations when cards are moved from one state to another.',
@@ -3,14 +3,14 @@
3
3
  //
4
4
 
5
5
  import { type Resource } from '@dxos/react-ui';
6
- import { KanbanView } from '@dxos/react-ui-kanban';
6
+ import { Kanban } from '@dxos/react-ui-kanban/types';
7
7
 
8
8
  import { meta } from './meta';
9
9
 
10
10
  export const translations = [
11
11
  {
12
12
  'en-US': {
13
- [KanbanView.typename]: {
13
+ [Kanban.Kanban.typename]: {
14
14
  'typename label': 'Kanban',
15
15
  'typename label_zero': 'Kanbans',
16
16
  'typename label_one': 'Kanban',
@@ -2,6 +2,5 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- export * from './kanban';
6
5
  export * from './schema';
7
6
  export type * from './types';
@@ -2,12 +2,12 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { Schema } from 'effect';
5
+ import * as Schema from 'effect/Schema';
6
6
 
7
7
  import { SpaceSchema } from '@dxos/react-client/echo';
8
8
  import { DataType, FieldSchema, TypenameAnnotationId } from '@dxos/schema';
9
9
 
10
- import { KANBAN_PLUGIN } from '../meta';
10
+ import { meta } from '../meta';
11
11
 
12
12
  /**
13
13
  * Kanban data model.
@@ -25,8 +25,8 @@ export const CreateKanbanSchema = Schema.Struct({
25
25
  name: Schema.optional(Schema.String),
26
26
  typename: Schema.optional(
27
27
  Schema.String.annotations({
28
- [TypenameAnnotationId]: ['limited-static', 'dynamic'],
29
- title: 'Select card schema (leave empty to start fresh)',
28
+ [TypenameAnnotationId]: ['used-static', 'dynamic'],
29
+ title: 'Select card record type (leave empty to start fresh)',
30
30
  }),
31
31
  ),
32
32
  initialPivotColumn: Schema.optional(
@@ -38,7 +38,7 @@ export const CreateKanbanSchema = Schema.Struct({
38
38
  });
39
39
 
40
40
  export namespace KanbanAction {
41
- const KANBAN_ACTION = `${KANBAN_PLUGIN}/action`;
41
+ const KANBAN_ACTION = `${meta.id}/action`;
42
42
 
43
43
  export class Create extends Schema.TaggedClass<Create>()(`${KANBAN_ACTION}/create`, {
44
44
  input: Schema.extend(Schema.Struct({ space: SpaceSchema }), CreateKanbanSchema),
@@ -1,174 +0,0 @@
1
- import {
2
- KanbanAction,
3
- meta
4
- } from "./chunk-X44RHBZK.mjs";
5
-
6
- // src/capabilities/artifact-definition.ts
7
- import { Schema, pipe } from "effect";
8
- import { createTool, ToolResult } from "@dxos/ai";
9
- import { Capabilities, chain, contributes, createIntent } from "@dxos/app-framework";
10
- import { createArtifactElement } from "@dxos/assistant";
11
- import { defineArtifact } from "@dxos/blueprints";
12
- import { Obj, Query } from "@dxos/echo";
13
- import { invariant } from "@dxos/invariant";
14
- import { SpaceAction } from "@dxos/plugin-space/types";
15
- import { Filter, fullyQualifiedId } from "@dxos/react-client/echo";
16
- import { KanbanView } from "@dxos/react-ui-kanban";
17
- import { DataType } from "@dxos/schema";
18
- import { isNonNullable } from "@dxos/util";
19
- var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-kanban/src/capabilities/artifact-definition.ts";
20
- var QualifiedId = Schema.String.annotations({
21
- description: "The fully qualified ID of the kanban `spaceID:objectID`"
22
- });
23
- var artifact_definition_default = () => {
24
- const definition = defineArtifact({
25
- id: `artifact:${meta.id}`,
26
- name: meta.name,
27
- instructions: `
28
- - Before adding items to a kanban board, inspect the board to see its schema
29
- - When adding items, you must not include the 'id' field -- it is automatically generated
30
- - BEFORE adding items, always make sure the board has been shown to the user!
31
- `,
32
- schema: KanbanView,
33
- tools: [
34
- createTool(meta.id, {
35
- name: "create",
36
- description: `
37
- Create a new kanban board using an existing schema.
38
- Use schema_create first to create a schema, or schema_list to choose an existing one.`,
39
- caption: "Creating kanban board...",
40
- schema: Schema.Struct({
41
- typename: Schema.String.annotations({
42
- description: "The fully qualified typename of the schema to use for the kanban cards."
43
- }),
44
- pivotColumn: Schema.optional(Schema.String).annotations({
45
- description: "Optional field name to use as the column pivot."
46
- })
47
- }),
48
- execute: async ({ typename, pivotColumn }, { extensions }) => {
49
- invariant(extensions?.space, "No space", {
50
- F: __dxlog_file,
51
- L: 59,
52
- S: void 0,
53
- A: [
54
- "extensions?.space",
55
- "'No space'"
56
- ]
57
- });
58
- invariant(extensions?.dispatch, "No intent dispatcher", {
59
- F: __dxlog_file,
60
- L: 60,
61
- S: void 0,
62
- A: [
63
- "extensions?.dispatch",
64
- "'No intent dispatcher'"
65
- ]
66
- });
67
- const schema = await extensions.space.db.schemaRegistry.query({
68
- typename
69
- }).firstOrUndefined();
70
- if (!schema) {
71
- return ToolResult.Error(`Schema not found: ${typename}`);
72
- }
73
- const intent = pipe(createIntent(KanbanAction.Create, {
74
- space: extensions.space,
75
- typename,
76
- initialPivotColumn: pivotColumn
77
- }), chain(SpaceAction.AddObject, {
78
- target: extensions.space
79
- }));
80
- const { data, error } = await extensions.dispatch(intent);
81
- if (!data || error) {
82
- return ToolResult.Error(error?.message ?? "Failed to create kanban board");
83
- }
84
- return ToolResult.Success(createArtifactElement(data.id));
85
- }
86
- }),
87
- createTool(meta.id, {
88
- name: "list",
89
- description: "List all kanban boards in the current space.",
90
- caption: "Listing kanban boards...",
91
- schema: Schema.Struct({}),
92
- execute: async (_input, { extensions }) => {
93
- invariant(extensions?.space, "No space", {
94
- F: __dxlog_file,
95
- L: 91,
96
- S: void 0,
97
- A: [
98
- "extensions?.space",
99
- "'No space'"
100
- ]
101
- });
102
- const space = extensions.space;
103
- const { objects } = await space.db.query(Filter.type(DataType.View)).run();
104
- const boardInfo = await Promise.all(objects.map(async (view) => {
105
- const kanban = await view.presentation.load();
106
- if (!Obj.instanceOf(KanbanView, kanban)) {
107
- return null;
108
- }
109
- return {
110
- id: fullyQualifiedId(view),
111
- name: view.name ?? "Unnamed Kanban",
112
- typename: view.query.typename
113
- };
114
- }));
115
- return ToolResult.Success(boardInfo.filter(isNonNullable));
116
- }
117
- }),
118
- createTool(meta.id, {
119
- name: "inspect",
120
- description: "Get details about a specific kanban board.",
121
- caption: "Inspecting kanban board...",
122
- schema: Schema.Struct({
123
- id: QualifiedId
124
- }),
125
- execute: async ({ id }, { extensions }) => {
126
- invariant(extensions?.space, "No space", {
127
- F: __dxlog_file,
128
- L: 119,
129
- S: void 0,
130
- A: [
131
- "extensions?.space",
132
- "'No space'"
133
- ]
134
- });
135
- const space = extensions.space;
136
- const view = await space.db.query(Query.select(Filter.and(Filter.type(DataType.View), Filter.ids(id)))).first();
137
- const kanban = await view.presentation.load();
138
- invariant(Obj.instanceOf(KanbanView, kanban), void 0, {
139
- F: __dxlog_file,
140
- L: 127,
141
- S: void 0,
142
- A: [
143
- "Obj.instanceOf(KanbanView, kanban)",
144
- ""
145
- ]
146
- });
147
- const typename = view.query.typename;
148
- const schema = await space.db.schemaRegistry.query({
149
- typename
150
- }).firstOrUndefined();
151
- invariant(schema, void 0, {
152
- F: __dxlog_file,
153
- L: 131,
154
- S: void 0,
155
- A: [
156
- "schema",
157
- ""
158
- ]
159
- });
160
- return ToolResult.Success({
161
- schema,
162
- columnField: kanban.columnFieldId,
163
- viewFields: view.projection.fields
164
- });
165
- }
166
- })
167
- ]
168
- });
169
- return contributes(Capabilities.ArtifactDefinition, definition);
170
- };
171
- export {
172
- artifact_definition_default as default
173
- };
174
- //# sourceMappingURL=artifact-definition-WMSZK3RW.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/artifact-definition.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema, pipe } from 'effect';\n\nimport { createTool, ToolResult } from '@dxos/ai';\nimport { Capabilities, chain, contributes, createIntent, type PromiseIntentDispatcher } from '@dxos/app-framework';\nimport { createArtifactElement } from '@dxos/assistant';\nimport { defineArtifact } from '@dxos/blueprints';\nimport { Obj, Query } from '@dxos/echo';\nimport { invariant } from '@dxos/invariant';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { Filter, fullyQualifiedId, type Space } from '@dxos/react-client/echo';\nimport { KanbanView } from '@dxos/react-ui-kanban';\nimport { DataType } from '@dxos/schema';\nimport { isNonNullable } from '@dxos/util';\n\nimport { meta } from '../meta';\nimport { KanbanAction } from '../types';\n\nconst QualifiedId = Schema.String.annotations({\n description: 'The fully qualified ID of the kanban `spaceID:objectID`',\n});\n\ndeclare global {\n interface ToolContextExtensions {\n space?: Space;\n dispatch?: PromiseIntentDispatcher;\n }\n}\n\nexport default () => {\n const definition = defineArtifact({\n id: `artifact:${meta.id}`,\n name: meta.name,\n instructions: `\n - Before adding items to a kanban board, inspect the board to see its schema\n - When adding items, you must not include the 'id' field -- it is automatically generated\n - BEFORE adding items, always make sure the board has been shown to the user!\n `,\n schema: KanbanView,\n tools: [\n createTool(meta.id, {\n name: 'create',\n description: `\n Create a new kanban board using an existing schema.\n Use schema_create first to create a schema, or schema_list to choose an existing one.`,\n caption: 'Creating kanban board...',\n schema: Schema.Struct({\n typename: Schema.String.annotations({\n description: 'The fully qualified typename of the schema to use for the kanban cards.',\n }),\n pivotColumn: Schema.optional(Schema.String).annotations({\n description: 'Optional field name to use as the column pivot.',\n }),\n }),\n execute: async ({ typename, pivotColumn }, { extensions }) => {\n invariant(extensions?.space, 'No space');\n invariant(extensions?.dispatch, 'No intent dispatcher');\n\n // Validate schema exists first\n const schema = await extensions.space.db.schemaRegistry.query({ typename }).firstOrUndefined();\n if (!schema) {\n return ToolResult.Error(`Schema not found: ${typename}`);\n }\n\n const intent = pipe(\n createIntent(KanbanAction.Create, {\n space: extensions.space,\n typename,\n initialPivotColumn: pivotColumn,\n }),\n chain(SpaceAction.AddObject, { target: extensions.space }),\n );\n\n const { data, error } = await extensions.dispatch(intent);\n if (!data || error) {\n return ToolResult.Error(error?.message ?? 'Failed to create kanban board');\n }\n\n return ToolResult.Success(createArtifactElement(data.id));\n },\n }),\n createTool(meta.id, {\n name: 'list',\n description: 'List all kanban boards in the current space.',\n caption: 'Listing kanban boards...',\n schema: Schema.Struct({}),\n execute: async (_input, { extensions }) => {\n invariant(extensions?.space, 'No space');\n const space = extensions.space;\n const { objects } = await space.db.query(Filter.type(DataType.View)).run();\n\n const boardInfo = await Promise.all(\n objects.map(async (view) => {\n const kanban = await view.presentation.load();\n if (!Obj.instanceOf(KanbanView, kanban)) {\n return null;\n }\n\n return {\n id: fullyQualifiedId(view),\n name: view.name ?? 'Unnamed Kanban',\n typename: view.query.typename,\n };\n }),\n );\n\n return ToolResult.Success(boardInfo.filter(isNonNullable));\n },\n }),\n createTool(meta.id, {\n name: 'inspect',\n description: 'Get details about a specific kanban board.',\n caption: 'Inspecting kanban board...',\n schema: Schema.Struct({ id: QualifiedId }),\n execute: async ({ id }, { extensions }) => {\n invariant(extensions?.space, 'No space');\n const space = extensions.space;\n const view = (await space.db\n // TODO(wittjosiah): Filter.and should aggregate type\n .query(Query.select(Filter.and(Filter.type(DataType.View), Filter.ids(id))))\n .first()) as DataType.View;\n\n const kanban = await view.presentation.load();\n invariant(Obj.instanceOf(KanbanView, kanban));\n\n const typename = view.query.typename;\n const schema = await space.db.schemaRegistry.query({ typename }).firstOrUndefined();\n invariant(schema);\n\n return ToolResult.Success({\n schema,\n columnField: kanban.columnFieldId,\n viewFields: view.projection.fields,\n });\n },\n }),\n ],\n });\n\n return contributes(Capabilities.ArtifactDefinition, definition);\n};\n"],
5
- "mappings": "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",
6
- "names": ["Schema", "pipe", "createTool", "ToolResult", "Capabilities", "chain", "contributes", "createIntent", "createArtifactElement", "defineArtifact", "Obj", "Query", "invariant", "SpaceAction", "Filter", "fullyQualifiedId", "KanbanView", "DataType", "isNonNullable", "QualifiedId", "Schema", "String", "annotations", "description", "definition", "defineArtifact", "id", "meta", "name", "instructions", "schema", "KanbanView", "tools", "createTool", "caption", "Struct", "typename", "pivotColumn", "optional", "execute", "extensions", "invariant", "space", "dispatch", "db", "schemaRegistry", "query", "firstOrUndefined", "ToolResult", "Error", "intent", "pipe", "createIntent", "KanbanAction", "Create", "initialPivotColumn", "chain", "SpaceAction", "AddObject", "target", "data", "error", "message", "Success", "createArtifactElement", "_input", "objects", "Filter", "type", "DataType", "View", "run", "boardInfo", "Promise", "all", "map", "view", "kanban", "presentation", "load", "Obj", "instanceOf", "fullyQualifiedId", "filter", "isNonNullable", "Query", "select", "and", "ids", "first", "columnField", "columnFieldId", "viewFields", "projection", "fields", "contributes", "Capabilities", "ArtifactDefinition"]
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/types/kanban.ts", "../../../src/types/schema.ts", "../../../src/meta.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Obj } from '@dxos/echo';\nimport { type JsonSchemaType } from '@dxos/echo-schema';\nimport { KanbanView } from '@dxos/react-ui-kanban';\nimport { type DataType, type CreateViewFromSpaceProps, createViewFromSpace, ProjectionModel } from '@dxos/schema';\n\ntype InitializeKanbanProps = Omit<CreateViewFromSpaceProps, 'presentation'> & {\n initialPivotColumn?: string;\n};\n\nexport const createKanban = async ({\n initialPivotColumn,\n ...props\n}: InitializeKanbanProps): Promise<{ jsonSchema: JsonSchemaType; view: DataType.View }> => {\n const kanban = Obj.make(KanbanView, { columnFieldId: undefined });\n const { jsonSchema, view } = await createViewFromSpace({ ...props, presentation: kanban });\n if (initialPivotColumn) {\n const projection = new ProjectionModel(jsonSchema, view.projection);\n const fieldId = projection.getFieldId(initialPivotColumn);\n if (fieldId) {\n kanban.columnFieldId = fieldId;\n }\n }\n\n return { jsonSchema, view };\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { SpaceSchema } from '@dxos/react-client/echo';\nimport { DataType, FieldSchema, TypenameAnnotationId } from '@dxos/schema';\n\nimport { KANBAN_PLUGIN } from '../meta';\n\n/**\n * Kanban data model.\n * A Kanban board is a collection of columns, each of which contains a collection of items.\n * The layout of columns and items is controlled by models.\n * The underlying data model may be represented by direct object relationships\n * (e.g., a column object containing an array of ordered items) or projections constructed\n * by the model (e.g., a query of items based on metadata within a column object).\n */\n\n// TODO(wittjosiah): Factor out?\nexport const PivotColumnAnnotationId = Symbol.for('@dxos/plugin-kanban/annotation/PivotColumn');\n\nexport const CreateKanbanSchema = Schema.Struct({\n name: Schema.optional(Schema.String),\n typename: Schema.optional(\n Schema.String.annotations({\n [TypenameAnnotationId]: ['limited-static', 'dynamic'],\n title: 'Select card schema (leave empty to start fresh)',\n }),\n ),\n initialPivotColumn: Schema.optional(\n Schema.String.annotations({\n [PivotColumnAnnotationId]: true,\n title: 'Pivot column',\n }),\n ),\n});\n\nexport namespace KanbanAction {\n const KANBAN_ACTION = `${KANBAN_PLUGIN}/action`;\n\n export class Create extends Schema.TaggedClass<Create>()(`${KANBAN_ACTION}/create`, {\n input: Schema.extend(Schema.Struct({ space: SpaceSchema }), CreateKanbanSchema),\n output: Schema.Struct({\n object: DataType.View,\n }),\n }) {}\n\n export class DeleteCardField extends Schema.TaggedClass<DeleteCardField>()(`${KANBAN_ACTION}/delete-card-field`, {\n input: Schema.Struct({\n view: DataType.View,\n fieldId: Schema.String,\n // TODO(wittjosiah): Separate fields for undo data?\n deletionData: Schema.optional(\n Schema.Struct({\n field: FieldSchema,\n // TODO(wittjosiah): This creates a type error.\n // props: PropertySchema,\n props: Schema.Any,\n index: Schema.Number,\n }),\n ),\n }),\n output: Schema.Void,\n }) {}\n\n export class DeleteCard extends Schema.TaggedClass<DeleteCard>()(`${KANBAN_ACTION}/delete-card`, {\n input: Schema.Struct({\n card: Schema.Any, // The card object to delete\n }),\n output: Schema.Void,\n }) {}\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const KANBAN_PLUGIN = 'dxos.org/plugin/kanban';\n\nexport const meta: PluginMeta = {\n id: KANBAN_PLUGIN,\n name: 'Kanban',\n description:\n 'Kanban allows you to explore Table data in sorted columns defined by your custom schema. You can use Kanbans to track progress or trigger custom automations when cards are moved from one state to another.',\n icon: 'ph--kanban--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-kanban',\n screenshots: ['https://dxos.network/plugin-details-kanban-dark.png'],\n};\n"],
5
- "mappings": ";AAIA,SAASA,WAAW;AAEpB,SAASC,kBAAkB;AAC3B,SAAuDC,qBAAqBC,uBAAuB;AAM5F,IAAMC,eAAe,OAAO,EACjCC,oBACA,GAAGC,MAAAA,MACmB;AACtB,QAAMC,SAASC,IAAIC,KAAKC,YAAY;IAAEC,eAAeC;EAAU,CAAA;AAC/D,QAAM,EAAEC,YAAYC,KAAI,IAAK,MAAMC,oBAAoB;IAAE,GAAGT;IAAOU,cAAcT;EAAO,CAAA;AACxF,MAAIF,oBAAoB;AACtB,UAAMY,aAAa,IAAIC,gBAAgBL,YAAYC,KAAKG,UAAU;AAClE,UAAME,UAAUF,WAAWG,WAAWf,kBAAAA;AACtC,QAAIc,SAAS;AACXZ,aAAOI,gBAAgBQ;IACzB;EACF;AAEA,SAAO;IAAEN;IAAYC;EAAK;AAC5B;;;ACxBA,SAASO,cAAc;AAEvB,SAASC,mBAAmB;AAC5B,SAASC,UAAUC,aAAaC,4BAA4B;;;ACDrD,IAAMC,gBAAgB;AAEtB,IAAMC,OAAmB;EAC9BC,IAAIF;EACJG,MAAM;EACNC,aACE;EACFC,MAAM;EACNC,QAAQ;EACRC,aAAa;IAAC;;AAChB;;;ADKO,IAAMC,0BAA0BC,OAAOC,IAAI,4CAAA;AAE3C,IAAMC,qBAAqBC,OAAOC,OAAO;EAC9CC,MAAMF,OAAOG,SAASH,OAAOI,MAAM;EACnCC,UAAUL,OAAOG,SACfH,OAAOI,OAAOE,YAAY;IACxB,CAACC,oBAAAA,GAAuB;MAAC;MAAkB;;IAC3CC,OAAO;EACT,CAAA,CAAA;EAEFC,oBAAoBT,OAAOG,SACzBH,OAAOI,OAAOE,YAAY;IACxB,CAACV,uBAAAA,GAA0B;IAC3BY,OAAO;EACT,CAAA,CAAA;AAEJ,CAAA;UAEiBE,eAAAA;AACf,QAAMC,gBAAgB,GAAGC,aAAAA;EAElB,MAAMC,eAAeb,OAAOc,YAAW,EAAW,GAAGH,aAAAA,WAAwB;IAClFI,OAAOf,OAAOgB,OAAOhB,OAAOC,OAAO;MAAEgB,OAAOC;IAAY,CAAA,GAAInB,kBAAAA;IAC5DoB,QAAQnB,OAAOC,OAAO;MACpBmB,QAAQC,SAASC;IACnB,CAAA;EACF,CAAA,EAAA;EAAI;gBALST,SAAAA;EAON,MAAMU,wBAAwBvB,OAAOc,YAAW,EAAoB,GAAGH,aAAAA,sBAAmC;IAC/GI,OAAOf,OAAOC,OAAO;MACnBuB,MAAMH,SAASC;MACfG,SAASzB,OAAOI;;MAEhBsB,cAAc1B,OAAOG,SACnBH,OAAOC,OAAO;QACZ0B,OAAOC;;;QAGPC,OAAO7B,OAAO8B;QACdC,OAAO/B,OAAOgC;MAChB,CAAA,CAAA;IAEJ,CAAA;IACAb,QAAQnB,OAAOiC;EACjB,CAAA,EAAA;EAAI;gBAhBSV,kBAAAA;EAkBN,MAAMW,mBAAmBlC,OAAOc,YAAW,EAAe,GAAGH,aAAAA,gBAA6B;IAC/FI,OAAOf,OAAOC,OAAO;MACnBkC,MAAMnC,OAAO8B;IACf,CAAA;IACAX,QAAQnB,OAAOiC;EACjB,CAAA,EAAA;EAAI;gBALSC,aAAAA;AAMf,GAlCiBxB,iBAAAA,eAAAA,CAAAA,EAAAA;;",
6
- "names": ["Obj", "KanbanView", "createViewFromSpace", "ProjectionModel", "createKanban", "initialPivotColumn", "props", "kanban", "Obj", "make", "KanbanView", "columnFieldId", "undefined", "jsonSchema", "view", "createViewFromSpace", "presentation", "projection", "ProjectionModel", "fieldId", "getFieldId", "Schema", "SpaceSchema", "DataType", "FieldSchema", "TypenameAnnotationId", "KANBAN_PLUGIN", "meta", "id", "name", "description", "icon", "source", "screenshots", "PivotColumnAnnotationId", "Symbol", "for", "CreateKanbanSchema", "Schema", "Struct", "name", "optional", "String", "typename", "annotations", "TypenameAnnotationId", "title", "initialPivotColumn", "KanbanAction", "KANBAN_ACTION", "KANBAN_PLUGIN", "Create", "TaggedClass", "input", "extend", "space", "SpaceSchema", "output", "object", "DataType", "View", "DeleteCardField", "view", "fieldId", "deletionData", "field", "FieldSchema", "props", "Any", "index", "Number", "Void", "DeleteCard", "card"]
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/intent-resolver.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { contributes, Capabilities, createResolver, type PluginContext } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { ClientCapabilities } from '@dxos/plugin-client';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { ProjectionModel } from '@dxos/schema';\n\nimport { KANBAN_PLUGIN } from '../meta';\nimport { createKanban, KanbanAction } from '../types';\n\nexport default (context: PluginContext) =>\n contributes(Capabilities.IntentResolver, [\n createResolver({\n intent: KanbanAction.Create,\n resolve: async ({ space, name, typename, initialPivotColumn }) => {\n const client = context.getCapability(ClientCapabilities.Client);\n const { view } = await createKanban({\n client,\n space,\n name,\n typename,\n initialPivotColumn,\n });\n return { data: { object: view } };\n },\n }),\n createResolver({\n intent: KanbanAction.DeleteCardField,\n resolve: async ({ view, fieldId, deletionData }, undo) => {\n const schema = getSpace(view)?.db.schemaRegistry.getSchema(view.query.typename!);\n invariant(schema);\n const projection = new ProjectionModel(schema.jsonSchema, view.projection);\n\n if (!undo) {\n const { deleted, index } = projection.deleteFieldProjection(fieldId);\n return {\n undoable: {\n message: ['card field deleted label', { ns: KANBAN_PLUGIN }],\n data: { deletionData: { ...deleted, index } },\n },\n };\n } else if (undo && deletionData) {\n const { field, props, index } = deletionData;\n projection.setFieldProjection({ field, props }, index);\n }\n },\n }),\n createResolver({\n intent: KanbanAction.DeleteCard,\n resolve: ({ card }, undo) => {\n const space = getSpace(card);\n invariant(space);\n\n if (!undo) {\n space.db.remove(card);\n return {\n undoable: {\n message: ['card deleted label', { ns: KANBAN_PLUGIN }],\n data: { card },\n },\n };\n } else {\n space.db.add(card);\n }\n },\n }),\n ]);\n"],
5
- "mappings": ";;;;;;;AAIA,SAASA,aAAaC,cAAcC,sBAA0C;AAC9E,SAASC,iBAAiB;AAC1B,SAASC,0BAA0B;AACnC,SAASC,gBAAgB;AACzB,SAASC,uBAAuB;;AAKhC,IAAA,0BAAe,CAACC,YACdC,YAAYC,aAAaC,gBAAgB;EACvCC,eAAe;IACbC,QAAQC,aAAaC;IACrBC,SAAS,OAAO,EAAEC,OAAOC,MAAMC,UAAUC,mBAAkB,MAAE;AAC3D,YAAMC,SAASb,QAAQc,cAAcC,mBAAmBC,MAAM;AAC9D,YAAM,EAAEC,KAAI,IAAK,MAAMC,aAAa;QAClCL;QACAJ;QACAC;QACAC;QACAC;MACF,CAAA;AACA,aAAO;QAAEO,MAAM;UAAEC,QAAQH;QAAK;MAAE;IAClC;EACF,CAAA;EACAb,eAAe;IACbC,QAAQC,aAAae;IACrBb,SAAS,OAAO,EAAES,MAAMK,SAASC,aAAY,GAAIC,SAAAA;AAC/C,YAAMC,SAASC,SAAST,IAAAA,GAAOU,GAAGC,eAAeC,UAAUZ,KAAKa,MAAMnB,QAAQ;AAC9EoB,gBAAUN,QAAAA,QAAAA;;;;;;;;;AACV,YAAMO,aAAa,IAAIC,gBAAgBR,OAAOS,YAAYjB,KAAKe,UAAU;AAEzE,UAAI,CAACR,MAAM;AACT,cAAM,EAAEW,SAASC,MAAK,IAAKJ,WAAWK,sBAAsBf,OAAAA;AAC5D,eAAO;UACLgB,UAAU;YACRC,SAAS;cAAC;cAA4B;gBAAEC,IAAIC;cAAc;;YAC1DtB,MAAM;cAAEI,cAAc;gBAAE,GAAGY;gBAASC;cAAM;YAAE;UAC9C;QACF;MACF,WAAWZ,QAAQD,cAAc;AAC/B,cAAM,EAAEmB,OAAOC,OAAOP,MAAK,IAAKb;AAChCS,mBAAWY,mBAAmB;UAAEF;UAAOC;QAAM,GAAGP,KAAAA;MAClD;IACF;EACF,CAAA;EACAhC,eAAe;IACbC,QAAQC,aAAauC;IACrBrC,SAAS,CAAC,EAAEsC,KAAI,GAAItB,SAAAA;AAClB,YAAMf,QAAQiB,SAASoB,IAAAA;AACvBf,gBAAUtB,OAAAA,QAAAA;;;;;;;;;AAEV,UAAI,CAACe,MAAM;AACTf,cAAMkB,GAAGoB,OAAOD,IAAAA;AAChB,eAAO;UACLR,UAAU;YACRC,SAAS;cAAC;cAAsB;gBAAEC,IAAIC;cAAc;;YACpDtB,MAAM;cAAE2B;YAAK;UACf;QACF;MACF,OAAO;AACLrC,cAAMkB,GAAGqB,IAAIF,IAAAA;MACf;IACF;EACF,CAAA;CACD;",
6
- "names": ["contributes", "Capabilities", "createResolver", "invariant", "ClientCapabilities", "getSpace", "ProjectionModel", "context", "contributes", "Capabilities", "IntentResolver", "createResolver", "intent", "KanbanAction", "Create", "resolve", "space", "name", "typename", "initialPivotColumn", "client", "getCapability", "ClientCapabilities", "Client", "view", "createKanban", "data", "object", "DeleteCardField", "fieldId", "deletionData", "undo", "schema", "getSpace", "db", "schemaRegistry", "getSchema", "query", "invariant", "projection", "ProjectionModel", "jsonSchema", "deleted", "index", "deleteFieldProjection", "undoable", "message", "ns", "KANBAN_PLUGIN", "field", "props", "setFieldProjection", "DeleteCard", "card", "remove", "add"]
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/react-surface.tsx", "../../../src/components/KanbanContainer.tsx", "../../../src/components/KanbanViewEditor.tsx"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Schema } from 'effect';\nimport React, { useMemo } from 'react';\n\nimport { Capabilities, contributes, createSurface, useCapabilities } from '@dxos/app-framework';\nimport { Obj, Type } from '@dxos/echo';\nimport { findAnnotation } from '@dxos/effect';\nimport { ClientCapabilities } from '@dxos/plugin-client';\nimport { getSpace, isSpace, type Space } from '@dxos/react-client/echo';\nimport { type InputProps, SelectInput, useFormValues } from '@dxos/react-ui-form';\nimport { KanbanView } from '@dxos/react-ui-kanban';\nimport { DataType } from '@dxos/schema';\n\nimport { KanbanContainer, KanbanViewEditor } from '../components';\nimport { meta } from '../meta';\nimport { PivotColumnAnnotationId } from '../types';\n\nexport default () =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: meta.id,\n role: ['article', 'section'],\n filter: (data): data is { subject: DataType.View } =>\n Obj.instanceOf(DataType.View, data.subject) && Obj.instanceOf(KanbanView, data.subject.presentation.target),\n component: ({ data, role }) => <KanbanContainer view={data.subject} role={role} />,\n }),\n createSurface({\n id: `${meta.id}/object-settings`,\n role: 'object-settings',\n position: 'hoist',\n filter: (data): data is { subject: DataType.View } =>\n Obj.instanceOf(DataType.View, data.subject) && Obj.instanceOf(KanbanView, data.subject.presentation.target),\n component: ({ data }) => <KanbanViewEditor view={data.subject} />,\n }),\n createSurface({\n id: `${meta.id}/create-initial-schema-form-[pivot-column]`,\n role: 'form-input',\n filter: (\n data,\n ): data is { prop: string; schema: Schema.Schema<any>; target: Space | DataType.Collection | undefined } => {\n const annotation = findAnnotation<boolean>((data.schema as Schema.Schema.All).ast, PivotColumnAnnotationId);\n return !!annotation;\n },\n component: ({ data: { target }, ...inputProps }) => {\n const props = inputProps as any as InputProps;\n const space = isSpace(target) ? target : getSpace(target);\n if (!space) {\n return null;\n }\n const { typename } = useFormValues();\n // TODO(wittjosiah): Unify this schema lookup.\n const schemaWhitelists = useCapabilities(ClientCapabilities.SchemaWhiteList);\n const staticSchema = schemaWhitelists.flat().find((schema) => Type.getTypename(schema) === typename);\n const [selectedSchema] = space?.db.schemaRegistry.query({ typename }).runSync();\n\n const singleSelectColumns = useMemo(() => {\n const properties = staticSchema\n ? Type.toJsonSchema(staticSchema).properties\n : selectedSchema?.jsonSchema?.properties;\n if (!properties) {\n return [];\n }\n\n const columns = Object.entries(properties).reduce<string[]>((acc, [key, value]) => {\n if (typeof value === 'object' && value?.format === 'single-select') {\n acc.push(key);\n }\n return acc;\n }, []);\n\n return columns;\n }, [selectedSchema?.jsonSchema, staticSchema]);\n\n if (!typename) {\n return null;\n }\n\n return <SelectInput {...props} options={singleSelectColumns.map((column) => ({ value: column }))} />;\n },\n }),\n ]);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { createIntent, useIntentDispatcher } from '@dxos/app-framework';\nimport { Filter, Obj, Type } from '@dxos/echo';\nimport { EchoSchema, type TypedObject } from '@dxos/echo-schema';\nimport { useGlobalFilteredObjects } from '@dxos/plugin-search';\nimport { useClient } from '@dxos/react-client';\nimport { useQuery, getSpace } from '@dxos/react-client/echo';\nimport { useKanbanModel, Kanban } from '@dxos/react-ui-kanban';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { ProjectionModel, type DataType } from '@dxos/schema';\n\nimport { KanbanAction } from '../types';\n\nexport const KanbanContainer = ({ view }: { view: DataType.View; role: string }) => {\n const client = useClient();\n const [cardSchema, setCardSchema] = useState<TypedObject<any, any>>();\n const [projection, setProjection] = useState<ProjectionModel>();\n const space = getSpace(view);\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n\n const jsonSchema = useMemo(() => {\n if (!cardSchema) {\n return undefined;\n }\n return cardSchema instanceof EchoSchema ? cardSchema.jsonSchema : Type.toJsonSchema(cardSchema);\n }, [cardSchema]);\n\n useEffect(() => {\n const typename = view.query.typename;\n const staticSchema = client.graph.schemaRegistry.schemas.find((schema) => Type.getTypename(schema) === typename);\n if (staticSchema) {\n setCardSchema(() => staticSchema as TypedObject<any, any>);\n }\n if (!staticSchema && typename && space) {\n const query = space.db.schemaRegistry.query({ typename });\n const unsubscribe = query.subscribe(\n () => {\n const [schema] = query.results;\n if (schema) {\n setCardSchema(schema);\n }\n },\n { fire: true },\n );\n return unsubscribe;\n }\n }, [view.query.typename, space]);\n\n useEffect(() => {\n if (jsonSchema) {\n setProjection(new ProjectionModel(jsonSchema, view.projection));\n }\n // TODO(ZaymonFC): Is there a better way to get notified about deep changes in the json schema?\n }, [view.projection, JSON.stringify(jsonSchema)]);\n\n const objects = useQuery(space, cardSchema ? Filter.type(cardSchema) : Filter.nothing());\n const filteredObjects = useGlobalFilteredObjects(objects);\n\n const model = useKanbanModel({\n view,\n schema: cardSchema,\n projection,\n items: filteredObjects,\n });\n\n const handleAddCard = useCallback(\n (columnValue: string | undefined) => {\n const path = model?.columnFieldPath;\n if (space && cardSchema && path) {\n const card = Obj.make(cardSchema, { [path]: columnValue });\n space.db.add(card);\n return card.id;\n }\n },\n [space, cardSchema, model],\n );\n\n const handleRemoveCard = useCallback(\n (card: { id: string }) => {\n void dispatch(createIntent(KanbanAction.DeleteCard, { card }));\n },\n [dispatch],\n );\n\n return (\n <StackItem.Content>\n {model && <Kanban model={model} onAddCard={handleAddCard} onRemoveCard={handleRemoveCard} />}\n </StackItem.Content>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Type } from '@dxos/echo';\nimport { EchoSchema, FormatEnum } from '@dxos/echo-schema';\nimport { useClient } from '@dxos/react-client';\nimport { getSpace, useSchema } from '@dxos/react-client/echo';\nimport { Form, SelectInput, type CustomInputMap } from '@dxos/react-ui-form';\nimport { KanbanSettingsSchema, type KanbanView } from '@dxos/react-ui-kanban';\nimport { type DataType, ProjectionModel } from '@dxos/schema';\n\ntype KanbanViewEditorProps = { view: DataType.View };\n\nexport const KanbanViewEditor = ({ view }: KanbanViewEditorProps) => {\n const client = useClient();\n const space = getSpace(view);\n const kanban = view.presentation.target as KanbanView;\n const currentTypename = useMemo(() => view.query.typename, [view.query.typename]);\n const schema = useSchema(client, space, currentTypename);\n\n const projection = useMemo(() => {\n if (schema) {\n const jsonSchema = schema instanceof EchoSchema ? schema.jsonSchema : Type.toJsonSchema(schema);\n return new ProjectionModel(jsonSchema, view.projection);\n }\n }, [view.projection, JSON.stringify(schema)]);\n\n const fieldProjections = projection?.getFieldProjections() || [];\n const selectFields = fieldProjections\n .filter((field) => field.props.format === FormatEnum.SingleSelect)\n .map(({ field }) => ({ value: field.id, label: field.path }));\n\n const handleSave = useCallback(\n (values: Partial<{ columnFieldId: string }>) => {\n kanban.columnFieldId = values.columnFieldId;\n },\n [kanban],\n );\n\n const initialValues = useMemo(() => ({ columnFieldId: kanban.columnFieldId }), [kanban.columnFieldId]);\n const custom: CustomInputMap = useMemo(\n () => ({ columnFieldId: (props) => <SelectInput {...props} options={selectFields} /> }),\n [selectFields],\n );\n\n return (\n <Form\n Custom={custom}\n schema={KanbanSettingsSchema}\n values={initialValues}\n onSave={handleSave}\n autoSave\n outerSpacing={false}\n classNames='pbs-inputSpacingBlock'\n />\n );\n};\n"],
5
- "mappings": "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",
6
- "names": ["React", "useMemo", "Capabilities", "contributes", "createSurface", "useCapabilities", "Obj", "Type", "findAnnotation", "ClientCapabilities", "getSpace", "isSpace", "SelectInput", "useFormValues", "KanbanView", "DataType", "React", "useCallback", "useEffect", "useMemo", "useState", "createIntent", "useIntentDispatcher", "Filter", "Obj", "Type", "EchoSchema", "useGlobalFilteredObjects", "useClient", "useQuery", "getSpace", "useKanbanModel", "Kanban", "StackItem", "ProjectionModel", "KanbanContainer", "view", "client", "useClient", "cardSchema", "setCardSchema", "useState", "projection", "setProjection", "space", "getSpace", "dispatchPromise", "dispatch", "useIntentDispatcher", "jsonSchema", "useMemo", "undefined", "EchoSchema", "Type", "toJsonSchema", "useEffect", "typename", "query", "staticSchema", "graph", "schemaRegistry", "schemas", "find", "schema", "getTypename", "db", "unsubscribe", "subscribe", "results", "fire", "ProjectionModel", "JSON", "stringify", "objects", "useQuery", "Filter", "type", "nothing", "filteredObjects", "useGlobalFilteredObjects", "model", "useKanbanModel", "items", "handleAddCard", "useCallback", "columnValue", "path", "columnFieldPath", "card", "Obj", "make", "add", "id", "handleRemoveCard", "createIntent", "KanbanAction", "DeleteCard", "StackItem", "Content", "Kanban", "onAddCard", "onRemoveCard", "React", "useCallback", "useMemo", "Type", "EchoSchema", "FormatEnum", "useClient", "getSpace", "useSchema", "Form", "SelectInput", "KanbanSettingsSchema", "ProjectionModel", "KanbanViewEditor", "view", "client", "useClient", "space", "getSpace", "kanban", "presentation", "target", "currentTypename", "useMemo", "query", "typename", "schema", "useSchema", "projection", "jsonSchema", "EchoSchema", "Type", "toJsonSchema", "ProjectionModel", "JSON", "stringify", "fieldProjections", "getFieldProjections", "selectFields", "filter", "field", "props", "format", "FormatEnum", "SingleSelect", "map", "value", "id", "label", "path", "handleSave", "useCallback", "values", "columnFieldId", "initialValues", "custom", "React", "SelectInput", "options", "Form", "Custom", "KanbanSettingsSchema", "onSave", "autoSave", "outerSpacing", "classNames", "contributes", "Capabilities", "ReactSurface", "createSurface", "id", "meta", "role", "filter", "data", "Obj", "instanceOf", "DataType", "View", "subject", "KanbanView", "presentation", "target", "component", "React", "KanbanContainer", "view", "position", "KanbanViewEditor", "annotation", "findAnnotation", "schema", "ast", "PivotColumnAnnotationId", "inputProps", "props", "space", "isSpace", "getSpace", "typename", "useFormValues", "schemaWhitelists", "useCapabilities", "ClientCapabilities", "SchemaWhiteList", "staticSchema", "flat", "find", "Type", "getTypename", "selectedSchema", "db", "schemaRegistry", "query", "runSync", "singleSelectColumns", "useMemo", "properties", "toJsonSchema", "jsonSchema", "columns", "Object", "entries", "reduce", "acc", "key", "value", "format", "push", "SelectInput", "options", "map", "column"]
7
- }
@@ -1,175 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- KanbanAction,
4
- meta
5
- } from "./chunk-6WK5CGYY.mjs";
6
-
7
- // src/capabilities/artifact-definition.ts
8
- import { Schema, pipe } from "effect";
9
- import { createTool, ToolResult } from "@dxos/ai";
10
- import { Capabilities, chain, contributes, createIntent } from "@dxos/app-framework";
11
- import { createArtifactElement } from "@dxos/assistant";
12
- import { defineArtifact } from "@dxos/blueprints";
13
- import { Obj, Query } from "@dxos/echo";
14
- import { invariant } from "@dxos/invariant";
15
- import { SpaceAction } from "@dxos/plugin-space/types";
16
- import { Filter, fullyQualifiedId } from "@dxos/react-client/echo";
17
- import { KanbanView } from "@dxos/react-ui-kanban";
18
- import { DataType } from "@dxos/schema";
19
- import { isNonNullable } from "@dxos/util";
20
- var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-kanban/src/capabilities/artifact-definition.ts";
21
- var QualifiedId = Schema.String.annotations({
22
- description: "The fully qualified ID of the kanban `spaceID:objectID`"
23
- });
24
- var artifact_definition_default = () => {
25
- const definition = defineArtifact({
26
- id: `artifact:${meta.id}`,
27
- name: meta.name,
28
- instructions: `
29
- - Before adding items to a kanban board, inspect the board to see its schema
30
- - When adding items, you must not include the 'id' field -- it is automatically generated
31
- - BEFORE adding items, always make sure the board has been shown to the user!
32
- `,
33
- schema: KanbanView,
34
- tools: [
35
- createTool(meta.id, {
36
- name: "create",
37
- description: `
38
- Create a new kanban board using an existing schema.
39
- Use schema_create first to create a schema, or schema_list to choose an existing one.`,
40
- caption: "Creating kanban board...",
41
- schema: Schema.Struct({
42
- typename: Schema.String.annotations({
43
- description: "The fully qualified typename of the schema to use for the kanban cards."
44
- }),
45
- pivotColumn: Schema.optional(Schema.String).annotations({
46
- description: "Optional field name to use as the column pivot."
47
- })
48
- }),
49
- execute: async ({ typename, pivotColumn }, { extensions }) => {
50
- invariant(extensions?.space, "No space", {
51
- F: __dxlog_file,
52
- L: 59,
53
- S: void 0,
54
- A: [
55
- "extensions?.space",
56
- "'No space'"
57
- ]
58
- });
59
- invariant(extensions?.dispatch, "No intent dispatcher", {
60
- F: __dxlog_file,
61
- L: 60,
62
- S: void 0,
63
- A: [
64
- "extensions?.dispatch",
65
- "'No intent dispatcher'"
66
- ]
67
- });
68
- const schema = await extensions.space.db.schemaRegistry.query({
69
- typename
70
- }).firstOrUndefined();
71
- if (!schema) {
72
- return ToolResult.Error(`Schema not found: ${typename}`);
73
- }
74
- const intent = pipe(createIntent(KanbanAction.Create, {
75
- space: extensions.space,
76
- typename,
77
- initialPivotColumn: pivotColumn
78
- }), chain(SpaceAction.AddObject, {
79
- target: extensions.space
80
- }));
81
- const { data, error } = await extensions.dispatch(intent);
82
- if (!data || error) {
83
- return ToolResult.Error(error?.message ?? "Failed to create kanban board");
84
- }
85
- return ToolResult.Success(createArtifactElement(data.id));
86
- }
87
- }),
88
- createTool(meta.id, {
89
- name: "list",
90
- description: "List all kanban boards in the current space.",
91
- caption: "Listing kanban boards...",
92
- schema: Schema.Struct({}),
93
- execute: async (_input, { extensions }) => {
94
- invariant(extensions?.space, "No space", {
95
- F: __dxlog_file,
96
- L: 91,
97
- S: void 0,
98
- A: [
99
- "extensions?.space",
100
- "'No space'"
101
- ]
102
- });
103
- const space = extensions.space;
104
- const { objects } = await space.db.query(Filter.type(DataType.View)).run();
105
- const boardInfo = await Promise.all(objects.map(async (view) => {
106
- const kanban = await view.presentation.load();
107
- if (!Obj.instanceOf(KanbanView, kanban)) {
108
- return null;
109
- }
110
- return {
111
- id: fullyQualifiedId(view),
112
- name: view.name ?? "Unnamed Kanban",
113
- typename: view.query.typename
114
- };
115
- }));
116
- return ToolResult.Success(boardInfo.filter(isNonNullable));
117
- }
118
- }),
119
- createTool(meta.id, {
120
- name: "inspect",
121
- description: "Get details about a specific kanban board.",
122
- caption: "Inspecting kanban board...",
123
- schema: Schema.Struct({
124
- id: QualifiedId
125
- }),
126
- execute: async ({ id }, { extensions }) => {
127
- invariant(extensions?.space, "No space", {
128
- F: __dxlog_file,
129
- L: 119,
130
- S: void 0,
131
- A: [
132
- "extensions?.space",
133
- "'No space'"
134
- ]
135
- });
136
- const space = extensions.space;
137
- const view = await space.db.query(Query.select(Filter.and(Filter.type(DataType.View), Filter.ids(id)))).first();
138
- const kanban = await view.presentation.load();
139
- invariant(Obj.instanceOf(KanbanView, kanban), void 0, {
140
- F: __dxlog_file,
141
- L: 127,
142
- S: void 0,
143
- A: [
144
- "Obj.instanceOf(KanbanView, kanban)",
145
- ""
146
- ]
147
- });
148
- const typename = view.query.typename;
149
- const schema = await space.db.schemaRegistry.query({
150
- typename
151
- }).firstOrUndefined();
152
- invariant(schema, void 0, {
153
- F: __dxlog_file,
154
- L: 131,
155
- S: void 0,
156
- A: [
157
- "schema",
158
- ""
159
- ]
160
- });
161
- return ToolResult.Success({
162
- schema,
163
- columnField: kanban.columnFieldId,
164
- viewFields: view.projection.fields
165
- });
166
- }
167
- })
168
- ]
169
- });
170
- return contributes(Capabilities.ArtifactDefinition, definition);
171
- };
172
- export {
173
- artifact_definition_default as default
174
- };
175
- //# sourceMappingURL=artifact-definition-QVZXPDXK.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/artifact-definition.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema, pipe } from 'effect';\n\nimport { createTool, ToolResult } from '@dxos/ai';\nimport { Capabilities, chain, contributes, createIntent, type PromiseIntentDispatcher } from '@dxos/app-framework';\nimport { createArtifactElement } from '@dxos/assistant';\nimport { defineArtifact } from '@dxos/blueprints';\nimport { Obj, Query } from '@dxos/echo';\nimport { invariant } from '@dxos/invariant';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { Filter, fullyQualifiedId, type Space } from '@dxos/react-client/echo';\nimport { KanbanView } from '@dxos/react-ui-kanban';\nimport { DataType } from '@dxos/schema';\nimport { isNonNullable } from '@dxos/util';\n\nimport { meta } from '../meta';\nimport { KanbanAction } from '../types';\n\nconst QualifiedId = Schema.String.annotations({\n description: 'The fully qualified ID of the kanban `spaceID:objectID`',\n});\n\ndeclare global {\n interface ToolContextExtensions {\n space?: Space;\n dispatch?: PromiseIntentDispatcher;\n }\n}\n\nexport default () => {\n const definition = defineArtifact({\n id: `artifact:${meta.id}`,\n name: meta.name,\n instructions: `\n - Before adding items to a kanban board, inspect the board to see its schema\n - When adding items, you must not include the 'id' field -- it is automatically generated\n - BEFORE adding items, always make sure the board has been shown to the user!\n `,\n schema: KanbanView,\n tools: [\n createTool(meta.id, {\n name: 'create',\n description: `\n Create a new kanban board using an existing schema.\n Use schema_create first to create a schema, or schema_list to choose an existing one.`,\n caption: 'Creating kanban board...',\n schema: Schema.Struct({\n typename: Schema.String.annotations({\n description: 'The fully qualified typename of the schema to use for the kanban cards.',\n }),\n pivotColumn: Schema.optional(Schema.String).annotations({\n description: 'Optional field name to use as the column pivot.',\n }),\n }),\n execute: async ({ typename, pivotColumn }, { extensions }) => {\n invariant(extensions?.space, 'No space');\n invariant(extensions?.dispatch, 'No intent dispatcher');\n\n // Validate schema exists first\n const schema = await extensions.space.db.schemaRegistry.query({ typename }).firstOrUndefined();\n if (!schema) {\n return ToolResult.Error(`Schema not found: ${typename}`);\n }\n\n const intent = pipe(\n createIntent(KanbanAction.Create, {\n space: extensions.space,\n typename,\n initialPivotColumn: pivotColumn,\n }),\n chain(SpaceAction.AddObject, { target: extensions.space }),\n );\n\n const { data, error } = await extensions.dispatch(intent);\n if (!data || error) {\n return ToolResult.Error(error?.message ?? 'Failed to create kanban board');\n }\n\n return ToolResult.Success(createArtifactElement(data.id));\n },\n }),\n createTool(meta.id, {\n name: 'list',\n description: 'List all kanban boards in the current space.',\n caption: 'Listing kanban boards...',\n schema: Schema.Struct({}),\n execute: async (_input, { extensions }) => {\n invariant(extensions?.space, 'No space');\n const space = extensions.space;\n const { objects } = await space.db.query(Filter.type(DataType.View)).run();\n\n const boardInfo = await Promise.all(\n objects.map(async (view) => {\n const kanban = await view.presentation.load();\n if (!Obj.instanceOf(KanbanView, kanban)) {\n return null;\n }\n\n return {\n id: fullyQualifiedId(view),\n name: view.name ?? 'Unnamed Kanban',\n typename: view.query.typename,\n };\n }),\n );\n\n return ToolResult.Success(boardInfo.filter(isNonNullable));\n },\n }),\n createTool(meta.id, {\n name: 'inspect',\n description: 'Get details about a specific kanban board.',\n caption: 'Inspecting kanban board...',\n schema: Schema.Struct({ id: QualifiedId }),\n execute: async ({ id }, { extensions }) => {\n invariant(extensions?.space, 'No space');\n const space = extensions.space;\n const view = (await space.db\n // TODO(wittjosiah): Filter.and should aggregate type\n .query(Query.select(Filter.and(Filter.type(DataType.View), Filter.ids(id))))\n .first()) as DataType.View;\n\n const kanban = await view.presentation.load();\n invariant(Obj.instanceOf(KanbanView, kanban));\n\n const typename = view.query.typename;\n const schema = await space.db.schemaRegistry.query({ typename }).firstOrUndefined();\n invariant(schema);\n\n return ToolResult.Success({\n schema,\n columnField: kanban.columnFieldId,\n viewFields: view.projection.fields,\n });\n },\n }),\n ],\n });\n\n return contributes(Capabilities.ArtifactDefinition, definition);\n};\n"],
5
- "mappings": "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",
6
- "names": ["Schema", "pipe", "createTool", "ToolResult", "Capabilities", "chain", "contributes", "createIntent", "createArtifactElement", "defineArtifact", "Obj", "Query", "invariant", "SpaceAction", "Filter", "fullyQualifiedId", "KanbanView", "DataType", "isNonNullable", "QualifiedId", "Schema", "String", "annotations", "description", "definition", "defineArtifact", "id", "meta", "name", "instructions", "schema", "KanbanView", "tools", "createTool", "caption", "Struct", "typename", "pivotColumn", "optional", "execute", "extensions", "invariant", "space", "dispatch", "db", "schemaRegistry", "query", "firstOrUndefined", "ToolResult", "Error", "intent", "pipe", "createIntent", "KanbanAction", "Create", "initialPivotColumn", "chain", "SpaceAction", "AddObject", "target", "data", "error", "message", "Success", "createArtifactElement", "_input", "objects", "Filter", "type", "DataType", "View", "run", "boardInfo", "Promise", "all", "map", "view", "kanban", "presentation", "load", "Obj", "instanceOf", "fullyQualifiedId", "filter", "isNonNullable", "Query", "select", "and", "ids", "first", "columnField", "columnFieldId", "viewFields", "projection", "fields", "contributes", "Capabilities", "ArtifactDefinition"]
7
- }