@dxos/plugin-kanban 0.8.2-main.2f9c567 → 0.8.2-main.36232bc

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 (79) hide show
  1. package/dist/lib/browser/{artifact-definition-VGRBHXJ6.mjs → artifact-definition-SVNHDJQT.mjs} +10 -10
  2. package/dist/lib/browser/artifact-definition-SVNHDJQT.mjs.map +7 -0
  3. package/dist/lib/browser/{chunk-6JAA7YSW.mjs → chunk-K5BYEZ4Z.mjs} +35 -23
  4. package/dist/lib/browser/chunk-K5BYEZ4Z.mjs.map +7 -0
  5. package/dist/lib/browser/index.mjs +4 -4
  6. package/dist/lib/browser/intent-resolver-XCDQ5N3Q.mjs +132 -0
  7. package/dist/lib/browser/intent-resolver-XCDQ5N3Q.mjs.map +7 -0
  8. package/dist/lib/browser/meta.json +1 -1
  9. package/dist/lib/browser/{react-surface-H5UD7LKX.mjs → react-surface-R25PYWQV.mjs} +26 -56
  10. package/dist/lib/browser/react-surface-R25PYWQV.mjs.map +7 -0
  11. package/dist/lib/browser/types.mjs +3 -1
  12. package/dist/lib/node/{artifact-definition-KDTULJLX.cjs → artifact-definition-M2XAYUI2.cjs} +17 -17
  13. package/dist/lib/node/artifact-definition-M2XAYUI2.cjs.map +7 -0
  14. package/dist/lib/node/{chunk-O4U7ZQ2I.cjs → chunk-3EUR6ZR2.cjs} +38 -25
  15. package/dist/lib/node/chunk-3EUR6ZR2.cjs.map +7 -0
  16. package/dist/lib/node/index.cjs +16 -16
  17. package/dist/lib/node/intent-resolver-P3PSZO7H.cjs +146 -0
  18. package/dist/lib/node/intent-resolver-P3PSZO7H.cjs.map +7 -0
  19. package/dist/lib/node/meta.json +1 -1
  20. package/dist/lib/node/{react-surface-LKFQ3TZH.cjs → react-surface-FVM64YAQ.cjs} +31 -61
  21. package/dist/lib/node/react-surface-FVM64YAQ.cjs.map +7 -0
  22. package/dist/lib/node/types.cjs +8 -6
  23. package/dist/lib/node/types.cjs.map +2 -2
  24. package/dist/lib/node-esm/{artifact-definition-G2R5LF26.mjs → artifact-definition-HQ5I2OO5.mjs} +10 -10
  25. package/dist/lib/node-esm/artifact-definition-HQ5I2OO5.mjs.map +7 -0
  26. package/dist/lib/node-esm/{chunk-NOC32MF5.mjs → chunk-2N7CO3DI.mjs} +35 -23
  27. package/dist/lib/node-esm/chunk-2N7CO3DI.mjs.map +7 -0
  28. package/dist/lib/node-esm/index.mjs +4 -4
  29. package/dist/lib/node-esm/intent-resolver-4G47V67J.mjs +133 -0
  30. package/dist/lib/node-esm/intent-resolver-4G47V67J.mjs.map +7 -0
  31. package/dist/lib/node-esm/meta.json +1 -1
  32. package/dist/lib/node-esm/{react-surface-TUKDSY4T.mjs → react-surface-LZ7MP3CQ.mjs} +26 -56
  33. package/dist/lib/node-esm/react-surface-LZ7MP3CQ.mjs.map +7 -0
  34. package/dist/lib/node-esm/types.mjs +3 -1
  35. package/dist/types/src/capabilities/index.d.ts +1 -1
  36. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  37. package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
  38. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  39. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  40. package/dist/types/src/components/KanbanContainer.d.ts.map +1 -1
  41. package/dist/types/src/types.d.ts +41 -34
  42. package/dist/types/src/types.d.ts.map +1 -1
  43. package/package.json +25 -29
  44. package/src/capabilities/artifact-definition.ts +8 -8
  45. package/src/capabilities/intent-resolver.ts +6 -10
  46. package/src/capabilities/react-surface.tsx +12 -46
  47. package/src/components/KanbanContainer.tsx +8 -21
  48. package/src/types.ts +43 -26
  49. package/dist/lib/browser/artifact-definition-VGRBHXJ6.mjs.map +0 -7
  50. package/dist/lib/browser/chunk-6JAA7YSW.mjs.map +0 -7
  51. package/dist/lib/browser/intent-resolver-44SXCRIH.mjs +0 -297
  52. package/dist/lib/browser/intent-resolver-44SXCRIH.mjs.map +0 -7
  53. package/dist/lib/browser/react-surface-H5UD7LKX.mjs.map +0 -7
  54. package/dist/lib/node/artifact-definition-KDTULJLX.cjs.map +0 -7
  55. package/dist/lib/node/chunk-O4U7ZQ2I.cjs.map +0 -7
  56. package/dist/lib/node/intent-resolver-23TVN46D.cjs +0 -308
  57. package/dist/lib/node/intent-resolver-23TVN46D.cjs.map +0 -7
  58. package/dist/lib/node/react-surface-LKFQ3TZH.cjs.map +0 -7
  59. package/dist/lib/node-esm/artifact-definition-G2R5LF26.mjs.map +0 -7
  60. package/dist/lib/node-esm/chunk-NOC32MF5.mjs.map +0 -7
  61. package/dist/lib/node-esm/intent-resolver-SUADAOIJ.mjs +0 -298
  62. package/dist/lib/node-esm/intent-resolver-SUADAOIJ.mjs.map +0 -7
  63. package/dist/lib/node-esm/react-surface-TUKDSY4T.mjs.map +0 -7
  64. package/dist/types/src/components/KanbanContainer.stories.d.ts +0 -10
  65. package/dist/types/src/components/KanbanContainer.stories.d.ts.map +0 -1
  66. package/dist/types/src/testing/index.d.ts +0 -3
  67. package/dist/types/src/testing/index.d.ts.map +0 -1
  68. package/dist/types/src/testing/initialize-kanban.d.ts +0 -17
  69. package/dist/types/src/testing/initialize-kanban.d.ts.map +0 -1
  70. package/dist/types/src/testing/kanban-manager.d.ts +0 -7
  71. package/dist/types/src/testing/kanban-manager.d.ts.map +0 -1
  72. package/dist/types/src/testing/playwright/smoke.spec.d.ts +0 -2
  73. package/dist/types/src/testing/playwright/smoke.spec.d.ts.map +0 -1
  74. package/src/components/KanbanContainer.stories.tsx +0 -186
  75. package/src/testing/index.ts +0 -6
  76. package/src/testing/initialize-kanban.ts +0 -139
  77. package/src/testing/kanban-manager.ts +0 -13
  78. package/src/testing/playwright/playwright.config.cts +0 -18
  79. package/src/testing/playwright/smoke.spec.ts +0 -7
@@ -2,15 +2,12 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { type Schema } from 'effect';
6
5
  import React, { useMemo } from 'react';
7
6
 
8
- import { Capabilities, contributes, createSurface, useCapabilities } from '@dxos/app-framework';
9
- import { getTypenameOrThrow, toJsonSchema } from '@dxos/echo-schema';
7
+ import { Capabilities, contributes, createSurface } from '@dxos/app-framework';
8
+ import { type S } from '@dxos/echo-schema';
10
9
  import { findAnnotation } from '@dxos/effect';
11
- import { ClientCapabilities } from '@dxos/plugin-client';
12
10
  import { type CollectionType } from '@dxos/plugin-space/types';
13
- import { useClient } from '@dxos/react-client';
14
11
  import { getSpace, isSpace, type Space } from '@dxos/react-client/echo';
15
12
  import { type InputProps, SelectInput, useFormValues } from '@dxos/react-ui-form';
16
13
  import { type KanbanType } from '@dxos/react-ui-kanban';
@@ -34,53 +31,28 @@ export default () =>
34
31
  component: ({ data }) => <KanbanViewEditor kanban={data.subject} />,
35
32
  }),
36
33
  createSurface({
37
- id: `${KANBAN_PLUGIN}/create-initial-schema-form`,
34
+ id: `${KANBAN_PLUGIN}/create-initial-schema-form-[schema]`,
38
35
  role: 'form-input',
39
- filter: (
40
- data,
41
- ): data is { prop: string; schema: Schema.Schema<any>; target: Space | CollectionType | undefined } => {
42
- if (data.prop !== 'typename') {
43
- return false;
44
- }
45
-
46
- const annotation = findAnnotation<boolean>((data.schema as Schema.Schema.All).ast, TypenameAnnotationId);
36
+ filter: (data): data is { prop: string; schema: S.Schema<any>; target: Space | CollectionType | undefined } => {
37
+ const annotation = findAnnotation<boolean>((data.schema as S.Schema.All).ast, TypenameAnnotationId);
47
38
  return !!annotation;
48
39
  },
49
40
  component: ({ data: { target }, ...inputProps }) => {
50
- const client = useClient();
51
41
  const props = inputProps as any as InputProps;
52
42
  const space = isSpace(target) ? target : getSpace(target);
53
43
  if (!space) {
54
44
  return null;
55
45
  }
56
46
 
57
- const schemaWhitelists = useCapabilities(ClientCapabilities.SchemaWhiteList);
58
- const whitelistedTypenames = useMemo(
59
- () => new Set(schemaWhitelists.flatMap((typeArray) => typeArray.map((type) => type.typename))),
60
- [schemaWhitelists],
61
- );
62
-
63
- const fixed = client.graph.schemaRegistry.schemas.filter((schema) =>
64
- whitelistedTypenames.has(getTypenameOrThrow(schema)),
65
- );
66
- const dynamic = space?.db.schemaRegistry.query().runSync();
67
- const typenames = Array.from(
68
- new Set<string>([
69
- ...fixed.map((schema) => getTypenameOrThrow(schema)),
70
- ...dynamic.map((schema) => schema.typename),
71
- ]),
72
- ).sort();
73
-
74
- return <SelectInput {...props} options={typenames.map((typename) => ({ value: typename }))} />;
47
+ const schemata = space?.db.schemaRegistry.query().runSync();
48
+ return <SelectInput {...props} options={schemata.map((schema) => ({ value: schema.typename }))} />;
75
49
  },
76
50
  }),
77
51
  createSurface({
78
52
  id: `${KANBAN_PLUGIN}/create-initial-schema-form-[pivot-column]`,
79
53
  role: 'form-input',
80
- filter: (
81
- data,
82
- ): data is { prop: string; schema: Schema.Schema<any>; target: Space | CollectionType | undefined } => {
83
- const annotation = findAnnotation<boolean>((data.schema as Schema.Schema.All).ast, PivotColumnAnnotationId);
54
+ filter: (data): data is { prop: string; schema: S.Schema<any>; target: Space | CollectionType | undefined } => {
55
+ const annotation = findAnnotation<boolean>((data.schema as S.Schema.All).ast, PivotColumnAnnotationId);
84
56
  return !!annotation;
85
57
  },
86
58
  component: ({ data: { target }, ...inputProps }) => {
@@ -90,20 +62,14 @@ export default () =>
90
62
  return null;
91
63
  }
92
64
  const { typename } = useFormValues();
93
- // TODO(wittjosiah): Unify this schema lookup.
94
- const schemaWhitelists = useCapabilities(ClientCapabilities.SchemaWhiteList);
95
- const staticSchema = schemaWhitelists.flat().find((schema) => getTypenameOrThrow(schema) === typename);
96
65
  const [selectedSchema] = space?.db.schemaRegistry.query({ typename }).runSync();
97
66
 
98
67
  const singleSelectColumns = useMemo(() => {
99
- const properties = staticSchema
100
- ? toJsonSchema(staticSchema).properties
101
- : selectedSchema?.jsonSchema?.properties;
102
- if (!properties) {
68
+ if (!selectedSchema?.jsonSchema?.properties) {
103
69
  return [];
104
70
  }
105
71
 
106
- const columns = Object.entries(properties).reduce<string[]>((acc, [key, value]) => {
72
+ const columns = Object.entries(selectedSchema.jsonSchema.properties).reduce<string[]>((acc, [key, value]) => {
107
73
  if (typeof value === 'object' && value?.format === 'single-select') {
108
74
  acc.push(key);
109
75
  }
@@ -111,7 +77,7 @@ export default () =>
111
77
  }, []);
112
78
 
113
79
  return columns;
114
- }, [selectedSchema?.jsonSchema, staticSchema]);
80
+ }, [selectedSchema?.jsonSchema]);
115
81
 
116
82
  if (!typename) {
117
83
  return null;
@@ -2,12 +2,11 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
- import React, { useCallback, useEffect, useMemo, useState } from 'react';
5
+ import React, { useCallback, useEffect, useState } from 'react';
6
6
 
7
7
  import { createIntent, useIntentDispatcher } from '@dxos/app-framework';
8
- import { EchoSchema, getTypenameOrThrow, toJsonSchema, type TypedObject } from '@dxos/echo-schema';
8
+ import { type EchoSchema } from '@dxos/echo-schema';
9
9
  import { useGlobalFilteredObjects } from '@dxos/plugin-search';
10
- import { useClient } from '@dxos/react-client';
11
10
  import { Filter, useQuery, getSpace, live } from '@dxos/react-client/echo';
12
11
  import { type KanbanType, useKanbanModel, Kanban } from '@dxos/react-ui-kanban';
13
12
  import { StackItem } from '@dxos/react-ui-stack';
@@ -16,26 +15,14 @@ import { ViewProjection } from '@dxos/schema';
16
15
  import { KanbanAction } from '../types';
17
16
 
18
17
  export const KanbanContainer = ({ kanban }: { kanban: KanbanType; role: string }) => {
19
- const client = useClient();
20
- const [cardSchema, setCardSchema] = useState<TypedObject<any, any>>();
18
+ const [cardSchema, setCardSchema] = useState<EchoSchema>();
21
19
  const [projection, setProjection] = useState<ViewProjection>();
22
20
  const space = getSpace(kanban);
23
21
  const { dispatchPromise: dispatch } = useIntentDispatcher();
24
22
 
25
- const jsonSchema = useMemo(
26
- () =>
27
- cardSchema instanceof EchoSchema ? cardSchema.jsonSchema : cardSchema ? toJsonSchema(cardSchema) : undefined,
28
- [cardSchema],
29
- );
30
-
31
23
  useEffect(() => {
32
- const typename = kanban.cardView?.target?.query?.typename;
33
- const staticSchema = client.graph.schemaRegistry.schemas.find((schema) => getTypenameOrThrow(schema) === typename);
34
- if (staticSchema) {
35
- setCardSchema(() => staticSchema as TypedObject<any, any>);
36
- }
37
- if (!staticSchema && typename && space) {
38
- const query = space.db.schemaRegistry.query({ typename });
24
+ if (kanban.cardView?.target?.query?.typename && space) {
25
+ const query = space.db.schemaRegistry.query({ typename: kanban.cardView.target.query.typename });
39
26
  const unsubscribe = query.subscribe(
40
27
  () => {
41
28
  const [schema] = query.results;
@@ -50,11 +37,11 @@ export const KanbanContainer = ({ kanban }: { kanban: KanbanType; role: string }
50
37
  }, [kanban.cardView?.target?.query, space]);
51
38
 
52
39
  useEffect(() => {
53
- if (kanban.cardView?.target && jsonSchema) {
54
- setProjection(new ViewProjection(jsonSchema, kanban.cardView.target));
40
+ if (kanban.cardView?.target && cardSchema) {
41
+ setProjection(new ViewProjection(cardSchema.jsonSchema, kanban.cardView.target));
55
42
  }
56
43
  // TODO(ZaymonFC): Is there a better way to get notified about deep changes in the json schema?
57
- }, [kanban.cardView?.target, JSON.stringify(jsonSchema)]);
44
+ }, [kanban.cardView?.target, cardSchema, JSON.stringify(cardSchema?.jsonSchema)]);
58
45
 
59
46
  const objects = useQuery(space, cardSchema ? Filter.schema(cardSchema) : Filter.nothing());
60
47
  const filteredObjects = useGlobalFilteredObjects(objects);
package/src/types.ts CHANGED
@@ -2,10 +2,12 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { Schema, SchemaAST } from 'effect';
5
+ import { TitleAnnotationId } from 'effect/SchemaAST';
6
6
 
7
- import { SpaceSchema } from '@dxos/react-client/echo';
7
+ import { S } from '@dxos/echo-schema';
8
+ import { type Space, SpaceSchema } from '@dxos/react-client/echo';
8
9
  import { KanbanType } from '@dxos/react-ui-kanban';
10
+ import { initializeKanban } from '@dxos/react-ui-kanban/testing';
9
11
  import { FieldSchema } from '@dxos/schema';
10
12
 
11
13
  import { KANBAN_PLUGIN } from './meta';
@@ -23,57 +25,57 @@ import { KANBAN_PLUGIN } from './meta';
23
25
  export const TypenameAnnotationId = Symbol.for('@dxos/plugin-kanban/annotation/Typename');
24
26
  export const PivotColumnAnnotationId = Symbol.for('@dxos/plugin-kanban/annotation/PivotColumn');
25
27
 
26
- export const CreateKanbanSchema = Schema.Struct({
27
- name: Schema.optional(Schema.String),
28
- typename: Schema.optional(
29
- Schema.String.annotations({
28
+ export const CreateKanbanSchema = S.Struct({
29
+ name: S.optional(S.String),
30
+ typename: S.optional(
31
+ S.String.annotations({
30
32
  [TypenameAnnotationId]: true,
31
- [SchemaAST.TitleAnnotationId]: 'Select card schema (leave empty to start fresh)',
33
+ [TitleAnnotationId]: 'Select card schema (leave empty to start fresh)',
32
34
  }),
33
35
  ),
34
- initialPivotColumn: Schema.optional(
35
- Schema.String.annotations({
36
+ initialPivotColumn: S.optional(
37
+ S.String.annotations({
36
38
  [PivotColumnAnnotationId]: true,
37
- [SchemaAST.TitleAnnotationId]: 'Pivot column',
39
+ [TitleAnnotationId]: 'Pivot column',
38
40
  }),
39
41
  ),
40
42
  });
41
43
 
42
- export type CreateKanbanType = Schema.Schema.Type<typeof CreateKanbanSchema>;
44
+ export type CreateKanbanType = S.Schema.Type<typeof CreateKanbanSchema>;
43
45
 
44
46
  export namespace KanbanAction {
45
47
  const KANBAN_ACTION = `${KANBAN_PLUGIN}/action`;
46
48
 
47
- export class Create extends Schema.TaggedClass<Create>()(`${KANBAN_ACTION}/create`, {
48
- input: Schema.extend(Schema.Struct({ space: SpaceSchema }), CreateKanbanSchema),
49
- output: Schema.Struct({
49
+ export class Create extends S.TaggedClass<Create>()(`${KANBAN_ACTION}/create`, {
50
+ input: S.extend(S.Struct({ space: SpaceSchema }), CreateKanbanSchema),
51
+ output: S.Struct({
50
52
  object: KanbanType,
51
53
  }),
52
54
  }) {}
53
55
 
54
- export class DeleteCardField extends Schema.TaggedClass<DeleteCardField>()(`${KANBAN_ACTION}/delete-card-field`, {
55
- input: Schema.Struct({
56
+ export class DeleteCardField extends S.TaggedClass<DeleteCardField>()(`${KANBAN_ACTION}/delete-card-field`, {
57
+ input: S.Struct({
56
58
  kanban: KanbanType,
57
- fieldId: Schema.String,
59
+ fieldId: S.String,
58
60
  // TODO(wittjosiah): Separate fields for undo data?
59
- deletionData: Schema.optional(
60
- Schema.Struct({
61
+ deletionData: S.optional(
62
+ S.Struct({
61
63
  field: FieldSchema,
62
64
  // TODO(wittjosiah): This creates a type error.
63
65
  // props: PropertySchema,
64
- props: Schema.Any,
65
- index: Schema.Number,
66
+ props: S.Any,
67
+ index: S.Number,
66
68
  }),
67
69
  ),
68
70
  }),
69
- output: Schema.Void,
71
+ output: S.Void,
70
72
  }) {}
71
73
 
72
- export class DeleteCard extends Schema.TaggedClass<DeleteCard>()(`${KANBAN_ACTION}/delete-card`, {
73
- input: Schema.Struct({
74
- card: Schema.Any, // The card object to delete
74
+ export class DeleteCard extends S.TaggedClass<DeleteCard>()(`${KANBAN_ACTION}/delete-card`, {
75
+ input: S.Struct({
76
+ card: S.Any, // The card object to delete
75
77
  }),
76
- output: Schema.Void,
78
+ output: S.Void,
77
79
  }) {}
78
80
  }
79
81
 
@@ -94,3 +96,18 @@ export type Location = {
94
96
  };
95
97
 
96
98
  export const isKanban = (object: unknown): object is KanbanType => object != null && object instanceof KanbanType;
99
+
100
+ export const createKanban = async ({
101
+ space,
102
+ name,
103
+ typename,
104
+ initialPivotColumn,
105
+ }: {
106
+ space: Space;
107
+ name?: string;
108
+ typename?: string;
109
+ initialPivotColumn?: string;
110
+ }) => {
111
+ const { kanban } = await initializeKanban({ space, name, typename, initialPivotColumn });
112
+ return kanban;
113
+ };
@@ -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 { Capabilities, chain, contributes, createIntent, type PromiseIntentDispatcher } from '@dxos/app-framework';\nimport { defineArtifact, defineTool, ToolResult } from '@dxos/artifact';\nimport { createArtifactElement } from '@dxos/assistant';\nimport { isInstanceOf } from '@dxos/echo-schema';\nimport { invariant } from '@dxos/invariant';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { Filter, fullyQualifiedId, type Space } from '@dxos/react-client/echo';\nimport { KanbanType } from '@dxos/react-ui-kanban';\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: KanbanType,\n tools: [\n defineTool(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 defineTool(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: boards } = await space.db.query(Filter.schema(KanbanType)).run();\n\n const boardInfo = await Promise.all(\n boards.map(async (board: KanbanType) => {\n const view = await board.cardView?.load();\n return {\n id: fullyQualifiedId(board),\n typename: view?.query.typename,\n };\n }),\n );\n\n return ToolResult.Success(boardInfo);\n },\n }),\n defineTool(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 { objects: boards } = await space.db.query(Filter.schema(KanbanType)).run();\n const board = boards.find((board: KanbanType) => fullyQualifiedId(board) === id);\n invariant(isInstanceOf(KanbanType, board));\n\n const view = await board.cardView?.load();\n invariant(view);\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: board.columnFieldId,\n viewFields: view.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", "Capabilities", "chain", "contributes", "createIntent", "defineArtifact", "defineTool", "ToolResult", "createArtifactElement", "isInstanceOf", "invariant", "SpaceAction", "Filter", "fullyQualifiedId", "KanbanType", "QualifiedId", "Schema", "String", "annotations", "description", "definition", "defineArtifact", "id", "meta", "name", "instructions", "schema", "KanbanType", "tools", "defineTool", "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", "boards", "Filter", "run", "boardInfo", "Promise", "all", "map", "board", "view", "cardView", "load", "fullyQualifiedId", "find", "isInstanceOf", "columnField", "columnFieldId", "viewFields", "fields", "contributes", "Capabilities", "ArtifactDefinition"]
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/types.ts", "../../../src/meta.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema, SchemaAST } from 'effect';\n\nimport { SpaceSchema } from '@dxos/react-client/echo';\nimport { KanbanType } from '@dxos/react-ui-kanban';\nimport { FieldSchema } 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(burdon): Move to FormatEnum or SDK.\nexport const TypenameAnnotationId = Symbol.for('@dxos/plugin-kanban/annotation/Typename');\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]: true,\n [SchemaAST.TitleAnnotationId]: 'Select card schema (leave empty to start fresh)',\n }),\n ),\n initialPivotColumn: Schema.optional(\n Schema.String.annotations({\n [PivotColumnAnnotationId]: true,\n [SchemaAST.TitleAnnotationId]: 'Pivot column',\n }),\n ),\n});\n\nexport type CreateKanbanType = Schema.Schema.Type<typeof CreateKanbanSchema>;\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: KanbanType,\n }),\n }) {}\n\n export class DeleteCardField extends Schema.TaggedClass<DeleteCardField>()(`${KANBAN_ACTION}/delete-card-field`, {\n input: Schema.Struct({\n kanban: KanbanType,\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// TODO(burdon): Undo?\n// TODO(burdon): Typescript types (replace proto with annotations?)\n// TODO(burdon): Should pure components depend on ECHO? Relationship between ECHO object/array and Observable.\n// TODO(burdon): Can the plugin configure the object based on the data? E.g., how are the models constructed?\n// TODO(burdon): Create models. Simple first based on actual data.\n// Model is always a projection since the dragging state is tentative.\n\n// TODO(burdon): Extend model for moving items (in and across columns).\nexport interface KanbanModel {\n root: KanbanType;\n}\n\nexport type Location = {\n idx?: number;\n};\n\nexport const isKanban = (object: unknown): object is KanbanType => object != null && object instanceof KanbanType;\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/experimental/plugin-kanban',\n tags: ['experimental'],\n screenshots: ['https://dxos.network/plugin-details-kanban-dark.png'],\n};\n"],
5
- "mappings": ";AAIA,SAASA,QAAQC,iBAAiB;AAElC,SAASC,mBAAmB;AAC5B,SAASC,kBAAkB;AAC3B,SAASC,mBAAmB;;;ACFrB,IAAMC,gBAAgB;AAEtB,IAAMC,OAAmB;EAC9BC,IAAIF;EACJG,MAAM;EACNC,aACE;EACFC,MAAM;EACNC,QAAQ;EACRC,MAAM;IAAC;;EACPC,aAAa;IAAC;;AAChB;;;ADKO,IAAMC,uBAAuBC,OAAOC,IAAI,yCAAA;AACxC,IAAMC,0BAA0BF,OAAOC,IAAI,4CAAA;AAE3C,IAAME,qBAAqBC,OAAOC,OAAO;EAC9CC,MAAMF,OAAOG,SAASH,OAAOI,MAAM;EACnCC,UAAUL,OAAOG,SACfH,OAAOI,OAAOE,YAAY;IACxB,CAACX,oBAAAA,GAAuB;IACxB,CAACY,UAAUC,iBAAiB,GAAG;EACjC,CAAA,CAAA;EAEFC,oBAAoBT,OAAOG,SACzBH,OAAOI,OAAOE,YAAY;IACxB,CAACR,uBAAAA,GAA0B;IAC3B,CAACS,UAAUC,iBAAiB,GAAG;EACjC,CAAA,CAAA;AAEJ,CAAA;;UAIiBE,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;IACV,CAAA;EACF,CAAA,EAAA;EAAI;gBALSR,SAAAA;EAON,MAAMS,wBAAwBtB,OAAOc,YAAW,EAAoB,GAAGH,aAAAA,sBAAmC;IAC/GI,OAAOf,OAAOC,OAAO;MACnBsB,QAAQF;MACRG,SAASxB,OAAOI;;MAEhBqB,cAAczB,OAAOG,SACnBH,OAAOC,OAAO;QACZyB,OAAOC;;;QAGPC,OAAO5B,OAAO6B;QACdC,OAAO9B,OAAO+B;MAChB,CAAA,CAAA;IAEJ,CAAA;IACAZ,QAAQnB,OAAOgC;EACjB,CAAA,EAAA;EAAI;gBAhBSV,kBAAAA;EAkBN,MAAMW,mBAAmBjC,OAAOc,YAAW,EAAe,GAAGH,aAAAA,gBAA6B;IAC/FI,OAAOf,OAAOC,OAAO;MACnBiC,MAAMlC,OAAO6B;IACf,CAAA;IACAV,QAAQnB,OAAOgC;EACjB,CAAA,EAAA;EAAI;gBALSC,aAAAA;AAMf,GAlCiBvB,iBAAAA,eAAAA,CAAAA,EAAAA;AAoDV,IAAMyB,WAAW,CAACf,WAA0CA,UAAU,QAAQA,kBAAkBC;",
6
- "names": ["Schema", "SchemaAST", "SpaceSchema", "KanbanType", "FieldSchema", "KANBAN_PLUGIN", "meta", "id", "name", "description", "icon", "source", "tags", "screenshots", "TypenameAnnotationId", "Symbol", "for", "PivotColumnAnnotationId", "CreateKanbanSchema", "Schema", "Struct", "name", "optional", "String", "typename", "annotations", "SchemaAST", "TitleAnnotationId", "initialPivotColumn", "KanbanAction", "KANBAN_ACTION", "KANBAN_PLUGIN", "Create", "TaggedClass", "input", "extend", "space", "SpaceSchema", "output", "object", "KanbanType", "DeleteCardField", "kanban", "fieldId", "deletionData", "field", "FieldSchema", "props", "Any", "index", "Number", "Void", "DeleteCard", "card", "isKanban"]
7
- }
@@ -1,297 +0,0 @@
1
- import {
2
- KANBAN_PLUGIN,
3
- KanbanAction
4
- } from "./chunk-6JAA7YSW.mjs";
5
-
6
- // packages/plugins/plugin-kanban/src/capabilities/intent-resolver.ts
7
- import { contributes, Capabilities, createResolver } from "@dxos/app-framework";
8
- import { invariant as invariant2 } from "@dxos/invariant";
9
- import { ClientCapabilities } from "@dxos/plugin-client";
10
- import { getSpace } from "@dxos/react-client/echo";
11
- import { ViewProjection as ViewProjection2 } from "@dxos/schema";
12
-
13
- // packages/plugins/plugin-kanban/src/testing/initialize-kanban.ts
14
- import { Schema, SchemaAST } from "effect";
15
- import { TypedObject, FormatEnum, TypeEnum, getTypenameOrThrow, toJsonSchema } from "@dxos/echo-schema";
16
- import { invariant } from "@dxos/invariant";
17
- import { PublicKey } from "@dxos/react-client";
18
- import { live, makeRef } from "@dxos/react-client/echo";
19
- import { KanbanType } from "@dxos/react-ui-kanban";
20
- import { createView, ViewProjection, createFieldId, getSchemaProperties } from "@dxos/schema";
21
- import { capitalize } from "@dxos/util";
22
- var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-kanban/src/testing/initialize-kanban.ts";
23
- var createDefaultTaskSchema = () => {
24
- const stateOptions = [
25
- {
26
- id: PublicKey.random().truncate(),
27
- title: "Draft",
28
- color: "indigo"
29
- },
30
- {
31
- id: PublicKey.random().truncate(),
32
- title: "Active",
33
- color: "cyan"
34
- },
35
- {
36
- id: PublicKey.random().truncate(),
37
- title: "Completed",
38
- color: "emerald"
39
- }
40
- ];
41
- const schema = TypedObject({
42
- typename: `example.com/type/${PublicKey.random().truncate()}`,
43
- version: "0.1.0"
44
- })({
45
- title: Schema.optional(Schema.String).annotations({
46
- [SchemaAST.TitleAnnotationId]: "Title"
47
- }),
48
- description: Schema.optional(Schema.String).annotations({
49
- [SchemaAST.TitleAnnotationId]: "Description"
50
- }),
51
- state: Schema.optional(Schema.String)
52
- });
53
- return {
54
- schema,
55
- stateOptions
56
- };
57
- };
58
- var initializeKanban = async ({ client, space, name, typename, initialPivotColumn }) => {
59
- if (typename) {
60
- const staticSchema = client.graph.schemaRegistry.schemas.find((schema2) => getTypenameOrThrow(schema2) === typename);
61
- const schema = await space.db.schemaRegistry.query({
62
- typename
63
- }).firstOrUndefined();
64
- const ast = staticSchema?.ast ?? schema?.ast;
65
- const jsonSchema = staticSchema ? toJsonSchema(staticSchema) : schema?.jsonSchema;
66
- invariant(ast, `Schema not found: ${typename}`, {
67
- F: __dxlog_file,
68
- L: 69,
69
- S: void 0,
70
- A: [
71
- "ast",
72
- "`Schema not found: ${typename}`"
73
- ]
74
- });
75
- invariant(jsonSchema, `Schema not found: ${typename}`, {
76
- F: __dxlog_file,
77
- L: 70,
78
- S: void 0,
79
- A: [
80
- "jsonSchema",
81
- "`Schema not found: ${typename}`"
82
- ]
83
- });
84
- const fields = getSchemaProperties(ast).filter((prop) => prop.type !== "object" || prop.format === FormatEnum.Ref).map((prop) => prop.name);
85
- const view = createView({
86
- name: "Kanban's card view",
87
- typename,
88
- jsonSchema,
89
- fields
90
- });
91
- const kanban = live(KanbanType, {
92
- cardView: makeRef(view),
93
- columnFieldId: void 0,
94
- name
95
- });
96
- if (initialPivotColumn) {
97
- const viewProjection = new ViewProjection(jsonSchema, view);
98
- const fieldId = viewProjection.getFieldId(initialPivotColumn);
99
- if (fieldId) {
100
- kanban.columnFieldId = fieldId;
101
- }
102
- }
103
- return {
104
- kanban,
105
- schema
106
- };
107
- } else {
108
- const { schema: taskSchema, stateOptions } = createDefaultTaskSchema();
109
- const [schema] = await space.db.schemaRegistry.register([
110
- taskSchema
111
- ]);
112
- const view = createView({
113
- name: "Kanban's card view",
114
- typename: schema.typename,
115
- jsonSchema: schema.jsonSchema,
116
- fields: [
117
- "title",
118
- "description"
119
- ]
120
- });
121
- const viewProjection = new ViewProjection(schema.jsonSchema, view);
122
- const descriptionFieldId = viewProjection.getFieldId("description");
123
- if (descriptionFieldId) {
124
- const fieldProjection = viewProjection.getFieldProjection(descriptionFieldId);
125
- if (fieldProjection) {
126
- viewProjection.setFieldProjection({
127
- ...fieldProjection,
128
- props: {
129
- ...fieldProjection.props,
130
- format: FormatEnum.Markdown
131
- }
132
- });
133
- }
134
- }
135
- const initialPivotField = "state";
136
- viewProjection.setFieldProjection({
137
- field: {
138
- id: createFieldId(),
139
- path: initialPivotField,
140
- size: 150
141
- },
142
- props: {
143
- property: initialPivotField,
144
- type: TypeEnum.String,
145
- format: FormatEnum.SingleSelect,
146
- title: capitalize(initialPivotField),
147
- options: stateOptions
148
- }
149
- });
150
- const fieldId = viewProjection.getFieldId(initialPivotField);
151
- invariant(fieldId, void 0, {
152
- F: __dxlog_file,
153
- L: 134,
154
- S: void 0,
155
- A: [
156
- "fieldId",
157
- ""
158
- ]
159
- });
160
- const kanban = live(KanbanType, {
161
- cardView: makeRef(view),
162
- columnFieldId: fieldId
163
- });
164
- return {
165
- kanban,
166
- schema
167
- };
168
- }
169
- };
170
-
171
- // packages/plugins/plugin-kanban/src/capabilities/intent-resolver.ts
172
- var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-kanban/src/capabilities/intent-resolver.ts";
173
- var intent_resolver_default = (context) => contributes(Capabilities.IntentResolver, [
174
- createResolver({
175
- intent: KanbanAction.Create,
176
- resolve: async ({ space, name, typename, initialPivotColumn }) => {
177
- const client = context.requestCapability(ClientCapabilities.Client);
178
- const { kanban } = await initializeKanban({
179
- client,
180
- space,
181
- name,
182
- typename,
183
- initialPivotColumn
184
- });
185
- return {
186
- data: {
187
- object: kanban
188
- }
189
- };
190
- }
191
- }),
192
- createResolver({
193
- intent: KanbanAction.DeleteCardField,
194
- resolve: ({ kanban, fieldId, deletionData }, undo) => {
195
- invariant2(kanban.cardView, void 0, {
196
- F: __dxlog_file2,
197
- L: 28,
198
- S: void 0,
199
- A: [
200
- "kanban.cardView",
201
- ""
202
- ]
203
- });
204
- invariant2(kanban.cardView.target?.query.typename, void 0, {
205
- F: __dxlog_file2,
206
- L: 29,
207
- S: void 0,
208
- A: [
209
- "kanban.cardView.target?.query.typename",
210
- ""
211
- ]
212
- });
213
- const schema = kanban.cardView.target && getSpace(kanban)?.db.schemaRegistry.getSchema(kanban.cardView.target.query.typename);
214
- invariant2(schema, void 0, {
215
- F: __dxlog_file2,
216
- L: 34,
217
- S: void 0,
218
- A: [
219
- "schema",
220
- ""
221
- ]
222
- });
223
- invariant2(kanban.cardView.target, void 0, {
224
- F: __dxlog_file2,
225
- L: 35,
226
- S: void 0,
227
- A: [
228
- "kanban.cardView.target",
229
- ""
230
- ]
231
- });
232
- const projection = new ViewProjection2(schema.jsonSchema, kanban.cardView.target);
233
- if (!undo) {
234
- const { deleted, index } = projection.deleteFieldProjection(fieldId);
235
- return {
236
- undoable: {
237
- message: [
238
- "card field deleted label",
239
- {
240
- ns: KANBAN_PLUGIN
241
- }
242
- ],
243
- data: {
244
- deletionData: {
245
- ...deleted,
246
- index
247
- }
248
- }
249
- }
250
- };
251
- } else if (undo && deletionData) {
252
- const { field, props, index } = deletionData;
253
- projection.setFieldProjection({
254
- field,
255
- props
256
- }, index);
257
- }
258
- }
259
- }),
260
- createResolver({
261
- intent: KanbanAction.DeleteCard,
262
- resolve: ({ card }, undo) => {
263
- const space = getSpace(card);
264
- invariant2(space, void 0, {
265
- F: __dxlog_file2,
266
- L: 56,
267
- S: void 0,
268
- A: [
269
- "space",
270
- ""
271
- ]
272
- });
273
- if (!undo) {
274
- space.db.remove(card);
275
- return {
276
- undoable: {
277
- message: [
278
- "card deleted label",
279
- {
280
- ns: KANBAN_PLUGIN
281
- }
282
- ],
283
- data: {
284
- card
285
- }
286
- }
287
- };
288
- } else {
289
- space.db.add(card);
290
- }
291
- }
292
- })
293
- ]);
294
- export {
295
- intent_resolver_default as default
296
- };
297
- //# sourceMappingURL=intent-resolver-44SXCRIH.mjs.map